/* COI Vorbereitungs-System - Design System (Engine) */
:root{
  --bg:#0a0a0b; --surface:#141417; --surface2:#1c1c20; --surface3:#232328;
  --gold:#af8144; --gold-soft:#c9a463; --teal:#05828e;
  --text:#f5f5f4; --muted:#a1a1aa; --line:#2a2a30;
  --tuerkis:#75cfcc; --mittel:#c9a463; --violett:#7c4dca;
  --on-gold:#1a1206;
  --r:16px;
}
html.light{
  --bg:#ffffff; --surface:#f9f7f4; --surface2:#f1ede7; --surface3:#eae4db;
  --text:#3e3e3e; --muted:#5a5a5a; --line:#e0e0e0;
  --tuerkis:#0a8f8a; --mittel:#9a6c2c; --violett:#6b3fb0;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%}
h1,h2,h3{font-family:'Space Grotesk',sans-serif;font-weight:700;line-height:1.15;letter-spacing:-0.01em}
a{color:var(--teal)}

.shell{max-width:760px;margin:0 auto;padding:clamp(18px,4vw,32px) clamp(16px,5vw,24px) 100px}

/* Topbar */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:22px}
.brand{display:flex;align-items:center;gap:11px;min-width:0}
.brand .dot{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--teal));flex:none;box-shadow:0 0 18px -5px rgba(5,130,142,.55)}
.brand .t{display:flex;flex-direction:column;line-height:1.1;min-width:0}
.brand .name{font-family:'Space Grotesk';font-weight:700;letter-spacing:.03em;font-size:13px;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brand .claim{font-size:11px;color:var(--muted);letter-spacing:.04em}
.toggle{flex:none;display:flex;align-items:center;gap:7px;min-height:38px;background:var(--surface);border:1px solid var(--line);color:var(--muted);border-radius:99px;padding:7px 13px;font-family:'Space Grotesk';font-size:12px;cursor:pointer;transition:.15s}
.toggle:hover{border-color:var(--gold);color:var(--text)}
.toggle:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.toggle .ic{width:8px;height:8px;border-radius:50%;background:var(--gold)}

/* Phasen-Leiste (Dashboard) */
.phases{display:flex;gap:8px;margin-bottom:8px}
.phase{flex:1;display:flex;flex-direction:column;gap:6px}
.phase .bar{height:5px;border-radius:99px;background:var(--surface2);overflow:hidden}
.phase .bar > i{display:block;height:100%;width:0;border-radius:99px;background:var(--gold);transition:width .4s}
.phase.tuerkis .bar > i{background:var(--tuerkis)} .phase.gold .bar > i{background:var(--mittel)} .phase.violett .bar > i{background:var(--violett)}
.phase .lbl{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.phase.active .lbl{color:var(--gold);font-weight:600}
.meta{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:14px 0 18px}

/* Karte */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:clamp(22px,5vw,32px) clamp(18px,4.5vw,28px)}
.eyebrow{color:var(--gold);font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;margin-bottom:12px}
.card h2{font-size:clamp(1.35rem,1.1rem+1.2vw,1.7rem);margin-bottom:12px;text-wrap:balance}
.lead{color:var(--muted);font-size:clamp(0.95rem,0.9rem+0.4vw,1.05rem);margin-bottom:8px;text-wrap:pretty}

/* Felder */
.q{display:block;font-family:'Space Grotesk';font-weight:500;font-size:clamp(1.05rem,1rem+0.5vw,1.2rem);margin:22px 0 6px;text-wrap:balance}
.q .sub{display:block;font-family:'Inter';font-weight:400;font-size:14px;color:var(--muted);margin-top:5px;line-height:1.5}
textarea,input[type=text],input[type=email],input[type=password]{width:100%;background:var(--surface2);border:1px solid var(--line);border-radius:12px;color:var(--text);font-family:'Inter';font-size:16px;padding:14px;resize:vertical}
textarea{min-height:104px}
textarea:focus,input:focus{outline:none;border-color:var(--gold)}
.count{font-size:12px;color:var(--muted);margin-top:6px;text-align:right}

/* Spiegel (KI) */
.spiegel{margin-top:14px;padding:16px 18px;border-left:3px solid var(--teal);background:color-mix(in srgb,var(--teal) 10%,transparent);border-radius:0 12px 12px 0;font-size:15px}
.spiegel .who{font-family:'Space Grotesk';font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);margin-bottom:6px}
.spiegel.parken{border-left-color:var(--violett);background:color-mix(in srgb,var(--violett) 10%,transparent)}
.spiegel.parken .who{color:var(--violett)}
.spiegel button{margin-top:10px}
.thinking{color:var(--muted);font-size:14px;font-style:italic}

