/* ============================================
   VitXtend — Design-System (aus Mockups v6/v7/v12)
   Eine Datei. Farbe hier aendern = gilt ueberall.
   ============================================ */

:root{
  /* Farben */
  --olive-primary:#6B7A3F;
  --olive-dark:#4A5E2A;
  --olive-darker:#3B4820;
  --olive-light:#9DAA68;
  --grau-sekundaer:#4A4641;
  --amber:#BA7517;
  --lila:#534AB7;
  --text-dunkel:#1a1816;
  --text-grau:#8a8680;
  --text-grau-2:#6F6A62;
  --border:#E8E4D9;
  --bg-warm:#FDFCF9;
  --bg-warm-2:#F7F9F2;
  --bg-creme:#F4F1E6;
  --bg-sand:#E8E4D9;
  --bg-karte:#FFFFFF;
  --bg-block:#F7F5EE;
  --rot:#9A4030;

  /* Typo */
  --font-display:'Fraunces',Georgia,serif;
  --font-body:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;

  /* Layout */
  --maxw:840px;
  --radius:16px;
  --radius-s:12px;
  --radius-karte:14px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg-sand);
  color:var(--text-dunkel);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  padding:40px 20px;
}

/* ---------- Layout-Container ---------- */
.page{
  max-width:var(--maxw);
  margin:0 auto;
  background:var(--bg-warm);
  min-height:100vh;
  border-radius:16px;
  border:0.5px solid #E8E4D9;
  box-shadow:0 4px 40px rgba(0,0,0,0.06);
}

/* ---------- Header ---------- */
.header{
  padding:24px 32px;
  border-bottom:0.5px solid var(--border);
  display:flex;
  justify-content:space-between;
  align-items:center;
  background:var(--bg-warm);
  position:sticky;top:0;z-index:50;
  border-top-left-radius:16px;border-top-right-radius:16px;
}
.logo{
  font-family:var(--font-display);
  font-size:38px;font-weight:500;
  color:var(--text-dunkel);
  letter-spacing:-0.02em;line-height:1;
  text-decoration:none;
}
.logo .x{font-style:italic;color:var(--olive-primary)}
.nav{display:flex;gap:24px;font-size:12px;color:var(--text-grau);letter-spacing:0.02em}
.nav a{cursor:pointer;text-decoration:none;color:var(--text-grau);transition:.2s}
.nav a:hover{color:var(--text-dunkel)}
.nav a.active{color:var(--text-dunkel);font-weight:500}

/* ---------- Typo-Bausteine ---------- */
.eyebrow{
  font-size:10px;letter-spacing:.35em;text-transform:uppercase;
  color:var(--olive-primary);font-weight:500;
  display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before,.eyebrow::after{
  content:'';display:inline-block;width:24px;height:0.5px;
  background:var(--olive-primary);opacity:0.5;
}
h1,h2,h3{font-family:var(--font-display);color:var(--text-dunkel);font-weight:500}
em{font-style:italic;font-weight:400}

/* ---------- Hero ---------- */
.hero{
  padding:64px 40px 56px;text-align:center;
  background:linear-gradient(180deg,var(--bg-warm) 0%,var(--bg-creme) 100%);
  border-bottom:0.5px solid var(--border);
}
.hero .eyebrow{margin-bottom:28px}
.hero-headline{
  font-family:var(--font-display);
  font-size:40px;font-weight:400;
  color:var(--text-dunkel);line-height:1.15;
  margin-bottom:24px;letter-spacing:-0.02em;
  max-width:580px;margin-left:auto;margin-right:auto;
}
.hero-headline em{font-style:italic;font-weight:400}
.hero-sub{
  font-size:15px;color:var(--grau-sekundaer);line-height:1.7;
  max-width:520px;margin:0 auto 12px;font-weight:400;
}
.hero-sub .highlight{color:var(--text-dunkel);font-weight:500}

/* ---------- Buttons ---------- */
.btn-primary{
  display:inline-block;background:var(--olive-dark);color:var(--bg-warm-2);
  padding:16px 32px;border-radius:var(--radius-s);text-align:center;
  font-family:var(--font-display);font-size:18px;font-weight:500;font-style:italic;
  text-decoration:none;letter-spacing:-0.01em;cursor:pointer;border:none;
  box-shadow:0 4px 24px rgba(74,94,42,0.25);transition:.2s;
}
.btn-primary:hover{background:var(--olive-darker);box-shadow:0 6px 28px rgba(74,94,42,0.35)}
.btn-secondary{
  display:inline-block;background:transparent;color:var(--olive-dark);
  padding:16px 32px;border-radius:var(--radius-s);text-align:center;
  font-family:var(--font-display);font-size:18px;font-weight:500;font-style:italic;
  text-decoration:none;letter-spacing:-0.01em;cursor:pointer;
  border:0.5px solid var(--border);transition:.2s;
}
.btn-secondary:hover{border-color:var(--olive-primary)}
.cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:32px}

