/* =========================================================
   IMMO Online Gutachten — Relaunch
   Modern Dark/Blue Premium, Responsive First
   ========================================================= */
:root{
  --bg:#0a101c;
  --bg-elev:#0f172a;
  --bg-card:#111a2e;
  --line:rgba(255,255,255,.08);
  --line-strong:rgba(255,255,255,.16);
  --ink:#eaf0ff;
  --ink-soft:#b9c4e2;
  --muted:#8591b2;
  --brand:#3b82f6;
  --brand-2:#60a5fa;
  --brand-dark:#1e40af;
  --accent:#22d3ee;
  --gold:#f2c46b;
  --success:#10b981;
  --radius:14px;
  --radius-lg:22px;
  --max:1240px;
  --shadow:0 20px 60px rgba(5,10,25,.55);
  --shadow-sm:0 6px 20px rgba(5,10,25,.35);
  --t:.25s cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:'Inter',-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color var(--t)}
a:hover{color:var(--brand-2)}
em{font-family:'Playfair Display',Georgia,serif;font-style:italic;font-weight:600;color:var(--brand-2)}
h1,h2,h3,h4{font-family:'Inter',sans-serif;font-weight:700;line-height:1.15;letter-spacing:-.01em;margin:0}
p{margin:0 0 1em}

.container{max-width:var(--max);margin:0 auto;padding:0 clamp(16px,3vw,32px)}

/* ---------- Topbar ---------- */
.topbar{background:#060a14;color:var(--ink-soft);font-size:.82rem;padding:10px 0;border-bottom:1px solid var(--line)}
.topbar__wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.topbar__contact{display:flex;gap:12px;align-items:center}
.topbar__contact a{color:var(--ink);font-weight:600}
.topbar__sep{opacity:.4}
@media(max-width:640px){.topbar__item{display:none}}

/* ---------- Navigation ---------- */
.nav{position:sticky;top:0;z-index:100;background:rgba(10,16,28,.85);backdrop-filter:blur(14px) saturate(1.4);-webkit-backdrop-filter:blur(14px) saturate(1.4);border-bottom:1px solid var(--line)}
.nav__wrap{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:24px}
.nav__logo img{height:42px;width:auto}
.nav__menu{list-style:none;display:flex;gap:28px;margin:0;padding:0;align-items:center}
.nav__menu a{font-size:.95rem;font-weight:500;color:var(--ink-soft);position:relative}
.nav__menu a:hover,.nav__menu a.is-active{color:var(--ink)}
.nav__menu a.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;background:var(--brand)}
.nav__cta{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff!important;padding:11px 22px;border-radius:999px;font-weight:600;box-shadow:0 8px 24px rgba(59,130,246,.35);transition:transform var(--t),box-shadow var(--t)}
.nav__cta:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(59,130,246,.5)}
.nav__burger{display:none;background:none;border:0;width:44px;height:44px;cursor:pointer;flex-direction:column;justify-content:center;gap:5px;padding:0}
.nav__burger span{display:block;width:24px;height:2px;background:var(--ink);transition:var(--t)}
.nav__burger[aria-expanded=true] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger[aria-expanded=true] span:nth-child(2){opacity:0}
.nav__burger[aria-expanded=true] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:980px){
  .nav__burger{display:flex}
  .nav__menu{position:fixed;top:72px;left:0;right:0;flex-direction:column;gap:0;background:var(--bg-elev);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:16px 24px 28px;transform:translateY(-110%);opacity:0;pointer-events:none;transition:var(--t);max-height:calc(100dvh - 72px);overflow-y:auto}
  .nav__menu.is-open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav__menu li{width:100%;border-bottom:1px solid var(--line)}
  .nav__menu li:last-child{border:0;padding-top:12px}
  .nav__menu a{display:block;padding:16px 0;font-size:1.05rem}
  .nav__menu a.is-active::after{display:none}
  .nav__cta{width:100%;text-align:center}
}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 28px;border-radius:999px;font-weight:600;font-size:.98rem;transition:var(--t);border:1.5px solid transparent;cursor:pointer;white-space:nowrap}
.btn--primary{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;box-shadow:0 14px 34px rgba(59,130,246,.35)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 18px 44px rgba(59,130,246,.5);color:#fff}
.btn--ghost{background:rgba(255,255,255,.06);color:var(--ink);border-color:var(--line-strong)}
.btn--ghost:hover{background:rgba(255,255,255,.12);color:var(--ink)}
.btn--outline{background:transparent;color:var(--ink);border-color:var(--brand)}
.btn--outline:hover{background:var(--brand);color:#fff}
.btn--outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn--outline-light:hover{background:#fff;color:var(--bg)}

/* ---------- Section base ---------- */
.section{padding:clamp(72px,9vw,128px) 0}
.section__intro{text-align:center;max-width:780px;margin:0 auto 56px}
.section__eyebrow{display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-2);margin-bottom:16px;padding:6px 16px;border:1px solid var(--line-strong);border-radius:999px;background:rgba(59,130,246,.08)}
.section__eyebrow.light{color:rgba(255,255,255,.9);border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.1)}
.section__title{font-size:clamp(1.85rem,4.4vw,3rem);margin-bottom:20px}
.section__title.light{color:#fff}
.section__lead{font-size:clamp(1.02rem,1.4vw,1.18rem);color:var(--ink-soft);line-height:1.7}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:92dvh;display:flex;align-items:center;overflow:hidden;padding:80px 0 120px}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;filter:brightness(.42) saturate(1.1)}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(130deg,rgba(10,16,28,.92) 0%,rgba(10,16,28,.72) 45%,rgba(10,16,28,.58) 100%),radial-gradient(circle at 80% 30%,rgba(59,130,246,.18),transparent 60%)}
.hero__content{position:relative;z-index:2;max-width:820px}
.hero__eyebrow{display:inline-block;font-size:.85rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-2);margin-bottom:24px}
.hero__title{font-size:clamp(2.4rem,6vw,4.8rem);line-height:1.05;margin-bottom:28px;font-weight:800}
.hero__sub{font-size:clamp(1.08rem,1.6vw,1.32rem);color:var(--ink-soft);max-width:640px;line-height:1.65;margin-bottom:40px}
.hero__sub strong{color:var(--ink);font-weight:600}
.hero__ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:60px}
.hero__badges{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;max-width:680px;padding-top:40px;border-top:1px solid var(--line-strong)}
.hero__badges div{display:flex;flex-direction:column;gap:4px}
.hero__badges strong{font-size:clamp(1.5rem,2.4vw,2rem);color:var(--brand-2);font-weight:700}
.hero__badges span{font-size:.85rem;color:var(--ink-soft);line-height:1.3}
.hero__scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);width:30px;height:46px;border:2px solid rgba(255,255,255,.35);border-radius:20px;z-index:2;display:flex;justify-content:center;padding-top:8px}
.hero__scroll span{width:4px;height:8px;background:#fff;border-radius:2px;animation:scrollDot 2s infinite}
@keyframes scrollDot{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(12px);opacity:.3}}
@media(max-width:720px){
  .hero{min-height:auto;padding:60px 0 90px}
  .hero__badges{grid-template-columns:1fr 1fr;gap:20px;padding-top:28px}
  .hero__scroll{display:none}
}

