/* CCA-F Study — mobile-first static site */
:root{
  --bg:#faf9f7; --surface:#ffffff; --surface-2:#f3f0ea; --text:#1f1d1b; --muted:#6b645c;
  --border:#e7e2db; --accent:#c2603a; --accent-weak:#f4e4dc; --accent-ink:#8f3f22;
  --ok:#2f7d57; --ok-bg:#e4f3ea; --bad:#c0392b; --bad-bg:#f7e3e1;
  --hi:#c0392b; --med:#b07a18; --lo:#2f7d57;
  --shadow:0 1px 2px rgba(0,0,0,.05),0 4px 16px rgba(0,0,0,.04);
  --radius:14px; --maxw:840px;
}
:root[data-theme="dark"]{
  --bg:#191715; --surface:#231f1d; --surface-2:#2c2724; --text:#ece8e3; --muted:#a79f97;
  --border:#37312c; --accent:#e0875f; --accent-weak:#3a2b23; --accent-ink:#f0b393;
  --ok:#5bbd8a; --ok-bg:#1e3329; --bad:#e8806f; --bad-bg:#3a2522;
  --hi:#e8806f; --med:#e0b257; --lo:#5bbd8a;
  --shadow:0 1px 2px rgba(0,0,0,.3),0 6px 22px rgba(0,0,0,.25);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--text);
  font:16px/1.62 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;overscroll-behavior-y:none;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 16px;width:100%}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.86em;
  background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:.05em .35em;word-break:break-word}
hr{border:0;border-top:1px solid var(--border);margin:1.6em 0}

/* top bar + tabs */
.topbar{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 86%,transparent);
  backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--border)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;min-height:54px}
.brand{font-weight:700;letter-spacing:-.01em}
.brand span{color:var(--muted);font-weight:500}
.iconbtn{background:var(--surface);border:1px solid var(--border);color:var(--text);
  width:38px;height:38px;border-radius:10px;font-size:17px;cursor:pointer;display:grid;place-items:center}
.iconbtn:active{transform:scale(.94)}
.tabs{overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;border-top:0}
.tabs::-webkit-scrollbar{display:none}
.tabs .wrap{display:flex;gap:4px;padding:6px 12px}
.tab{flex:0 0 auto;padding:8px 14px;border-radius:999px;color:var(--muted);font-weight:600;font-size:14px;
  white-space:nowrap;cursor:pointer;border:1px solid transparent}
.tab.active{background:var(--accent-weak);color:var(--accent-ink);border-color:var(--border)}

main{padding:18px 0 80px;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

h1,h2,h3,h4{line-height:1.25;letter-spacing:-.015em}
h1{font-size:1.7rem;margin:.2em 0 .4em}
h2{font-size:1.28rem;margin:1.4em 0 .5em}
h3{font-size:1.08rem;margin:1.2em 0 .4em}
h4{font-size:.98rem;margin:1em 0 .3em;color:var(--muted)}

/* hero / overview */
.hero{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow);margin-bottom:18px}
.hero .eyebrow{color:var(--accent-ink);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.06em}
.hero h1{margin:.2em 0 .1em}
.hero p{color:var(--muted);margin:.2em 0 0}
.stats{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.stat{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:8px 12px;flex:1 0 auto;min-width:76px;text-align:center}
.stat b{display:block;font-size:1.25rem}
.stat span{font-size:12px;color:var(--muted)}
.cta{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.btn{display:inline-block;background:var(--accent);color:#fff;border:0;border-radius:10px;padding:11px 16px;
  font-weight:600;font-size:14px;cursor:pointer;text-align:center;flex:1 0 auto}
.btn.ghost{background:var(--surface);color:var(--text);border:1px solid var(--border)}
.btn:active{transform:scale(.98)}
.btn:hover{text-decoration:none}

/* generic prose */
.note{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 18px 6px;box-shadow:var(--shadow)}
.note-body :first-child{margin-top:0}
.note-body ul,.note-body ol{padding-left:1.3em}
.note-body li{margin:.25em 0}
.note-body li.task{list-style:none;margin-left:-1.1em}
.note-body li.task input{margin-right:.5em;transform:translateY(1px)}
.note-body blockquote{margin:1em 0;padding:.4em 0 .4em 1em;border-left:3px solid var(--border);color:var(--muted)}
.tablewrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:1em 0}
table{border-collapse:collapse;width:100%;font-size:14px;min-width:380px}
th,td{border:1px solid var(--border);padding:8px 10px;text-align:left;vertical-align:top}
th{background:var(--surface-2);font-weight:700}

/* callouts */
.callout{border:1px solid var(--border);border-left-width:4px;border-radius:10px;padding:12px 14px;margin:1em 0;background:var(--surface-2)}
.callout .co-title{font-weight:700;margin-bottom:.3em}
.callout .co-body :first-child{margin-top:0}
.callout .co-body :last-child{margin-bottom:0}
.co-warning{border-left-color:var(--med)} .co-success{border-left-color:var(--ok)}
.co-note,.co-info{border-left-color:var(--accent)} .co-question{border-left-color:var(--accent)}
details.callout summary{font-weight:700;cursor:pointer}
details.callout[open] summary{margin-bottom:.4em}

/* domain index */
.grid{display:grid;gap:12px;grid-template-columns:1fr}
@media(min-width:620px){.grid{grid-template-columns:1fr 1fr}}
.dcard{display:block;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:14px 16px;box-shadow:var(--shadow);color:inherit}
.dcard:hover{text-decoration:none;border-color:var(--accent)}
.dcard .num{color:var(--muted);font-weight:700;font-size:13px}
.dcard h3{margin:.15em 0 .5em;font-size:1.05rem}
.badges{display:flex;gap:6px;flex-wrap:wrap}
.badge{font-size:11.5px;font-weight:700;padding:3px 8px;border-radius:999px;border:1px solid var(--border);background:var(--surface-2)}
.b-high{color:var(--hi)} .b-medium{color:var(--med)} .b-low{color:var(--lo)}
.b-hoch{color:var(--hi)} .b-mittel{color:var(--med)} .b-niedrig{color:var(--lo)}
.b-core{color:var(--accent-ink);background:var(--accent-weak)} .b-stretch{color:var(--muted)}
.tracktitle{margin:1.6em 0 .5em;font-size:1.05rem;color:var(--muted);font-weight:700}
.backlink{display:inline-block;margin-bottom:10px;font-weight:600;font-size:14px}

/* controls (filters/search) */
.controls{position:sticky;top:108px;z-index:10;background:var(--bg);padding:6px 0 10px;margin-bottom:6px}
.chips{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}
.chips::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;padding:7px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);
  color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}
.chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.searchrow{display:flex;gap:8px;margin-top:8px}
.search{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text);
  padding:10px 12px;font-size:15px}
.meter{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:2px 0 12px;color:var(--muted);font-size:13px;font-weight:600}
.bar{flex:1;height:8px;min-width:120px;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;overflow:hidden}
.bar i{display:block;height:100%;background:var(--accent);width:0}
.linkbtn{background:none;border:0;color:var(--accent);font-weight:600;cursor:pointer;padding:0;font-size:13px}

/* flashcards */
.flash{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);
  margin-bottom:12px;overflow:hidden}
.flash .face{padding:15px 16px;cursor:pointer}
.flash .qrow{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.flash .q{font-weight:600}
.flash .deck{color:var(--muted);font-size:12px;font-weight:600;margin-bottom:6px}
.flash .ans{max-height:0;opacity:0;overflow:hidden;transition:max-height .3s ease,opacity .25s ease,padding .3s ease;
  padding:0 16px;border-top:1px solid transparent;color:var(--text)}
.flash.open .ans{max-height:1400px;opacity:1;padding:14px 16px;border-top:1px solid var(--border);background:var(--surface-2)}
.flash .ans p{margin:.2em 0}
.flash .tap{color:var(--muted);font-size:12px;margin-top:8px}
.star{background:none;border:0;font-size:18px;cursor:pointer;line-height:1;color:var(--muted);flex:0 0 auto}
.star.on{color:var(--accent)}
.known .face .q{opacity:.55}

/* quiz */
.q{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:16px;margin-bottom:14px}
.q .tag{display:inline-block;font-size:11.5px;font-weight:700;color:var(--accent-ink);background:var(--accent-weak);
  border-radius:999px;padding:3px 9px;margin-bottom:8px}
.q .stem{font-weight:500}
.q .stem p{margin:.4em 0}
.opts{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.opt{display:flex;gap:10px;text-align:left;width:100%;background:var(--surface);border:1px solid var(--border);
  border-radius:10px;padding:11px 13px;color:var(--text);font:inherit;font-size:15px;cursor:pointer}
.opt:hover{border-color:var(--accent)}
.opt .l{font-weight:700;color:var(--muted);flex:0 0 auto}
.opt.correct{background:var(--ok-bg);border-color:var(--ok)} .opt.correct .l{color:var(--ok)}
.opt.wrong{background:var(--bad-bg);border-color:var(--bad)} .opt.wrong .l{color:var(--bad)}
.opt.dim{opacity:.55}
.opt[disabled]{cursor:default}
.explain{margin-top:12px;padding:12px 14px;border-radius:10px;background:var(--surface-2);border:1px solid var(--border);
  font-size:14.5px;display:none}
.explain.show{display:block;animation:fade .2s ease}
.explain b{color:var(--accent-ink)}
.empty{color:var(--muted);text-align:center;padding:40px 0}
.foot{color:var(--muted);font-size:12.5px;text-align:center;padding:24px 0 8px}
