/* =========================================================================
   Glücksherz Soziallotterie — style.css
   Дизайн-пресет B (доверие/комплаенс). Палитра: красный + крем.
   Структура: @font-face · tokens · reset · typo · layout · components · utils
   ========================================================================= */

/* ---------- @font-face (self-hosted) ----------------------------------- */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;
  src:url('../fonts/inter-400.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;
  src:url('../fonts/inter-500.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;
  src:url('../fonts/inter-600.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;
  src:url('../fonts/inter-700.woff2') format('woff2')}
@font-face{font-family:'Sora';font-style:normal;font-weight:600;font-display:swap;
  src:url('../fonts/sora-600.woff2') format('woff2')}
@font-face{font-family:'Sora';font-style:normal;font-weight:700;font-display:swap;
  src:url('../fonts/sora-700.woff2') format('woff2')}
@font-face{font-family:'Sora';font-style:normal;font-weight:800;font-display:swap;
  src:url('../fonts/sora-800.woff2') format('woff2')}

/* ---------- Design Tokens ---------------------------------------------- */
:root{
  /* Marke / Rot */
  --red-600:#C8102E; --red-700:#A50D26; --red-800:#8E0B20; --red-900:#6E0A1A;
  /* Creme */
  --cream-50:#FBF7F0; --cream-100:#F5EEE1; --cream-200:#ECE0CC;
  /* Tinte / Text */
  --ink:#2A2024; --ink-soft:#574D51; --ink-mute:#6A626E;
  /* Akzente */
  --brass:#B08D57; --brass-soft:#CDB68C; --brass-tint:#F3E9D6;
  --green:#2F6B4F; --green-700:#245940; --green-tint:#E4EFE8;
  --white:#ffffff;

  /* Semantisch */
  --bg:var(--cream-50);
  --surface:var(--white);
  --surface-alt:var(--cream-100);
  --border:#E6DCCB;
  --border-strong:#D8CBB4;
  --primary:var(--red-600);
  --primary-ink:#ffffff;
  --focus:#1E63C8;

  /* Typografie */
  --font-display:'Sora',system-ui,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --fs-xs:.8125rem; --fs-sm:.9375rem; --fs-base:1.125rem; --fs-md:1.25rem;
  --fs-lg:1.5rem; --fs-xl:1.95rem; --fs-2xl:2.5rem; --fs-3xl:3.15rem; --fs-4xl:3.9rem;
  --lh-tight:1.12; --lh-snug:1.3; --lh-base:1.65;

  /* Raster / Abstände (8px) */
  --sp-1:.25rem; --sp-2:.5rem; --sp-3:.75rem; --sp-4:1rem; --sp-5:1.5rem;
  --sp-6:2rem; --sp-7:3rem; --sp-8:4rem; --sp-9:6rem;
  --container:1200px; --container-wide:1340px;

  /* Radien */
  --r-sm:4px; --r-md:5px; --r-lg:6px; --r-xl:8px; --r-pill:6px; --r-round:999px;

  /* Schatten */
  --shadow-sm:0 1px 2px rgba(42,32,36,.06), 0 1px 1px rgba(42,32,36,.04);
  --shadow-md:0 6px 18px rgba(42,32,36,.08), 0 2px 6px rgba(42,32,36,.05);
  --shadow-lg:0 18px 44px rgba(42,32,36,.13), 0 6px 14px rgba(42,32,36,.07);
  --shadow-red:0 14px 30px rgba(200,16,46,.22);

  /* Bewegung */
  --t-fast:140ms; --t:240ms; --t-slow:420ms;
  --ease:cubic-bezier(.4,0,.2,1);
}

/* ---------- Reset ------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  font-size:var(--fs-base);
  line-height:var(--lh-base);
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%}
img{height:auto}
a{color:var(--red-700);text-decoration:none;transition:color var(--t-fast) var(--ease)}
a:hover{color:var(--red-900)}
ul,ol{list-style:none;padding:0}
button{font:inherit;color:inherit;cursor:pointer;border:0;background:none}
input,textarea,select{font:inherit;color:inherit}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:var(--lh-tight);
  letter-spacing:-.02em;color:var(--ink)}
strong{font-weight:700}

/* Icons */
.icon{width:1.25em;height:1.25em;flex:none;stroke-width:2;vertical-align:middle}

/* Fokus sichtbar (a11y) */
:focus-visible{outline:3px solid var(--focus);outline-offset:2px;border-radius:4px}

.skip-link{position:fixed;left:50%;top:-60px;transform:translateX(-50%);z-index:200;
  background:var(--ink);color:#fff;padding:.7rem 1.2rem;border-radius:0 0 var(--r-sm) var(--r-sm);
  transition:top var(--t) var(--ease)}
.skip-link:focus{top:0;color:#fff}

/* ---------- Layout ------------------------------------------------------ */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(1rem,4vw,2rem)}
.container--wide{max-width:var(--container-wide)}
.section{padding-block:clamp(3rem,7vw,5.5rem)}
.section--tight{padding-block:clamp(2rem,5vw,3.5rem)}
.section--alt{background:var(--surface-alt)}
.section--ink{background:var(--ink);color:var(--cream-100)}
.section--ink h2,.section--ink h3{color:#fff}

.section-head{max-width:46rem;margin-bottom:clamp(1.5rem,4vw,2.75rem)}
.section-head--center{margin-inline:auto;text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-display);
  font-weight:600;font-size:var(--fs-sm);letter-spacing:.08em;text-transform:uppercase;
  color:var(--red-700)}
.eyebrow .icon{width:1.1em;height:1.1em;color:var(--brass)}
.section-head h2{font-size:var(--fs-2xl);margin-top:.6rem}
.section-head p{margin-top:.9rem;color:var(--ink-soft);font-size:var(--fs-md)}

.lead{font-size:var(--fs-md);color:var(--ink-soft);line-height:1.55}

/* ---------- Buttons ----------------------------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--font-display);font-weight:600;font-size:var(--fs-sm);
  padding:.85rem 1.5rem;border-radius:var(--r-pill);text-align:center;
  transition:transform var(--t-fast) var(--ease),box-shadow var(--t) var(--ease),
    background var(--t) var(--ease),color var(--t) var(--ease);white-space:nowrap;
  line-height:1.1;border:1.5px solid transparent}
.btn .icon{width:1.15em;height:1.15em}
.btn--primary{background:var(--red-600);color:#fff;box-shadow:var(--shadow-red)}
.btn--primary:hover{background:var(--red-700);color:#fff;transform:translateY(-2px);
  box-shadow:0 18px 36px rgba(200,16,46,.28)}
.btn--green{background:var(--green);color:#fff}
.btn--green:hover{background:var(--green-700);color:#fff;transform:translateY(-2px)}
.btn--outline{background:transparent;border-color:var(--border-strong);color:var(--ink)}
.btn--outline:hover{border-color:var(--red-600);color:var(--red-700);transform:translateY(-2px)}
.btn--ghost{background:var(--cream-100);color:var(--ink)}
.btn--ghost:hover{background:var(--cream-200);color:var(--ink)}
.btn--light{background:#fff;color:var(--red-700)}
.btn--light:hover{background:var(--cream-100);color:var(--red-800);transform:translateY(-2px)}
.btn--lg{padding:1.05rem 2rem;font-size:var(--fs-base)}
.btn--block{width:100%}
.btn--link{padding:0;background:none;color:var(--red-700);border:0;font-weight:600}
.btn--link:hover{color:var(--red-900)}

.text-link{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-display);
  font-weight:600;color:var(--red-700)}
.text-link .icon{transition:transform var(--t) var(--ease)}
.text-link:hover .icon{transform:translateX(4px)}

/* ---------- Badges ------------------------------------------------------ */
.age-badge{display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:800;font-size:.75rem;line-height:1;
  background:var(--ink);color:#fff;border-radius:var(--r-pill);padding:.32em .6em;letter-spacing:.02em}
.pill{display:inline-flex;align-items:center;gap:.4rem;font-size:var(--fs-xs);font-weight:600;
  padding:.35rem .8rem;border-radius:var(--r-pill);background:var(--brass-tint);color:#7a5f2e}
.pill--green{background:var(--green-tint);color:var(--green-700)}
.pill--red{background:#fbe1e5;color:var(--red-800)}

/* =========================================================================
   HEADER / NAVIGATION
   ========================================================================= */
.site-header{position:sticky;top:0;z-index:100;background:rgba(251,247,240,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--border);
  transition:box-shadow var(--t) var(--ease)}
.site-header.is-stuck{box-shadow:var(--shadow-md)}

.utility-bar{background:var(--ink);color:var(--cream-100);font-size:var(--fs-xs)}
.utility-bar__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  min-height:38px;flex-wrap:wrap}
.utility-bar__compliance{display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}
.utility-bar__warn{display:inline-flex;align-items:center;gap:.35rem}
.utility-bar__warn .icon{width:1.05em;height:1.05em;color:var(--brass-soft)}
.utility-bar__link{display:inline-block;padding-block:4px;color:#fff;text-decoration:underline;text-underline-offset:2px}
.utility-bar__link:hover{color:var(--brass-soft)}
.utility-bar__contact a{display:inline-flex;align-items:center;gap:.35rem;color:var(--cream-100)}
.utility-bar__contact a:hover{color:#fff}
.utility-bar__contact .icon{width:1.05em;height:1.05em}

.nav-bar__inner{display:flex;align-items:center;gap:1.5rem;min-height:74px}
.brand{display:inline-flex;align-items:center;gap:.7rem;color:var(--ink)}
.brand__mark{display:grid;place-items:center;width:46px;height:46px;flex:none}
.brand__mark img{width:46px;height:46px;display:block}
.brand__mark .icon{width:26px;height:26px}
.brand__text{display:flex;flex-direction:column;line-height:1.05}
.brand__name{font-family:var(--font-display);font-weight:800;font-size:1.35rem;letter-spacing:-.02em}
.brand__sub{font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brass)}

.main-nav{margin-left:auto}
.main-nav__list{display:flex;align-items:center;gap:.25rem}
.main-nav__link{display:inline-flex;align-items:center;gap:.3rem;padding:.6rem .8rem;
  border-radius:var(--r-sm);font-family:var(--font-display);font-weight:600;font-size:.97rem;
  color:var(--ink);transition:color var(--t-fast),background var(--t-fast)}
.main-nav__link:hover{color:var(--red-700);background:var(--cream-100)}
.main-nav__link.is-active{color:var(--red-700)}
.main-nav__chev{width:1em;height:1em;transition:transform var(--t) var(--ease)}
.main-nav__item.has-dropdown{position:relative}
.has-dropdown[aria-expanded] .main-nav__chev,
.has-dropdown.is-open .main-nav__chev{transform:rotate(180deg)}

.dropdown{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);
  min-width:264px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);
  box-shadow:var(--shadow-lg);padding:.5rem;opacity:0;visibility:hidden;
  transition:opacity var(--t) var(--ease),transform var(--t) var(--ease);z-index:20}
.dropdown::before{content:"";position:absolute;top:-16px;left:0;right:0;height:16px}
.main-nav__item.has-dropdown:hover .dropdown,
.main-nav__item.has-dropdown.is-open .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown__link{display:flex;align-items:center;gap:.7rem;padding:.65rem .75rem;border-radius:var(--r-sm);
  font-weight:500;font-size:.97rem;color:var(--ink)}
.dropdown__link:hover{background:var(--cream-100);color:var(--red-700)}
.dropdown__link.is-active{background:var(--cream-100);color:var(--red-700)}
.dropdown__icon{display:grid;place-items:center;width:34px;height:34px;border-radius:var(--r-sm);
  background:var(--cream-100);color:var(--red-700);flex:none}
.dropdown__icon .icon{width:18px;height:18px}

.nav-bar__actions{display:flex;align-items:center;gap:.75rem;margin-left:.25rem}
.nav-toggle{display:none;width:46px;height:46px;border-radius:var(--r-md);background:var(--cream-100);
  place-items:center;color:var(--ink)}
.nav-toggle .icon{width:24px;height:24px}
.nav-toggle__close{display:none}
.nav-toggle[aria-expanded="true"] .nav-toggle__open{display:none}
.nav-toggle[aria-expanded="true"] .nav-toggle__close{display:block}

/* Mobile nav */
.mobile-nav{position:fixed;top:0;right:0;bottom:0;width:min(86vw,380px);z-index:130;
  background:var(--surface);box-shadow:var(--shadow-lg);padding:1.25rem;overflow-y:auto;
  transform:translateX(101%);visibility:hidden;
  transition:transform var(--t-slow) var(--ease),visibility var(--t-slow) var(--ease);
  display:flex;flex-direction:column;gap:.25rem}
.mobile-nav.is-open{transform:translateX(0);visibility:visible}
.mobile-nav[hidden]{display:flex}
.mobile-nav__link{display:flex;align-items:center;justify-content:space-between;width:100%;
  padding:.85rem .9rem;border-radius:var(--r-sm);font-family:var(--font-display);font-weight:600;
  color:var(--ink)}
.mobile-nav__link:hover,.mobile-nav__link.is-active{background:var(--cream-100);color:var(--red-700)}
.mobile-nav__chev{transition:transform var(--t) var(--ease)}
.mobile-nav__acc[aria-expanded="true"] .mobile-nav__chev{transform:rotate(180deg)}
.mobile-nav__sub{padding:.2rem .2rem .5rem 1rem;display:flex;flex-direction:column;gap:.1rem}
.mobile-nav__sublink{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;border-radius:var(--r-sm);
  font-size:.97rem;color:var(--ink-soft)}
.mobile-nav__sublink .icon{width:18px;height:18px;color:var(--brass)}
.mobile-nav__sublink:hover,.mobile-nav__sublink.is-active{background:var(--cream-100);color:var(--red-700)}
.mobile-nav__cta{margin-top:1rem}
.nav-backdrop{position:fixed;inset:0;z-index:120;background:rgba(42,32,36,.5);
  opacity:0;transition:opacity var(--t) var(--ease)}
.nav-backdrop.is-open{opacity:1}
.nav-backdrop[hidden]{display:block;opacity:0;pointer-events:none}
.nav-backdrop.is-open{pointer-events:auto}

/* Breadcrumb */
.breadcrumb{background:var(--surface-alt);border-bottom:1px solid var(--border)}
.breadcrumb__list{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;padding-block:.75rem;
  font-size:var(--fs-sm);color:var(--ink-mute)}
.breadcrumb__list li{display:flex;align-items:center;gap:.5rem}
.breadcrumb__list li+li::before{content:"/";color:var(--border-strong)}
.breadcrumb__list a{color:var(--ink-soft);font-weight:500}
.breadcrumb__list a:hover{color:var(--red-700)}
.breadcrumb__list [aria-current]{color:var(--ink);font-weight:600}

/* =========================================================================
   HERO
   ========================================================================= */
.hero{position:relative;overflow:hidden;background:var(--ink);isolation:isolate}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media .hero__img,.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 35%}
.hero__scrim{position:absolute;inset:0;background:
    linear-gradient(100deg,rgba(28,20,22,.93) 0%,rgba(28,20,22,.78) 34%,rgba(28,20,22,.42) 64%,rgba(28,20,22,.2) 100%),
    linear-gradient(0deg,rgba(28,20,22,.55),transparent 40%)}
.hero__inner{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);
  gap:clamp(2rem,5vw,4rem);align-items:center;
  min-height:clamp(440px,62vh,600px);padding-block:clamp(3rem,7vw,5rem)}
.hero__content{max-width:38rem;color:#fff}
.hero__title{font-size:var(--fs-4xl);font-weight:800;letter-spacing:-.03em;color:#fff;
  text-shadow:0 2px 24px rgba(0,0,0,.25)}
.hero__title .accent{color:var(--brass-soft)}
.hero__text{margin-top:1.25rem;font-size:var(--fs-md);color:rgba(245,238,225,.9);max-width:33rem}
.hero__actions{margin-top:1.9rem;display:flex;flex-wrap:wrap;gap:.85rem}
.hero__trust{margin-top:2rem;display:flex;flex-wrap:wrap;gap:1rem 1.5rem;align-items:center;
  padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.18)}
.hero__trust-item{display:flex;align-items:center;gap:.55rem;font-size:var(--fs-sm);
  color:rgba(245,238,225,.92);font-weight:500}
.hero__trust-item .icon{width:1.3em;height:1.3em;color:var(--brass-soft)}
.pill--light{background:rgba(255,255,255,.15);color:#fff;backdrop-filter:blur(4px)}
.pill--light .icon{color:var(--brass-soft)}

/* Hero-Chip (nächste Sonderauslosung) */
.hero__chip{justify-self:end;width:min(100%,300px);background:rgba(255,255,255,.96);
  border-radius:var(--r-xl);box-shadow:var(--shadow-lg);padding:1.5rem;
  display:flex;flex-direction:column;gap:.35rem;backdrop-filter:blur(6px)}
.hero__chip .age-badge{align-self:flex-start;margin-bottom:.4rem}
.hero__chip-label{font-size:var(--fs-xs);color:var(--ink-mute);font-weight:600;
  text-transform:uppercase;letter-spacing:.06em}
.hero__chip-value{font-family:var(--font-display);font-weight:800;font-size:var(--fs-xl);color:var(--red-700);line-height:1.1}
.hero__chip-value span{font-size:var(--fs-sm);font-weight:600;color:var(--ink-soft)}
.hero__chip-date{display:flex;align-items:center;gap:.45rem;font-size:var(--fs-sm);color:var(--ink-soft);margin-bottom:.6rem}
.hero__chip-date .icon{color:var(--brass);width:1.1em;height:1.1em}

/* Image placeholder (Soft, CSS-only) */
.img-ph{position:relative;display:grid;place-items:center;background:
    linear-gradient(135deg,var(--cream-200),var(--brass-soft));color:#fff;overflow:hidden}
.img-ph::after{content:"";position:absolute;inset:0;
  background:radial-gradient(60% 60% at 30% 20%,rgba(255,255,255,.35),transparent 60%)}
.img-ph .icon{width:48px;height:48px;opacity:.85;position:relative;z-index:1}

/* =========================================================================
   CARDS / PILLARS / GRID
   ========================================================================= */
.grid{display:grid;gap:clamp(1.25rem,3vw,2rem)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}

.card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:1.6rem;box-shadow:var(--shadow-sm);
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease),border-color var(--t) var(--ease);height:100%}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-strong)}
.card__icon{display:grid;place-items:center;width:54px;height:54px;border-radius:var(--r-md);
  background:var(--cream-100);color:var(--red-700);margin-bottom:1.1rem}
