/* ============================================================
   Gotteswasser — Shared Brand Layout (Full-bleed Hero)
   Theme-Variablen werden pro Seite via :root override gesetzt.
   ============================================================ */
:root{
  --bg:#0a0708; --fg:#f3ede4; --muted:rgba(243,237,228,.66);
  --accent:#c01722; --accent2:#e0a23a; --line:rgba(255,255,255,.16);
  --field:#16121a; --field-bd:#39303a; --btn-bg:var(--accent); --btn-fg:#fff;
  --scrim:linear-gradient(90deg,rgba(0,0,0,.78) 0%,rgba(0,0,0,.55) 42%,rgba(0,0,0,.12) 100%);
  --display:"Cinzel",Georgia,"Times New Roman",serif;
  --body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--bg);color:var(--fg);
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit}
.slide{min-height:100vh;width:100%;position:relative;display:flex;flex-direction:column}

/* ---- Topbar ---- */
.topbar{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;
  justify-content:space-between;align-items:center;padding:20px 32px}
.brandmark{font-family:var(--display);letter-spacing:.22em;text-transform:uppercase;
  font-size:13px;font-weight:600;color:#fff;text-decoration:none;opacity:.95;
  text-shadow:0 1px 12px rgba(0,0,0,.6)}
.nav-right{display:flex;align-items:center;gap:22px}
.switch-side{font-size:11px;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;
  color:rgba(255,255,255,.75);display:inline-flex;align-items:center;gap:7px;transition:.25s;
  text-shadow:0 1px 10px rgba(0,0,0,.6)}
.switch-side:hover{color:#fff}
.switch-side svg{width:13px;height:13px}
.lang{display:flex;gap:2px;font-size:12px;letter-spacing:.1em}
.lang button{background:none;border:none;color:#fff;cursor:pointer;padding:4px 7px;opacity:.55;
  font:inherit;letter-spacing:.1em;text-shadow:0 1px 10px rgba(0,0,0,.6)}
.lang button.active{opacity:1;border-bottom:1px solid var(--accent2)}

/* ---- Hero (full-bleed background image) ---- */
#hero{justify-content:center;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;
  transform:scale(1.03)}
.hero-scrim{position:absolute;inset:0;z-index:1;background:var(--scrim)}
.hero-glow{position:absolute;z-index:1;width:60vw;height:60vw;right:-12vw;top:50%;
  transform:translateY(-50%);background:radial-gradient(circle,var(--halo),transparent 66%);
  filter:blur(10px);pointer-events:none}
.hero-copy{position:relative;z-index:2;max-width:680px;padding:128px 6vw 72px}
.eyebrow{font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--accent2);
  margin-bottom:22px;font-weight:600}
.eyebrow .dot{opacity:.5;margin:0 8px}
h1.title{font-family:var(--display);font-weight:700;line-height:.92;
  font-size:clamp(48px,8.5vw,112px);letter-spacing:.02em;text-transform:uppercase;
  text-shadow:0 2px 40px rgba(0,0,0,.5)}
.source{font-family:var(--display);font-size:clamp(17px,2.2vw,25px);letter-spacing:.13em;
  text-transform:uppercase;margin-top:20px;opacity:.92}
.tagline{margin-top:26px;font-size:clamp(16px,1.8vw,20px);line-height:1.5;color:var(--muted);max-width:40ch}
.tagline strong{color:#fff;font-weight:600}
.pillars{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:30px;list-style:none}
.pillars li{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.8);
  display:flex;align-items:center;gap:9px}
.pillars li::before{content:"";width:5px;height:5px;background:var(--accent2);transform:rotate(45deg)}
.cta-row{margin-top:44px;display:flex;flex-wrap:wrap;gap:16px;align-items:center}
.btn{display:inline-flex;align-items:center;gap:11px;cursor:pointer;font:inherit;font-size:12px;
  letter-spacing:.2em;text-transform:uppercase;font-weight:600;padding:17px 34px;
  border:1px solid var(--btn-bg);background:var(--btn-bg);color:var(--btn-fg);text-decoration:none;transition:.28s}
