/* =========================================================
   Migrationsberatung V.K. — Design System
   Marke: Navy + Gold · "Warm Premium"
   Keine externen Schriften/Aufrufe (privacy by design)
   ========================================================= */

:root{
  /* Blau (Marke) */
  --navy-900:#0a1f3a;
  --navy-800:#0e2a4d;
  --navy-700:#143a66;
  --navy-600:#1d4e85;
  --navy-50:#eef2f9;
  /* Gold (Akzent) */
  --gold-700:#92701d;   /* für kleinen Text auf Hell (Kontrast) */
  --gold-600:#b8902f;
  --gold-500:#c9a24a;
  --gold-300:#e3c879;
  --gold-soft:#f1e6cc;
  /* Neutral / warm */
  --ivory:#f6f3ec;
  --cream:#fffdf9;
  --ink:#1b2230;
  --muted:#5d6677;
  --muted-2:#9aa6bd;
  --line:#e7e1d4;
  --line-cool:#dfe4ee;
  /* System */
  --radius:14px;
  --radius-sm:10px;
  --shadow:0 16px 48px rgba(10,31,58,.12);
  --shadow-sm:0 6px 20px rgba(10,31,58,.08);
  --wrap:1100px;
  --serif:"Iowan Old Style","Palatino Linotype","Palatino",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,"Helvetica Neue",Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--ivory);
  line-height:1.7;font-size:16.5px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
h1,h2,h3,h4,.serif{font-family:var(--serif);font-weight:600;letter-spacing:-.2px}
a{color:var(--navy-700);text-decoration:none}
a:hover{color:var(--navy-600)}
img{max-width:100%;display:block}
:focus-visible{outline:3px solid var(--gold-500);outline-offset:2px;border-radius:4px}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 22px}
.skip{position:absolute;left:-9999px;top:0;background:var(--navy-800);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:200}
.skip:focus{left:0}

