/* ============================================================
   USAAIO Course — Shared Stylesheet
   Used by every page. Edit here to restyle the whole course.
   ============================================================ */

:root{
  --bg:#f6f8fc;
  --bg-soft:#eef2f9;
  --card:#ffffff;
  --card-2:#eff4fb;
  --ink:#16203a;
  --ink-soft:#46506b;
  --muted:#7b8699;
  --brand:#0d9488;       /* teal */
  --brand-2:#6366f1;     /* indigo */
  --accent:#d97706;      /* amber */
  --good:#059669;
  --warn:#dc2626;
  --line:#dde4ee;
  --radius:16px;
  --shadow:0 8px 24px rgba(33,52,89,.10);
  --mono:"SF Mono",ui-monospace,"JetBrains Mono",Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);background:linear-gradient(160deg,#f6f8fc,#eaf0f8 60%,#f6f8fc);
  color:var(--ink);line-height:1.65;-webkit-font-smoothing:antialiased;
}
.wrap{max-width:1080px;margin:0 auto;padding:32px 22px 90px}

/* ---------- top nav ---------- */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);
  background:rgba(246,248,252,.82);border-bottom:1px solid var(--line)}
.nav-inner{max-width:1080px;margin:0 auto;display:flex;gap:6px;align-items:center;
  padding:12px 20px;flex-wrap:wrap}
.nav .brand{font-weight:800;letter-spacing:.3px;margin-right:auto;display:flex;gap:10px;align-items:center}
.nav .brand .dot{width:11px;height:11px;border-radius:50%;background:var(--brand);box-shadow:0 0 14px var(--brand)}
.nav a{color:var(--ink-soft);text-decoration:none;font-size:.9rem;padding:6px 11px;border-radius:9px}
.nav a:hover{background:var(--card-2);color:var(--ink)}
.nav a.active{background:var(--brand);color:#ffffff;font-weight:700}

/* ---------- hero ---------- */
.hero{padding:30px 0 10px}
.eyebrow{color:var(--brand);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:.74rem}
h1{font-size:2.3rem;line-height:1.15;margin:.3em 0 .25em}
h2{font-size:1.5rem;margin:1.8em 0 .5em;border-left:4px solid var(--brand);padding-left:12px}
h3{font-size:1.15rem;margin:1.4em 0 .4em;color:var(--ink)}
.lead{font-size:1.12rem;color:var(--ink-soft);max-width:70ch}
a{color:var(--brand)}

/* ---------- cards / grid ---------- */
.grid{display:grid;gap:18px}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:820px){.grid.cols-2,.grid.cols-3,.grid.cols-4{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow);transition:transform .15s,border-color .15s}
.card:hover{transform:translateY(-3px);border-color:var(--brand-2)}
.card h3{margin-top:0}
.card .meta{color:var(--muted);font-size:.82rem}
a.card{display:block;text-decoration:none;color:inherit}
.tag{display:inline-block;font-size:.72rem;font-weight:700;padding:3px 9px;border-radius:999px;
  background:var(--card-2);color:var(--brand);border:1px solid var(--line);margin:2px 4px 2px 0}
.tag.amber{color:var(--accent)} .tag.indigo{color:var(--brand-2)} .tag.warn{color:var(--warn)}

/* ---------- callouts ---------- */
.callout{border-radius:12px;padding:14px 18px;margin:18px 0;border:1px solid var(--line);background:var(--card)}
.callout.info{border-left:4px solid var(--brand-2)}
.callout.tip{border-left:4px solid var(--good)}
.callout.warn{border-left:4px solid var(--warn)}
.callout .k{font-weight:800;display:block;margin-bottom:3px}

/* ---------- tables ---------- */
table{width:100%;border-collapse:collapse;margin:16px 0;font-size:.94rem}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}
th{color:var(--brand);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}
tr:hover td{background:rgba(255,255,255,.02)}

/* ---------- timeline ---------- */
.tl{position:relative;margin:24px 0;padding-left:28px}
.tl::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:2px;background:var(--line)}
.tl-item{position:relative;margin-bottom:22px}
.tl-item::before{content:"";position:absolute;left:-24px;top:5px;width:14px;height:14px;border-radius:50%;
  background:var(--brand);box-shadow:0 0 0 4px rgba(94,234,212,.15)}
.tl-item.done::before{background:var(--good)}
.tl-item.now::before{background:var(--accent);box-shadow:0 0 0 4px rgba(251,191,36,.2)}
.tl-item .when{font-size:.78rem;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.05em}

/* ---------- progress ---------- */
.bar{height:10px;border-radius:999px;background:var(--card-2);overflow:hidden;margin:6px 0}
.bar > span{display:block;height:100%;background:linear-gradient(90deg,var(--brand),var(--brand-2))}
.kpi{display:flex;gap:18px;flex-wrap:wrap;margin:18px 0}
.kpi .box{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 20px;min-width:140px;flex:1}
.kpi .box .n{font-size:1.9rem;font-weight:800;color:var(--brand)}
.kpi .box .l{color:var(--muted);font-size:.82rem}

/* ---------- code / math ---------- */
code{font-family:var(--mono);background:var(--bg-soft);padding:2px 6px;border-radius:6px;font-size:.88em;color:var(--brand)}
pre{background:#0f1729;border:1px solid var(--line);border-radius:12px;padding:16px;overflow:auto;font-family:var(--mono);font-size:.86rem;line-height:1.55;color:#e8edf7}
pre code{background:none;padding:0;color:#e8edf7}
.eq{background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;padding:12px 16px;margin:14px 0;overflow-x:auto;font-family:var(--mono);color:var(--ink-soft)}

/* ---------- checklist ---------- */
.check{list-style:none;padding:0}
.check li{padding:7px 0 7px 30px;position:relative;border-bottom:1px solid var(--line)}
.check li::before{content:"☐";position:absolute;left:4px;color:var(--muted);font-size:1.1rem}
.check li.done{color:var(--muted);text-decoration:line-through}
.check li.done::before{content:"☑";color:var(--good);text-decoration:none}

/* ---------- footer ---------- */
.foot{margin-top:60px;padding-top:20px;border-top:1px solid var(--line);color:var(--muted);font-size:.82rem}
.btn{display:inline-block;background:var(--brand);color:#ffffff;font-weight:700;padding:10px 18px;border-radius:10px;text-decoration:none;margin:6px 8px 6px 0}
.btn.ghost{background:transparent;border:1px solid var(--brand);color:var(--brand)}
.zh{color:var(--ink-soft);font-style:normal}
.pill-row{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
hr{border:none;border-top:1px solid var(--line);margin:30px 0}
