/* ===========================================================
   iPAS AI 應用規劃師 中級 備考站 — 視覺系統
   設計概念：技術參考手冊。深藍灰主色傳達穩重專業，
   琥珀色標記必考重點，等寬字體用於公式/代碼語境。
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Spectral:wght@400;500;600;700&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root{
  --ink-950:#0E1320;
  --ink-900:#141A2B;
  --ink-800:#1C2438;
  --ink-700:#283149;
  --ink-600:#3A4361;
  --ink-500:#566080;
  --ink-300:#8C96B5;
  --ink-100:#D8DCEA;
  --paper:#F6F4EC;
  --paper-dim:#EDEADF;

  --amber:#D89C3F;
  --amber-deep:#B97D1F;
  --amber-pale:#F4E3C2;

  --teal:#3E8E82;
  --teal-deep:#2A6359;
  --teal-pale:#D9ECE8;

  --coral:#C2614A;
  --coral-pale:#F2DCD3;

  --font-display:'Spectral', Georgia, serif;
  --font-body:'Inter', -apple-system, sans-serif;
  --font-mono:'JetBrains Mono', monospace;

  --radius:6px;
  --max-w:980px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink-900);
  font-family:var(--font-body);
  line-height:1.65;
  font-size:16px;
}

a{color:inherit;text-decoration:none}

img{max-width:100%;display:block}

/* ---------- Skip link ---------- */
.skip-link{
  position:absolute;left:-9999px;top:0;
  background:var(--amber);color:var(--ink-950);
  padding:8px 16px;font-weight:600;z-index:999;border-radius:0 0 6px 0;
}
.skip-link:focus{left:0}

/* ---------- Top bar ---------- */
.topbar{
  background:var(--ink-950);
  border-bottom:1px solid var(--ink-700);
  position:sticky;top:0;z-index:100;
}
.topbar-inner{
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:64px;
}
.brand{
  display:flex;align-items:baseline;gap:10px;
  font-family:var(--font-display);
  color:var(--paper);
}
.brand .mark{
  font-family:var(--font-mono);
  font-size:13px;
  color:var(--amber);
  letter-spacing:.08em;
  border:1px solid var(--ink-600);
  padding:3px 7px;
  border-radius:4px;
}
.brand .name{font-size:19px;font-weight:600}
.brand .name .sub{font-size:13px;color:var(--ink-300);font-family:var(--font-body);font-weight:400;margin-left:6px}

nav.primary{display:flex;gap:4px}
nav.primary a{
  font-size:14px;
  color:var(--ink-300);
  padding:9px 14px;
  border-radius:5px;
  font-weight:500;
  transition:background .15s, color .15s;
  white-space:nowrap;
}
nav.primary a:hover{background:var(--ink-800);color:var(--paper)}
nav.primary a.active{background:var(--ink-800);color:var(--amber)}

.nav-toggle{
  display:none;
  background:none;border:1px solid var(--ink-600);
  color:var(--paper);border-radius:5px;
  padding:7px 10px;font-size:14px;cursor:pointer;
}

/* ---------- Layout shell ---------- */
main{max-width:var(--max-w);margin:0 auto;padding:48px 24px 96px}

/* ---------- Hero ---------- */
.page-hero{
  padding-bottom:32px;
  margin-bottom:40px;
  border-bottom:1px solid var(--ink-100);
}
.eyebrow{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--teal-deep);
  background:var(--teal-pale);
  display:inline-block;
  padding:4px 10px;
  border-radius:4px;
  margin-bottom:16px;
}
.eyebrow.amber{color:var(--amber-deep);background:var(--amber-pale)}
h1.page-title{
  font-family:var(--font-display);
  font-size:38px;
  font-weight:600;
  line-height:1.18;
  color:var(--ink-950);
  margin-bottom:14px;
}
.page-lede{
  font-size:17px;
  color:var(--ink-600);
  max-width:640px;
}

/* ---------- Section headings ---------- */
h2.section-head{
  font-family:var(--font-display);
  font-size:24px;
  font-weight:600;
  margin:48px 0 18px;
  color:var(--ink-950);
  display:flex;
  align-items:baseline;
  gap:10px;
}
h2.section-head .tag{
  font-family:var(--font-mono);
  font-size:13px;
  font-weight:500;
  color:var(--ink-500);
}
h3.section-sub{
  font-size:15px;
  font-weight:600;
  color:var(--ink-700);
  text-transform:uppercase;
  letter-spacing:.04em;
  margin:32px 0 14px;
}