/* ---------- Top language bar ---------- */
.langbar{background:var(--navy-900);color:#bcd0ec;font-size:13px}
.langbar .wrap{display:flex;align-items:center;justify-content:center;gap:8px;padding:7px 22px;flex-wrap:wrap}
.langbar .label{opacity:.7;letter-spacing:.3px}
.langbar a{color:#ccd9ee;background:rgba(255,255,255,.07);padding:4px 12px;border-radius:999px;font-weight:700;font-size:12.5px}
.langbar a:hover{background:rgba(255,255,255,.15);color:#fff}
.langbar a.active{background:var(--gold-600);color:#1a1305}
.langbar a.soon{opacity:.55}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(246,243,236,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:18px;height:72px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-weight:700;font-size:18px;color:var(--navy-800)}
.brand .mark{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,var(--navy-800),var(--navy-600));color:#fff;display:grid;place-items:center;font-size:15px;border:1px solid var(--gold-500);box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
.brand .mark b{color:var(--gold-300);font-weight:700}
.nav-links{display:none;align-items:center;gap:22px;margin-left:6px}
.nav-links a{color:var(--muted);font-size:14.5px;font-weight:600}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--navy-800)}
.nav-spacer{flex:1}
.nav .nav-cta{display:none}
.nav-toggle{display:inline-flex;flex-direction:column;gap:4px;background:none;border:1px solid var(--line);border-radius:9px;padding:9px 10px;cursor:pointer;margin-left:auto}
.nav-toggle span{width:20px;height:2px;background:var(--navy-800);border-radius:2px}
.mobile-menu{display:none;border-top:1px solid var(--line);background:var(--cream)}
.mobile-menu.open{display:block}
.mobile-menu a{display:block;padding:13px 22px;border-bottom:1px solid var(--line);color:var(--ink);font-weight:600}
.mobile-menu a:last-child{border-bottom:0}
.mobile-menu .m-cta{margin:14px 22px;display:block;text-align:center}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border-radius:11px;padding:13px 20px;font-weight:700;font-size:15px;cursor:pointer;border:1.5px solid transparent;transition:.15s;font-family:var(--sans);text-align:center}
.btn-gold{background:linear-gradient(135deg,var(--gold-600),var(--gold-500));color:#1a1305;box-shadow:0 8px 20px rgba(184,144,47,.28)}
.btn-gold:hover{filter:brightness(1.05);color:#1a1305}
.btn-navy{background:var(--navy-800);color:#fff}
.btn-navy:hover{background:var(--navy-700);color:#fff}
.btn-outline{background:transparent;color:var(--navy-800);border-color:var(--line-cool)}
.btn-outline:hover{border-color:var(--navy-800);color:var(--navy-800)}
.btn-light{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.25)}
.btn-light:hover{background:rgba(255,255,255,.2);color:#fff}
.btn-sm{padding:9px 15px;font-size:14px}
.btn-block{width:100%}
.btn-sub{display:block;font-weight:500;font-size:12px;opacity:.85;margin-top:2px}

/* ---------- Hero ---------- */
.hero{padding:56px 0 50px}
.hero-grid{display:grid;gap:40px;grid-template-columns:1fr;align-items:center}
.greet{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.greet span{background:var(--cream);border:1px solid var(--line);border-radius:999px;padding:5px 13px;font-size:13px;color:var(--navy-700);font-weight:600}
.kicker{font-size:12.5px;letter-spacing:2.2px;text-transform:uppercase;color:var(--gold-700);font-weight:700}
h1{font-size:clamp(31px,6vw,50px);line-height:1.12;margin:14px 0 16px;color:var(--ink)}
.rule{width:54px;height:2px;background:var(--gold-600);margin:0 0 20px;border:0}
.lead{font-size:clamp(16px,2.3vw,19px);color:var(--muted);max-width:560px;margin:0 0 26px}
.cta-row{display:flex;flex-wrap:wrap;gap:13px;margin-bottom:22px}
.meta-row{display:flex;flex-wrap:wrap;gap:16px;font-size:14px;color:var(--muted)}
.meta-row span{display:inline-flex;gap:7px;align-items:center}
.meta-row .g{color:var(--gold-600);font-weight:800}
.hero-photo{position:relative}
.photo-ph{aspect-ratio:4/5;border-radius:var(--radius);background:linear-gradient(160deg,var(--navy-700),var(--navy-900));display:grid;place-items:center;color:#a9bedd;text-align:center;padding:26px;box-shadow:var(--shadow)}
.photo-ph .e{font-size:42px;display:block;margin-bottom:10px;color:var(--gold-300)}
.hello-card{position:absolute;left:-12px;bottom:-14px;background:var(--cream);border:1px solid var(--line);border-left:3px solid var(--gold-600);border-radius:12px;padding:13px 16px;box-shadow:var(--shadow);max-width:255px;font-size:14px}
.hello-card b{color:var(--navy-800)}
.hello-card small{color:var(--muted)}

/* ---------- Values strip ---------- */
.values{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--cream)}
.values .wrap{display:grid;gap:0;grid-template-columns:1fr}
.val{padding:22px 0;border-top:1px solid var(--line)}
.val:first-child{border-top:0}
.val .serif{font-size:19px;color:var(--gold-700);margin-bottom:3px}
.val p{margin:0;color:var(--muted);font-size:14.5px}

/* ---------- Sections ---------- */
section{padding:50px 0}
.sec-head{max-width:640px;margin-bottom:30px}
.sec-head .kicker{display:block;margin-bottom:10px}
.sec-head h2{font-size:clamp(24px,4.3vw,34px);margin:0 0 8px;color:var(--ink)}
.sec-head p{color:var(--muted);margin:0}
.center{text-align:center;margin-left:auto;margin-right:auto}
.bg-cream{background:var(--cream);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* problems grid */
.probs{display:grid;gap:13px;grid-template-columns:1fr 1fr}
.prob{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:15px;font-weight:600;display:flex;gap:10px;align-items:center;font-size:15px}
.prob .e{font-size:21px}

/* free/paid split */
.split{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;grid-template-columns:1fr}
.col{background:var(--cream);padding:26px}
.col .tag{font-size:12px;letter-spacing:1.4px;text-transform:uppercase;font-weight:800}
.col.free .tag{color:var(--navy-700)}
.col.paid .tag{color:var(--gold-700)}
.col h3{margin:6px 0 0;font-size:21px;color:var(--navy-800)}
.col ul{margin:14px 0 0;padding:0;list-style:none}
.col li{padding:8px 0 8px 24px;position:relative;font-size:15.5px}
.col.free li::before{content:"—";position:absolute;left:0;color:var(--navy-600)}
.col.paid li::before{content:"—";position:absolute;left:0;color:var(--gold-600)}
.col .note{margin-top:16px;font-size:14px;color:var(--muted);border-left:2px solid var(--gold-600);padding-left:14px}

/* steps */
.steps{display:grid;gap:16px;grid-template-columns:1fr}
.step{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.step .n{width:44px;height:44px;border-radius:50%;background:var(--navy-50);color:var(--navy-800);font-family:var(--serif);font-weight:700;display:grid;place-items:center;margin-bottom:12px;font-size:19px;border:1px solid var(--gold-soft)}
.step h4{margin:0 0 6px;color:var(--navy-800);font-size:18px}
.step p{margin:0;color:var(--muted);font-size:14.5px}

/* price table */
.ptable{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--cream);box-shadow:var(--shadow-sm)}
.ptable .glabel{padding:14px 22px;background:var(--navy-50);color:var(--navy-800);font-weight:700;font-size:12.5px;letter-spacing:1.2px;text-transform:uppercase}
.prow{display:flex;justify-content:space-between;gap:16px;align-items:baseline;padding:16px 22px;border-top:1px solid var(--line)}
.prow .n{font-weight:600}
.info-i{position:relative;display:inline-flex;align-items:center;justify-content:center;cursor:help;color:var(--gold-700);font-size:.72em;font-weight:700;vertical-align:super;margin-left:4px;width:1.35em;height:1.35em;border:1px solid var(--gold-700);border-radius:50%;line-height:1}
.info-i:hover,.info-i:focus{color:var(--cream);background:var(--gold-700);outline:none}
.info-i .info-bubble{position:absolute;left:50%;bottom:calc(100% + 8px);transform:translateX(-50%);width:max-content;max-width:260px;background:#0e2a4d;color:#fff;font-size:12.5px;font-weight:400;line-height:1.4;text-align:left;padding:8px 10px;border-radius:8px;box-shadow:var(--shadow-sm);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .12s ease;z-index:60;white-space:normal}
.info-i .info-bubble::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:#0e2a4d}
.info-i:hover .info-bubble,.info-i:focus .info-bubble,.info-i:focus-within .info-bubble{opacity:1;visibility:visible}
.prow .d{display:block;color:var(--muted);font-size:13.5px;font-weight:400;margin-top:2px}
.prow .p{font-family:var(--serif);font-size:19px;color:var(--gold-700);white-space:nowrap}
.prow .p.free{color:var(--navy-700)}
.pay{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}
.pill{background:var(--cream);border:1px solid var(--line);border-radius:999px;padding:9px 16px;font-size:14.5px}

/* notes / callouts */
.note{font-size:14.5px;color:var(--navy-800);background:var(--navy-50);border-radius:12px;padding:14px 16px}
.note-gold{color:#5b4708;background:var(--gold-soft)}
.legal-box{font-size:13.5px;color:var(--muted);background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.legal-box strong{color:var(--ink)}

/* voices */
.voices{display:grid;gap:16px;grid-template-columns:1fr}
.voice{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.voice .stars{color:var(--gold-600);letter-spacing:2px;margin-bottom:8px}
.voice p{margin:0 0 14px;font-style:italic;font-size:16px;color:var(--ink)}
.voice .who{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:14px}
.voice .av{width:38px;height:38px;border-radius:50%;background:var(--navy-50);display:grid;place-items:center;color:var(--navy-800);font-weight:700}

/* trust band (dark) */
.trust{background:var(--navy-900);color:#cdd9ec;border-radius:18px;padding:42px 30px}
.trust .kicker{color:var(--gold-300)}
.trust h2{color:#fff;margin:10px 0 22px;font-size:clamp(23px,4vw,32px)}
.tg{display:grid;gap:22px;grid-template-columns:1fr}
.ti .ic{color:var(--gold-300);font-size:20px;margin-bottom:8px;display:block}
.ti b{color:#fff;display:block;margin-bottom:4px;font-size:16px}
.ti small{color:#9fb2cf;font-size:14px;line-height:1.6}
.trust .disc{margin-top:24px;font-size:13px;color:#9fb2cf;border-top:1px solid rgba(255,255,255,.14);padding-top:16px}

/* channels (assistent) */
.chans{display:grid;gap:16px;grid-template-columns:1fr}
.chan{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:22px;display:flex;gap:14px;align-items:center}
.chan .ic{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;font-size:22px;color:#fff;flex:none}
.chan b{display:block}
.chan small{color:var(--muted)}
.flow{display:grid;gap:12px;grid-template-columns:1fr;counter-reset:s;margin-top:8px}
.flow .f{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:14px 16px 14px 48px;position:relative;font-size:14.5px}
.flow .f::before{counter-increment:s;content:counter(s);position:absolute;left:14px;top:13px;width:24px;height:24px;border-radius:7px;background:var(--navy-800);color:#fff;font-weight:700;display:grid;place-items:center;font-size:13px}

/* FAQ */
.faq{max-width:820px}
.faq details{background:var(--cream);border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden}
.faq summary{cursor:pointer;padding:16px 20px;font-weight:700;color:var(--navy-800);list-style:none;display:flex;justify-content:space-between;gap:12px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold-600);font-size:22px;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq .a{padding:0 20px 18px;color:var(--muted)}
.faq .a p{margin:0 0 8px}

/* contact */
.contact-grid{display:grid;gap:16px;grid-template-columns:1fr}
.cbox{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.cbox h3{margin:0 0 12px;font-size:18px;color:var(--navy-800)}
.cline{display:flex;gap:12px;align-items:center;padding:9px 0}
.cline .ic{width:40px;height:40px;border-radius:11px;background:var(--navy-50);display:grid;place-items:center;font-size:18px;flex:none}
.cline b{display:block;font-size:15px}
.cline small{color:var(--muted)}

/* prose (legal pages) */
.prose{max-width:820px}
.prose h2{font-size:23px;margin:32px 0 10px;color:var(--navy-800)}
.prose h3{font-size:18px;margin:22px 0 8px;color:var(--navy-800)}
.prose p,.prose li{color:var(--ink);font-size:15.5px}
.prose ul{padding-left:20px}
.prose .muted{color:var(--muted);font-size:14px}
.page-head{padding:46px 0 6px}
.page-head h1{font-size:clamp(27px,5vw,40px);margin:0 0 10px}
.page-head p{color:var(--muted);max-width:640px;margin:0}

/* CTA band */
.cta-band{background:var(--cream);border:1.5px solid var(--gold-soft);border-radius:18px;padding:34px 28px;text-align:center}
.cta-band h2{color:var(--navy-800);margin:0 0 8px}
.cta-band p{color:var(--muted);margin:0 0 20px}

/* footer */
.site-footer{background:var(--navy-900);color:#9fb2cf;padding:38px 0 26px;font-size:14px}
.foot-grid{display:flex;flex-wrap:wrap;gap:26px;justify-content:space-between}
.site-footer a{color:#cdddf0}
.site-footer a:hover{color:var(--gold-300)}
.site-footer .brand{color:#fff}
.foot-legal{font-size:12.5px;color:#7e93b3;margin-top:20px;border-top:1px solid rgba(255,255,255,.1);padding-top:15px}

/* utilities */
.mt0{margin-top:0}.mb0{margin-bottom:0}
.tac{text-align:center}
.demo-note{display:none}

@media (max-width:540px){
  .probs{grid-template-columns:1fr}
}
@media (min-width:760px){
  .nav-links{display:flex}
  .nav .nav-cta{display:inline-flex}
  .nav-toggle{display:none}
  .hero-grid{grid-template-columns:1.12fr .88fr}
  .values .wrap{grid-template-columns:repeat(3,1fr)}
  .val{border-top:0;padding:26px 0}
  .split{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:repeat(3,1fr)}
  .voices{grid-template-columns:repeat(3,1fr)}
  .tg{grid-template-columns:1fr 1fr}
  .chans{grid-template-columns:1fr 1fr}
  .flow{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr 1fr}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{transition:none!important}
}

/* ============================================================
   THEME-UMSCHALTER (Button) + DUNKELMODUS
   Standard = hell. data-theme="dark" auf <html> aktiviert dunkel.
   ============================================================ */
.theme-toggle{display:inline-grid;place-items:center;width:40px;height:40px;border:1px solid var(--line);border-radius:9px;background:var(--cream);color:var(--ink);cursor:pointer;font-size:17px;line-height:1;margin-left:4px;padding:0}
.theme-toggle:hover{border-color:var(--navy-600)}

/* sanfter Übergang beim Umschalten */
body,.site-header,.langbar,.col,.ptable,.step,.voice,.prob,.pill,.cbox,.faq details,.legal-box,.cta-band,.hello-card,.values,.bg-cream,.theme-toggle,.btn-outline,.btn-navy{transition:background-color .2s ease,color .2s ease,border-color .2s ease}

:root[data-theme="dark"]{
  --ivory:#0b1626;       /* Seitenhintergrund */
  --cream:#13233d;       /* Karten/Flächen */
  --ink:#e8eef8;         /* Haupttext */
  --muted:#a7b6cd;
  --muted-2:#7d8ca6;
  --line:#26374f;
  --line-cool:#2b3c55;
  --navy-50:#172a44;     /* Tönungen (glabel, Schritt-Zahl, Icons, note-bg) */
  --gold-soft:#2c2614;
}
:root[data-theme="dark"] body{background:var(--ivory)}
:root[data-theme="dark"] .site-header{background:rgba(11,22,38,.9)}
:root[data-theme="dark"] .bg-cream,
:root[data-theme="dark"] .values{background:#0e1c33}
:root[data-theme="dark"] h1,
:root[data-theme="dark"] .sec-head h2,
:root[data-theme="dark"] .brand,
:root[data-theme="dark"] .nav-links a:hover,
:root[data-theme="dark"] .nav-links a[aria-current="page"],
:root[data-theme="dark"] .col h3,
:root[data-theme="dark"] .step h4,
:root[data-theme="dark"] .faq summary,
:root[data-theme="dark"] .cbox h3,
:root[data-theme="dark"] .prose h2,
:root[data-theme="dark"] .prose h3,
:root[data-theme="dark"] .cta-band h2,
:root[data-theme="dark"] .hello-card b,
:root[data-theme="dark"] .ptable .glabel{color:#eef3fb}
:root[data-theme="dark"] .kicker,
:root[data-theme="dark"] .val .serif,
:root[data-theme="dark"] .col.paid .tag,
:root[data-theme="dark"] .prow .p,
:root[data-theme="dark"] .note-gold,
:root[data-theme="dark"] .step .n,
:root[data-theme="dark"] .voice .av,
:root[data-theme="dark"] .cline .ic{color:var(--gold-300)}
:root[data-theme="dark"] .col.free .tag,
:root[data-theme="dark"] .prow .p.free,
:root[data-theme="dark"] a,
:root[data-theme="dark"] .greet span{color:#9cc1f5}
:root[data-theme="dark"] .note,
:root[data-theme="dark"] .prose p,
:root[data-theme="dark"] .prose li,
:root[data-theme="dark"] .legal-box strong{color:var(--ink)}
:root[data-theme="dark"] .btn-navy{background:var(--navy-600);color:#fff;border-color:rgba(201,162,74,.35)}
:root[data-theme="dark"] .btn-outline{color:#eef3fb;border-color:var(--line-cool)}
:root[data-theme="dark"] .btn-outline:hover{background:#1a2b45;color:#fff}
:root[data-theme="dark"] .trust{border:1px solid #243a59}
:root[data-theme="dark"] .voice p{color:#dde6f3}

/* ============================================================
   SPRACH-DROPDOWN (Flagge + Name + ▾ → lange Liste)
   ============================================================ */
.lang-switch{position:relative;display:inline-block}
.lang-btn{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);color:#e8eefb;border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:5px 13px;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;line-height:1.4}
.lang-btn:hover{background:rgba(255,255,255,.16)}
.lang-flag{font-size:16px;line-height:1}
.lang-caret{font-size:11px;opacity:.85;transition:transform .15s}
.lang-switch.open .lang-caret{transform:rotate(180deg)}
.lang-menu{position:absolute;top:calc(100% + 7px);left:50%;transform:translateX(-50%);background:var(--cream);color:var(--ink);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:6px;margin:0;list-style:none;min-width:210px;max-height:62vh;overflow-y:auto;z-index:130;text-align:left}
.lang-menu li{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:14.5px;white-space:nowrap}
.lang-menu li:hover,.lang-menu li:focus{background:var(--navy-50);outline:none}
.lang-menu li[aria-selected="true"]{font-weight:700;color:var(--navy-800)}
.lang-menu li[aria-selected="true"]::after{content:"✓";margin-left:auto;color:var(--gold-600);font-weight:700}

/* ============================================================
   RTL (Arabisch / Farsi) – Grundausrichtung + Marker spiegeln
   Hinweis: erster Durchgang; vor Live für AR/FA gegenprüfen.
   ============================================================ */
[dir="rtl"] .col li{padding-left:0;padding-right:24px}
[dir="rtl"] .col li::before{left:auto;right:0}
[dir="rtl"] .col .note,[dir="rtl"] .legal-box[style*="border-left"]{border-left:0;border-right:2px solid var(--gold-600);padding-left:0;padding-right:14px}
[dir="rtl"] .flow .f{padding-left:16px;padding-right:48px}
[dir="rtl"] .flow .f::before{left:auto;right:14px}
[dir="rtl"] .hello-card{left:auto;right:-12px;border-left:0;border-right:3px solid var(--gold-600)}
[dir="rtl"] .lang-menu{text-align:right}
[dir="rtl"] .lang-menu li[aria-selected="true"]::after{margin-left:0;margin-right:auto}
[dir="rtl"] .prose ul{padding-left:0;padding-right:20px}
[dir="rtl"] .skip{left:auto;right:-9999px}

/* ============================================================
   BEWERTUNGEN — Verifiziert-Abzeichen + Formular
   ============================================================ */
.vbadge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:#1a7d4f;background:#e7f6ee;border:1px solid #bfe6cf;border-radius:999px;padding:3px 10px;margin-bottom:10px}
:root[data-theme="dark"] .vbadge{color:#82e0a8;background:rgba(40,120,70,.20);border-color:rgba(70,160,100,.4)}

.rform{max-width:560px}
.rform label{display:block;font-weight:600;margin:18px 0 6px;font-size:14.5px;color:var(--navy-800)}
:root[data-theme="dark"] .rform label{color:#eef3fb}
.rform input[type="text"],.rform textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;background:var(--cream);color:var(--ink);font-family:inherit;font-size:15px}
.rform textarea{min-height:110px;resize:vertical}
.rform input:focus,.rform textarea:focus{outline:none;border-color:var(--gold-500)}
.star-input{display:flex;gap:6px;font-size:30px;line-height:1;-webkit-user-select:none;user-select:none}
.star-input .st{cursor:pointer;color:var(--line)}
.star-input .st.on{color:var(--gold-500)}
.rconsent{display:flex;gap:10px;align-items:flex-start;margin-top:18px;font-size:14px;color:var(--muted)}
.rconsent input{margin-top:3px;flex:none}
.rthanks{display:none;margin-top:18px;padding:16px 18px;border-radius:12px;background:#e7f6ee;border:1px solid #bfe6cf;color:#176b43;font-weight:600}
:root[data-theme="dark"] .rthanks{background:rgba(40,120,70,.18);border-color:rgba(70,160,100,.4);color:#9fe9bf}
.rthanks.show{display:block}
.demo-ribbon{display:inline-block;background:var(--gold-soft);color:#6b4f12;font-size:12.5px;font-weight:700;border-radius:8px;padding:5px 12px;margin-bottom:14px}
:root[data-theme="dark"] .demo-ribbon{background:rgba(201,162,74,.18);color:var(--gold-300)}

/* ============================================================
   UI-Veredelung (v4): Aktiv-Navigation, Glow, sanfte Übergänge
   Alles bewegungsreduziert-sicher (siehe @media unten).
   ============================================================ */

/* --- Aktive Seite in der Navigation: leuchtende Gold-Linie --- */
.nav-links a{position:relative}
.nav-links a.is-active,.nav-links a[aria-current="page"]{color:var(--navy-800)}
.nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--gold-600),var(--gold-300));
  transform:scaleX(0);transform-origin:left;transition:transform .26s ease;
}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-links a.is-active::after,.nav-links a[aria-current="page"]::after{
  transform:scaleX(1);
  box-shadow:0 0 8px rgba(201,162,74,.75),0 0 2px rgba(201,162,74,.9);
  animation:navglow 2.6s ease-in-out infinite;
}
@keyframes navglow{0%,100%{opacity:.82}50%{opacity:1}}
.mobile-menu a.is-active{color:var(--navy-800);border-left:3px solid var(--gold-600);padding-left:9px;background:linear-gradient(90deg,rgba(201,162,74,.12),transparent)}

/* --- Scroll-Fortschrittsbalken oben (leuchtendes Gold) --- */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:100%;z-index:300;
  transform:scaleX(0);transform-origin:0 50%;
  background:linear-gradient(90deg,var(--gold-600),var(--gold-300),var(--gold-500));
  box-shadow:0 0 10px rgba(201,162,74,.7);transition:transform .08s linear;pointer-events:none;
}

/* --- Einblenden beim Scrollen (nur aktiv, wenn JS .js-reveal setzt) --- */
.js-reveal .reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s cubic-bezier(.2,.7,.2,1)}
.js-reveal .reveal.in{opacity:1;transform:none}

/* --- Seite beim Laden sanft einblenden --- */
@keyframes pagefade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.page-ready main{animation:pagefade .5s ease both}

/* --- Hover-Glow an Buttons, Karten, Logo, Theme-Schalter --- */
.btn{transition:transform .15s ease,box-shadow .2s ease,filter .15s ease}
.btn-gold:hover{box-shadow:0 10px 26px rgba(184,144,47,.45),0 0 14px rgba(227,200,121,.5);transform:translateY(-1px)}
.btn-navy:hover{box-shadow:0 10px 24px rgba(20,58,102,.4),0 0 12px rgba(201,162,74,.25);transform:translateY(-1px)}
.btn-outline:hover{box-shadow:0 0 0 1px var(--gold-500),0 6px 16px rgba(201,162,74,.18)}
.step,.voice,.col,.ptable{transition:transform .2s ease,box-shadow .25s ease,border-color .25s ease}
.step:hover,.voice:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(10,31,58,.10);border-color:var(--gold-soft)}
.brand .mark{transition:box-shadow .25s ease,transform .25s ease}
.brand:hover .mark{box-shadow:0 0 0 1px var(--gold-500),0 0 14px rgba(201,162,74,.55);transform:translateY(-1px)}
.theme-toggle{transition:filter .2s ease,transform .2s ease}
.theme-toggle:hover{filter:drop-shadow(0 0 6px rgba(201,162,74,.6));transform:scale(1.06)}

/* --- Dunkelmodus: edleres, kräftigeres Leuchten + Hero-Lichtschein --- */
:root[data-theme="dark"] .scroll-progress{box-shadow:0 0 14px rgba(227,200,121,.85)}
:root[data-theme="dark"] .nav-links a.is-active::after{box-shadow:0 0 12px rgba(227,200,121,.9)}
:root[data-theme="dark"] .btn-gold{box-shadow:0 8px 20px rgba(0,0,0,.5),0 0 14px rgba(201,162,74,.35)}
:root[data-theme="dark"] .step:hover,:root[data-theme="dark"] .voice:hover{box-shadow:0 14px 34px rgba(0,0,0,.5),0 0 18px rgba(201,162,74,.18)}
:root[data-theme="dark"] .hero{position:relative;overflow:hidden}
:root[data-theme="dark"] .hero>.wrap{position:relative;z-index:1}
:root[data-theme="dark"] .hero::before{content:"";position:absolute;top:-130px;right:-90px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,74,.16),transparent 70%);pointer-events:none;z-index:0}

/* --- Bewegungsreduktion respektieren --- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .js-reveal .reveal{opacity:1!important;transform:none!important}
  .nav-links a.is-active::after{animation:none}
}

/* ---------- Design-Feinschliff (dezent; Reduced-Motion greift global oben) ---------- */
/* Logo: nur das goldene VK schimmert/pulsiert minimal (nur im Header) */
@keyframes vkGlow{0%,100%{box-shadow:inset 0 0 0 1px rgba(255,255,255,.06),0 0 0 0 rgba(201,162,74,0);transform:scale(1)}50%{box-shadow:inset 0 0 0 1px rgba(255,255,255,.06),0 0 12px 1px rgba(201,162,74,.55);transform:scale(1.045)}}
.site-header .brand .mark{animation:vkGlow 3.6s ease-in-out infinite}
/* Navi-Unterstrich ist oben (bei „Aktive Seite") vereinheitlicht — Basis/Hover/aktiv in einem Mechanismus */
/* Sanftes Anheben von Karten + Buttons */
.btn{transition:transform .16s ease,box-shadow .16s ease,background-color .15s,color .15s,border-color .15s}
.btn:hover{transform:translateY(-2px)}
.col,.step,.cbox,.voice{transition:transform .22s ease,box-shadow .22s ease,background-color .2s,color .2s,border-color .2s}
.col:hover,.step:hover,.cbox:hover,.voice:hover{transform:translateY(-3px);box-shadow:0 12px 30px -14px rgba(14,42,77,.3)}
/* Hero-Gold-Schimmer sanft driften lassen */
@keyframes heroDrift{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-18px,12px) scale(1.07)}}
.hero::before{animation:heroDrift 13s ease-in-out infinite}
/* Glas-Header: leichter Schatten beim Scrollen */
.site-header{transition:background-color .25s ease,box-shadow .25s ease}
.site-header.scrolled{box-shadow:0 6px 22px -18px rgba(14,42,77,.55)}
/* Aufklappbare Info (Sozialtarif etc.) */
.acc{border:1px solid var(--line);border-radius:var(--radius);background:var(--cream);overflow:hidden}
.acc>summary{cursor:pointer;list-style:none;padding:13px 16px;font-weight:700;color:var(--navy-800)}
.acc>summary::-webkit-details-marker{display:none}
.acc>summary::after{content:"▾";float:right;transition:transform .2s ease}
.acc[open]>summary::after{transform:rotate(180deg)}
.acc>*:not(summary){padding:0 16px 14px;color:var(--muted);font-size:14.5px;line-height:1.55}