/* ---------- Trust-Strip ---------- */
.strip{background:var(--bg-elev);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:28px 0}
.strip__wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;align-items:center}
.strip__wrap > div{display:flex;align-items:center;gap:14px;color:var(--ink-soft);font-size:.95rem;font-weight:500;justify-content:center}
.strip__wrap svg{width:26px;height:26px;color:var(--brand-2);flex-shrink:0}
@media(max-width:860px){.strip__wrap{grid-template-columns:1fr 1fr;gap:20px}}
@media(max-width:460px){.strip__wrap{grid-template-columns:1fr}}

/* ---------- Benefits ---------- */
.benefits__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.benefit-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px 28px;transition:var(--t);position:relative;overflow:hidden}
.benefit-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 0%,rgba(59,130,246,.15),transparent 70%);opacity:0;transition:var(--t)}
.benefit-card:hover{transform:translateY(-6px);border-color:rgba(59,130,246,.4);box-shadow:var(--shadow)}
.benefit-card:hover::before{opacity:1}
.benefit-card__icon{font-size:2.2rem;margin-bottom:18px;position:relative}
.benefit-card h3{font-size:1.18rem;margin-bottom:12px;position:relative}
.benefit-card p{color:var(--ink-soft);font-size:.95rem;line-height:1.6;margin:0;position:relative}
.benefit-card strong{color:var(--ink)}
@media(max-width:980px){.benefits__grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.benefits__grid{grid-template-columns:1fr}}

/* ---------- Example ---------- */
.example{background:var(--bg-elev);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.example__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:center}
.example__media{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.example__media img{width:100%;aspect-ratio:4/3;object-fit:cover}
.example__badge{position:absolute;top:18px;left:18px;background:var(--brand);color:#fff;font-weight:600;padding:8px 16px;border-radius:999px;font-size:.82rem;letter-spacing:.05em;text-transform:uppercase}
.example__list{list-style:none;padding:0;margin:28px 0 32px;display:flex;flex-direction:column;gap:2px}
.example__list li{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid var(--line);gap:16px}
.example__list li:last-child{border-bottom:0}
.example__list span{color:var(--ink-soft);font-size:.95rem}
.example__list strong{font-size:1.08rem;color:var(--ink);font-variant-numeric:tabular-nums}
.example__highlight{background:linear-gradient(90deg,rgba(59,130,246,.15),transparent);border-radius:10px;padding:20px 16px!important;margin-top:8px}
.example__highlight strong{color:var(--brand-2);font-size:1.3rem}
.example__ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:20px}
.example__disclaimer{color:var(--muted);font-size:.82rem;line-height:1.5;margin:0}
@media(max-width:880px){.example__grid{grid-template-columns:1fr;gap:40px}}

/* ---------- When ---------- */
.when__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.when__card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:40px 32px;position:relative;transition:var(--t)}
.when__card:hover{transform:translateY(-4px);border-color:var(--brand)}
.when__num{font-family:'Playfair Display',serif;font-size:3.4rem;font-weight:700;color:var(--brand);line-height:1;margin-bottom:16px;opacity:.85}
.when__card h3{font-size:1.3rem;margin-bottom:12px}
.when__card p{color:var(--ink-soft);margin:0;font-size:.96rem}
.when__cta{text-align:center;margin-top:48px}
@media(max-width:880px){.when__grid{grid-template-columns:1fr}}

/* ---------- Process ---------- */
.process{background:var(--bg-elev);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.process__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;counter-reset:step}
.process__step{text-align:center;padding:32px 20px;position:relative}
.process__num{width:62px;height:62px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:700;margin:0 auto 18px;box-shadow:0 10px 28px rgba(59,130,246,.35)}
.process__step h3{font-size:1.15rem;margin-bottom:10px}
.process__step p{color:var(--ink-soft);font-size:.94rem;margin:0}
@media(max-width:980px){.process__grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.process__grid{grid-template-columns:1fr}}

/* ---------- Expert ---------- */
.expert{position:relative;padding:clamp(72px,9vw,128px) 0;background:linear-gradient(135deg,#0a101c,#0f1e3d)}
.expert::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(59,130,246,.25),transparent 60%);pointer-events:none}
.expert__grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:center;position:relative}
.expert__media img{border-radius:var(--radius-lg);aspect-ratio:4/5;object-fit:cover;box-shadow:var(--shadow);max-width:420px;margin:0 auto;width:100%}
.expert__tagline{color:var(--brand-2);font-size:1.08rem;margin-bottom:28px}
.expert__points{list-style:none;padding:0;margin:0 0 32px;display:flex;flex-direction:column;gap:14px}
.expert__points li{color:var(--ink);font-size:1.02rem;display:flex;gap:12px;align-items:center}
.expert__ctas{display:flex;gap:14px;flex-wrap:wrap}
@media(max-width:880px){.expert__grid{grid-template-columns:1fr;gap:40px;text-align:center}.expert__points li{justify-content:center}.expert__ctas{justify-content:center}}

/* ---------- FAQ ---------- */
.faq__list{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq__item{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:border-color var(--t)}
.faq__item[open]{border-color:rgba(59,130,246,.4)}
.faq__item summary{padding:22px 28px;cursor:pointer;font-weight:600;font-size:1.02rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;color:var(--ink)}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-size:1.5rem;font-weight:300;color:var(--brand-2);transition:var(--t);flex-shrink:0}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__answer{padding:0 28px 24px;color:var(--ink-soft);line-height:1.7}
.faq__answer p{margin:0}
@media(max-width:560px){.faq__item summary{padding:18px 22px;font-size:.98rem}.faq__answer{padding:0 22px 22px}}