/* ---------- Content-Bereich ---------- */
.content{padding:48px 40px;background:var(--bg-warm)}
.section{margin-bottom:48px}
.section:last-child{margin-bottom:0}
.section-eyebrow{
  font-size:10px;font-weight:500;letter-spacing:.18em;color:var(--text-grau);
  text-transform:uppercase;margin-bottom:8px;text-align:center;
}
.section-title{
  font-family:var(--font-display);font-size:24px;font-weight:500;
  letter-spacing:-0.01em;text-align:center;margin-bottom:32px;
  color:var(--text-dunkel);line-height:1.3;
}
.section-title em{font-style:italic}

/* ---------- Karten ---------- */
.karte{
  background:var(--bg-karte);border:0.5px solid var(--border);
  border-radius:var(--radius-karte);padding:22px 26px;
  position:relative;overflow:hidden;
}
.karte::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--olive-primary)}
.karte.amber::before{background:var(--amber)}
.karte.olive::before{background:var(--olive-dark)}
.karte.lila::before{background:var(--lila)}
.karte-title{font-family:var(--font-display);font-size:17px;font-weight:500;color:var(--text-dunkel);margin-bottom:8px;letter-spacing:-0.01em}
.karte-text{font-size:13.5px;color:var(--grau-sekundaer);line-height:1.65}
.karten-stack{display:flex;flex-direction:column;gap:12px}

/* ---------- Steps ---------- */
.steps{display:flex;flex-direction:column;gap:12px}
.step{
  background:var(--bg-karte);border:0.5px solid var(--border);border-radius:var(--radius-karte);
  padding:22px 26px;position:relative;overflow:hidden;
  display:grid;grid-template-columns:48px 1fr;gap:18px;align-items:flex-start;
}
.step::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--olive-primary)}
.step-num{font-family:var(--font-display);font-size:32px;font-weight:400;color:var(--olive-primary);line-height:1;letter-spacing:-0.02em;font-style:italic}
.step-title{font-family:var(--font-display);font-size:17px;font-weight:500;color:var(--text-dunkel);margin-bottom:6px;letter-spacing:-0.01em}
.step-text{font-size:13.5px;color:var(--grau-sekundaer);line-height:1.65}

/* ---------- Quiz ---------- */
.quiz-box{
  background:var(--bg-karte);border:0.5px solid var(--border);
  border-radius:var(--radius);padding:36px 32px;margin-top:8px;
  position:relative;overflow:hidden;
}
.quiz-box::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--olive-primary)}
.quiz-label{font-size:13px;font-weight:600;color:var(--text-dunkel);margin-bottom:14px;display:block}
.quiz-frage{margin-bottom:28px}
.quiz-frage:last-child{margin-bottom:0}