.card__icon .icon{width:27px;height:27px}
.card__icon--green{background:var(--green-tint);color:var(--green-700)}
.card__icon--brass{background:var(--brass-tint);color:#7a5f2e}
.card__title{font-size:var(--fs-lg);margin-bottom:.5rem}
.card__text{color:var(--ink-soft);font-size:var(--fs-sm);line-height:1.6}
.card__link{margin-top:auto;padding-top:1.1rem;display:inline-flex;align-self:flex-start}

/* Feature-Liste (Häkchen auf hellem Hintergrund) */
.feature-item{display:flex;align-items:flex-start;gap:.65rem;font-size:var(--fs-base);
  color:var(--ink);font-weight:500;line-height:1.5}
.feature-item .icon{color:var(--green);flex:none;width:1.3em;height:1.3em;margin-top:.12em}
.feature-item strong{color:var(--ink);font-weight:700}

/* Media-Karten (Bild oben) */
.media-card{display:flex;flex-direction:column;height:100%;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease)}
.media-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.media-card__img{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--cream-100)}
.media-card__img img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow) var(--ease)}
.media-card:hover .media-card__img img{transform:scale(1.05)}
.media-card__tag{position:absolute;top:.85rem;left:.85rem;z-index:2}
.media-card__body{padding:1.4rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.media-card__body .card__text{flex:1}

/* Bild-Rahmen (rund, mit Schatten) */
.framed{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-md);display:block}
.framed img{width:100%;height:100%;object-fit:cover;display:block}
.ratio-43{aspect-ratio:4/3}
.ratio-169{aspect-ratio:16/9}