/* Skala */
.scale{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.scale button{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--surface2);color:var(--text);cursor:pointer;font-family:'Space Grotesk';font-size:14px}
.scale button.sel{border-color:var(--gold);background:color-mix(in srgb,var(--gold) 16%,transparent)}

/* Vorschläge / Chips */
.choices{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.choice{min-height:48px;background:var(--surface2);border:1px solid var(--line);border-radius:12px;color:var(--text);padding:14px 16px;cursor:pointer;text-align:left;font-size:15px;transition:.15s}
.choice:hover{border-color:var(--gold-soft)}
.choice.sel{border-color:var(--gold);background:color-mix(in srgb,var(--gold) 14%,transparent)}

/* Canvas-Raster */
.grid{display:grid;gap:12px;margin-top:14px}
.cell{background:var(--surface2);border:1px solid var(--line);border-radius:12px;padding:14px}
.cell label{display:block;font-family:'Space Grotesk';font-weight:500;font-size:14px;margin-bottom:6px;color:var(--gold)}
.cell .hint{font-size:12.5px;color:var(--muted);margin-bottom:8px}
.cell textarea{min-height:70px;font-size:15px}

/* Tech Setup */
.steps{display:flex;flex-direction:column;gap:10px;margin:14px 0}
.step{display:flex;gap:12px;align-items:flex-start;background:var(--surface2);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.step .n{width:24px;height:24px;border-radius:50%;background:var(--surface3);color:var(--gold);font-family:'Space Grotesk';font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex:none}
.step .body{font-size:14.5px}
.step .body b{font-family:'Space Grotesk'}
.verify-row{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.verify-row input{flex:1;min-width:200px}
.status-line{display:flex;align-items:center;gap:9px;margin-top:12px;font-size:14px}
.status-line .pip{width:11px;height:11px;border-radius:50%;flex:none;background:var(--muted)}
.status-line.tuerkis .pip{background:var(--tuerkis)} .status-line.gold .pip{background:var(--mittel)} .status-line.violett .pip{background:var(--violett)}

/* Readiness Ringe */
.rings{display:flex;gap:18px;flex-wrap:wrap;justify-content:center;margin:8px 0}
.ring{text-align:center}
.ring svg{display:block;margin:0 auto}
.ring .cap{font-size:12px;color:var(--muted);margin-top:6px;font-family:'Space Grotesk';letter-spacing:.04em}

/* Dossier */
.dossier dt{color:var(--gold);font-size:12px;letter-spacing:.08em;text-transform:uppercase;margin-top:18px;font-weight:600}
.dossier dd{margin-top:4px;font-size:15px;white-space:pre-wrap}
.offene{margin-top:18px;padding:16px;border:1px solid var(--violett);border-radius:12px}
.offene h3{font-size:15px;color:var(--violett);margin-bottom:8px}
.offene li{margin-left:18px;font-size:14.5px;color:var(--muted)}
.consent{display:flex;gap:12px;align-items:flex-start;margin:20px 0;padding:16px;background:var(--surface2);border-radius:12px}
.consent input{margin-top:3px;width:18px;height:18px;flex:none;accent-color:var(--gold)}
.consent label{font-size:14px;color:var(--muted)}

/* Buttons / Nav */
.btn{min-height:44px;font-family:'Space Grotesk';font-weight:500;font-size:15px;border-radius:12px;padding:12px 24px;cursor:pointer;border:1px solid var(--line);background:transparent;color:var(--text);transition:.15s}
.btn:hover{border-color:var(--gold)}
.btn:focus-visible,.btn-primary:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.btn[disabled]{opacity:.4;cursor:not-allowed}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold-soft));border:none;color:var(--on-gold);font-weight:700;box-shadow:0 10px 30px -14px rgba(175,129,68,.6)}
.btn-primary:hover{filter:brightness(1.05)}
.nav{display:flex;justify-content:space-between;gap:12px;margin-top:28px}
.center{text-align:center}
.foot{margin-top:22px;text-align:center;color:var(--muted);font-size:12px}
@media print{body{background:#fff;color:#000}.no-print{display:none}.card{border:none}}

/* ---- Responsive und Premium Feinschliff (Review) ---- */
body{background:var(--bg) radial-gradient(70% 45% at 50% -5%, color-mix(in srgb, var(--gold) 8%, transparent), transparent 70%) no-repeat fixed}
html.light body{background:var(--bg)}
html.light{ --gold:#a06f2e; }
.card{box-shadow:0 24px 60px -34px rgba(0,0,0,.6)}
html.light .card{box-shadow:0 18px 50px -34px rgba(0,0,0,.16)}
.btn-primary{transition:transform .16s, box-shadow .16s, filter .16s}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 16px 38px -16px rgba(175,129,68,.7)}
.phase.active .bar > i{box-shadow:0 0 10px -2px var(--gold)}
textarea:focus-visible,input:focus-visible,.scale button:focus-visible,.choice:focus-visible{outline:2px solid var(--teal);outline-offset:2px}

/* Meta-Zeile: Position, Speichern, Parken */
.meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.saved{font-size:11px;color:var(--tuerkis);opacity:0;transition:opacity .25s;text-transform:none;letter-spacing:0}
.saved.show{opacity:1}
.parkn{font-size:11px;color:var(--violett);text-transform:none;letter-spacing:.02em;margin-left:auto}
.wiedereinstieg{background:color-mix(in srgb,var(--teal) 12%,transparent);border:1px solid color-mix(in srgb,var(--teal) 30%,transparent);border-radius:12px;padding:12px 14px;margin-bottom:14px;font-size:14px;display:flex;justify-content:space-between;align-items:center;gap:10px}
.wiedereinstieg button{background:none;border:none;color:var(--teal);cursor:pointer;font-family:'Space Grotesk';font-size:13px}
.opt-hint{display:block;font-size:12.5px;color:var(--muted);margin-top:6px}

/* Phasen klickbar */
.phase{cursor:pointer}
.phases{position:sticky;top:0;z-index:20;background:var(--bg);padding-top:8px}

/* Skala als Raster, 44px Touch */
.scale{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.scale button{width:auto;height:44px}
@media(min-width:560px){ .scale{display:flex} .scale button{width:44px} }

/* Canvas Raster responsiv: einspaltig mobil, zweispaltig ab Tablet */
.grid{grid-template-columns:1fr}
@media(min-width:640px){ .grid--2{grid-template-columns:1fr 1fr} }

/* Verify-Row mobil: Eingabe und Knopf untereinander */
@media(max-width:560px){ .verify-row{flex-direction:column} .verify-row input{min-width:0;width:100%} .verify-row .btn{width:100%} }

.toggle{min-height:40px}

/* Phasenleiste mobil schmaler */
@media(max-width:520px){
  .phases{gap:5px}
  .phase .lbl{font-size:9px;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center}
}

/* Navigation als feste Bodenleiste in der Daumenzone (mobil) */
@media(max-width:640px){
  .nav-main{position:fixed;left:0;right:0;bottom:0;z-index:30;margin:0;padding:12px 16px calc(12px + env(safe-area-inset-bottom));background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:blur(8px);border-top:1px solid var(--line)}
  .shell{padding-bottom:120px}
}
@media(prefers-reduced-motion:reduce){ *{transition:none!important;animation:none!important} }