.goals{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.goal{
  background:var(--bg-warm);border:1px solid var(--border);border-radius:var(--radius-karte);
  padding:20px 14px;text-align:center;cursor:pointer;transition:.2s;user-select:none;
}
.goal:hover{border-color:var(--olive-primary)}
.goal.aktiv{border-color:var(--olive-dark);background:var(--bg-warm-2);box-shadow:0 2px 12px rgba(74,94,42,0.12)}
.goal-icon{font-size:34px;line-height:1;margin-bottom:10px;display:block}
.goal-name{font-family:var(--font-display);font-size:15px;font-weight:500;color:var(--text-dunkel);margin-bottom:2px}
.goal-sub{font-size:11px;color:var(--text-grau)}
.goal-counter{font-size:11px;color:var(--text-grau);font-style:italic;text-align:center;margin-top:10px}

.pills{display:flex;gap:8px;flex-wrap:wrap}
.pill{
  background:var(--bg-warm);border:1px solid var(--border);border-radius:99px;
  padding:9px 18px;font-size:13px;color:var(--grau-sekundaer);cursor:pointer;transition:.2s;user-select:none;
}
.pill:hover{border-color:var(--olive-primary)}
.pill.aktiv{border-color:var(--olive-dark);background:var(--olive-dark);color:var(--bg-warm-2)}

.feld{margin-bottom:20px}
.feld-label{font-size:13px;font-weight:500;color:var(--text-dunkel);margin-bottom:10px;display:block}
.slider-wrap{display:flex;align-items:center;gap:16px}
input[type=range]{flex:1;accent-color:var(--olive-dark)}
.slider-val{font-family:var(--font-display);font-size:18px;color:var(--olive-dark);min-width:90px;font-style:italic}

/* ---------- Profil / Themen ---------- */
.theme{
  background:var(--bg-karte);border:0.5px solid var(--border);border-radius:var(--radius-karte);
  padding:22px 26px;position:relative;overflow:hidden;margin-bottom:12px;
}
.theme::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--olive-primary)}
.theme.amber::before{background:var(--amber)}
.theme.lila::before{background:var(--lila)}
.theme-title{font-family:var(--font-display);font-size:18px;font-weight:500;color:var(--text-dunkel);margin-bottom:8px}
.theme-text{font-size:13.5px;color:var(--grau-sekundaer);line-height:1.65;margin-bottom:8px}
.theme-text b{color:var(--text-dunkel);font-weight:500}

/* ---------- Produkt-Karten ---------- */
.produkt{
  background:var(--bg-karte);border:0.5px solid var(--border);border-radius:var(--radius-karte);
  padding:24px 26px;margin-bottom:14px;position:relative;overflow:hidden;
}
.produkt::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--olive-primary)}
.produkt-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:10px}
.produkt-marke{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--olive-primary);font-weight:600;margin-bottom:4px}
.produkt-name{font-family:var(--font-display);font-size:18px;font-weight:500;color:var(--text-dunkel);line-height:1.3}
.produkt-preis{font-family:var(--font-display);font-size:20px;color:var(--olive-dark);white-space:nowrap;font-style:italic}
.produkt-preis-tag{font-size:11px;color:var(--text-grau);text-align:right;margin-top:2px;font-style:normal;font-family:var(--font-body)}
.produkt-warum{font-size:13px;color:var(--grau-sekundaer);line-height:1.6;margin-bottom:14px}
.produkt-rang{display:inline-block;font-size:10px;letter-spacing:.08em;text-transform:uppercase;background:var(--bg-warm-2);color:var(--olive-dark);padding:3px 10px;border-radius:99px;font-weight:600;margin-bottom:10px}
.produkt-meta{display:flex;gap:16px;font-size:12px;color:var(--text-grau);margin-bottom:16px;flex-wrap:wrap}
.partnerlink-note{font-size:11px;color:var(--text-grau);font-style:italic;margin-top:10px}

/* ---------- Transparenz-Box ---------- */
.transparenz{
  background:var(--bg-block);border:0.5px solid var(--border);border-radius:var(--radius-karte);
  padding:18px 22px;font-size:12.5px;color:var(--grau-sekundaer);line-height:1.6;
  border-left:3px solid var(--olive-primary);margin-bottom:24px;
}
.transparenz b{color:var(--text-dunkel)}

/* ---------- Breadcrumb / Progress ---------- */
.breadcrumb{
  display:flex;gap:8px;align-items:center;font-size:11px;color:var(--text-grau);
  padding:16px 40px;background:var(--bg-warm);border-bottom:0.5px solid var(--border);
  flex-wrap:wrap;
}
.breadcrumb .akt{color:var(--olive-dark);font-weight:600}
.breadcrumb .sep{opacity:.5}

/* ---------- Hinweis-Block ---------- */
.hinweis{
  background:var(--bg-block);border:0.5px solid var(--border);border-radius:var(--radius-karte);
  padding:20px 24px;text-align:center;
}
.hinweis-title{font-family:var(--font-display);font-size:15px;font-weight:500;color:var(--text-dunkel);margin-bottom:8px}
.hinweis-text{font-size:13px;color:var(--grau-sekundaer);line-height:1.6}

