:root{
  --ink:#0a0a0a;--ink-soft:#26261f;--mid:#5a5a5a;--muted:#8a8a8a;--faint:#b9b9b2;
  --rule:#e6e6e2;--rule-soft:#efefe9;--paper:#fff;--wash:#f6f6f2;--wash-deep:#efefe8;
  --accent:#2F5C3B;--accent-soft:#DDEBD8;--ok:#1f9d55;--ok-soft:#f1faf4;
  --sidebar:#2D1B12;--side-muted:#8A7D6E;--side-text:#EEEAE0;--gold:#B89668;
}
*{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;color:var(--ink);background:var(--wash);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.55}
a{color:inherit}
.app{display:flex;min-height:100vh}
/* ---------- sidebar ---------- */
.side{width:264px;flex:0 0 264px;background:var(--sidebar);color:var(--side-text);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:.65rem;padding:1.4rem}
.brand .mark{width:34px;height:34px;border-radius:7px;background:#fff;color:#000;font-weight:800;font-size:1.05rem;display:grid;place-items:center}
.brand .name{font-weight:700;color:#fff;font-size:.95rem;line-height:1}
.brand .sub{font-size:.58rem;letter-spacing:.22em;color:var(--side-muted);margin-top:.32rem}
.nav{flex:1;padding:.2rem .8rem;overflow-y:auto}
.nav .grp{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--side-muted);padding:1.15rem .6rem .55rem}
.nav a{display:flex;align-items:center;gap:.7rem;padding:.58rem .65rem;border-radius:7px;color:var(--side-text);text-decoration:none;font-size:.875rem;margin-bottom:.1rem}
.nav a:hover{background:rgba(255,255,255,.06)}
.nav a.active{background:rgba(255,255,255,.09);color:#fff;box-shadow:inset 0 0 0 1px rgba(120,150,235,.55)}
.nav a svg{width:17px;height:17px;flex:0 0 17px;opacity:.9}
.nav a .rtag{margin-left:auto;font-size:.55rem;letter-spacing:.1em;color:var(--side-muted)}
.who{display:flex;align-items:center;gap:.6rem;padding:.85rem 1.1rem;border-top:1px solid rgba(255,255,255,.08)}
.who .av{width:30px;height:30px;border-radius:50%;background:#2a2a2e;color:#fff;display:grid;place-items:center;font-size:.66rem;font-weight:600;flex:0 0 30px}
.who .em{font-size:.72rem;color:var(--side-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.logout{display:flex;align-items:center;gap:.55rem;padding:.75rem 1.25rem;color:var(--side-muted);font-size:.8rem;border-top:1px solid rgba(255,255,255,.08);text-decoration:none}
/* ---------- main ---------- */
.main{flex:1;min-width:0;background:var(--wash)}
.wrap{max-width:1080px;padding:0 3.2rem 5rem}
/* ---------- masthead ---------- */
.masthead{padding:3rem 0 2.4rem;border-bottom:1px solid var(--ink)}
.crumb{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:1.4rem;display:flex;align-items:center;gap:.6rem}
.crumb .accent{color:var(--accent);font-weight:700}
.crumb .dot{width:3px;height:3px;border-radius:50%;background:var(--faint)}
.masthead h1{font-family:'Newsreader',Georgia,serif;font-weight:500;font-size:clamp(2.2rem,3.6vw,3rem);letter-spacing:-.02em;line-height:1.04;max-width:680px}
.masthead h1 em{font-style:italic;color:var(--accent)}
.masthead .standfirst{margin-top:.9rem;color:var(--mid);font-size:.97rem;max-width:560px}
.mast-grid{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap}
.quarter{text-align:right;flex:0 0 auto}
.quarter .q{font-family:'Newsreader',Georgia,serif;font-size:1.05rem;font-style:italic;color:var(--ink)}
.quarter .qsub{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:.2rem}
/* ---------- continue strip ---------- */
.continue{display:flex;align-items:center;gap:1.3rem;background:var(--ink);color:#fff;border-radius:12px;padding:1.05rem 1.4rem;margin:1.9rem 0 0;flex-wrap:wrap}
.continue .k{font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:700}
.continue .what{font-family:'Newsreader',Georgia,serif;font-size:1.12rem;letter-spacing:-.01em}
.continue .what span{color:rgba(255,255,255,.55);font-family:'Inter';font-size:.8rem;margin-left:.6rem}
.continue a.go{margin-left:auto;display:inline-flex;align-items:center;gap:.45rem;background:var(--accent);color:#fff;text-decoration:none;font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.68rem 1.1rem;border-radius:7px;transition:transform .15s ease,background .15s ease}
.continue a.go:hover{background:#24472E;transform:translateX(2px)}
/* ---------- section label ---------- */
.sec-label{display:flex;align-items:baseline;justify-content:space-between;margin:2.8rem 0 0;padding-bottom:.8rem;border-bottom:1px solid var(--rule)}
.sec-label h2{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:700}
.sec-label .count{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.sec-label h2 b{color:var(--accent);font-weight:700;margin-right:.5rem}
/* ---------- program index ---------- */
.prog{display:grid;grid-template-columns:88px minmax(0,1.25fr) minmax(0,1fr) 150px 30px;gap:1.6rem;align-items:center;padding:1.7rem .4rem;border-bottom:1px solid var(--rule);text-decoration:none;position:relative;transition:background .18s ease}
.prog:hover{background:#fbfbf8}
.prog:hover .num{color:var(--accent)}
.prog:hover .arrow{transform:translateX(4px);color:var(--accent)}
.prog .num{font-family:'Newsreader',Georgia,serif;font-size:2.9rem;font-weight:400;line-height:1;color:var(--faint);letter-spacing:-.03em;transition:color .18s ease;font-variant-numeric:tabular-nums}
.prog .title h3{font-family:'Newsreader',Georgia,serif;font-weight:500;font-size:1.45rem;letter-spacing:-.015em;line-height:1.1;color:var(--ink)}
.prog .title .desc{color:var(--mid);font-size:.86rem;margin-top:.35rem;max-width:330px}
.prog .meter{min-width:0}
.prog .meter .row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.5rem}
.prog .meter .done{font-size:.78rem;color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}
.prog .meter .of{font-size:.7rem;color:var(--muted)}
.ticks{display:flex;gap:3px}
.ticks i{height:14px;flex:1;border-radius:2px;background:var(--rule);transition:background .18s ease}
.ticks i.on{background:var(--accent)}
.prog .stat{text-align:right}
.prog .arrow{color:var(--faint);transition:transform .18s ease,color .18s ease;justify-self:end}
.prog .arrow svg{width:20px;height:20px}
/* ---------- badges ---------- */
.badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.62rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.32rem .65rem;border-radius:20px;border:1px solid var(--rule);color:var(--mid);background:#fff;white-space:nowrap}
.badge.ok{color:var(--ok);border-color:#bfe6cd;background:var(--ok-soft)}
.badge.now{color:var(--accent);border-color:#B7D7B0;background:var(--accent-soft)}
.badge .pip{width:6px;height:6px;border-radius:50%;background:currentColor}
/* ---------- pills ---------- */
.pill{display:inline-block;font-size:.6rem;letter-spacing:.07em;text-transform:uppercase;font-weight:600;padding:.22rem .55rem;border-radius:20px;background:var(--wash);border:1px solid var(--rule);color:var(--muted)}
/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--ink);color:#fff;border:none;font-size:.68rem;font-weight:700;letter-spacing:.11em;text-transform:uppercase;padding:.72rem 1.15rem;border-radius:7px;cursor:pointer;text-decoration:none;transition:background .15s ease,transform .15s ease}
.btn:hover{background:#262626;transform:translateY(-1px)}
.btn.accent2{background:var(--accent)}
.btn.accent2:hover{background:#24472E}
.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--rule)}
.btn.ghost:hover{background:var(--wash);transform:none}
.btn.sm{padding:.5rem .8rem;font-size:.62rem}
/* ---------- prose ---------- */
.prose p{color:var(--mid);font-size:.94rem;line-height:1.68;max-width:660px;margin:0 0 .9rem}
.prose strong{color:var(--ink);font-weight:650}
/* ---------- section ---------- */
.section{padding:2.2rem 0 0}
/* ---------- embed ---------- */
.embed{position:relative;width:100%;max-width:780px;height:0;padding-bottom:44%;border-radius:12px;overflow:hidden;background:#0b0b0c;border:1px solid var(--rule);margin-top:1.4rem}
.embed-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;color:#cfcfd3;font-size:.8rem;letter-spacing:.02em}
.embed-play{width:62px;height:62px;border-radius:50%;background:rgba(255,255,255,.14);display:grid;place-items:center;transition:transform .18s ease,background .18s ease;cursor:pointer}
.embed-play:hover{transform:scale(1.06);background:rgba(216,72,31,.85)}
.embed-play svg{width:30px;height:30px;color:#fff;opacity:.95}
/* ---------- frow (feature row) ---------- */
.frow{display:flex;align-items:center;gap:1rem;padding:1rem .4rem;border-bottom:1px solid var(--rule)}
.frow .fic{width:44px;height:44px;border-radius:10px;background:#fff;border:1px solid var(--rule);display:grid;place-items:center;flex:0 0 44px;color:var(--ink)}
.frow .fic svg{width:19px;height:19px}
.frow .body{flex:1;min-width:0}
.frow .body strong{color:var(--ink);font-size:.92rem;font-weight:600}
.frow .body div{color:var(--muted);font-size:.74rem;margin-top:.15rem}
/* ---------- drop zone ---------- */
.drop{border:1.5px dashed var(--faint);border-radius:12px;padding:2rem 1.6rem;text-align:center;background:#fcfcf9;color:var(--muted);font-size:.85rem;max-width:780px;margin-top:1.3rem;transition:border-color .18s ease,background .18s ease}
.drop:hover{border-color:var(--accent);background:var(--accent-soft)}
.drop .big{color:var(--ink);font-weight:600;margin:.55rem 0 .2rem;font-family:'Newsreader',Georgia,serif;font-size:1.15rem}
.drop svg{width:30px;height:30px;color:var(--muted);opacity:.65}
/* ---------- note ---------- */
.note{background:#fff;border:1px solid var(--rule);border-left:3px solid var(--accent);padding:1rem 1.25rem;border-radius:0 10px 10px 0;font-size:.86rem;color:var(--ink-soft);margin:1.5rem 0 0;max-width:780px}
.note a{font-weight:600;text-decoration:none;border-bottom:1px solid var(--faint)}
.note a:hover{border-bottom-color:var(--accent)}
.muted{color:var(--muted);font-size:.8rem}
/* ---------- fields ---------- */
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:.45rem}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--rule);border-radius:8px;padding:.72rem .85rem;font-size:.9rem;font-family:inherit;color:var(--ink);background:#fff;transition:border-color .15s ease}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ink)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 1.2rem}
/* ---------- panel ---------- */
.panel{background:#fff;border:1px solid var(--rule);border-radius:14px;padding:1.8rem 1.9rem;margin-top:1.5rem}
/* ---------- table ---------- */
table{width:100%;border-collapse:collapse;font-size:.86rem;background:#fff;border:1px solid var(--rule);border-radius:12px;overflow:hidden;margin-top:1.4rem}
th{text-align:left;background:#fbfbf8;border-bottom:1px solid var(--rule);padding:.75rem 1rem;color:var(--muted);font-size:.6rem;text-transform:uppercase;letter-spacing:.14em;font-weight:700}
td{border-bottom:1px solid var(--rule-soft);padding:.95rem 1rem;color:var(--mid);vertical-align:middle}
td:first-child{color:var(--ink);font-weight:600}
tr:last-child td{border-bottom:none}
tbody tr{transition:background .15s ease}
tbody tr:hover{background:#fbfbf8}
/* ---------- when (date block) ---------- */
.when{flex:0 0 92px;text-align:center;border:1px solid var(--rule);border-radius:12px;padding:.8rem .4rem .7rem;background:#fff}
.when .d{font-family:'Newsreader',Georgia,serif;font-size:2rem;line-height:1;letter-spacing:-.02em;color:var(--ink)}
.when .m{font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-top:.3rem}
/* ---------- crow (calendar row) ---------- */
.crow{display:flex;gap:1.5rem;align-items:center;padding:1.4rem .4rem;border-bottom:1px solid var(--rule);transition:background .18s ease}
.crow:hover{background:#fbfbf8}
.crow .body{flex:1;min-width:0}
.crow .body h3{font-family:'Newsreader',Georgia,serif;font-weight:500;font-size:1.3rem;letter-spacing:-.012em;color:var(--ink)}
.crow .body p{color:var(--mid);font-size:.85rem;margin-top:.3rem;max-width:480px}
.crow .body .meta{display:flex;gap:.5rem;align-items:center;margin-top:.55rem;flex-wrap:wrap}
.crow .time{font-size:.78rem;color:var(--ink);font-weight:600;white-space:nowrap}
/* ---------- lesson row ---------- */
.gnum{font-family:'Newsreader',Georgia,serif;font-size:2.9rem;font-weight:400;line-height:1;color:var(--faint);letter-spacing:-.03em;transition:color .18s ease;font-variant-numeric:tabular-nums}
.lrow{display:grid;grid-template-columns:88px minmax(0,1.45fr) 170px 30px;gap:1.6rem;align-items:center;padding:1.55rem .4rem;border-bottom:1px solid var(--rule);text-decoration:none;transition:background .18s ease}
.lrow:hover{background:#fbfbf8}
.lrow:hover .gnum{color:var(--accent)}
.lrow:hover .arrow2{transform:translateX(4px);color:var(--accent)}
.lrow .title h3{font-family:'Newsreader',Georgia,serif;font-weight:500;font-size:1.3rem;letter-spacing:-.012em;line-height:1.12;color:var(--ink)}
.lrow .title .desc{color:var(--mid);font-size:.85rem;margin-top:.3rem;max-width:420px}
.lrow .title .has{display:flex;gap:.45rem;margin-top:.55rem;flex-wrap:wrap}
.lrow .stat{text-align:right}
.lrow .next2{font-size:.7rem;color:var(--muted);margin-top:.5rem}
.arrow2{color:var(--faint);transition:transform .18s ease,color .18s ease;justify-self:end}
.arrow2 svg{width:20px;height:20px}
/* ---------- footer strip ---------- */
.foot-note{display:flex;gap:2.5rem;margin-top:2.6rem;padding-top:1.6rem;border-top:1px solid var(--ink);flex-wrap:wrap}
.foot-note .cell{flex:1;min-width:200px}
.foot-note .cell h4{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:.45rem}
.foot-note .cell p{font-size:.83rem;color:var(--mid);line-height:1.55}
.foot-note .cell a{color:var(--ink);font-weight:600;text-decoration:none;border-bottom:1px solid var(--faint)}
.foot-note .cell a:hover{border-bottom-color:var(--accent)}
/* ---------- responsive ---------- */
@media (max-width:980px){
  .prog{grid-template-columns:60px minmax(0,1fr) 30px;grid-template-rows:auto auto}
  .prog .meter{grid-column:2;grid-row:2}
  .prog .stat{display:none}
  .wrap{padding:0 1.5rem 4rem}
  .lrow{grid-template-columns:56px minmax(0,1fr) 30px}
  .lrow .stat{display:none}
  .grid2{grid-template-columns:1fr}
}
.drop.drag{border-color:var(--accent);background:var(--accent-soft)}
