/* FÜCHSE · Sternenpfad — tema oscuro único (handoff desde fuechse.pen). WCAG AA. */

@font-face{font-family:"Baloo 2";src:url("/static/fonts/baloo2.woff2") format("woff2");font-weight:400 800;font-display:swap}
@font-face{font-family:"Plus Jakarta Sans";src:url("/static/fonts/jakarta.woff2") format("woff2");font-weight:400 800;font-display:swap}
@font-face{font-family:"JetBrains Mono";src:url("/static/fonts/jbmono.woff2") format("woff2");font-weight:400 700;font-display:swap}

:root{
  --bg:#0E1320; --surface:#161D2E; --surface-2:#1F2740; --border:#2C3550; --scrim:#060912AA;
  --text:#EAF0FA; --text-dim:#9AA6BF; --text-faint:#6B7793;
  --fox:#FF8A3D; --fox-strong:#F2702A; --fox-soft:#FF8A3D24; --on-accent:#0E1320;
  --python:#5BC8FF; --egoi:#B79CFF; --cpp:#4DD9B0; --plus:#9BE85B;
  --success:#45D483; --warning:#FFC857; --danger:#FF7A85;
  --gold:#FFC94D; --silver:#CBD5E1; --bronze:#E08A3C;
  --radius-sm:8px; --radius-md:12px; --radius-lg:16px; --pill:999px;
  --akzent:var(--fox);
  --font-display:"Baloo 2",system-ui,sans-serif;
  --font-ui:"Plus Jakarta Sans",system-ui,-apple-system,sans-serif;
  --font-mono:"JetBrains Mono","Fira Code",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, #1a2336 0%, transparent 60%),
    var(--bg);
  color:var(--text);font-family:var(--font-ui);line-height:1.5;min-height:100vh;
}
code,pre,.editor,.output,.mono{font-family:var(--font-mono)}
h1,h2,h3,.brand,.world-title,.etappe-titel{font-family:var(--font-display)}
.dim{color:var(--text-dim)} .hidden{display:none!important}
a{color:var(--python);text-decoration:none}
::selection{background:var(--fox-soft)}

/* TOPBAR */
.topbar{display:flex;align-items:center;gap:16px;padding:14px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:rgba(14,19,32,.85);backdrop-filter:blur(8px);z-index:10}
.brand{font-weight:800;font-size:1.15rem;color:var(--fox);letter-spacing:-.01em}
.langs{margin-left:auto;text-transform:uppercase;font-size:.78rem;letter-spacing:.06em;display:flex;gap:2px}
.langs a{padding:4px 8px;border-radius:6px;color:var(--text-dim)}
.langs a:hover{color:var(--text);background:var(--surface-2)}
.link{background:none;border:none;color:var(--text-dim);cursor:pointer;font:inherit;padding:6px 8px;border-radius:6px}
.link:hover{color:var(--text);background:var(--surface-2)}
.app{max-width:560px;margin:0 auto;padding:24px 20px 96px}

/* HERO / SECTIONS */
.hero{padding:18px 0 18px 16px;border-left:3px solid var(--akzent);margin-bottom:24px}
.hero h1{font-size:1.7rem;font-weight:700;letter-spacing:-.02em}
.section{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);font-weight:700;margin:26px 0 12px}
.back{display:inline-block;margin-bottom:14px;color:var(--text-dim);font-size:1.1rem}

/* CARD / FORM */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}
.card.narrow{max-width:380px;margin:40px auto}
.stack{display:flex;flex-direction:column;gap:14px;margin-top:16px}
.stack label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--text-dim)}
input,textarea{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:12px 14px;border-radius:var(--radius-md);font:inherit;font-size:1rem}
input:focus,textarea:focus{outline:2px solid var(--fox);outline-offset:1px;border-color:var(--fox)}

/* BUTTONS — pill */
.btn{background:var(--fox);color:var(--on-accent);border:1px solid var(--fox);border-radius:var(--pill);padding:12px 22px;font-family:var(--font-display);font-weight:700;cursor:pointer;font-size:1rem;transition:transform .12s ease,filter .12s ease}
.btn:hover{filter:brightness(1.06)} .btn:active{transform:scale(.97)}
.btn:focus-visible{outline:2px solid var(--text);outline-offset:2px}
.btn.ghost{background:transparent;color:var(--text);border-color:var(--border);font-family:var(--font-ui);font-weight:600}
.btn.ghost:hover{border-color:var(--text-dim);background:var(--surface)}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0}

/* WORLDS */
.grid{display:flex;flex-direction:column;gap:14px}
.world-tile{display:flex;flex-direction:column;gap:10px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--akzent);border-radius:var(--radius-lg);padding:18px;color:var(--text);transition:transform .12s ease,border-color .12s}
.world-tile:hover{transform:translateY(-2px);border-color:var(--akzent)}
.world-lang{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--akzent)}
.world-title{font-weight:700;font-size:1.25rem}
.world-ctx{font-size:.82rem}

/* PATHMAP / STATIONS */
.pfad{display:flex;flex-direction:column;gap:22px}
.etappe-titel{font-size:1.05rem;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:10px}
.stationen{display:flex;flex-direction:column;gap:12px;padding-left:14px;border-left:2px dashed var(--border)}
.station{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;color:var(--text);font-weight:600;min-height:56px}
.station.aktiv{border-color:var(--fox);box-shadow:0 0 0 1px var(--fox),0 0 22px -4px var(--fox)}
.station.erledigt{border-color:rgba(69,212,131,.45)}
.station.gesperrt{color:var(--text-dim);opacity:.65}
.sterne{margin-left:auto;color:var(--gold);font-family:var(--font-mono);font-weight:700}
.level{font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;padding:3px 9px;border-radius:var(--pill);border:1px solid var(--border);font-weight:700}
.level.bronze{color:var(--bronze)} .level.silber{color:var(--silver)} .level.gold{color:var(--gold)}