/* ---------- CTA Band ---------- */
.cta-band{background:linear-gradient(135deg,var(--brand-dark),var(--brand));padding:clamp(60px,7vw,96px) 0;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.15),transparent 50%),radial-gradient(circle at 80% 80%,rgba(34,211,238,.2),transparent 50%);pointer-events:none}
.cta-band__wrap{text-align:center;max-width:720px;margin:0 auto;position:relative}
.cta-band h2{font-size:clamp(1.85rem,3.6vw,2.6rem);color:#fff;margin-bottom:14px}
.cta-band h2 em{color:#fff;text-shadow:0 2px 20px rgba(255,255,255,.35)}
.cta-band p{color:rgba(255,255,255,.88);font-size:1.1rem;margin-bottom:32px}
.cta-band__ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-band .btn--primary{background:#fff;color:var(--brand-dark)}
.cta-band .btn--primary:hover{background:#fff;color:var(--brand-dark);transform:translateY(-2px)}
.cta-band .btn--ghost{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.4);color:#fff}

/* ---------- Footer ---------- */
.footer{background:#060a14;border-top:1px solid var(--line);padding:72px 0 28px;color:var(--ink-soft)}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:48px}
.footer__brand img{height:48px;width:auto;margin-bottom:18px}
.footer__tag{color:var(--ink);font-weight:600;margin-bottom:14px;line-height:1.5}
.footer__small{font-size:.88rem;color:var(--muted);line-height:1.6}
.footer h4{color:var(--ink);font-size:.98rem;margin-bottom:18px}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.footer ul a{font-size:.92rem;color:var(--ink-soft);transition:color var(--t)}
.footer ul a:hover{color:var(--brand-2)}
.footer__hours{margin-top:18px;font-size:.86rem;color:var(--muted)}
.footer__hours strong{color:var(--ink);display:block;margin-bottom:4px}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding-top:24px;border-top:1px solid var(--line);font-size:.82rem;color:var(--muted)}
.footer__dev{padding:6px 14px;border:1px dashed rgba(59,130,246,.45);border-radius:999px;color:var(--brand-2)}
@media(max-width:880px){.footer__grid{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:520px){.footer__grid{grid-template-columns:1fr}}

/* ---------- Stub ---------- */
.stub{min-height:60dvh;display:flex;align-items:center}
.stub .container{text-align:center;max-width:640px}
.stub .btn{margin-top:28px}

/* =========================================================
   WIZARD — Gutachten beauftragen
   ========================================================= */
.wizard{padding:clamp(40px,6vw,80px) 0 180px;background:linear-gradient(180deg,var(--bg) 0%,var(--bg-elev) 100%)}
.wizard__container{max-width:1340px;margin:0 auto;padding:0 clamp(16px,3vw,32px)}
.wizard__header{text-align:center;max-width:760px;margin:0 auto 56px}
.wizard__header h1{font-size:clamp(2rem,4.4vw,3rem);margin:12px 0 16px;font-weight:800}
.wizard__header p{color:var(--ink-soft);font-size:clamp(1rem,1.3vw,1.12rem);line-height:1.7}
.wizard__layout{display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:start}
@media(max-width:1100px){.wizard__layout{grid-template-columns:1fr;gap:32px}}

/* --- Step navigation --- */
.wizard__nav{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:40px;padding:0 4px;flex-wrap:nowrap}
.wizard__step{background:none;border:0;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;color:var(--muted);font-family:inherit;padding:4px 2px;min-width:0;flex:0 0 auto;transition:var(--t)}
.wizard__step-num{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.05rem;border:2px solid var(--line-strong);background:var(--bg-card);color:var(--muted);transition:var(--t)}
.wizard__step-label{font-size:.82rem;font-weight:500;letter-spacing:.02em;white-space:nowrap}
.wizard__step:hover .wizard__step-num{border-color:var(--brand-2)}
.wizard__step.is-active{color:var(--ink)}
.wizard__step.is-active .wizard__step-num{background:linear-gradient(135deg,var(--brand),var(--brand-2));border-color:transparent;color:#fff;box-shadow:0 10px 28px rgba(59,130,246,.4)}
.wizard__step.is-done{color:var(--ink-soft)}
.wizard__step.is-done .wizard__step-num{background:rgba(59,130,246,.16);border-color:var(--brand);color:var(--brand-2)}
.wizard__step-line{flex:1 1 auto;height:2px;background:var(--line);min-width:16px;max-width:60px}
@media(max-width:720px){
  .wizard__nav{overflow-x:auto;justify-content:flex-start;gap:6px;padding-bottom:8px;margin:0 -16px 32px;padding-left:16px;padding-right:16px;scrollbar-width:none}
  .wizard__nav::-webkit-scrollbar{display:none}
  .wizard__step-num{width:36px;height:36px;font-size:.95rem}
  .wizard__step-label{font-size:.72rem}
  .wizard__step-line{max-width:20px;min-width:12px}
}

/* --- Form main --- */
.wizard__form{position:relative}
.wizard__page{border:0;margin:0;padding:0;display:none;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(28px,3.5vw,48px);box-shadow:var(--shadow)}
.wizard__page.is-active{display:block;animation:fadeUp .4s var(--t)}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.wizard__legend{display:flex;flex-direction:column;gap:6px;margin-bottom:32px;padding:0}
.wizard__legend span{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brand-2);font-weight:600}
.wizard__legend h2{font-size:clamp(1.5rem,2.8vw,2rem);margin:0;color:var(--ink);font-weight:700}
.wizard__intro{color:var(--ink-soft);font-size:.98rem;line-height:1.65;margin:-12px 0 28px}
.wizard__intro strong{color:var(--ink)}

/* --- Fields --- */
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:22px}
.field--hidden{display:none!important}
.field-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:22px;margin-bottom:22px}
.field-row > .field{margin-bottom:0}
.field__label{font-size:.92rem;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:4px}
.field__label em{color:var(--brand-2);font-style:normal;font-family:inherit;font-weight:700}
.field__hint{font-size:.82rem;color:var(--muted);margin-top:2px;display:block}
.field__hint.is-valid{color:#34d399}
.field__hint.is-error{color:#f87171}
.field input[type=text],.field input[type=number],.field input[type=email],.field input[type=tel],.field input[type=date],.field select,.field textarea{
  width:100%;background:var(--bg-elev);border:1.5px solid var(--line-strong);border-radius:12px;padding:14px 16px;color:var(--ink);font:inherit;font-size:.98rem;transition:var(--t);appearance:none;-webkit-appearance:none
}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--brand);background:rgba(59,130,246,.06);box-shadow:0 0 0 4px rgba(59,130,246,.12)}
.field input.is-invalid,.field select.is-invalid,.field textarea.is-invalid{border-color:#f87171;background:rgba(248,113,113,.06)}
.field textarea{resize:vertical;min-height:92px;font-family:inherit}
.field select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23b9c4e2'><path d='M10 14l-5-5h10z'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:42px}
.field input[type=date]{color-scheme:dark}

/* --- Type Cards --- */
.type-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:12px}
.type-card{position:relative;cursor:pointer}
.type-card input{position:absolute;inset:0;opacity:0;cursor:pointer}
.type-card__body{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:20px 14px;background:var(--bg-elev);border:1.5px solid var(--line-strong);border-radius:14px;transition:var(--t);text-align:center;min-height:112px}
.type-card__body svg{width:32px;height:32px;color:var(--brand-2);transition:var(--t)}
.type-card__body strong{font-size:.88rem;font-weight:600;color:var(--ink);line-height:1.3}
.type-card:hover .type-card__body{border-color:var(--brand-2);transform:translateY(-2px)}
.type-card input:checked + .type-card__body{background:linear-gradient(135deg,rgba(59,130,246,.2),rgba(96,165,250,.1));border-color:var(--brand);box-shadow:0 10px 28px rgba(59,130,246,.25)}
.type-card input:checked + .type-card__body svg{color:#fff;transform:scale(1.08)}
.type-card input:focus-visible + .type-card__body{outline:2px solid var(--brand);outline-offset:2px}

/* --- Modernisierung --- */
.mod-list{display:flex;flex-direction:column;gap:12px}
.mod-row{display:grid;grid-template-columns:1.2fr 2fr;gap:20px;align-items:center;padding:18px 22px;background:var(--bg-elev);border:1px solid var(--line);border-radius:14px;transition:var(--t)}
.mod-row:hover{border-color:var(--line-strong)}
.mod-row__label{display:flex;align-items:center;gap:14px;color:var(--ink);font-size:.98rem}
.mod-row__num{width:30px;height:30px;border-radius:50%;background:rgba(59,130,246,.18);color:var(--brand-2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem;flex-shrink:0}
.mod-row__selects{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mod-row__selects select{background:var(--bg-card);border:1.5px solid var(--line-strong);border-radius:10px;padding:12px 14px;color:var(--ink);font:inherit;font-size:.92rem;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23b9c4e2'><path d='M10 14l-5-5h10z'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer;transition:var(--t)}
.mod-row__selects select:focus{outline:0;border-color:var(--brand);box-shadow:0 0 0 3px rgba(59,130,246,.15)}
.mod-row__selects select:disabled{opacity:.4;cursor:not-allowed}
@media(max-width:680px){.mod-row{grid-template-columns:1fr;gap:12px}.mod-row__selects{grid-template-columns:1fr 1fr}}

/* --- Uploads --- */
.upload-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
.upload{background:var(--bg-elev);border:1px solid var(--line);border-radius:14px;padding:18px;transition:var(--t)}
.upload:hover{border-color:var(--line-strong)}
.upload__head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px;gap:12px}
.upload__head strong{font-size:.96rem;color:var(--ink)}
.upload__max{font-size:.78rem;color:var(--muted)}
.upload__drop{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px 16px;background:var(--bg-card);border:1.5px dashed var(--line-strong);border-radius:12px;cursor:pointer;transition:var(--t);text-align:center;min-height:120px}
.upload__drop:hover{border-color:var(--brand);background:rgba(59,130,246,.04)}
.upload__drop svg{width:30px;height:30px;color:var(--brand-2)}
.upload__hint{font-size:.88rem;color:var(--ink-soft)}
.upload__count{font-size:.78rem;color:var(--muted)}
.upload.has-files .upload__drop{border-color:#34d399;background:rgba(52,211,153,.06)}
.upload.has-files .upload__count{color:#34d399;font-weight:600}
.upload__input{position:absolute;inset:0;opacity:0;cursor:pointer}

/* --- Consent checkboxes --- */
.consent{display:flex;gap:12px;align-items:flex-start;margin-bottom:18px;cursor:pointer;line-height:1.5;font-size:.92rem;color:var(--ink-soft)}
.consent input[type=checkbox]{flex-shrink:0;margin-top:3px;width:20px;height:20px;accent-color:var(--brand);cursor:pointer}
.consent input[type=checkbox].is-invalid{outline:2px solid #f87171;outline-offset:2px;border-radius:4px}
.consent a{color:var(--brand-2);text-decoration:underline}
.consent em{color:var(--brand-2);font-style:normal;font-family:inherit;font-weight:700}
.consent strong{color:var(--ink)}

.hp-field{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important}

/* --- Actions --- */
.wizard__actions{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:36px;padding-top:28px;border-top:1px solid var(--line);flex-wrap:wrap}
.wizard__actions > span{display:block}
.btn--large{padding:16px 36px;font-size:1.05rem}
@media(max-width:560px){.wizard__actions{flex-direction:column-reverse}.wizard__actions .btn{width:100%}}

/* --- Live preview aside --- */
.wizard__aside{position:sticky;top:100px;display:flex;flex-direction:column;gap:20px}
@media(max-width:1100px){.wizard__aside{position:static;top:auto}}
.preview-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px 26px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.preview-card::before{content:"";position:absolute;top:-40px;right:-40px;width:140px;height:140px;background:radial-gradient(circle,rgba(59,130,246,.22),transparent 70%);pointer-events:none}
.preview-card__head{position:relative;margin-bottom:20px}
.preview-badge{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-2);padding:4px 12px;border:1px solid rgba(59,130,246,.35);border-radius:999px;background:rgba(59,130,246,.1);margin-bottom:10px}
.preview-badge--gold{color:var(--gold);border-color:rgba(242,196,107,.4);background:rgba(242,196,107,.08)}
.preview-card__head h3{font-size:1.2rem;color:var(--ink);margin:0}
.preview-list{margin:0;padding:0;display:flex;flex-direction:column;gap:2px;position:relative}
.preview-row{display:flex;justify-content:space-between;align-items:baseline;padding:10px 0;border-bottom:1px solid var(--line);gap:12px}
.preview-row:last-child{border-bottom:0}
.preview-row dt{color:var(--ink-soft);font-size:.88rem;font-weight:500;margin:0}
.preview-row dd{margin:0;color:var(--ink);font-size:.98rem;font-weight:600;font-variant-numeric:tabular-nums;text-align:right}
.preview-row--hero{padding:14px 16px;margin:8px -16px;background:linear-gradient(90deg,rgba(59,130,246,.15),transparent);border-radius:10px;border-bottom:0}
.preview-row--hero dt{color:var(--ink);font-weight:600}
.preview-row--hero dd{font-size:1.18rem;color:var(--brand-2)}
.preview-row--highlight{padding:14px 16px;margin-top:8px;background:linear-gradient(90deg,rgba(52,211,153,.14),transparent);border-radius:10px;border-bottom:0}
.preview-row--highlight dd{color:#34d399;font-size:1.15rem}
.preview-row--big{padding:16px 16px;margin-top:4px;background:var(--bg-elev);border-radius:10px;border-bottom:0}
.preview-row--big dt{font-size:.92rem}
.preview-row--big dd{font-size:1.35rem;color:#fff;font-weight:700}
.preview-row--total{padding:16px 16px;margin-top:4px;background:linear-gradient(90deg,var(--brand-dark),var(--brand));border-radius:10px;border-bottom:0}
.preview-row--total dt{color:rgba(255,255,255,.85)}
.preview-row--total dd{color:#fff;font-size:1.4rem;font-weight:700}
.preview-divider{height:1px;background:var(--line);margin:8px 0}
.preview-warn{margin-top:16px;padding:12px 14px;background:rgba(242,196,107,.12);border:1px solid rgba(242,196,107,.35);border-radius:10px;color:var(--gold);font-size:.82rem;line-height:1.5}
.preview-hint{color:var(--muted);font-size:.8rem;line-height:1.55;margin:0;padding:0 4px}

/* --- Mobile sticky --- */
.wizard__sticky{display:none}
@media(max-width:1100px){
  .wizard__sticky{display:flex;position:fixed;left:12px;right:12px;bottom:12px;background:rgba(10,16,28,.92);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);border:1px solid var(--line-strong);border-radius:14px;padding:12px 16px;box-shadow:0 20px 50px rgba(0,0,0,.5);z-index:60;gap:8px;justify-content:space-between}
  .wizard__sticky-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1 1 0}
  .wizard__sticky-info span{font-size:.68rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}
  .wizard__sticky-info strong{font-size:1rem;color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .wizard__sticky-info:last-child strong{color:#34d399}
}

/* --- Thank You --- */
.thanks{padding:clamp(80px,10vw,140px) 0;text-align:center}
.thanks__wrap{max-width:640px;margin:0 auto}
.thanks__icon{width:96px;height:96px;margin:0 auto 32px;border-radius:50%;background:linear-gradient(135deg,rgba(52,211,153,.2),rgba(52,211,153,.05));border:2px solid rgba(52,211,153,.4);display:flex;align-items:center;justify-content:center;color:#34d399}
.thanks__icon svg{width:56px;height:56px}
.thanks .section__title{margin-bottom:16px}
.thanks__summary{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px 32px;margin:36px auto;display:flex;flex-direction:column;gap:2px;text-align:left;max-width:480px}
.thanks__row{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0;border-bottom:1px solid var(--line);gap:12px}
.thanks__row:last-child{border-bottom:0}
.thanks__row span{color:var(--ink-soft);font-size:.92rem}
.thanks__row strong{color:var(--ink);font-variant-numeric:tabular-nums}
.thanks__row--total{padding:16px 16px;margin-top:8px;background:linear-gradient(90deg,var(--brand-dark),var(--brand));border-radius:10px;border-bottom:0}
.thanks__row--total span{color:rgba(255,255,255,.85)}
.thanks__row--total strong{color:#fff;font-size:1.35rem}
.thanks__ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:28px}
.thanks__note{color:var(--muted);font-size:.88rem;line-height:1.6}
.thanks__note a{color:var(--brand-2)}

/* =========================================================
   PREMIUM UPGRADES — Hero, Video, Stats, Compare, Audience,
   Testimonials, Trust, Form polish, Reveal Animations
   ========================================================= */

/* --- Scroll Reveal --- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.25,1),transform .9s cubic-bezier(.2,.7,.25,1)}
.reveal.is-visible{opacity:1;transform:none}

/* --- Pulse dot in hero eyebrow --- */
.pulse-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#34d399;box-shadow:0 0 0 0 rgba(52,211,153,.6);animation:pulse 2s infinite;margin-right:4px;vertical-align:middle}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(52,211,153,.6)}70%{box-shadow:0 0 0 10px rgba(52,211,153,0)}100%{box-shadow:0 0 0 0 rgba(52,211,153,0)}}

/* --- Hero Premium Upgrade --- */
.hero--premium{min-height:100dvh;padding:60px 0 120px}
.hero--premium .hero__eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 18px;background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.3);border-radius:999px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.hero__glow{position:absolute;top:20%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(59,130,246,.4),transparent 60%);filter:blur(80px);pointer-events:none;animation:float 16s ease-in-out infinite}
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(-40px,30px)}}
.hero__grid{position:relative;z-index:2;display:grid;grid-template-columns:1.2fr 420px;gap:64px;align-items:center}
@media(max-width:1080px){.hero__grid{grid-template-columns:1fr;gap:48px}}
.hero--premium .hero__title{font-size:clamp(2.4rem,6.5vw,5.6rem);line-height:1.02;font-weight:800;letter-spacing:-.02em}
.hero--premium .hero__title em{background:linear-gradient(135deg,var(--brand-2),#a78bfa);-webkit-background-clip:text;background-clip:text;color:transparent;font-family:'Playfair Display',serif;font-weight:700;display:inline-block}
.hero__trust{display:flex;align-items:center;gap:16px;margin-top:36px;padding-top:36px;border-top:1px solid var(--line-strong)}
.hero__trust-stars{color:var(--gold);font-size:1.5rem;letter-spacing:2px;text-shadow:0 0 20px rgba(242,196,107,.5)}
.hero__trust strong{display:block;font-size:1.05rem;color:var(--ink);font-weight:700;margin-bottom:2px}
.hero__trust span{font-size:.85rem;color:var(--muted);display:block}
.btn--large{padding:18px 36px;font-size:1.05rem;font-weight:700}
.btn--large svg{width:20px;height:20px}

/* --- Hero Live-Calc Card --- */
.hero__calc{background:linear-gradient(160deg,rgba(15,30,61,.85),rgba(10,16,28,.9));border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:32px 30px;box-shadow:0 40px 80px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.08);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);position:relative;overflow:hidden}
.hero__calc::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--brand-2),transparent)}
.hero__calc-badge{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-2);padding:6px 14px;background:rgba(59,130,246,.15);border:1px solid rgba(59,130,246,.35);border-radius:999px;margin-bottom:22px}
.hero__calc-row{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.06);gap:12px}
.hero__calc-row:last-of-type{border-bottom:0}
.hero__calc-row span{font-size:.88rem;color:var(--ink-soft)}
.hero__calc-row strong{font-size:1.02rem;color:var(--ink);font-variant-numeric:tabular-nums;font-weight:700}
.hero__calc-row--muted span{color:var(--muted);font-size:.82rem}
.hero__calc-row--muted strong{color:var(--ink-soft);font-size:.94rem;font-weight:600}
.hero__calc-row--diff strong{color:#34d399;font-size:1.1rem}
.hero__calc-total{margin:20px -30px -32px;padding:24px 30px 32px;background:linear-gradient(135deg,var(--brand-dark),var(--brand));position:relative}
.hero__calc-total > div:first-child{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.hero__calc-total span{font-size:.88rem;color:rgba(255,255,255,.9);font-weight:500}
.hero__calc-total strong{font-size:2.1rem;color:#fff;font-weight:800;font-variant-numeric:tabular-nums;text-shadow:0 2px 20px rgba(255,255,255,.2)}
.hero__calc-note{font-size:.78rem;color:rgba(255,255,255,.7);margin-top:4px}
.hero__calc-cta{display:block;text-align:center;padding:14px 22px;background:rgba(255,255,255,.12);color:#fff!important;border:1px solid rgba(255,255,255,.2);border-radius:999px;font-weight:600;margin-top:20px;transition:var(--t);text-decoration:none}
.hero__calc-cta:hover{background:rgba(255,255,255,.2);transform:translateY(-2px)}
@media(max-width:1080px){.hero__calc-total{margin:20px -30px -32px}}

/* --- Video Section --- */
.video-section{padding:clamp(72px,9vw,128px) 0;background:linear-gradient(180deg,var(--bg) 0%,#0a1428 50%,var(--bg) 100%);position:relative;overflow:hidden}
.video-section::before{content:"";position:absolute;top:50%;left:50%;width:900px;height:900px;background:radial-gradient(circle,rgba(59,130,246,.15),transparent 60%);transform:translate(-50%,-50%);filter:blur(40px);pointer-events:none}
.video-frame{position:relative;max-width:980px;margin:0 auto}
.video-frame__inner{position:relative;border-radius:24px;overflow:hidden;background:#000;box-shadow:0 40px 100px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.08);aspect-ratio:16/9}
.video-frame__inner::before{content:"";position:absolute;inset:-2px;border-radius:24px;background:linear-gradient(135deg,var(--brand),#a78bfa,var(--brand));z-index:-1;opacity:.6;filter:blur(16px)}
.video-player{width:100%;height:100%;display:block;object-fit:cover;background:#000}
.video-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:88px;height:88px;border-radius:50%;background:rgba(255,255,255,.96);color:var(--brand-dark);border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 0 0 rgba(255,255,255,.3);transition:var(--t);z-index:2;animation:videoPulse 2.5s infinite}
.video-play svg{width:36px;height:36px;margin-left:5px}
.video-play:hover{transform:translate(-50%,-50%) scale(1.08)}
.video-play[hidden]{display:none}
@keyframes videoPulse{0%{box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 0 0 rgba(255,255,255,.4)}70%{box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 0 24px rgba(255,255,255,0)}100%{box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 0 0 rgba(255,255,255,0)}}
.video-captions{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.video-caption{background:var(--bg-card);border:1px solid var(--line);border-radius:14px;padding:18px 20px;text-align:center}
.video-caption strong{display:block;color:var(--ink);font-size:1rem;margin-bottom:2px}
.video-caption span{font-size:.82rem;color:var(--ink-soft)}
@media(max-width:680px){.video-captions{grid-template-columns:1fr;gap:12px}.video-play{width:72px;height:72px}.video-play svg{width:28px;height:28px}}

/* --- Stats --- */
.stats{padding:clamp(48px,6vw,80px) 0;background:var(--bg-elev);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;text-align:center}
.stat strong{display:block;font-size:clamp(2.4rem,5vw,3.8rem);font-weight:800;color:var(--brand-2);line-height:1;margin-bottom:8px;font-variant-numeric:tabular-nums;background:linear-gradient(135deg,var(--brand-2),#a78bfa);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat span{font-size:.92rem;color:var(--ink-soft);font-weight:500}
@media(max-width:720px){.stats__grid{grid-template-columns:1fr 1fr;gap:28px}}

/* --- Compare Vor/Nach --- */
.compare{padding:clamp(72px,9vw,128px) 0;background:var(--bg)}
.compare__grid{display:grid;grid-template-columns:1fr auto 1fr;gap:28px;align-items:stretch;max-width:1100px;margin:0 auto}
.compare__col{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:36px 32px;position:relative;overflow:hidden}
.compare__col--bad{opacity:.7}
.compare__col--good{background:linear-gradient(160deg,rgba(59,130,246,.15),rgba(10,16,28,.6));border-color:rgba(59,130,246,.4);box-shadow:0 40px 80px rgba(59,130,246,.15)}
.compare__col--good::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--brand),var(--brand-2),#a78bfa)}
.compare__label{display:inline-block;font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);padding:6px 14px;background:rgba(255,255,255,.05);border-radius:999px;margin-bottom:20px;font-weight:600}
.compare__label--gold{color:var(--gold);background:rgba(242,196,107,.1);border:1px solid rgba(242,196,107,.3)}
.compare__big{font-size:clamp(2.2rem,4vw,3.2rem);font-weight:800;color:var(--ink);line-height:1;margin-bottom:8px;font-variant-numeric:tabular-nums}
.compare__big span{font-size:1rem;font-weight:400;color:var(--muted);margin-left:6px}
.compare__big--gold{background:linear-gradient(135deg,#fff,var(--brand-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.compare__note{font-size:.92rem;color:var(--ink-soft);margin-bottom:24px}
.compare__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.compare__list li{font-size:.92rem;color:var(--ink-soft);padding:10px 0;border-top:1px solid var(--line)}
.compare__list li:first-child{border-top:0}
.compare__col--good .compare__list li{color:var(--ink)}
.compare__col--good .compare__list li strong{color:#34d399}
.compare__vs{font-size:3rem;color:var(--brand-2);font-family:'Playfair Display',serif;align-self:center;font-weight:300;padding:0 12px}
.compare__cta{text-align:center;margin-top:52px;display:flex;flex-direction:column;align-items:center;gap:14px}
.compare__hint{font-size:.82rem;color:var(--muted)}
@media(max-width:880px){.compare__grid{grid-template-columns:1fr}.compare__vs{transform:rotate(90deg);padding:8px 0}}

/* --- Audience Cards --- */
.audience__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.audience__card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:36px 30px;position:relative;transition:var(--t)}
.audience__card:hover{transform:translateY(-6px);border-color:var(--brand)}
.audience__card--featured{background:linear-gradient(160deg,rgba(59,130,246,.12),var(--bg-card));border-color:rgba(59,130,246,.4);transform:scale(1.03)}
.audience__card--featured:hover{transform:scale(1.03) translateY(-6px)}
.audience__tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;font-size:.72rem;font-weight:700;padding:6px 18px;border-radius:999px;letter-spacing:.08em;text-transform:uppercase;box-shadow:0 10px 30px rgba(59,130,246,.4);white-space:nowrap}
.audience__icon{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,rgba(59,130,246,.2),rgba(96,165,250,.05));display:flex;align-items:center;justify-content:center;color:var(--brand-2);margin-bottom:22px;border:1px solid rgba(59,130,246,.2)}
.audience__icon svg{width:32px;height:32px}
.audience__card h3{font-size:1.3rem;margin-bottom:12px;color:var(--ink)}
.audience__card > p{color:var(--ink-soft);line-height:1.65;margin:0 0 22px;font-size:.96rem}
.audience__card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.audience__card li{color:var(--ink-soft);font-size:.88rem;padding-left:22px;position:relative}
.audience__card li::before{content:"✓";position:absolute;left:0;color:#34d399;font-weight:700}
@media(max-width:960px){.audience__grid{grid-template-columns:1fr;gap:20px}.audience__card--featured{transform:none}.audience__card--featured:hover{transform:translateY(-6px)}}

/* --- Testimonials --- */
.testimonials{padding:clamp(72px,9vw,128px) 0;background:var(--bg-elev);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.testimonials__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonial{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px 28px;position:relative;transition:var(--t)}
.testimonial:hover{transform:translateY(-4px);border-color:var(--brand)}
.testimonial--highlight{background:linear-gradient(160deg,rgba(59,130,246,.12),var(--bg-card));border-color:rgba(59,130,246,.4);box-shadow:0 30px 60px rgba(59,130,246,.12)}
.testimonial__stars{color:var(--gold);font-size:1.1rem;letter-spacing:3px;margin-bottom:16px;text-shadow:0 0 15px rgba(242,196,107,.4)}
.testimonial__quote{color:var(--ink);font-size:.98rem;line-height:1.7;margin:0 0 24px;font-style:italic}
.testimonial__meta{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--line);font-style:normal}
.testimonial__avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;flex-shrink:0}
.testimonial__meta strong{display:block;color:var(--ink);font-size:.95rem;margin-bottom:2px}
.testimonial__meta span{display:block;color:var(--muted);font-size:.82rem}
@media(max-width:960px){.testimonials__grid{grid-template-columns:1fr;gap:20px}}

/* --- Trust Detail --- */
.trust-detail{background:linear-gradient(180deg,var(--bg),#0a1428)}
.trust-detail__wrap{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:center;max-width:1100px;margin:0 auto}
.trust-detail__grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:32px 0}
.trust-chip{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--bg-card);border:1px solid var(--line);border-radius:14px;transition:var(--t)}
.trust-chip:hover{border-color:var(--brand);transform:translateY(-2px)}
.trust-chip__icon{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,rgba(52,211,153,.25),rgba(52,211,153,.05));color:#34d399;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;border:1px solid rgba(52,211,153,.3)}
.trust-chip strong{display:block;color:var(--ink);font-size:.92rem;margin-bottom:2px}
.trust-chip span{display:block;color:var(--muted);font-size:.78rem}
.trust-detail__ctas{display:flex;gap:14px;flex-wrap:wrap}
.trust-detail__card{display:flex;flex-direction:column;align-items:center;gap:24px;padding:48px 32px;background:linear-gradient(160deg,rgba(242,196,107,.12),rgba(10,16,28,.8));border:1px solid rgba(242,196,107,.3);border-radius:var(--radius-lg);box-shadow:0 40px 80px rgba(242,196,107,.1)}
.trust-detail__seal{width:160px;height:160px;color:var(--gold);animation:slowSpin 60s linear infinite}
@keyframes slowSpin{to{transform:rotate(360deg)}}
.trust-detail__seal svg{width:100%;height:100%;filter:drop-shadow(0 0 20px rgba(242,196,107,.4))}
.trust-detail__seal-text{text-align:center}
.trust-detail__seal-text strong{display:block;color:var(--gold);font-size:1.1rem;line-height:1.3;margin-bottom:6px}
.trust-detail__seal-text span{display:block;color:var(--ink-soft);font-size:.82rem}
@media(max-width:880px){.trust-detail__wrap{grid-template-columns:1fr;gap:40px}.trust-detail__grid{grid-template-columns:1fr}}

/* --- Nav scroll enhance --- */
.nav.is-scrolled{background:rgba(5,10,20,.94);box-shadow:0 10px 40px rgba(0,0,0,.4)}

/* --- Wizard tweaks for premium look --- */
.wizard__page{position:relative}
.wizard__page::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--brand),var(--brand-2),transparent);opacity:.6}
.field input:hover:not(:focus),.field select:hover:not(:focus),.field textarea:hover:not(:focus){border-color:rgba(96,165,250,.4)}
.type-card__body{position:relative;overflow:hidden}
.type-card__body::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,rgba(59,130,246,.18),transparent 60%);opacity:0;transition:var(--t)}
.type-card input:checked + .type-card__body::after{opacity:1}
.preview-card{position:relative}
.preview-card::after{content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;background:linear-gradient(160deg,rgba(59,130,246,.4),transparent 50%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}

/* =========================================================
   NEW SECTIONS — Marquee, Glossar, Cases, Pricing, Reasons
   + Cursor Glow, Noise, Form polish v2
   ========================================================= */

/* --- Grain / Noise overlay --- */
body::before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='280' height='280'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.06 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");opacity:.6;pointer-events:none;z-index:1;mix-blend-mode:overlay}
body > *{position:relative;z-index:2}

/* --- Marquee Ticker --- */
.marquee{background:linear-gradient(90deg,#050a14,#0a1428,#050a14);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:18px 0;overflow:hidden;position:relative;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:flex;width:max-content;animation:marquee 40s linear infinite}
.marquee__inner{display:flex;align-items:center;gap:48px;padding-right:48px;white-space:nowrap}
.marquee__inner span{font-size:.92rem;font-weight:500;color:var(--ink-soft);letter-spacing:.04em}
.marquee__inner span:nth-child(odd){color:var(--brand-2)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* --- Glossar --- */
.glossar{padding:clamp(72px,9vw,128px) 0;background:var(--bg)}
.glossar__grid{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:center;max-width:1180px;margin:0 auto}
.glossar__text .section__title{margin-bottom:28px}
.glossar__lead{font-size:1.08rem;color:var(--ink);line-height:1.7;margin-bottom:20px}
.glossar__lead strong,.glossar__text p strong{color:var(--brand-2)}
.glossar__text p{color:var(--ink-soft);line-height:1.7}
.glossar__laws{margin-top:32px;padding:24px 26px;background:var(--bg-card);border:1px solid var(--line);border-radius:16px;border-left:3px solid var(--brand)}
.glossar__laws > strong{display:block;color:var(--ink);margin-bottom:14px;font-size:.95rem}
.glossar__laws ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.glossar__laws li{color:var(--ink-soft);font-size:.88rem;line-height:1.55;padding-left:20px;position:relative}
.glossar__laws li::before{content:"§";position:absolute;left:0;color:var(--brand-2);font-weight:700;font-family:'Playfair Display',serif}
.glossar__laws code{background:rgba(59,130,246,.12);color:var(--brand-2);padding:2px 8px;border-radius:6px;font-size:.82rem;font-family:ui-monospace,Consolas,monospace;margin-right:6px}

.glossar__card{background:linear-gradient(160deg,var(--bg-card),#0f1a33);border:1px solid var(--line-strong);border-radius:var(--radius-lg);padding:32px 30px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.glossar__card::before{content:"";position:absolute;top:-50px;right:-50px;width:200px;height:200px;background:radial-gradient(circle,rgba(242,196,107,.2),transparent 60%);pointer-events:none;filter:blur(20px)}
.glossar__card-head{color:var(--muted);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;margin-bottom:18px;line-height:1.4}
.glossar__card-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}
.glossar__card-list li{display:flex;justify-content:space-between;align-items:baseline;padding:13px 0;border-bottom:1px solid var(--line);gap:12px}
.glossar__card-list li:last-child{border-bottom:0}
.glossar__card-list span{color:var(--ink-soft);font-size:.9rem}
.glossar__card-list strong{color:var(--ink);font-variant-numeric:tabular-nums;font-weight:700}
.glossar__arrow{text-align:center;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:18px 0;font-weight:600}
.glossar__card-highlight{padding:22px 24px;background:linear-gradient(135deg,rgba(242,196,107,.18),rgba(242,196,107,.04));border:1px solid rgba(242,196,107,.35);border-radius:14px;text-align:center}
.glossar__card-highlight span{display:block;font-size:.82rem;color:var(--ink-soft);margin-bottom:8px}
.glossar__card-highlight strong{display:block;font-size:2rem;font-weight:800;color:var(--gold);line-height:1;margin-bottom:6px;background:linear-gradient(135deg,var(--gold),#fff);-webkit-background-clip:text;background-clip:text;color:transparent}
.glossar__card-highlight em{display:block;font-size:.72rem;color:var(--muted);font-style:normal;margin-top:4px}
@media(max-width:960px){.glossar__grid{grid-template-columns:1fr;gap:40px}}

/* --- Cases --- */
.cases{padding:clamp(72px,9vw,128px) 0;background:linear-gradient(180deg,var(--bg) 0%,#0a1428 100%)}
.cases__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1200px;margin:0 auto}
.case{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px 28px;position:relative;transition:var(--t);display:flex;flex-direction:column;gap:20px}
.case:hover{transform:translateY(-6px);border-color:var(--brand);box-shadow:var(--shadow)}
.case--featured{background:linear-gradient(160deg,rgba(59,130,246,.14),var(--bg-card));border-color:rgba(59,130,246,.4);transform:scale(1.02);box-shadow:0 30px 80px rgba(59,130,246,.15)}
.case--featured:hover{transform:scale(1.02) translateY(-6px)}
.case__ribbon{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--gold),#fde68a);color:#0a101c;font-size:.72rem;font-weight:800;padding:6px 18px;border-radius:999px;letter-spacing:.1em;text-transform:uppercase;box-shadow:0 10px 30px rgba(242,196,107,.5);white-space:nowrap}
.case__head{}
.case__tag{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--brand-2);padding:5px 12px;background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.3);border-radius:999px;margin-bottom:12px}
.case__head h3{font-size:1.1rem;color:var(--ink);line-height:1.35;margin:0}
.case__props{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.case__props div{text-align:center}
.case__props span{display:block;font-size:.7rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}
.case__props strong{display:block;color:var(--ink);font-size:.96rem;font-variant-numeric:tabular-nums}
.case__result{display:flex;flex-direction:column;gap:2px;margin-top:auto}
.case__result-row{display:flex;justify-content:space-between;padding:9px 0;font-size:.88rem;color:var(--ink-soft)}
.case__result-row strong{color:var(--ink);font-variant-numeric:tabular-nums}
.case__result-row--hi{padding:12px 14px;margin:6px -14px;background:linear-gradient(90deg,rgba(52,211,153,.15),transparent);border-radius:10px;color:var(--ink);font-weight:600}
.case__result-row--hi strong{color:#34d399;font-size:1.02rem}
.case__result-total{padding:16px 18px;margin-top:10px;background:linear-gradient(135deg,var(--brand-dark),var(--brand));border-radius:12px;display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.case__result-total span{color:rgba(255,255,255,.85);font-size:.82rem}
.case__result-total strong{color:#fff;font-size:1.4rem;font-weight:800;font-variant-numeric:tabular-nums}
.cases__note{text-align:center;color:var(--muted);font-size:.82rem;max-width:680px;margin:48px auto 0;line-height:1.6}
@media(max-width:1020px){.cases__grid{grid-template-columns:1fr;gap:20px}.case--featured{transform:none}.case--featured:hover{transform:translateY(-6px)}}

/* --- Pricing --- */
.pricing{padding:clamp(72px,9vw,128px) 0;background:var(--bg-elev)}
.pricing__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1200px;margin:0 auto 64px}
.price-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:36px 32px;display:flex;flex-direction:column;position:relative;transition:var(--t)}
.price-card:hover{transform:translateY(-6px);border-color:var(--brand);box-shadow:var(--shadow)}
.price-card--featured{background:linear-gradient(160deg,rgba(59,130,246,.18),var(--bg-card));border-color:var(--brand);transform:scale(1.04);box-shadow:0 40px 100px rgba(59,130,246,.2)}
.price-card--featured:hover{transform:scale(1.04) translateY(-6px)}
.price-card__ribbon{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;font-size:.72rem;font-weight:800;padding:6px 18px;border-radius:999px;letter-spacing:.1em;text-transform:uppercase;box-shadow:0 10px 30px rgba(59,130,246,.45);white-space:nowrap}
.price-card__icon{font-size:2.4rem;margin-bottom:14px}
.price-card h3{font-size:1.35rem;color:var(--ink);margin:0 0 6px}
.price-card__note{font-size:.82rem;color:var(--ink-soft);margin:0 0 24px;line-height:1.5}
.price-card__amount{display:flex;flex-direction:column;margin-bottom:4px}
.price-card__amount strong{font-size:2.8rem;font-weight:800;color:var(--ink);line-height:1;font-variant-numeric:tabular-nums}
.price-card--featured .price-card__amount strong{background:linear-gradient(135deg,#fff,var(--brand-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.price-card__amount span{font-size:.82rem;color:var(--muted);margin-top:6px}
.price-card__net{font-size:.82rem;color:var(--ink-soft);margin-bottom:28px}
.price-card__list{list-style:none;padding:0;margin:0 0 32px;display:flex;flex-direction:column;gap:10px;flex:1}
.price-card__list li{color:var(--ink-soft);font-size:.9rem;line-height:1.5}
.price-card .btn{width:100%;justify-content:center}
@media(max-width:1020px){.pricing__grid{grid-template-columns:1fr;gap:24px}.price-card--featured{transform:none}.price-card--featured:hover{transform:translateY(-6px)}}

.pricing__matrix{max-width:1000px;margin:0 auto;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px 36px;box-shadow:var(--shadow-sm)}
.pricing__matrix-head{margin-bottom:20px}
.pricing__matrix-head strong{display:block;color:var(--ink);font-size:1.1rem;margin-bottom:4px}
.pricing__matrix-head span{color:var(--ink-soft);font-size:.88rem}
.pricing__matrix-wrap{overflow-x:auto;margin:0 -36px;padding:0 36px}
.pricing__table{width:100%;border-collapse:collapse;min-width:520px}
.pricing__table th,.pricing__table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line);font-size:.92rem}
.pricing__table th{color:var(--muted);font-size:.74rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase}
.pricing__table td{color:var(--ink-soft)}
.pricing__table tr:hover td{background:rgba(59,130,246,.04)}
.pricing__table tr:last-child td{border-bottom:0}
.pricing__table td strong{color:var(--ink);font-variant-numeric:tabular-nums}
.pricing__table td:nth-child(2),.pricing__table td:nth-child(3),.pricing__table th:nth-child(2),.pricing__table th:nth-child(3){text-align:right;font-variant-numeric:tabular-nums}
.pricing__matrix-foot{color:var(--muted);font-size:.82rem;margin-top:20px;line-height:1.6}

/* --- Reasons 6-grid --- */
.reasons{padding:clamp(72px,9vw,128px) 0;background:var(--bg)}
.reasons__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1200px;margin:0 auto}
.reason{padding:32px 30px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);position:relative;transition:var(--t)}
.reason:hover{border-color:var(--brand);transform:translateY(-4px)}
.reason__num{font-family:'Playfair Display',serif;font-size:2.6rem;font-weight:700;color:var(--brand-2);line-height:1;margin-bottom:14px;opacity:.85;background:linear-gradient(135deg,var(--brand-2),#a78bfa);-webkit-background-clip:text;background-clip:text;color:transparent}
.reason h3{font-size:1.15rem;color:var(--ink);margin:0 0 10px}
.reason p{color:var(--ink-soft);font-size:.92rem;line-height:1.6;margin:0}
.reason p strong{color:var(--ink)}
@media(max-width:960px){.reasons__grid{grid-template-columns:1fr 1fr;gap:20px}}
@media(max-width:600px){.reasons__grid{grid-template-columns:1fr}}

/* --- Cursor Glow on cards (opt-in via .cursor-glow) --- */
.benefit-card,.when__card,.audience__card,.testimonial,.case,.price-card,.reason,.trust-chip{--mx:50%;--my:50%}
.benefit-card::after,.when__card::after,.audience__card::after,.testimonial::after,.case::after,.price-card::after,.reason::after{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(250px circle at var(--mx) var(--my),rgba(59,130,246,.16),transparent 50%);opacity:0;transition:opacity .4s;pointer-events:none}
.benefit-card:hover::after,.when__card:hover::after,.audience__card:hover::after,.testimonial:hover::after,.case:hover::after,.price-card:hover::after,.reason:hover::after{opacity:1}

/* --- Section intro improvements --- */
.section__title em{background:linear-gradient(135deg,var(--brand-2),#a78bfa);-webkit-background-clip:text;background-clip:text;color:transparent}

/* --- Typography upgrade --- */
body{font-feature-settings:"kern","liga","calt","ss01"}
.hero__title{text-wrap:balance}
.section__title{text-wrap:balance}
.section__lead{text-wrap:pretty}

/* --- Form polish v2 — animated progress bar --- */
.wizard__progress{position:relative;height:4px;background:var(--line);border-radius:999px;margin-bottom:40px;overflow:hidden}
.wizard__progress-fill{position:absolute;top:0;left:0;bottom:0;background:linear-gradient(90deg,var(--brand),var(--brand-2),#a78bfa);border-radius:999px;transition:width .6s cubic-bezier(.2,.7,.25,1);box-shadow:0 0 20px rgba(96,165,250,.6)}

/* --- Better focus rings (accessibility) --- */
:focus-visible{outline:3px solid var(--brand-2);outline-offset:3px;border-radius:6px}
.btn:focus-visible,.nav__cta:focus-visible{outline-offset:4px}
input:focus-visible,select:focus-visible,textarea:focus-visible{outline:0}

/* --- Skip link --- */
.skip-link{position:absolute;left:-9999px;top:16px;background:var(--brand);color:#fff;padding:12px 20px;border-radius:8px;font-weight:600;z-index:200}
.skip-link:focus{left:16px}

/* --- Magnetic button subtle effect --- */
.btn--primary{position:relative;overflow:hidden}
.btn--primary::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 20%,rgba(255,255,255,.25) 50%,transparent 80%);transform:translateX(-110%);transition:transform .7s}
.btn--primary:hover::before{transform:translateX(110%)}

/* --- Hero typography polish --- */
.hero--premium .hero__title{letter-spacing:-.025em}
.hero--premium .hero__sub{font-size:clamp(1.08rem,1.4vw,1.24rem);max-width:560px}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}.marquee__track{animation:none}}