.btn:hover{filter:brightness(1.12);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:#fff;border-color:var(--line)}
.btn.ghost:hover{border-color:var(--accent2);color:var(--accent2);filter:none}
.btn svg{width:15px;height:15px}

/* ---- Register ---- */
#register{align-items:center;justify-content:center;padding:110px 28px;
  background:linear-gradient(180deg,#000,var(--bg))}
.reg-card{width:100%;max-width:480px;text-align:center}
.reg-card .eyebrow{display:block}
.reg-card h2{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(30px,5vw,52px);line-height:1.02;margin-bottom:16px}
.reg-card p.lead{color:var(--muted);font-size:15px;line-height:1.6;margin:0 auto 32px;max-width:40ch}
form{display:flex;flex-direction:column;gap:13px;text-align:left}
.field label{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.field input{width:100%;padding:15px 17px;background:var(--field);border:1px solid var(--field-bd);
  color:var(--fg);font:inherit;font-size:15px;border-radius:2px;transition:.2s}
.field input:focus{outline:none;border-color:var(--accent2)}
button.submit{margin-top:6px;padding:17px;background:var(--btn-bg);color:var(--btn-fg);border:none;
  font:inherit;font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;cursor:pointer;border-radius:2px;transition:.22s}
button.submit:hover{filter:brightness(1.12)}
.reg-note{margin-top:20px;font-size:12px;color:var(--muted);opacity:.85;line-height:1.5}
.form-ok{display:none;padding:20px;border:1px solid var(--accent2);color:var(--accent2);border-radius:2px;font-size:14px;line-height:1.5}
.form-ok.show{display:block}

/* ---- Footer ---- */
.site-footer{padding:34px 32px;text-align:center;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);border-top:1px solid var(--line)}
.site-footer a{color:var(--accent2);text-decoration:none}

@media(max-width:760px){
  .hero-copy{padding:120px 7vw 64px}
  :root{--scrim:linear-gradient(180deg,rgba(0,0,0,.5) 0%,rgba(0,0,0,.72) 100%)}
}

/* ============================================================
   Module-Bänder (CMS-Renderer: pillars / product / sponsor / faq)
   ============================================================ */
.slide-band{padding:96px 6vw;position:relative}
.band-h{font-family:var(--display);text-transform:uppercase;font-weight:700;
  font-size:clamp(26px,4vw,46px);letter-spacing:.03em;text-align:center;margin-bottom:48px;color:var(--fg)}

/* Pillars */
#pillars{background:linear-gradient(180deg,var(--bg),#000)}
.pillar-grid{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  max-width:1100px;margin:0 auto;background:var(--line)}
.pillar-grid li{background:var(--bg);padding:40px 24px;text-align:center;display:flex;
  flex-direction:column;align-items:center;gap:14px;font-family:var(--display);
  text-transform:uppercase;letter-spacing:.14em;font-size:15px;color:var(--fg)}
.pillar-grid .pn{font-size:12px;letter-spacing:.2em;color:var(--accent2);opacity:.9}
@media(max-width:760px){.pillar-grid{grid-template-columns:repeat(2,1fr)}}

/* Product */
#product{background:var(--bg)}
.product-wrap{max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:6vw;flex-wrap:wrap}
.product-img{flex:1 1 320px;position:relative}
.product-img::before{content:"";position:absolute;inset:0;z-index:0;
  background:radial-gradient(circle at 50% 45%,var(--halo),transparent 65%);filter:blur(12px);opacity:.4}
.product-img img{position:relative;z-index:1;width:100%;border-radius:3px;
  box-shadow:0 30px 70px rgba(0,0,0,.5)}
.product-copy{flex:1 1 320px}
.product-copy h2{font-family:var(--display);text-transform:uppercase;font-weight:700;
  font-size:clamp(28px,4vw,48px);margin-bottom:18px;color:var(--fg)}
.product-copy p{color:var(--muted);font-size:17px;line-height:1.6;margin-bottom:22px;max-width:42ch}
.product-copy .cap{display:inline-block;font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent2);border:1px solid var(--accent2);padding:8px 16px;border-radius:2px}

/* Sponsor */
#sponsor{background:linear-gradient(180deg,#000,var(--bg));text-align:center}
.sponsor-inner{max-width:760px;margin:0 auto}
.sponsor-label{display:block;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.sponsor-brand{display:block;font-family:var(--display);text-transform:uppercase;font-weight:700;
  font-size:clamp(28px,5vw,56px);letter-spacing:.04em;color:var(--accent2);
  text-shadow:0 0 36px var(--halo)}
.sponsor-text{margin-top:18px;color:var(--muted);font-size:16px;line-height:1.6}

/* FAQ */
#faq{background:var(--bg)}
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid var(--line);border-radius:3px;padding:4px 22px;background:var(--paper);
  background:color-mix(in srgb,var(--bg) 70%, #000 0%)}
.faq-item summary{cursor:pointer;list-style:none;padding:18px 0;font-family:var(--display);
  text-transform:uppercase;letter-spacing:.06em;font-size:16px;color:var(--fg);
  display:flex;justify-content:space-between;align-items:center}
.faq-item summary::after{content:"+";color:var(--accent2);font-size:22px;line-height:1}
.faq-item[open] summary::after{content:"–"}
.faq-item p{padding:0 0 20px;color:var(--muted);font-size:15px;line-height:1.6}

/* ============================================================
   SOTA-Module (Fabrik): features / stats / cta-band / testimonial
   Rein token-getrieben, gleiche Variablen wie oben.
   ============================================================ */

/* Features (3-Spalten Icon-Grid) */
#features{background:var(--bg)}
.feat-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line)}
.feat-card{background:var(--bg);padding:44px 28px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.feat-ic{display:grid;place-items:center;width:48px;height:48px;color:var(--accent2)}
.feat-ic svg{width:100%;height:100%;display:block}
.feat-ic img{width:100%;height:100%;object-fit:contain}
.feat-h{font-family:var(--display);text-transform:uppercase;letter-spacing:.08em;font-size:18px;color:var(--fg)}
.feat-p{color:var(--muted);font-size:15px;line-height:1.6;max-width:34ch}
@media(max-width:760px){.feat-grid{grid-template-columns:1fr}}

/* Stats (Kennzahlen-Band) */
#stats{background:linear-gradient(180deg,#000,var(--bg))}
.stat-band{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1px;background:var(--line);text-align:center}
.stat-cell{background:var(--bg);padding:40px 20px}
.stat-val{font-family:var(--display);font-weight:700;font-size:clamp(34px,5vw,56px);line-height:1;color:var(--accent2);text-shadow:0 0 30px var(--halo)}
.stat-lbl{margin-top:12px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}

/* CTA-Band */
#ctaband{background:radial-gradient(circle at 50% 0%,var(--halo),transparent 60%),var(--bg);text-align:center}
.ctaband-inner{max-width:720px;margin:0 auto}
.ctaband-h{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:clamp(28px,4.5vw,52px);letter-spacing:.03em;color:var(--fg)}
.ctaband-text{margin:18px auto 30px;color:var(--muted);font-size:17px;line-height:1.6;max-width:46ch}

/* Testimonial (Einzel-Zitat) */
#testimonial{background:var(--bg);text-align:center}
.tm-fig{max-width:780px;margin:0 auto}
.tm-quote{font-family:var(--display);font-style:normal;font-size:clamp(22px,3.4vw,38px);line-height:1.3;color:var(--fg)}
.tm-quote::before{content:"\201C"}.tm-quote::after{content:"\201D"}
.tm-cap{margin-top:26px;display:inline-flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:center;color:var(--muted)}
.tm-avatar{width:46px;height:46px;border-radius:50%;object-fit:cover;border:1px solid var(--line)}
.tm-author{font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:13px;color:var(--accent2)}
.tm-role{font-size:12px;letter-spacing:.06em}
.tm-role::before{content:"\00b7";margin-right:10px;opacity:.6}

/* ============================================================
   SOTA-Module (Fabrik): features / stats / cta-band / testimonial
   Rein token-getrieben, gleiche Variablen wie oben.
   ============================================================ */

/* Features (3-Spalten Icon-Grid) */
#features{background:var(--bg)}
.feat-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line)}
.feat-card{background:var(--bg);padding:44px 28px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.feat-ic{display:grid;place-items:center;width:48px;height:48px;color:var(--accent2)}
.feat-ic svg{width:100%;height:100%;display:block}
.feat-ic img{width:100%;height:100%;object-fit:contain}
.feat-h{font-family:var(--display);text-transform:uppercase;letter-spacing:.08em;font-size:18px;color:var(--fg)}
.feat-p{color:var(--muted);font-size:15px;line-height:1.6;max-width:34ch}
@media(max-width:760px){.feat-grid{grid-template-columns:1fr}}

/* Stats (Kennzahlen-Band) */
#stats{background:linear-gradient(180deg,#000,var(--bg))}
.stat-band{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1px;background:var(--line);text-align:center}
.stat-cell{background:var(--bg);padding:40px 20px}
.stat-val{font-family:var(--display);font-weight:700;font-size:clamp(34px,5vw,56px);line-height:1;color:var(--accent2);text-shadow:0 0 30px var(--halo)}
.stat-lbl{margin-top:12px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}

/* CTA-Band */
#ctaband{background:radial-gradient(circle at 50% 0%,var(--halo),transparent 60%),var(--bg);text-align:center}
.ctaband-inner{max-width:720px;margin:0 auto}
.ctaband-h{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:clamp(28px,4.5vw,52px);letter-spacing:.03em;color:var(--fg)}
.ctaband-text{margin:18px auto 30px;color:var(--muted);font-size:17px;line-height:1.6;max-width:46ch}

/* Testimonial (Einzel-Zitat) */
#testimonial{background:var(--bg);text-align:center}
.tm-fig{max-width:780px;margin:0 auto}
.tm-quote{font-family:var(--display);font-style:normal;font-size:clamp(22px,3.4vw,38px);line-height:1.3;color:var(--fg)}
.tm-quote::before{content:"\201C"}.tm-quote::after{content:"\201D"}
.tm-cap{margin-top:26px;display:inline-flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:center;color:var(--muted)}
.tm-avatar{width:46px;height:46px;border-radius:50%;object-fit:cover;border:1px solid var(--line)}
.tm-author{font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:13px;color:var(--accent2)}
.tm-role{font-size:12px;letter-spacing:.06em}
.tm-role::before{content:"\00b7";margin-right:10px;opacity:.6}