/* Page-Hero mit Bild (zweispaltig) */
.page-hero--split .page-hero__inner{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);
  gap:clamp(2rem,5vw,3.5rem);align-items:center;max-width:none}
.page-hero__media{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:4/3}
.page-hero__media img{width:100%;height:100%;object-fit:cover}
@media (max-width:880px){
  .page-hero--split .page-hero__inner{grid-template-columns:1fr}
  .page-hero__media{aspect-ratio:16/9;max-height:280px}
}

.pillar{position:relative;overflow:hidden;background:linear-gradient(168deg,#fff 0%,var(--cream-50) 100%)}
.pillar::after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  background:radial-gradient(120% 80% at 100% 0,rgba(200,16,46,.07),transparent 55%);
  opacity:0;transition:opacity var(--t) var(--ease)}
.pillar:hover::after{opacity:1}
.pillar__top{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  margin-bottom:1.1rem;position:relative;z-index:1}
.pillar .card__icon{margin-bottom:0;background:linear-gradient(145deg,var(--red-600),var(--red-800));
  color:#fff;box-shadow:0 8px 16px rgba(200,16,46,.2)}
.pillar__num{font-family:var(--font-display);font-weight:800;font-size:3.5rem;line-height:.8;
  letter-spacing:-.04em;background:linear-gradient(160deg,var(--brass-soft),var(--cream-200));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.pillar>:not(.pillar__top){position:relative;z-index:1}

/* Steps */
.steps{counter-reset:step}
.step{position:relative;padding-left:0}
.step__num{display:grid;place-items:center;width:48px;height:48px;border-radius:var(--r-round);
  background:var(--red-600);color:#fff;font-family:var(--font-display);font-weight:800;
  font-size:1.25rem;margin-bottom:1rem}
.step__title{font-size:var(--fs-md);margin-bottom:.4rem}
.step__text{color:var(--ink-soft);font-size:var(--fs-sm)}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.stat{text-align:center;padding:1.5rem 1rem;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
.stat__value{font-family:var(--font-display);font-weight:800;font-size:var(--fs-2xl);
  color:var(--red-700);line-height:1}
.stat__label{margin-top:.5rem;color:var(--ink-soft);font-size:var(--fs-sm);font-weight:500}
.stat .icon{color:var(--brass);width:28px;height:28px;margin:0 auto .6rem}

/* CTA-Band */
.cta-band{background:linear-gradient(135deg,var(--red-700),var(--red-900));color:#fff;
  border-radius:var(--r-xl);padding:clamp(2rem,5vw,3.5rem);position:relative;overflow:hidden;
  box-shadow:var(--shadow-lg)}
.cta-band::before{content:"";position:absolute;inset:0;
  background:radial-gradient(70% 120% at 100% 0,rgba(255,255,255,.12),transparent 55%)}
.cta-band__inner{position:relative;display:flex;align-items:center;justify-content:space-between;
  gap:2rem;flex-wrap:wrap}
.cta-band h2{color:#fff;font-size:var(--fs-2xl)}
.cta-band p{color:rgba(255,255,255,.85);margin-top:.6rem;max-width:38rem}

/* Maskottchen "Kleo" */
.cta-band__mascot{width:clamp(110px,14vw,168px);height:auto;align-self:flex-end;flex:none;
  filter:drop-shadow(0 10px 20px rgba(0,0,0,.28));margin-bottom:-1px}
.hero__mascot{position:absolute;left:clamp(.5rem,3vw,2rem);bottom:0;width:clamp(96px,11vw,150px);
  height:auto;z-index:1;pointer-events:none;filter:drop-shadow(0 8px 16px rgba(0,0,0,.3))}
.mascot-inline{width:clamp(140px,22vw,240px);height:auto}
@media (max-width:880px){ .hero__mascot{display:none} }

/* Accordion */
.accordion{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--surface)}
.accordion__item+.accordion__item{border-top:1px solid var(--border)}
.accordion__btn{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;
  padding:1.15rem 1.4rem;text-align:left;font-family:var(--font-display);font-weight:600;
  font-size:var(--fs-base);color:var(--ink);transition:background var(--t-fast)}
.accordion__btn:hover{background:var(--cream-100)}
.accordion__btn .icon{flex:none;color:var(--red-600);transition:transform var(--t) var(--ease)}
.accordion__btn[aria-expanded="true"] .icon{transform:rotate(45deg)}
.accordion__panel{overflow:hidden;height:0;transition:height var(--t) var(--ease)}
.accordion__panel-inner{padding:0 1.4rem 1.35rem;color:var(--ink-soft);font-size:var(--fs-sm);line-height:1.65}
.accordion__meta{display:inline-flex;align-items:center;gap:.5rem;margin-right:auto;
  font-size:var(--fs-sm);color:var(--red-700);font-weight:700}

/* Trust strip / Marquee */
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:flex;gap:3rem;width:max-content;animation:marquee 32s linear infinite}
.marquee__item{display:flex;align-items:center;gap:.6rem;color:var(--ink-mute);font-weight:600;
  font-family:var(--font-display);white-space:nowrap}
.marquee__item .icon{color:var(--brass)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* Winner cards */
.winner{display:flex;align-items:center;gap:1rem;padding:1.2rem 1.3rem;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
.winner__amount{font-family:var(--font-display);font-weight:800;font-size:var(--fs-lg);color:var(--red-700)}
.winner__meta{font-size:var(--fs-sm);color:var(--ink-soft)}
.winner__avatar{display:grid;place-items:center;width:48px;height:48px;border-radius:var(--r-round);
  background:var(--cream-100);color:var(--brass);font-family:var(--font-display);font-weight:700;flex:none}

/* Slider (Gewinner-Karussell) */
.slider{position:relative}
.slider__viewport{display:flex;gap:1.25rem;overflow-x:auto;scroll-snap-type:x proximity;
  scroll-behavior:smooth;padding:.5rem 2px 1.25rem;scrollbar-width:none;-ms-overflow-style:none}
.slider__viewport::-webkit-scrollbar{display:none}
.slider__viewport:focus-visible{outline:3px solid var(--focus);outline-offset:2px;border-radius:var(--r-sm)}
.slider__slide{flex:0 0 calc((100% - 2.5rem)/3);scroll-snap-align:start}
.slider__nav{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1.25rem}
.slider__btn{width:46px;height:46px;border-radius:var(--r-round);border:1.5px solid var(--border-strong);
  display:grid;place-items:center;background:var(--surface);color:var(--ink);
  transition:border-color var(--t-fast),color var(--t-fast),background var(--t-fast),opacity var(--t-fast)}
.slider__btn:hover{border-color:var(--red-600);color:var(--red-700);background:var(--cream-50)}
.slider__btn:disabled{opacity:.35;cursor:default;border-color:var(--border)}
.slider__btn .icon{width:22px;height:22px}

.winner-card{height:100%;display:flex;flex-direction:column;gap:.45rem;
  background:linear-gradient(168deg,#fff 0%,var(--cream-50) 100%);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:1.6rem;box-shadow:var(--shadow-sm);
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease)}
.winner-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.winner-card .pill{align-self:flex-start;margin-bottom:.4rem}
.winner-card__amount{font-family:var(--font-display);font-weight:800;font-size:var(--fs-2xl);
  color:var(--red-700);line-height:1}
.winner-card__meta,.winner-card__date{display:flex;align-items:center;gap:.45rem;
  color:var(--ink-soft);font-size:var(--fs-sm)}
.winner-card__meta .icon,.winner-card__date .icon{color:var(--brass);width:1.1em;height:1.1em;flex:none}
@media (max-width:880px){.slider__slide{flex-basis:calc((100% - 1.25rem)/2)}}
@media (max-width:560px){.slider__slide{flex-basis:86%}}

/* Newsletter */
.newsletter{background:var(--ink);color:var(--cream-100);border-radius:var(--r-xl);
  padding:clamp(2rem,5vw,3.25rem);position:relative;overflow:hidden}
.newsletter::before{content:"";position:absolute;inset:0;
  background:radial-gradient(60% 100% at 0 100%,rgba(176,141,87,.18),transparent 55%)}
.newsletter__inner{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}
.newsletter h2{color:#fff}
.newsletter p{color:rgba(245,238,225,.78);margin-top:.6rem}

/* =========================================================================
   FORMS
   ========================================================================= */
.field{margin-bottom:1.1rem}
.field__label{display:block;font-weight:600;font-size:var(--fs-sm);margin-bottom:.4rem;font-family:var(--font-display)}
.field__req{color:var(--red-600)}
.input,.textarea,.select{width:100%;padding:.85rem 1rem;background:var(--surface);
  border:1.5px solid var(--border-strong);border-radius:var(--r-sm);font-size:var(--fs-base);
  transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--red-600);
  box-shadow:0 0 0 3px rgba(200,16,46,.14)}
.textarea{min-height:140px;resize:vertical}
.input--invalid{border-color:var(--red-600)}
.field__error{display:none;margin-top:.35rem;font-size:var(--fs-sm);color:var(--red-700)}
.field.has-error .field__error{display:block}
.field.has-error .input,.field.has-error .textarea{border-color:var(--red-600)}
.checkbox{display:flex;align-items:flex-start;gap:.6rem;font-size:var(--fs-sm);color:var(--ink-soft)}
.checkbox input{margin-top:.2rem;width:1.15rem;height:1.15rem;accent-color:var(--red-600);flex:none}
.form-note{font-size:var(--fs-xs);color:var(--ink-mute);margin-top:.5rem}
.form-success{display:none;align-items:center;gap:.75rem;padding:1rem 1.2rem;background:var(--green-tint);
  border:1px solid #bfe0cd;border-radius:var(--r-md);color:var(--green-700);font-weight:500}
.form-success .icon{color:var(--green);flex:none}
.is-submitted .form-success{display:flex}
.is-submitted .form-body{display:none}
.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:clamp(1.5rem,4vw,2.25rem);box-shadow:var(--shadow-md)}

/* Tables */
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface)}
table.data{width:100%;border-collapse:collapse;min-width:520px}
table.data th,table.data td{padding:.9rem 1.1rem;text-align:left;font-size:var(--fs-sm);
  border-bottom:1px solid var(--border)}
table.data thead th{background:var(--cream-100);font-family:var(--font-display);font-weight:700;
  color:var(--ink);white-space:nowrap}
table.data tbody tr:hover{background:var(--cream-50)}
table.data tbody tr:last-child td{border-bottom:0}

/* =========================================================================
   PROSE (Legal/Content pages)
   ========================================================================= */
.page-hero{background:linear-gradient(180deg,var(--cream-100),var(--cream-50));
  border-bottom:1px solid var(--border);padding-block:clamp(2rem,5vw,3.25rem)}
.page-hero__inner{max-width:50rem}
.page-hero h1{font-size:var(--fs-3xl)}
.page-hero p{margin-top:.9rem;font-size:var(--fs-md);color:var(--ink-soft)}

.layout-aside{display:grid;grid-template-columns:260px 1fr;gap:clamp(2rem,5vw,3.5rem);align-items:start}
.toc{position:sticky;top:130px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:1.25rem;box-shadow:var(--shadow-sm)}
.toc__title{font-size:var(--fs-sm);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-mute);
  margin-bottom:.75rem}
.toc a{display:block;padding:.4rem 0;font-size:var(--fs-sm);color:var(--ink-soft);font-weight:500;
  border-left:2px solid transparent;padding-left:.75rem;margin-left:-.75rem}
.toc a:hover{color:var(--red-700);border-color:var(--red-600)}

.prose{max-width:48rem}
.prose>*+*{margin-top:1.1rem}
.prose h2{font-size:var(--fs-xl);margin-top:2.5rem;scroll-margin-top:130px}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:var(--fs-md);margin-top:1.75rem}
.prose p,.prose li{color:var(--ink-soft);line-height:1.7}
.prose ul{list-style:disc;padding-left:1.3rem}
.prose ol{list-style:decimal;padding-left:1.3rem}
.prose li+li{margin-top:.4rem}
.prose a{text-decoration:underline;text-underline-offset:2px;font-weight:500}
.prose strong{color:var(--ink)}
.prose table{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}
.prose th,.prose td{border:1px solid var(--border);padding:.7rem .9rem;text-align:left}
.prose th{background:var(--cream-100)}

.callout{display:flex;gap:.9rem;padding:1.15rem 1.3rem;border-radius:var(--r-md);
  background:var(--brass-tint);border:1px solid #e7d6b6}
.callout .icon{color:#7a5f2e;flex:none;margin-top:.15rem}
.callout--red{background:#fbe1e5;border-color:#f3c2cb}
.callout--red .icon{color:var(--red-700)}
.callout--green{background:var(--green-tint);border-color:#bfe0cd}
.callout--green .icon{color:var(--green-700)}
.callout p{color:var(--ink);font-size:var(--fs-sm);margin:0}
.callout strong{display:block;margin-bottom:.2rem;font-family:var(--font-display)}

.last-updated{font-size:var(--fs-sm);color:var(--ink-mute);font-style:italic}

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer{background:var(--ink);color:var(--cream-100);margin-top:auto;
  padding-block:clamp(2.5rem,5vw,3.5rem) 2rem}
.site-footer a{color:var(--cream-100)}
.site-footer a:hover{color:#fff}

/* RG-Pflichtblock */
.footer-rg{display:flex;gap:1.1rem;padding:1.5rem;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);margin-bottom:2.5rem}
.footer-rg__icon{display:grid;place-items:center;width:48px;height:48px;border-radius:var(--r-md);
  background:rgba(200,16,46,.2);color:#ff8a9c;flex:none}
.footer-rg__icon .icon{width:26px;height:26px}
.footer-rg__title{font-family:var(--font-display);font-weight:700;font-size:var(--fs-md);color:#fff;
  margin-bottom:.3rem}
.footer-rg__text{font-size:var(--fs-sm);color:rgba(245,238,225,.82);line-height:1.6}
.footer-rg__text a{text-decoration:underline;text-underline-offset:2px}
.footer-rg__links{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;margin-top:.9rem}
.footer-rg__links a{display:inline-flex;align-items:center;gap:.4rem;padding-block:4px;font-size:var(--fs-sm);
  font-weight:500;color:var(--brass-soft)}
.footer-rg__links a:hover{color:#fff}
.footer-rg__links .icon{width:1em;height:1em}

/* Hauptbereich */
.footer-main{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:2rem;
  padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand .brand{color:#fff}
.footer-brand__slogan{margin-top:1rem;font-size:var(--fs-sm);color:rgba(245,238,225,.72);max-width:22rem}
.footer-brand__contact{margin-top:1rem;font-size:var(--fs-sm);line-height:2}
.footer-brand__contact a{display:inline-flex;align-items:center;gap:.5rem;color:rgba(245,238,225,.82)}
.footer-brand__contact a:hover{color:#fff}
.footer-brand__contact .icon{width:1.1em;height:1.1em;color:var(--brass-soft)}
.footer-col__title{font-family:var(--font-display);font-weight:700;font-size:var(--fs-sm);color:#fff;
  margin-bottom:1rem;letter-spacing:.01em}
.footer-col__list{display:flex;flex-direction:column;gap:.25rem}
.footer-col__list a{display:inline-block;font-size:var(--fs-sm);color:rgba(245,238,225,.78);
  padding-block:5px;transition:color var(--t-fast),padding-left var(--t-fast)}
.footer-col__list a:hover{color:#fff;padding-left:3px}

/* Zahlungsarten & Altersmarkierung */
.footer-pay{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.25rem;
  padding:1.5rem 0;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-pay__group{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.footer-pay__label{font-size:var(--fs-xs);font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  color:rgba(245,238,225,.55)}
.footer-pay__list{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}
.pay-badge{display:inline-flex;align-items:center;justify-content:center;min-height:30px;padding:.3rem .7rem;
  font-size:var(--fs-xs);font-weight:600;color:rgba(245,238,225,.92);background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.16);border-radius:var(--r-sm);letter-spacing:.01em}
.pay-badge--logo{background:#fff;border-color:rgba(0,0,0,.08);padding:.35rem .55rem}
.pay-badge--logo img{height:20px;width:auto;display:block}
.pay-badge--icon{gap:.45rem;background:#fff;border-color:rgba(0,0,0,.08);color:var(--ink)}
.pay-badge--icon .icon{width:1.15em;height:1.15em;color:currentColor}
/* giropay: quadratischer viewBox mit viel Rand → optisch vergrößern, Badge-Höhe via negativer Margin halten */
.pay-badge--giropay img{height:36px;margin-block:-8px}
.footer-pay__age{display:inline-flex;align-items:center;gap:.6rem}
.footer-pay__age-text{font-size:var(--fs-sm);color:rgba(245,238,225,.78)}
.age-badge--lg{font-size:.95rem;padding:.4em .7em}

/* Lizenz / Anbieterangaben */
.footer-license{display:flex;align-items:flex-start;gap:.75rem;padding:1.5rem 0;
  border-bottom:1px solid rgba(255,255,255,.1)}
.footer-license .icon{color:var(--brass-soft);flex:none;margin-top:.1rem;width:1.3em;height:1.3em}
.footer-license__body{display:flex;flex-direction:column;gap:.5rem}
.footer-license p{font-size:var(--fs-xs);color:rgba(245,238,225,.62);line-height:1.6}
.footer-license strong{color:rgba(245,238,225,.82);font-weight:600}
.footer-license a{color:var(--brass-soft);text-decoration:underline;text-underline-offset:2px}
.footer-license a:hover{color:#fff}

/* Sub-Footer */
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  flex-wrap:wrap;padding-top:1.5rem}
.footer-bottom__legal{display:flex;flex-wrap:wrap;gap:.1rem 1.2rem}
.footer-bottom__legal a{display:inline-block;padding-block:5px;font-size:var(--fs-sm);color:rgba(245,238,225,.78)}
.footer-bottom__legal a:hover{color:#fff}
.footer-bottom__meta{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap}
.footer-bottom__cookies{display:inline-flex;align-items:center;gap:.45rem;font-size:var(--fs-sm);
  font-weight:500;color:var(--brass-soft)}
.footer-bottom__cookies:hover{color:#fff}
.footer-bottom__cookies .icon{width:1.1em;height:1.1em}
.footer-bottom__copy{font-size:var(--fs-xs);color:rgba(245,238,225,.55)}

/* =========================================================================
   COOKIE CONSENT
   ========================================================================= */
.consent{position:fixed;inset:0;z-index:200;display:flex;align-items:flex-end;justify-content:center;
  padding:1rem}
.consent[hidden]{display:none}
.consent__backdrop{position:absolute;inset:0;background:rgba(42,32,36,.45)}
.consent__dialog{position:relative;width:100%;max-width:600px;background:var(--surface);
  border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:clamp(1.4rem,4vw,2rem);
  max-height:90vh;overflow-y:auto;animation:consent-in var(--t-slow) var(--ease)}
@keyframes consent-in{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.consent__head{display:flex;align-items:center;gap:.7rem;margin-bottom:.75rem}
.consent__logo{display:grid;place-items:center;width:42px;height:42px;border-radius:var(--r-md);
  background:var(--cream-100);color:var(--red-700)}
.consent__title{font-size:var(--fs-lg)}
.consent__desc{font-size:var(--fs-sm);color:var(--ink-soft);line-height:1.6}
.consent__desc a{text-decoration:underline}
.consent__options{margin:1.25rem 0;display:flex;flex-direction:column;gap:.6rem}
.consent__option{display:flex;gap:.8rem;padding:.9rem 1rem;border:1px solid var(--border);
  border-radius:var(--r-md);cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast)}
.consent__option:hover{background:var(--cream-50)}
.consent__option input{margin-top:.2rem;width:1.2rem;height:1.2rem;accent-color:var(--red-600);flex:none}
.consent__option-title{display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);
  font-weight:600;font-size:var(--fs-sm)}
.consent__badge{font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:var(--r-pill);
  background:var(--green-tint);color:var(--green-700)}
.consent__option-text{display:block;margin-top:.25rem;font-size:var(--fs-xs);color:var(--ink-mute)}
.consent__actions{display:flex;gap:.6rem;flex-wrap:wrap}
.consent__actions .btn{flex:1 1 auto}

/* Calc rows (Beispielrechnung) */
.calc-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.calc-row span{display:inline-flex;align-items:center;gap:.6rem;color:var(--ink-soft);font-size:var(--fs-sm)}
.calc-row .icon{color:var(--red-600)}
.calc-row strong{font-family:var(--font-display);font-size:var(--fs-md)}

/* Ergebnis-Boxen (Gewinnabfrage / Selbsttest) */
.gewinnabfrage-result,.selbsttest-result{margin-top:1.5rem;padding:1.25rem 1.4rem;border-radius:var(--r-md);
  border:1px solid var(--border);background:var(--surface);font-size:var(--fs-sm);line-height:1.6}
.gewinnabfrage-result.is-win,.selbsttest-result.is-low{background:var(--green-tint);border-color:#bfe0cd}
.gewinnabfrage-result.is-nowin{background:var(--cream-100)}
.selbsttest-result.is-mid{background:var(--brass-tint);border-color:#e7d6b6}
.selbsttest-result.is-high{background:#fbe1e5;border-color:#f3c2cb}
.selbsttest-result__level{font-family:var(--font-display);font-weight:700;font-size:var(--fs-md);margin-bottom:.4rem}
.selbsttest fieldset{border:1px solid var(--border);border-radius:var(--r-md);padding:1.2rem 1.3rem;margin-bottom:1rem}
.selbsttest legend{font-family:var(--font-display);font-weight:600;padding:0 .5rem;font-size:var(--fs-sm)}
.selbsttest .opt{display:flex;align-items:center;gap:.6rem;padding:.45rem 0;font-size:var(--fs-sm);color:var(--ink-soft)}
.selbsttest .opt input{width:1.1rem;height:1.1rem;accent-color:var(--red-600)}
.selbsttest-note{color:var(--red-700);font-weight:600;font-size:var(--fs-sm);margin-bottom:1rem}
.selbsttest-note[hidden]{display:none}

/* Accordion-Button-Layout: Meta links, Rest rechts */
.accordion__btn .accordion__meta{margin-right:auto}

/* Tabs */
.tabs__list{display:flex;flex-wrap:wrap;gap:.5rem;border-bottom:1px solid var(--border);margin-bottom:1.75rem}
.tabs__tab{padding:.8rem 1.2rem;font-family:var(--font-display);font-weight:600;font-size:var(--fs-sm);
  color:var(--ink-soft);border-bottom:2px solid transparent;margin-bottom:-1px;border-radius:var(--r-sm) var(--r-sm) 0 0;
  transition:color var(--t-fast),border-color var(--t-fast),background var(--t-fast)}
.tabs__tab:hover{color:var(--red-700);background:var(--cream-100)}
.tabs__tab[aria-selected="true"]{color:var(--red-700);border-color:var(--red-600)}
.tabs__panel[hidden]{display:none}

/* Pricing cards */
.price-card{display:flex;flex-direction:column;height:100%;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem;box-shadow:var(--shadow-sm);
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease),border-color var(--t)}
.price-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.price-card.is-featured{border-color:var(--red-600);box-shadow:var(--shadow-md);position:relative}
.price-card.is-featured::before{content:"Beliebt";position:absolute;top:-.75rem;right:1.5rem;
  background:var(--red-600);color:#fff;font-family:var(--font-display);font-weight:600;font-size:.7rem;
  padding:.3rem .8rem;border-radius:var(--r-pill)}
.price-card__name{font-family:var(--font-display);font-weight:700;font-size:var(--fs-md)}
.price-card__price{font-family:var(--font-display);font-weight:800;font-size:var(--fs-2xl);color:var(--red-700);
  margin:.5rem 0 .25rem}
.price-card__price span{font-size:var(--fs-sm);font-weight:500;color:var(--ink-mute)}
.price-card__features{margin:1.25rem 0;display:flex;flex-direction:column;gap:.6rem}
.price-card__features li{display:flex;align-items:flex-start;gap:.55rem;font-size:var(--fs-sm);color:var(--ink-soft)}
.price-card__features .icon{color:var(--green);flex:none;margin-top:.1rem;width:1.1em;height:1.1em}
.price-card .btn{margin-top:auto}

/* FAQ */
.faq-search{position:relative;margin-bottom:2rem}
.faq-search .input{padding-left:3rem}
.faq-search__icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--ink-mute)}
.faq-group{margin-bottom:2.25rem}
.faq-group__title{display:flex;align-items:center;gap:.6rem;font-size:var(--fs-lg);margin-bottom:1rem}
.faq-group__title .icon{color:var(--red-600)}
.faq-empty{display:flex;align-items:center;gap:.6rem;padding:1rem 1.2rem;background:var(--cream-100);
  border-radius:var(--r-md);color:var(--ink-soft);font-size:var(--fs-sm)}
.faq-empty .icon{color:var(--brass)}

/* Scroll-to-top */
.scroll-top{position:fixed;right:1.25rem;bottom:1.25rem;z-index:90;width:48px;height:48px;
  border-radius:var(--r-round);background:var(--red-600);color:#fff;display:grid;place-items:center;
  box-shadow:var(--shadow-md);opacity:0;transform:translateY(12px);
  transition:opacity var(--t) var(--ease),transform var(--t) var(--ease),background var(--t-fast)}
.scroll-top.is-visible{opacity:1;transform:none}
.scroll-top:hover{background:var(--red-700)}
.scroll-top[hidden]{display:grid}

/* =========================================================================
   SCROLL-REVEAL & MOTION
   ========================================================================= */
/* Reveal nur mit JS aktiv – ohne JS bleibt Inhalt sichtbar (SEO/no-JS). */
.js [data-reveal]{opacity:0;transform:translateY(24px);
  transition:opacity var(--t-slow) var(--ease),transform var(--t-slow) var(--ease)}
.js [data-reveal].is-visible{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:80ms}
[data-reveal-delay="2"]{transition-delay:160ms}
[data-reveal-delay="3"]{transition-delay:240ms}

/* Utilities */
.text-center{text-align:center}
.mt-0{margin-top:0}.mt-4{margin-top:1rem}.mt-6{margin-top:2rem}.mt-8{margin-top:4rem}
.mb-6{margin-bottom:2rem}
.flow>*+*{margin-top:1.1rem}
.flow-lg>*+*{margin-top:1.75rem}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.divider{height:1px;background:var(--border);border:0;margin-block:var(--sp-6)}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width:1080px){
  .main-nav{display:none}
  .nav-toggle{display:grid}
  .hero__inner{grid-template-columns:1fr;gap:2rem;min-height:0}
  .hero__chip{justify-self:start;width:min(100%,340px)}
  .layout-aside{grid-template-columns:1fr}
  .toc{position:static;display:none}
}
@media (max-width:1080px){
  .footer-main{grid-template-columns:1fr 1fr 1fr}
  .footer-brand{grid-column:1 / -1;margin-bottom:.5rem}
}
@media (max-width:880px){
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .newsletter__inner{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .cta-band__inner{flex-direction:column;align-items:flex-start}
  .footer-main{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .footer-main{grid-template-columns:1fr}
  .footer-rg{flex-direction:column}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}
@media (max-width:640px){
  :root{--fs-base:1.0625rem;--fs-4xl:2.6rem;--fs-3xl:2.2rem;--fs-2xl:1.85rem;--fs-xl:1.55rem}
  .grid--2,.grid--3,.grid--4{grid-template-columns:1fr}
  .nav-bar__cta span{display:none}
  .nav-bar__cta{padding:.7rem .9rem}
  .utility-bar__contact{display:none}
  .consent{align-items:center}
  .consent__actions .btn{flex:1 1 100%}
  .winner{flex-wrap:wrap}
}

/* =========================================================================
   REDUCED MOTION
   ========================================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  [data-reveal]{opacity:1;transform:none}
  .marquee__track{animation:none}
}