/* AUFGABE / EDITOR */
.kat{font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;color:var(--fox);font-weight:700;background:var(--fox-soft);padding:4px 10px;border-radius:var(--pill);display:inline-block}
.frage{margin:10px 0;font-size:1rem}
.signal{background:var(--surface-2);border-left:3px solid var(--warning);padding:10px 14px;border-radius:var(--radius-md);margin:12px 0;font-size:.9rem;color:var(--warning)}
.editor{width:100%;min-height:200px;color:var(--python);background:#0B0F1A;border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;resize:vertical;margin-top:6px;font-size:.9rem;line-height:1.6}
.CodeMirror{border-radius:var(--radius-md);border:1px solid var(--border);height:auto}
.output{background:#0B0F1A;border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;min-height:44px;white-space:pre-wrap;margin-top:12px;color:var(--python)}
.feedback{padding:12px 16px;border-radius:var(--radius-md);margin-top:12px;font-weight:600;border-left:3px solid var(--border)}
.feedback.success{background:rgba(69,212,131,.08);border-left-color:var(--success);color:var(--success)}
.feedback.error{background:rgba(255,122,133,.07);border-left-color:var(--danger);color:var(--danger)}
.feedback.hint{background:rgba(255,200,87,.08);border-left-color:var(--warning);color:var(--warning)}
.solution{margin-top:12px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md)}
.solution pre{background:#0B0F1A;border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;white-space:pre-wrap;margin-top:4px}
.hint{color:var(--text-dim)}

/* BOTTOM NAV (mobile-native) */
.app{padding-bottom:96px}
.bottomnav{position:fixed;left:0;right:0;bottom:0;display:flex;justify-content:space-around;align-items:stretch;
  background:rgba(22,29,46,.92);backdrop-filter:blur(10px);border-top:1px solid var(--border);
  padding:6px 8px env(safe-area-inset-bottom,8px);z-index:20}
.bottomnav .navtab-form{display:flex;flex:1}
.navtab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  min-height:52px;padding:6px 4px;color:var(--text-dim);background:none;border:none;cursor:pointer;
  font-family:var(--font-ui);font-size:.7rem;font-weight:600;text-decoration:none;border-radius:var(--radius-md)}
.navtab svg{width:24px;height:24px}
.navtab.active{color:var(--fox)}
.navtab:focus-visible{outline:2px solid var(--fox);outline-offset:-2px}
.bottomnav{max-width:560px;margin:0 auto}

/* STATS */
.stat-summary{display:flex;gap:10px;margin:4px 0 8px}
.chip{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:var(--pill);padding:6px 14px;font-weight:700}
.catbars{display:flex;flex-direction:column;gap:14px}
.catbar{display:flex;flex-direction:column;gap:6px}
.catbar-top{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;font-weight:600}
.catbar.weak .catbar-name{color:var(--warning)}
.catbar-num{color:var(--text-dim);font-size:.8rem}
.track{height:8px;background:var(--surface-2);border-radius:var(--pill);overflow:hidden}
.track .fill{height:100%;background:var(--akzent);border-radius:var(--pill)}
.catbar .fill{background:var(--python)}
.catbar.weak .fill{background:var(--warning)}

/* ADMIN */
.admin-head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin:8px 0 20px}
.admin-head h1{font-size:1.6rem}
.admin-kids{display:flex;flex-direction:column;gap:16px}
.kid-card{display:flex;flex-direction:column;gap:10px}
.kid-top{display:flex;justify-content:space-between;align-items:center}
.kid-name{font-family:var(--font-display);font-weight:700;font-size:1.3rem;color:var(--text)}

/* MOTIVACIÓN */
.motiv-btn{margin-top:14px}
.motiv-line{margin-top:12px;background:var(--surface-2);border:1px solid var(--border);border-left:3px solid var(--fox);border-radius:var(--radius-md);padding:12px 16px;color:var(--text);font-family:var(--font-display);font-weight:600}

/* FOOTER + COOKIE NOTICE + LEGAL */
.sitefoot{text-align:center;color:var(--text-faint);font-size:.78rem;padding:28px 0 8px}
.sitefoot a{color:var(--text-dim)}
.cookie-notice{position:fixed;left:0;right:0;bottom:0;display:flex;gap:12px;align-items:center;justify-content:center;flex-wrap:wrap;background:var(--surface-2);border-top:1px solid var(--border);padding:12px 16px;z-index:30;font-size:.85rem;color:var(--text)}
.cookie-notice[hidden]{display:none}
.cookie-notice a{color:var(--python)}
.cookie-notice .btn{padding:8px 16px;font-size:.85rem}
.legal{line-height:1.7}
.legal p{margin-bottom:10px;color:var(--text)}
.legal a{color:var(--python)}
.legal code{background:var(--surface-2);padding:2px 6px;border-radius:6px;color:var(--text)}
.legal-list{margin:0 0 10px 18px;color:var(--text-dim)}
.legal-list li{margin-bottom:4px}

@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
@media (min-width:1024px){ .app{max-width:640px} }