/* ---------- Footer ---------- */
.footer{background:var(--text-dunkel);color:#A8A39A;border-bottom-left-radius:16px;border-bottom-right-radius:16px;overflow:hidden}
.footer-disclaimer{
  padding:14px 40px;color:var(--olive-light);font-size:10px;line-height:1.55;
  text-align:center;letter-spacing:0.02em;border-bottom:0.5px solid #3A3631;
}
.footer-top{
  padding:40px;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;
  border-bottom:0.5px solid #3A3631;
}
.footer-logo{font-family:var(--font-display);font-size:22px;font-weight:500;color:var(--bg-warm);letter-spacing:-0.02em;margin-bottom:14px}
.footer-logo .x{font-style:italic;color:var(--olive-light)}
.footer-tagline{font-size:12px;color:#A8A39A;line-height:1.6;max-width:280px}
.footer-col-title{font-size:9px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--olive-light);margin-bottom:14px}
.footer-link{display:block;font-size:12px;color:#A8A39A;margin-bottom:8px;text-decoration:none;transition:.2s}
.footer-link:hover{color:var(--bg-warm)}
.footer-affiliate{padding:18px 40px;background:#0F0E0C;font-size:10.5px;color:#8a8580;line-height:1.6;text-align:center;border-bottom:0.5px solid #3A3631}
.footer-affiliate b{color:var(--bg-warm);font-weight:500}
.footer-bottom{padding:18px 40px;display:flex;justify-content:space-between;align-items:center;font-size:10.5px;color:var(--text-grau-2);flex-wrap:wrap;gap:12px}
.footer-stand{flex-basis:100%;text-align:center;font-size:10.5px;color:#6f6a64;padding-bottom:10px;margin-bottom:4px;border-bottom:0.5px solid #2a2622}
.footer-bottom a{color:#A8A39A;text-decoration:none}
.footer-bottom a:hover{color:var(--bg-warm)}

/* ---------- Helfer ---------- */
.versteckt{display:none!important}
.zentriert{text-align:center}

/* ---------- Mobile ---------- */
@media (max-width:680px){
  .page{box-shadow:none}
  .logo{font-size:32px}
  .hero-claim{font-size:28px;gap:10px}
  .hero-claim::before,.hero-claim::after{width:20px}
  .hero-headline-sub{font-size:16px}
  .header{padding:18px 20px}
  .logo{font-size:28px}
  .nav{gap:16px}
  .hero{padding:44px 22px 40px}
  .hero-headline{font-size:28px}
  .hero-sub{font-size:14px}
  .content{padding:36px 22px}
  .goals{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr;gap:28px;padding:32px 24px}
  .footer-disclaimer,.footer-affiliate,.footer-bottom{padding-left:24px;padding-right:24px}
  .footer-bottom{flex-direction:column;text-align:center}
  .breadcrumb{padding:14px 22px}
  .produkt-top{flex-direction:column}
  .produkt-preis{text-align:left}
  .produkt-preis-tag{text-align:left}
}

/* ============================================
   QUIZ-STAGE (aus Startseite v7): Figur sticky links + Quiz rechts
   ============================================ */
.quiz-stage{display:grid;grid-template-columns:210px 1fr;gap:38px;padding:0 40px 48px;background:var(--bg-warm);scroll-margin-top:87px}
.figure-sticky{position:sticky;top:120px;align-self:start;display:flex;flex-direction:column;align-items:center;gap:12px;background:var(--bg-warm);padding-bottom:14px;z-index:5}
.figure-wrap{display:flex;align-items:center;justify-content:center;width:200px;height:380px}
.figure-wrap svg{width:auto;height:340px;max-height:340px;transition:opacity .4s ease}
.figure-status{font-size:11px;color:var(--text-grau);text-align:center;line-height:1.5;font-style:italic}
.figure-status b{color:var(--text-dunkel);font-style:normal;font-weight:500}
.figure-progress{width:100%;background:var(--bg-creme);border-radius:99px;height:4px;overflow:hidden;margin-top:14px}
.figure-progress-fill{background:var(--olive-primary);height:100%;border-radius:99px;width:0%;transition:width .3s}

.quiz-content{min-width:0}
.section-label{font-size:10px;font-weight:500;letter-spacing:.18em;color:var(--text-grau);text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.section-label::before{content:'';display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--olive-primary)}
.section-label.next{margin-top:24px}

/* Goals mit echten SVG-Icons */
.goals{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-bottom:6px}
.goal{background:#FFFFFF;border:0.5px solid var(--border);border-radius:12px;padding:18px 10px 16px 14px;text-align:center;cursor:pointer;transition:.2s;position:relative;overflow:hidden;user-select:none}
.goal:hover{border-color:#C4C0B8;box-shadow:0 2px 12px rgba(0,0,0,0.04)}
.goal.aktiv{border-color:var(--text-dunkel);box-shadow:0 0 0 1px var(--text-dunkel) inset}
.goal::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px}
.goal.lang::before{background:var(--amber)}
.goal.fit::before{background:var(--olive-dark)}
.goal.klar::before{background:var(--lila)}
.goal-icon{height:54px;display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.goal-name{font-family:var(--font-display);font-size:13px;font-weight:500;color:var(--text-dunkel);letter-spacing:-0.01em;line-height:1.2;margin-bottom:2px}
.goal-sub{font-size:9.5px;color:var(--text-grau);text-transform:uppercase;letter-spacing:.06em;font-weight:500}
.goal-counter{font-size:10px;color:var(--text-grau);text-align:right;font-style:italic;margin:8px 0 14px}

/* Input-Blöcke (v7-Stil) */
.input-block{background:#FFFFFF;border:0.5px solid var(--border);border-radius:12px;padding:14px 18px 14px 22px;margin-bottom:6px;position:relative;overflow:hidden}
.input-block::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--olive-primary)}
.input-label{font-size:9.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-grau);margin-bottom:8px}
.input-block .slider-wrap{display:flex;align-items:center;gap:14px}
.input-block .slider-val{font-family:var(--font-display);font-size:18px;font-weight:500;color:var(--text-dunkel);min-width:84px;font-style:normal}
.input-block input[type=range]{flex:1;accent-color:var(--olive-dark)}
.input-block .pills{display:flex;gap:5px;flex-wrap:wrap;margin-top:2px}
.input-block .pill{padding:7px 13px;border-radius:20px;background:var(--bg-warm);border:0.5px solid var(--border);font-size:11.5px;color:var(--grau-sekundaer);cursor:pointer;transition:.2s}
.input-block .pill:hover{border-color:var(--text-dunkel)}
.input-block .pill.aktiv{background:var(--text-dunkel);color:var(--bg-warm);border-color:var(--text-dunkel)}

/* Optional-Bereich */
.optional-toggle{font-size:11px;color:var(--text-grau);font-style:italic;text-align:center;margin:14px 0;cursor:pointer;user-select:none;transition:.2s}
.optional-toggle:hover{color:var(--text-dunkel)}
.optional-bereich{overflow:hidden;max-height:0;transition:max-height .4s ease}
.optional-bereich.offen{max-height:600px}

.quiz-cta-wrap{margin-top:18px}
.quiz-cta-wrap .btn-primary{width:100%;display:block}

/* ============================================
   PROFILSEITE (aus Analyseseite v12)
   ============================================ */
.user-summary{display:flex;justify-content:center;flex-wrap:wrap;gap:6px;margin-top:18px}
.summary-chip{font-size:11.5px;color:var(--grau-sekundaer);background:#FFFFFF;border:0.5px solid var(--border);padding:5px 12px;border-radius:99px}
.summary-chip.sep{border:none;background:transparent;padding:5px 0;color:var(--text-grau)}

.status-hero{padding:40px;border-bottom:0.5px solid var(--border);background:var(--bg-warm)}
.hero-card{background:#FFFFFF;border:0.5px solid var(--border);border-radius:16px;padding:24px 28px 20px;position:relative;overflow:hidden}
.hero-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,#9A4030 0%,#7A5118 50%,#5C7027 100%)}
.hero-main{display:grid;grid-template-columns:185px 1fr;gap:36px;align-items:center}
.hero-main .figure-wrap{width:auto;height:auto}
.hero-main .figure-wrap svg{width:175px;height:auto}

.bars-list{display:flex;flex-direction:column;gap:16px;min-width:0;padding:4px 0}
.bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;gap:8px}
.bar-label-wrap{display:flex;align-items:center;gap:6px;min-width:0;flex:1}
.bar-label{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-pill{font-size:8px;letter-spacing:.04em;text-transform:uppercase;font-weight:500;padding:2px 5px;border-radius:3px;line-height:1.3;white-space:nowrap;flex-shrink:0}
.bar-pill.amber{background:#FBF2DE;color:#7A4210}
.bar-pill.olive{background:#EEF0E6;color:#2E3A17}
.bar-pill.lila{background:#EDEBF8;color:#342E8A}
.bar-status{font-size:8px;letter-spacing:.04em;text-transform:uppercase;font-weight:600;padding:3px 6px;border-radius:4px;white-space:nowrap;flex-shrink:0}
.bar-status.prioritaet{background:#F5DDD8;color:#6B2B20}
.bar-status.ergaenzung{background:#F3E5C7;color:#573912}
.bar-status.solide{background:#E5EBD5;color:#3F4D1B}
.bar-track{height:5px;background:var(--border);border-radius:99px;overflow:hidden}
.bar-fill{height:100%;border-radius:99px;transition:width .5s ease}
.bar-fill.prioritaet{background:#9A4030}
.bar-fill.ergaenzung{background:#7A5118}
.bar-fill.solide{background:#5C7027}

.score-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:18px;padding-top:16px;border-top:0.5px solid var(--border);flex-wrap:wrap}
.score-badge{display:inline-flex;align-items:baseline;gap:10px;background:var(--text-dunkel);color:var(--bg-warm);padding:8px 18px;border-radius:10px;flex-shrink:0}
.score-label{font-size:9px;text-transform:uppercase;letter-spacing:.16em;color:var(--olive-light);font-weight:500}
.score-value{font-family:var(--font-display);font-size:22px;font-weight:500;line-height:1;letter-spacing:-0.01em}
.score-hint{font-size:11px;color:var(--text-grau);font-style:italic;line-height:1.4;flex:1;text-align:right}

.themes-sub{font-size:13px;color:var(--text-grau);margin-bottom:32px;font-style:italic;text-align:center}
.theme-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.theme-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.theme-dot.prioritaet{background:#9A4030}
.theme-dot.ergaenzung{background:#7A5118}
.theme-dot.solide{background:#5C7027}
.theme.prioritaet::before{background:#9A4030}
.theme.ergaenzung::before{background:#7A5118}
.theme.solide::before{background:#5C7027}
.theme-fakt{font-size:12px;color:var(--grau-sekundaer);background:var(--bg-block);border-radius:8px;padding:10px 14px;margin-bottom:10px;line-height:1.6}
.theme-fakt b{color:var(--text-dunkel)}
.theme-wirkstoffe{font-size:12px;color:var(--olive-dark);font-weight:500;margin-top:10px}

@media (max-width:680px){
  .quiz-stage{grid-template-columns:1fr;padding:0 20px 32px;gap:0;scroll-margin-top:65px}
  .figure-sticky{position:sticky;top:var(--header-h,63px);margin-top:-1px;border-bottom:0.5px solid var(--border);padding:11px 20px 10px;margin-bottom:20px;margin-left:-20px;margin-right:-20px;flex-direction:row;align-items:center;justify-content:center;gap:16px;z-index:10;background:var(--bg-warm)!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}
  .figure-wrap{width:54px;height:108px}
  .figure-wrap svg{width:54px}
  .figure-status{font-size:10px;text-align:left;max-width:160px;line-height:1.4}
  .figure-progress{width:60px;margin-top:0;flex-shrink:0}
  .goal-icon{height:46px}
  .goal-name{font-size:12px}
  .goal-sub{display:none}
  .hero-main{grid-template-columns:1fr;text-align:center}
  .hero-main .figure-wrap{justify-content:center}
  .score-footer{flex-direction:column;align-items:stretch;gap:8px}
  .score-hint{text-align:left}
}

/* ============================================
   ERGEBNISSEITE v6: Sektionen + aufklappbare Wirkstoff-Kacheln
   ============================================ */
.sektion-header{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.sektion-badge{font-size:9px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;padding:4px 10px;border-radius:5px}
.sektion-badge.essentiell{background:#EEF0E6;color:#3B4820}
.sektion-badge.ergaenzung{background:#F0EEE8;color:#6F6A62}
.sektion-label{font-family:var(--font-display);font-size:16px;font-weight:500;color:var(--text-dunkel)}
.sektion-counter{font-size:11px;color:var(--text-grau);font-style:italic;margin-left:auto}

.supp-liste{display:flex;flex-direction:column;gap:8px}
.supp{background:#FFFFFF;border:0.5px solid var(--border);border-radius:12px;position:relative;overflow:hidden;cursor:pointer;transition:.2s}
.supp:hover{box-shadow:0 2px 12px rgba(0,0,0,0.04)}
.supp::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--zielfarbe-1,#6B7A3F)}
.supp.zwei-ziele::before{background:linear-gradient(180deg,var(--zielfarbe-1) 0%,var(--zielfarbe-1) 50%,var(--zielfarbe-2) 50%,var(--zielfarbe-2) 100%)}
.supp-kopf{display:flex;align-items:center;gap:12px;padding:16px 20px 16px 24px;flex-wrap:wrap}
.supp-name{font-family:var(--font-display);font-size:16px;font-weight:500;color:var(--text-dunkel)}
.ziel-pill{font-size:8px;letter-spacing:.04em;text-transform:uppercase;font-weight:500;padding:2px 6px;border-radius:3px;white-space:nowrap}
.ziel-pill.amber{background:#FBF2DE;color:#7A4210}
.ziel-pill.olive{background:#EEF0E6;color:#2E3A17}
.ziel-pill.lila{background:#EDEBF8;color:#342E8A}
.supp-tags{font-size:11px;color:var(--text-grau);flex-basis:100%;margin-top:2px}
.supp-meta{display:flex;gap:14px;font-size:11px;color:var(--grau-sekundaer);margin-left:auto;white-space:nowrap;align-items:center}
.supp-pfeil{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--bg-block);color:var(--olive-dark);font-size:12px;transition:transform .25s,background .2s}
.supp-kopf:hover{background:rgba(107,122,63,0.035)}
.supp-kopf:hover .supp-pfeil{background:var(--olive-primary);color:#fff}
.supp.offen .supp-pfeil{transform:rotate(180deg)}
.supp-detail{max-height:0;overflow:hidden;transition:max-height .35s ease}
.supp.offen .supp-detail{max-height:600px}
.supp-detail-inner{padding:0 20px 18px 24px;border-top:0.5px solid var(--border);margin-top:0;padding-top:14px}
.supp-text{font-size:13px;color:var(--grau-sekundaer);line-height:1.65;margin-bottom:12px}
.supp-bloecke{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.supp-block{background:var(--bg-block);border-radius:8px;padding:10px 14px}
.supp-block-label{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--olive-dark);font-weight:600;margin-bottom:4px}
.supp-block-text{font-size:12px;color:var(--grau-sekundaer);line-height:1.5}
.warn-box{background:#FBF6E3;border-left:3px solid var(--amber);border-radius:8px;padding:10px 14px;font-size:12px;color:#573912;line-height:1.55;margin-bottom:12px}
.supp-produktlink{font-size:13px;color:var(--olive-dark);font-weight:500;text-decoration:none}
.supp-produktlink:hover{color:var(--text-dunkel)}

.cta-wrap-ende{text-align:center;margin:40px 0 32px}
.cta-label-klein{font-family:var(--font-display);font-size:16px;font-style:italic;color:var(--grau-sekundaer);margin-bottom:14px}
.disclaimer-box{background:#FBF6E3;border:0.5px solid #EADFC0;border-radius:10px;padding:16px 20px;font-size:12px;color:#573912;line-height:1.6}
.disclaimer-box b{display:block;margin-bottom:4px;color:#3d2a0e}

/* ============================================
   PRODUKTSEITE v6: Bundle-Karte + Einzelprodukt-Karten
   ============================================ */
.bundle-karte{background:#FFFFFF;border:0.5px solid var(--border);border-radius:16px;padding:26px 28px;position:relative;overflow:hidden;margin-top:8px}
.bundle-karte::before{content:'';position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg,var(--amber) 0%,var(--amber) 33%,var(--olive-dark) 33%,var(--olive-dark) 66%,var(--lila) 66%,var(--lila) 100%)}
.bundle-badge{display:inline-block;font-size:9px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;padding:4px 10px;border-radius:5px;background:#EEF0E6;color:#3B4820;margin-bottom:12px}
.bundle-title{font-family:var(--font-display);font-size:22px;font-weight:500;color:var(--text-dunkel);margin-bottom:8px}
.bundle-title em{font-style:italic}
.bundle-desc{font-size:13px;color:var(--grau-sekundaer);line-height:1.6;margin-bottom:16px;max-width:480px}
.bundle-preis-zeile{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:4px}
.bundle-preis{font-family:var(--font-display);font-size:32px;font-weight:500;color:var(--text-dunkel)}
.bundle-vergleich{font-size:12px;color:var(--text-grau);text-decoration:line-through}
.spar-pill{font-size:10px;font-weight:600;background:#E5EBD5;color:#3F4D1B;padding:4px 10px;border-radius:99px}
.bundle-monat{font-size:11px;color:var(--text-grau);font-style:italic;margin-bottom:16px}
.bundle-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}
.bundle-chip{font-size:10.5px;background:var(--bg-warm);border:0.5px solid var(--border);padding:5px 11px;border-radius:99px;color:var(--grau-sekundaer)}
.bundle-cta-zeile{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.bundle-hinweis{font-size:11px;color:var(--text-grau);font-style:italic}

.produkt-specs{display:flex;gap:16px;font-size:11.5px;color:var(--grau-sekundaer);margin:10px 0;flex-wrap:wrap}
.produkt-specs b{color:var(--text-dunkel);font-weight:500}
.warum-box{background:var(--bg-block);border-left:3px solid var(--olive-primary);border-radius:8px;padding:10px 14px;font-size:12.5px;color:var(--grau-sekundaer);line-height:1.6;margin:12px 0}
.warum-box b{color:var(--text-dunkel)}
.produkt-fuss{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-top:14px}
.produkt-partner{font-size:11px;color:var(--text-grau)}
.norsan-code{display:inline-flex;align-items:center;gap:8px;background:#EEF0E6;border:1px dashed var(--olive-dark);border-radius:8px;padding:6px 12px;font-size:12px;color:#2E3A17;font-weight:600;cursor:pointer;margin:8px 0}
.norsan-code:hover{background:#E2E7D2}

/* Für-wen Exit-Box (Startseite) */
.exit-box{background:var(--bg-block);border:0.5px solid var(--border);border-left:4px solid var(--amber);border-radius:12px;padding:20px 24px;margin-top:10px}
.exit-box-title{font-family:var(--font-display);font-size:16px;font-weight:500;color:var(--text-dunkel);margin-bottom:8px}
.exit-box-text{font-size:13px;color:var(--grau-sekundaer);line-height:1.65}

@media (max-width:680px){
  .supp-meta{margin-left:0;flex-basis:100%}
  .supp-bloecke{grid-template-columns:1fr}
  .bundle-preis{font-size:26px}
}

/* Exit-Box: sanftes Einblenden */
.exit-box{max-height:0;opacity:0;transform:translateY(-6px);padding-top:0;padding-bottom:0;margin-top:0;border-width:0;overflow:hidden;transition:max-height .45s ease,opacity .4s ease .08s,transform .4s ease .08s,padding .35s ease,margin .35s ease}
.exit-box.offen{max-height:280px;opacity:1;transform:translateY(0);padding:20px 24px;margin-top:10px;border-width:0.5px;border-left-width:4px}

/* Status-Text unter der Figur: Abstand + sauberer Umbruch */
.figure-status{margin-top:10px;max-width:180px}

/* CTA-Validierungshinweis */
.cta-hinweis{font-size:12px;color:#9A4030;text-align:center;margin-top:10px;opacity:0;transition:opacity .3s;min-height:16px}
.cta-hinweis.sichtbar{opacity:1}


/* Hero-Hierarchie: Claim zentral mit Strich-Ästhetik, Headline untergeordnet */
.hero-claim{font-family:var(--font-display);font-size:40px;font-weight:500;color:var(--text-dunkel);line-height:1.15;letter-spacing:-0.02em;margin-bottom:14px;display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
.hero-claim em{font-style:italic;color:var(--olive-dark)}
.hero-claim::before,.hero-claim::after{content:'';display:inline-block;width:40px;height:0.5px;background:var(--olive-primary);opacity:0.5;flex-shrink:0}
.hero-headline-sub{font-family:var(--font-display);font-size:21px;font-weight:400;color:var(--grau-sekundaer);line-height:1.3;margin-bottom:18px;letter-spacing:-0.01em}
.hero-headline-sub em{font-style:italic}
/* Fortschritt mit Prozentzahl */
.progress-prozent{font-family:var(--font-display);font-size:15px;color:var(--olive-dark);font-style:italic;margin-top:8px;text-align:center}

.themen-toggle{display:block;margin:8px auto 0;background:none;border:0.5px solid var(--olive-primary);color:var(--olive-dark);font-family:Inter,sans-serif;font-size:12.5px;font-weight:500;letter-spacing:.02em;padding:9px 20px;border-radius:99px;cursor:pointer;transition:background .2s ease,color .2s ease}
.themen-toggle:hover{background:var(--olive-primary);color:#fff}
