/* HomepageAbo · main.css
 * Public-Pages benutzen die orig-* Files (1:1 aus Design-Handoff).
 * Das ältere components/sections-CSS bleibt für Funnel/Kundenbereich-Plugins aktiv. */

@import url("./tokens.css");
@import url("./base.css");

/* Funnel + Kundenbereich (legacy classes) — unsichtbar auf Public-Pages */
@import url("./components.css");
@import url("./sections.css");
@import url("./print.css");

/* Public-Pages — exakt das Design aus orig-*.jsx */
@import url("./orig.css");
@import url("./orig-conv.css");
@import url("./orig-pages.css");

@font-face {
	font-family: "Inter"; font-style: normal; font-weight: 400; font-display: swap;
	src: url("../fonts/inter-400.woff2") format("woff2");
}
@font-face {
	font-family: "Inter"; font-style: normal; font-weight: 500; font-display: swap;
	src: url("../fonts/inter-500.woff2") format("woff2");
}
@font-face {
	font-family: "Inter"; font-style: normal; font-weight: 600; font-display: swap;
	src: url("../fonts/inter-600.woff2") format("woff2");
}
@font-face {
	font-family: "Inter"; font-style: normal; font-weight: 700; font-display: swap;
	src: url("../fonts/inter-700.woff2") format("woff2");
}

/* Lang-Switcher: Override für theme-orig */
.theme-orig .lang-switcher { display: inline-flex; gap: 2px; padding: 2px; background: var(--bg-soft); border-radius: 999px; }
.theme-orig .lang-switcher__item { display: inline-flex; align-items: center; gap: 4px; padding: 6px 10px; font-size: 12px; font-weight: 600; color: var(--ink-3); text-decoration: none; border-radius: 999px; line-height: 1; }
.theme-orig .lang-switcher__item:hover { color: var(--ink); }
.theme-orig .lang-switcher__item.is-active { background: white; color: var(--ink); box-shadow: 0 1px 3px rgba(0,0,0,.04); }

/* Nav (für theme-orig) — JSX-Klassen sind .nav, .nav-inner, .nav-logo, .nav-main, .nav-item, .nav-cta, .nav-drop, .nav-mega */
.theme-orig .nav { background: white; border-bottom: 1px solid var(--line); }
.theme-orig .nav-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 14px 0; }
.theme-orig .nav-logo { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; }
.theme-orig .nav-main { display: flex; gap: 4px; align-items: center; }
.theme-orig .nav-item { background: transparent; border: 0; padding: 10px 14px; border-radius: 8px; cursor: pointer; font: inherit; display: inline-flex; gap: 4px; align-items: center; text-decoration: none; }
.theme-orig .nav-caret { font-size: 10px; opacity: .5; }
.theme-orig .nav-cta { display: flex; gap: 8px; align-items: center; }
.theme-orig .nav-drop { position: relative; }
.theme-orig .nav-mega { position: absolute; top: 100%; left: 0; right: 0; background: white; border: 1px solid var(--line); border-radius: 12px; box-shadow: 0 30px 60px -30px rgba(15,38,71,.25); padding: 18px; min-width: 560px; z-index: 50; }
.theme-orig .nav-mega-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }
.theme-orig .nav-mega-item { background: transparent; border: 0; padding: 10px 12px; border-radius: 8px; display: flex; gap: 12px; align-items: center; cursor: pointer; font: inherit; text-align: left; }
.theme-orig .nav-mega-item:hover { background: var(--bg-soft); }
.theme-orig .nav-mega-item strong { display: block; font-size: 13.5px; color: var(--ink); }
.theme-orig .nav-mega-item span { display: block; font-size: 12px; color: var(--ink-3); }
.theme-orig .nav-mega-foot { padding: 8px 12px; font-size: 12.5px; color: var(--ink-2); border-top: 1px solid var(--line); margin-top: 8px; }
.theme-orig .nav-mega-sm { min-width: 320px; }
.theme-orig .btn-ghost { background: transparent; border: 0; color: var(--ink); padding: 12px 16px; cursor: pointer; }
.theme-orig .btn-ghost:hover { background: var(--bg-soft); }

/* Footer (für theme-orig) */
.theme-orig .ft { background: var(--bg-deep); color: rgba(255,255,255,.85); padding: 64px 0 32px; }
.theme-orig .ft-top { display: grid; grid-template-columns: 1fr 2fr; gap: 64px; }
.theme-orig .ft-brand p { font-size: 14px; color: rgba(255,255,255,.65); margin: 18px 0; max-width: 320px; line-height: 1.55; }
.theme-orig .ft-trust { display: flex; flex-direction: column; gap: 4px; font-size: 12.5px; color: rgba(255,255,255,.55); }
.theme-orig .ft-cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
.theme-orig .ft-cols h4 { color: white; font-size: 13.5px; margin: 0 0 14px; font-weight: 600; }
.theme-orig .ft-cols a { display: block; color: rgba(255,255,255,.65); text-decoration: none; font-size: 13px; padding: 4px 0; cursor: pointer; }
.theme-orig .ft-cols a:hover { color: white; }
.theme-orig .ft-bot { margin-top: 48px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.1); display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; font-size: 12.5px; color: rgba(255,255,255,.5); }
.theme-orig .ft-legal { display: flex; gap: 16px; }
.theme-orig .ft-legal a { color: rgba(255,255,255,.65); text-decoration: none; }

@media (max-width: 900px) {
	.theme-orig .ft-top { grid-template-columns: 1fr; gap: 32px; }
	.theme-orig .ft-cols { grid-template-columns: 1fr 1fr; }
	.theme-orig .nav-main { display: none; }
}