/* ---------- Index cards (homepage subject grid) ---------- */
.subject-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
  margin-top:24px;
}
.subject-card{
  background:var(--ink-950);
  color:var(--paper);
  border-radius:10px;
  padding:26px 24px;
  position:relative;
  overflow:hidden;
  border:1px solid var(--ink-700);
  transition:transform .15s, border-color .15s;
}
.subject-card:hover{transform:translateY(-2px);border-color:var(--amber)}
.subject-card .code{
  font-family:var(--font-mono);
  font-size:13px;
  color:var(--amber);
  letter-spacing:.08em;
  margin-bottom:8px;
  display:block;
}
.subject-card h3{
  font-family:var(--font-display);
  font-size:21px;
  font-weight:600;
  margin-bottom:10px;
  color:var(--paper);
}
.subject-card p{
  font-size:13.5px;
  color:var(--ink-300);
  line-height:1.6;
  margin-bottom:16px;
}
.subject-card .stat-row{
  display:flex;
  gap:18px;
  padding-top:14px;
  border-top:1px solid var(--ink-700);
}
.subject-card .stat{font-size:12px;color:var(--ink-300)}
.subject-card .stat b{display:block;font-size:17px;color:var(--paper);font-weight:600;font-family:var(--font-mono)}
.subject-card .go{
  position:absolute;top:24px;right:24px;
  font-size:13px;color:var(--ink-300);
}

.mini-stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin:28px 0;
}
.mini-stat{
  background:var(--paper-dim);
  border-radius:8px;
  padding:14px 16px;
  border:1px solid var(--ink-100);
}
.mini-stat .label{font-size:12px;color:var(--ink-500);margin-bottom:4px}
.mini-stat .val{font-family:var(--font-mono);font-size:21px;font-weight:600;color:var(--ink-950)}

/* ---------- Chapter accordion ---------- */
.chapter{
  background:#fff;
  border:1px solid var(--ink-100);
  border-radius:8px;
  margin-bottom:10px;
  overflow:hidden;
}
.chapter summary{
  list-style:none;
  cursor:pointer;
  padding:16px 18px;
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:600;
  font-size:15px;
}
.chapter summary::-webkit-details-marker{display:none}
.chapter summary .code-pill{
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:500;
  padding:3px 8px;
  border-radius:4px;
  flex-shrink:0;
}
.l21 .code-pill{background:var(--coral-pale);color:#7A3322}
.l22 .code-pill{background:var(--teal-pale);color:var(--teal-deep)}
.chapter summary .chev{margin-left:auto;color:var(--ink-500);transition:transform .2s;font-size:13px}
.chapter[open] summary .chev{transform:rotate(180deg)}
.chapter summary .badge{
  font-size:11px;
  background:var(--amber-pale);
  color:var(--amber-deep);
  padding:2px 8px;
  border-radius:4px;
  font-weight:600;
  flex-shrink:0;
}
.chapter-body{
  padding:4px 18px 18px;
  border-top:1px solid var(--ink-100);
}
.topic-row{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:10px 0;
  border-bottom:1px solid var(--paper-dim);
  font-size:14px;
}
.topic-row:last-child{border-bottom:none}
.topic-code{
  font-family:var(--font-mono);
  color:var(--ink-500);
  min-width:74px;
  font-size:12.5px;
  margin-top:2px;
  flex-shrink:0;
}
.topic-name{flex:1;line-height:1.55;color:var(--ink-800)}
.hot{
  font-size:11px;
  padding:2px 7px;
  border-radius:4px;
  background:var(--coral-pale);
  color:#7A3322;
  flex-shrink:0;
  font-weight:600;
  white-space:nowrap;
}

.tip-box{
  background:var(--paper-dim);
  border-left:3px solid var(--amber);
  border-radius:0 6px 6px 0;
  padding:12px 16px;
  margin-top:12px;
  font-size:13.5px;
  line-height:1.65;
  color:var(--ink-700);
}
.l22 .tip-box{border-left-color:var(--teal)}

/* ---------- Formula box ---------- */
.formula{
  font-family:var(--font-mono);
  background:var(--ink-950);
  color:var(--amber-pale);
  border-radius:8px;
  padding:18px 24px;
  text-align:center;
  font-size:18px;
  margin:18px 0;
  letter-spacing:.02em;
}

/* ---------- Calculator card ---------- */
.calc-card{
  background:#fff;
  border:1px solid var(--ink-100);
  border-radius:10px;
  padding:24px 26px;
  margin:24px 0 36px;
}
.calc-row{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:16px;
}
.calc-row label{
  font-size:13.5px;
  color:var(--ink-600);
  min-width:84px;
  flex-shrink:0;
  font-weight:500;
}
.calc-row input[type=range]{
  flex:1;
  accent-color:var(--amber-deep);
}
.calc-row .readout{
  min-width:48px;
  text-align:right;
  font-family:var(--font-mono);
  font-weight:600;
  color:var(--ink-950);
}
.calc-result{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  padding-top:16px;
  margin-top:6px;
  border-top:1px solid var(--ink-100);
}
.calc-result .rlabel{font-size:13.5px;color:var(--ink-600)}
.calc-result .rval{font-family:var(--font-mono);font-size:30px;font-weight:600;color:var(--amber-deep)}
.calc-interp{
  font-size:13.5px;
  color:var(--ink-600);
  margin-top:10px;
  line-height:1.6;
}

/* ---------- Quiz ---------- */
.quiz{
  background:#fff;
  border:1px solid var(--ink-100);
  border-radius:10px;
  padding:20px 22px;
  margin-bottom:16px;
}
.quiz .qmeta{
  font-family:var(--font-mono);
  font-size:11.5px;
  color:var(--ink-500);
  margin-bottom:10px;
  letter-spacing:.02em;
}
.quiz .qtext{
  font-size:15px;
  line-height:1.65;
  margin-bottom:14px;
  color:var(--ink-900);
}
.quiz .qopts{display:flex;flex-direction:column;gap:8px}
.quiz .qopt{
  font-size:14px;
  padding:10px 14px;
  border:1px solid var(--ink-100);
  border-radius:6px;
  cursor:pointer;
  background:var(--paper);
  transition:background .12s, border-color .12s;
}
.quiz .qopt:hover{background:var(--paper-dim);border-color:var(--ink-300)}
.quiz .qopt.correct{background:#E3EFD8;border-color:#6E9C4A;color:#3C5A28}
.quiz .qopt.wrong{background:var(--coral-pale);border-color:var(--coral);color:#7A3322}
.quiz .qexp{
  display:none;
  margin-top:14px;
  font-size:13.5px;
  line-height:1.65;
  color:var(--ink-700);
  background:var(--paper-dim);
  border-radius:6px;
  padding:14px 16px;
}

/* ---------- Buttons / links ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--ink-950);
  color:var(--paper);
  border:1px solid var(--ink-950);
  border-radius:6px;
  padding:11px 20px;
  font-size:14px;
  font-weight:600;
  cursor:pointer;
  transition:background .15s;
}
.btn:hover{background:var(--ink-800)}
.btn.amber{background:var(--amber-deep);border-color:var(--amber-deep)}
.btn.amber:hover{background:var(--amber)}
.btn.ghost{background:transparent;color:var(--ink-900);border-color:var(--ink-300)}
.btn.ghost:hover{background:var(--paper-dim)}

/* ---------- Crumb / errata callout ---------- */
.errata{
  background:var(--coral-pale);
  border:1px solid var(--coral);
  border-radius:8px;
  padding:16px 20px;
  margin:32px 0;
  font-size:14px;
  line-height:1.65;
  color:#5A2415;
}
.errata strong{color:#7A3322}

/* ---------- Footer ---------- */
footer{
  border-top:1px solid var(--ink-100);
  padding:32px 24px;
  text-align:center;
  font-size:13px;
  color:var(--ink-500);
}

/* ---------- Responsive ---------- */
@media (max-width:780px){
  .subject-grid{grid-template-columns:1fr}
  .mini-stats{grid-template-columns:repeat(2,1fr)}
  h1.page-title{font-size:30px}
  nav.primary{
    display:none;
    position:absolute;
    top:64px;left:0;right:0;
    background:var(--ink-950);
    flex-direction:column;
    padding:8px;
    border-bottom:1px solid var(--ink-700);
  }
  nav.primary.open{display:flex}
  nav.primary a{padding:12px 14px}
  .nav-toggle{display:block}
}

@media (prefers-reduced-motion:reduce){
  *{transition:none !important;scroll-behavior:auto !important}
}

/* Focus visibility */
a:focus-visible, button:focus-visible, summary:focus-visible, input:focus-visible{
  outline:2px solid var(--amber-deep);
  outline-offset:2px;
}
