:root{
  --cream:#F6F6E9; --paper:#fffdf6; --navy:#343F56; --navy-soft:#46536f;
  --red:#DC1D26; --ink:#222a3a; --muted:#6b7384; --line:#e4e3d4;
  --btn:#343F56; --login-glow:#ffffff;
  --shadow:0 2px 14px rgba(52,63,86,.10); --radius:14px;
}
html[data-theme="dark"]{
  --cream:#1d2331; --paper:#28303f; --navy:#eef1f7; --navy-soft:#aeb7cc;
  --red:#DC1D26; --ink:#d4d9e3; --muted:#838ca3; --line:#384256;
  --btn:#46536f; --login-glow:#28303f;
  --shadow:0 2px 16px rgba(0,0,0,.45);
}
html,body{transition:background-color .2s ease}
.theme-toggle{position:fixed;bottom:18px;right:18px;z-index:60;width:42px;height:42px;border-radius:50%;
  border:1px solid var(--line);background:var(--paper);color:var(--navy);font-size:18px;cursor:pointer;
  box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;transition:transform .12s,background .2s}
.theme-toggle:hover{transform:scale(1.08)}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:'Inter',system-ui,sans-serif;background:var(--cream);color:var(--ink);
  -webkit-font-smoothing:antialiased}
a{color:var(--red);text-decoration:none}
a:hover{text-decoration:underline}

/* ---------- login ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(1200px 600px at 50% -10%, var(--login-glow) 0%, var(--cream) 60%)}
.login-card{background:var(--paper);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);
  width:100%;max-width:400px;padding:38px 34px;text-align:center}
.login-logo{width:230px;max-width:80%;margin:0 auto 18px;display:block}
.login-card h1{font-family:'Source Serif 4',serif;color:var(--navy);font-size:24px;margin:6px 0 2px}
.login-sub{color:var(--muted);font-size:13.5px;margin:0 0 22px}
.login-card label{display:block;text-align:left;font-size:11px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--navy-soft);margin:14px 0 5px}
.login-card input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;
  font-size:15px;background:#fff;color:#222a3a}
.login-card input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(52,63,86,.12)}
.btn-primary{width:100%;margin-top:22px;background:var(--red);color:#fff;border:none;border-radius:10px;
  padding:12px;font-size:15px;font-weight:700;cursor:pointer;transition:filter .12s}
.btn-primary:hover{filter:brightness(1.06)}
.login-note{color:var(--muted);font-size:11.5px;margin:18px 0 0;line-height:1.5}
html[data-theme="dark"] .login-sub,
html[data-theme="dark"] .login-note{color:var(--navy-soft)}

/* ---------- topbar ---------- */
.topbar{background:var(--paper);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.topbar-in{max-width:1040px;margin:0 auto;display:flex;align-items:center;gap:14px;padding:13px 22px}
.topbar-logo{height:30px;cursor:pointer}
.spacer{flex:1}
.who{color:var(--muted);font-size:13px}
.btn-ghost{background:transparent;border:1px solid var(--line);border-radius:9px;padding:7px 13px;
  font-size:13px;font-weight:600;color:var(--navy);cursor:pointer}
.btn-ghost:hover{background:var(--cream)}
main{max-width:1040px;margin:0 auto;padding:26px 22px 60px}
.foot{text-align:center;color:var(--muted);font-size:11.5px;padding:26px;border-top:1px solid var(--line)}

/* ---------- library ---------- */
.lib-h{font-family:'Source Serif 4',serif;color:var(--navy);font-size:26px;margin:4px 0 4px}
.lib-sub{color:var(--muted);font-size:14px;margin:0 0 26px}
.series-h{font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:.12em;
  font-size:14px;font-weight:700;color:var(--navy);margin:26px 0 12px;padding-bottom:6px;border-bottom:2px solid var(--line)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);cursor:pointer;transition:transform .12s,box-shadow .12s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(52,63,86,.14)}
.card-tile{background:linear-gradient(135deg,#343F56,#46536f);padding:30px 22px 22px;display:flex;
  flex-direction:column;align-items:center;gap:16px;text-align:center;position:relative}
.card-num{position:absolute;top:11px;left:11px;min-width:26px;height:26px;padding:0 7px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;font-family:'Roboto Condensed',sans-serif;
  font-weight:700;font-size:14px;color:#F6F6E9;background:rgba(246,246,233,.12);border:1px solid rgba(246,246,233,.34)}
.card-logo{width:74%;max-width:232px;height:auto}
.card-series{font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:.1em;
  font-size:12px;font-weight:700;color:rgba(246,246,233,.86)}
.card-chip{background:#F6F6E9;color:#343F56;font-size:13.5px;font-weight:600;border-radius:7px;padding:9px 13px;
  width:100%;line-height:1.3;text-wrap:balance}
.card-body{padding:15px 17px 17px;display:flex;flex-direction:column;gap:7px;flex:1}
.card-title{font-family:'Source Serif 4',serif;font-size:18px;color:var(--navy);line-height:1.22;
  min-height:2.44em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-wrap:balance}
.card-sub{font-size:13px;color:var(--muted)}
.card-tags{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:2px}
.pill.ce{display:inline-flex;align-items:center;gap:5px}
.irs-eagle{display:inline-block;width:15px;height:13px;flex-shrink:0;background-color:currentColor;
  -webkit-mask:url(assets/eagle-mask.png) center/contain no-repeat;mask:url(assets/eagle-mask.png) center/contain no-repeat}
.card-bar{position:relative;height:24px;border-radius:20px;background:var(--line);overflow:hidden;margin-top:auto}
.card-bar-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#2f9e63,#34c178);
  border-radius:20px;transition:width .35s ease}
.card-bar-lbl{position:absolute;left:13px;top:50%;transform:translateY(-50%);font-family:'Roboto Condensed',sans-serif;
  font-weight:700;font-size:12px;color:#fff;z-index:2;letter-spacing:.03em}
.card-bar.zero .card-bar-lbl{color:var(--muted)}
.card-match{margin-top:9px;padding-top:9px;border-top:1px solid var(--line);font-size:11.5px;color:var(--muted);line-height:1.55}
.cm-field{display:inline-block;text-transform:uppercase;font-size:9.5px;font-weight:700;letter-spacing:.05em;
  color:var(--red);margin-right:5px}

/* library search + filters */
.lib-tools{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:24px}
.lib-search{flex:1;min-width:250px;display:flex;align-items:center;gap:9px;background:var(--paper);
  border:1px solid var(--line);border-radius:11px;padding:10px 14px;box-shadow:var(--shadow)}
.lib-search svg{width:18px;height:18px;fill:var(--muted);flex-shrink:0}
.lib-search input{flex:1;border:none;background:transparent;font-size:14.5px;color:var(--ink);outline:none}
.lib-search input::placeholder{color:var(--muted)}
.lib-filters{display:flex;gap:7px;flex-wrap:wrap}
.lib-sortrow{display:flex;justify-content:flex-end;margin:18px 0 8px}
.lib-sort{border:1px solid var(--line);background:var(--paper);color:var(--navy);
  font-family:'Inter',sans-serif;font-size:13px;font-weight:600;border-radius:20px;padding:8px 14px;cursor:pointer;
  box-shadow:var(--shadow)}
.lib-sort:hover{border-color:var(--navy-soft)}
.fchip{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:8px 14px;font-size:13px;
  font-weight:600;color:var(--navy-soft);cursor:pointer;transition:background .12s,border-color .12s,color .12s}
.fchip:hover{border-color:var(--navy-soft)}
.fchip.on{background:var(--navy);border-color:var(--navy);color:#F6F6E9}
html[data-theme="dark"] .fchip.on{color:var(--cream)}
.lib-resultnote{font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:.08em;
  font-size:12px;font-weight:700;color:var(--navy-soft);margin-bottom:14px}
.sh-row{display:flex;align-items:center}
.sh-hide{margin-left:auto;background:transparent;border:1px solid var(--line);border-radius:8px;
  padding:4px 12px;font-family:'Inter',sans-serif;font-size:11.5px;font-weight:600;letter-spacing:0;text-transform:none;
  color:var(--navy-soft);cursor:pointer;transition:background .12s,border-color .12s}
.sh-hide:hover{background:var(--cream);border-color:var(--navy-soft);color:var(--navy)}
.sh-show{background:transparent;border:1px dashed var(--line);border-radius:9px;padding:9px 15px;margin-bottom:22px;
  font-size:13px;font-weight:600;color:var(--navy-soft);cursor:pointer;transition:background .12s,border-color .12s}
.sh-show:hover{background:var(--cream);border-color:var(--navy-soft);color:var(--navy)}
.pill{font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border-radius:20px;
  padding:3px 9px;background:rgba(220,29,38,.09);color:var(--red)}
.pill.ce{background:rgba(47,111,79,.12);color:#2f6f4f}
html[data-theme="dark"] .pill.ce{background:rgba(126,224,171,.18);color:#7ee0ab}
.pill.upd{background:rgba(202,138,4,.16);color:#b07d12}
html[data-theme="dark"] .pill.upd{color:#e3b248}
.card-upd{border-left:3px solid rgba(202,138,4,.55)}
.pill.rev{background:rgba(70,110,200,.16);color:#4f72c8}
html[data-theme="dark"] .pill.rev{color:#7fa0e6}
.pill.guest{background:rgba(150,90,200,.16);color:#8b54c4}
html[data-theme="dark"] .pill.guest{color:#bd8fe0}
.pill.bonus{background:rgba(52,63,86,.12);color:var(--navy-soft)}
html[data-theme="dark"] .pill.bonus{color:#aeb7cc}
/* Start Here welcome banner */
.start-here{background:linear-gradient(135deg,#343F56,#46536f);border-radius:var(--radius);
  padding:20px 24px;margin-bottom:26px;cursor:pointer;box-shadow:var(--shadow);
  transition:transform .12s,box-shadow .12s}
.start-here:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,0,0,.3)}
.sh-tag{font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:.09em;font-size:11px;
  font-weight:700;color:#DC1D26;background:#F6F6E9;display:inline-block;padding:3px 11px;border-radius:20px;margin-bottom:9px}
.sh-title{font-family:'Source Serif 4',serif;font-size:23px;color:#F6F6E9;margin-bottom:3px}
.sh-sub{font-size:13px;color:rgba(246,246,233,.72)}

/* ---------- class page ---------- */
.back{display:inline-flex;align-items:center;gap:6px;color:var(--navy-soft);font-size:13px;font-weight:600;
  cursor:pointer;margin-bottom:14px}
.back:hover{color:var(--navy)}
.cls-eyebrow{font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:.12em;
  font-size:12px;font-weight:700;color:var(--navy-soft);margin-bottom:4px}
.cls-title{font-family:'Source Serif 4',serif;color:var(--navy);font-size:30px;margin:0 0 20px;line-height:1.15}
/* pinned class header + progress bar. top must match the real topbar height
   (58px) so nothing peeks through the seam; sits below the topbar (z-index). */
.cls-sticky{position:sticky;top:57px;z-index:6;padding:24px 0 13px;margin-bottom:18px}
/* full-bleed opaque backdrop: spans the WHOLE viewport width (not just the
   1040px content column) and caps the gap above (to the topbar) and below
   (the margin), so a scrolling card and its box-shadow are fully hidden
   behind the pinned header on every side and it blends into the page bg */
.cls-sticky::before{content:"";position:absolute;top:-10px;bottom:-18px;left:50%;margin-left:-50vw;width:100vw;background:var(--cream);z-index:-1}
.cls-sticky .cls-title{margin:0 0 12px}
.cls-sticky .prog{margin:0}
/* search-term highlighting */
mark.hl{background:#ffe27a;color:#222a3a;border-radius:3px;padding:0 2px;box-shadow:0 0 0 1px rgba(220,29,38,.25)}
html[data-theme="dark"] mark.hl,html[data-theme="dark"] .tr-count{background:#e3b733;color:#1d2331}
.hl-banner{margin-top:10px;font-size:12.5px;font-weight:600;color:var(--navy-soft);display:flex;align-items:center;gap:8px}
.hl-clear{background:transparent;border:1px solid var(--line);border-radius:7px;padding:3px 10px;font-size:12px;
  font-weight:600;color:var(--navy);cursor:pointer}
.hl-clear:hover{background:var(--cream)}
/* single-column sectioned layout */
.sec{margin-top:38px;padding-top:30px;border-top:1px solid var(--line)}
.sec-h{display:flex;align-items:center;gap:9px;font-family:'Source Serif 4',serif;font-weight:600;
  font-size:22px;color:var(--navy);margin:0 0 16px}
.sec-opt{font-family:'Inter',sans-serif;font-size:11px;font-weight:600;color:var(--muted);text-transform:none;
  letter-spacing:0;background:var(--cream);border:1px solid var(--line);border-radius:20px;padding:3px 10px}
.vactions{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin:4px 0 20px}
.panel.reslist{padding:8px 18px}
.vwrap{position:relative;width:100%;aspect-ratio:16/9;background:#0c1020;border-radius:12px;overflow:hidden;
  box-shadow:var(--shadow);margin-bottom:8px}
.vwrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.vposter{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.vempty{display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;
  background:repeating-linear-gradient(45deg,#0c1020,#0c1020 12px,#11162a 12px,#11162a 24px)}
.vempty-big{color:#e6e9f0;font-size:17px;font-weight:600;margin-bottom:6px}
.vempty-sub{color:#9aa2b6;font-size:13px;font-style:italic;max-width:440px;margin:0 auto;line-height:1.5}
.vplay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:82px;height:56px;border-radius:14px;
  background:rgba(52,63,86,.78);border:none;cursor:pointer;z-index:3;
  display:flex;align-items:center;justify-content:center;transition:background .15s,transform .15s}
.vplay:hover{background:rgba(246,246,233,.62);transform:translate(-50%,-50%) scale(1.05)}
.vplay svg{width:32px;height:32px;fill:#F6F6E9;margin-left:3px;transition:fill .15s}
.vplay:hover svg{fill:#343F56}
.vplay.hide{display:none}
.vlabel{font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:.09em;font-size:13.5px;
  font-weight:700;color:var(--navy-soft);margin:18px 0 8px}
.qa-section{margin-top:28px;padding-top:24px;border-top:1px solid var(--line)}
.qa-section .vlabel{margin-top:0}
.panel{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;
  box-shadow:var(--shadow);margin-bottom:16px}
.panel h3{font-family:'Source Serif 4',serif;color:var(--navy);font-size:18px;margin:0 0 10px}
.panel p{font-size:14.5px;line-height:1.6;margin:0 0 10px;text-align:justify}
.panel ul{margin:0;padding-left:20px}
.panel li{font-size:14px;line-height:1.55;margin:0 0 6px}
.cebar{display:inline-flex;align-items:center;gap:8px;background:rgba(47,111,79,.1);color:#2f6f4f;
  font-size:13px;font-weight:700;border-radius:8px;padding:8px 12px;margin:0}
html[data-theme="dark"] .cebar{background:rgba(86,200,143,.16);color:#7ee0ab}
.impl-btn{display:inline-flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--line);
  border-radius:9px;padding:9px 14px;font-size:13.5px;font-weight:600;color:var(--navy);cursor:pointer;
  margin:0;transition:background .12s,border-color .12s}
.impl-btn:hover{background:var(--cream);border-color:var(--navy-soft)}
.impl-btn svg{width:15px;height:15px;fill:var(--red)}
.tr-link{display:inline-flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--line);
  border-radius:9px;padding:9px 14px;font-size:13.5px;font-weight:600;color:var(--navy);cursor:pointer;
  margin:0;transition:background .12s,border-color .12s}
.tr-link:hover{background:var(--cream);border-color:var(--navy-soft)}
.tr-link svg{width:15px;height:15px;fill:var(--red)}
.tr-count{display:inline-flex;align-items:center;background:#ffe27a;color:#222a3a;font-size:11px;
  font-weight:700;letter-spacing:.02em;border-radius:999px;padding:2px 8px;margin-left:2px;
  box-shadow:0 0 0 1px rgba(220,29,38,.25)}
.impl-time{color:var(--muted);font-weight:500}
/* sidebar */
.side .panel{padding:15px 16px}
.side h4{font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:11px;
  font-weight:700;color:var(--navy-soft);margin:0 0 10px}
.res{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.res:last-child{border-bottom:none}
.res .ricon{width:22px;height:22px;border-radius:5px;background:var(--red);color:#fff;font-size:8px;font-weight:800;
  display:flex;align-items:center;justify-content:center;flex-shrink:0}
.res a{flex:1;color:var(--navy);font-weight:500}
.res.off{opacity:.4}
.res.off .ricon{background:var(--muted)}
.cs-group{font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:.07em;
  font-size:10.5px;font-weight:700;color:var(--navy-soft);margin:13px 0 3px;
  padding-top:9px;border-top:1px solid var(--line)}
.cs-group:first-child{margin-top:0;padding-top:2px;border-top:none}
/* unified resource cards (Loom walkthroughs, downloadable PDFs, sheet links) */
.rcards{display:flex;flex-direction:column;gap:16px}
.rcard{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.rcard-h{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.rcard-ic{font-size:18px;line-height:1;flex-shrink:0}
.rcard-t{font-family:'Source Serif 4',serif;font-size:17px;font-weight:600;color:var(--navy);line-height:1.2}
.loom-wrap{position:relative;width:100%;aspect-ratio:16/9;background:#0c1020;border-radius:12px;overflow:hidden;margin-bottom:12px}
.loom-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.rcard-desc{font-size:14px;color:var(--ink);line-height:1.55}
.rcard-desc p{margin:0 0 8px}
.rcard-desc p:last-child{margin-bottom:0}
.rcard-desc ul{margin:6px 0 8px;padding-left:20px}
.rcard-res{margin-top:12px;padding:2px 0 0}
.rcard-disc{margin-top:14px;padding-top:13px;border-top:1px solid var(--line);
  font-size:12.5px;font-style:italic;color:var(--muted);line-height:1.5}
.rcard-disc-lbl{font-weight:700;font-style:normal;color:var(--navy-soft);letter-spacing:.02em}
/* literal navy (not var(--navy), which inverts to near-white in dark mode and
   hides the white arrow); white arrow stays visible in both themes */
.res .ricon.link{background:#343F56;color:#fff;font-size:12px}
.res .ricon.doc{background:#4a73d6}
.rcard-img{display:block;width:100%;padding:0;border:1px solid var(--line);background:#0c1020;
  border-radius:12px;overflow:hidden;cursor:zoom-in;margin-bottom:12px;line-height:0}
.rcard-img img{display:block;width:100%;height:auto;min-height:60px}
.rcard-img + .rcard-img{margin-top:-2px}
.res-ext{flex:1;color:var(--navy);font-weight:600}
.res-ext:hover{text-decoration:underline}
.srcs .src-row{display:block;padding:8px 0;border-bottom:1px dashed var(--line)}
.srcs .src-row:last-child{border-bottom:none}
.src-name{display:block;font-size:13px;font-weight:600;color:var(--navy);line-height:1.35}
.src-cite{display:block;font-size:11.5px;color:var(--red);font-weight:600;margin-top:1px}
.srcs .src-row:hover .src-name{text-decoration:underline}
.exam-btn{display:inline-flex;align-items:center;background:var(--red);color:#fff;border-radius:10px;
  padding:12px 26px;font-weight:700;font-size:14px;margin-top:14px}
.exam-btn:hover{filter:brightness(1.07);text-decoration:none}

/* progress tracking */
.prog{display:flex;align-items:center;gap:11px;margin:0 0 26px;padding-top:24px}
.prog-track{position:relative;flex:1;height:11px;background:var(--line);border-radius:20px}
.prog-fill{position:absolute;left:0;top:0;height:100%;width:0;background:linear-gradient(90deg,#e0a93b,#f2c34e);
  border-radius:20px;transition:width .35s ease,background .25s ease}
.prog.ready .prog-fill,.prog.full .prog-fill{background:linear-gradient(90deg,#2f9e63,#34c178)}
.prog-marker{position:absolute;top:-3px;bottom:-3px;width:0;border-left:2px dashed #9aa1b0;display:none;z-index:2;transform:translateX(-1px)}
html[data-theme="dark"] .prog-marker{border-left-color:#717a8d}
.prog-mlbl{position:absolute;bottom:100%;left:0;transform:translateX(-50%);margin-bottom:9px;white-space:nowrap;
  font-family:'Roboto Condensed',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  font-size:11px;color:#9aa1b0}
html[data-theme="dark"] .prog-mlbl{color:#717a8d}
.prog.ready .prog-mlbl{color:#2f9e63}
html[data-theme="dark"] .prog.ready .prog-mlbl{color:#56c88f}
.prog-pct{font-family:'Roboto Condensed',sans-serif;font-weight:700;font-size:14px;color:#c98a10;min-width:38px;text-align:right}
.prog-lbl{font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:700;color:var(--muted)}
.prog.ready .prog-pct,.prog.full .prog-pct{color:#2f9e63}
html[data-theme="dark"] .prog.ready .prog-pct,html[data-theme="dark"] .prog.full .prog-pct{color:#56c88f}
.prog.ready .prog-lbl,.prog.full .prog-lbl{color:#2f9e63}
html[data-theme="dark"] .prog.ready .prog-lbl,html[data-theme="dark"] .prog.full .prog-lbl{color:#56c88f}
.vlabel-row{display:flex;align-items:center;gap:10px}
.sec-h .chk,.vlabel-row .chk{margin-left:auto}
.chk{width:28px;height:28px;border-radius:50%;border:2px solid var(--line);background:transparent;cursor:pointer;
  flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s,border-color .15s}
.chk svg{width:16px;height:16px;fill:var(--muted);opacity:.45;transition:fill .15s,opacity .15s}
.chk:hover{border-color:#2f9e63}
.chk:hover svg{opacity:.8}
.chk.on{background:#2f9e63;border-color:#2f9e63}
.chk.on svg{fill:#fff;opacity:1}
.chk.ro{cursor:default}
.chk.ro:hover{border-color:var(--line)}
.vlabel-row .chk{width:26px;height:26px}
/* exam passed card */
.exam-pass{background:rgba(47,158,99,.08);border:1px solid rgba(47,158,99,.35);border-radius:var(--radius);padding:16px 18px}
html[data-theme="dark"] .exam-pass{background:rgba(86,200,143,.1);border-color:rgba(86,200,143,.32)}
.ep-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.ep-badge{background:#2f9e63;color:#fff;font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:.05em;
  font-size:12px;font-weight:700;border-radius:20px;padding:4px 12px}
.ep-score{font-weight:700;color:var(--navy);font-size:15px}
.ep-date{color:var(--muted);font-size:13.5px}
.ep-note{font-size:13.5px;color:var(--ink);margin:10px 0 0}
.ep-cert{display:inline-block;margin-top:10px;font-size:13.5px;font-weight:700;color:var(--red)}
.exam-sec{margin:22px 0 34px;padding-top:0;border-top:none}
.exam-locked{display:none;align-items:center;gap:9px;background:var(--cream);border:1px dashed var(--line);
  border-radius:var(--radius);padding:14px 18px;font-size:14px;font-weight:600;color:var(--muted)}
.exam-sec.locked .exam-locked{display:flex}
.exam-sec.locked .exam-btn{display:none}
.exam-sec.locked .chk{opacity:.5}

/* in-page PDF viewer */
body.modal-open{overflow:hidden}
.pdf-modal{position:fixed;inset:0;z-index:100;background:rgba(12,15,24,.8);display:none;
  align-items:center;justify-content:center;padding:24px;overscroll-behavior:contain}
.pdf-modal.show{display:flex}
.pdf-frame{overscroll-behavior:contain}
.pdf-box{background:var(--paper);width:min(980px,100%);height:min(92vh,100%);border-radius:14px;
  overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 70px rgba(0,0,0,.55)}
.pdf-head{display:flex;align-items:center;gap:12px;padding:11px 14px 11px 18px;background:var(--paper);
  border-bottom:1px solid var(--line)}
.pdf-title{flex:1;font-weight:700;color:var(--navy);font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pdf-dl{font-size:13px;font-weight:600;color:var(--navy);border:1px solid var(--line);border-radius:8px;padding:6px 12px}
.pdf-dl:hover{text-decoration:none;background:var(--cream)}
.pdf-close{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:transparent;
  color:var(--navy);font-size:15px;cursor:pointer}
.pdf-close:hover{background:var(--cream)}
.pdf-frame{flex:1;width:100%;border:0;background:#525659}

/* ---- branded HTML transcript viewer (highlight + jump) ---- */
.tr-nav{display:inline-flex;align-items:center;gap:6px}
.tr-nav button{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:transparent;
  color:var(--navy);font-size:17px;line-height:1;cursor:pointer}
.tr-nav button:hover{background:var(--cream)}
.tr-pos{font-size:12.5px;font-weight:700;color:var(--muted);min-width:54px;text-align:center;font-variant-numeric:tabular-nums}
.tr-scroll{flex:1;min-height:0;overflow:auto;background:#525659;padding:26px 18px}
.tr-doc{max-width:760px;margin:0 auto;background:#fff;color:#1d2330;border:2px solid #343F56;
  border-radius:2px;padding:40px 48px;box-shadow:0 10px 40px rgba(0,0,0,.4);font-size:15px;line-height:1.62}
.tr-masthead{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;
  padding-bottom:12px;border-bottom:2px solid #343F56;margin-bottom:20px}
.tr-masthead img{height:30px;display:block}
.tr-docid{text-align:right;font-weight:700;font-size:9px;letter-spacing:.16em;color:#343F56;line-height:1.5}
.tr-eyebrow{font-weight:700;font-size:11px;letter-spacing:.18em;color:#DC1D26;margin-bottom:7px}
.tr-title{font-family:'Source Serif 4',Georgia,serif;font-weight:600;font-size:26px;line-height:1.14;
  color:#343F56;margin:0 0 20px}
.tr-paras p{margin:0 0 12px;text-align:justify}
.tr-ts{font-weight:700;font-size:12px;letter-spacing:.02em;color:#343F56;margin-right:8px;white-space:nowrap}
/* every keyword highlight (page + transcript, active or not) is the same yellow */
.tr-hl,.tr-hl.active{background:#ffe27a;color:#222a3a;border-radius:3px;padding:0 2px;box-shadow:0 0 0 1px rgba(220,29,38,.25)}
@media (max-width:560px){ .tr-doc{padding:26px 20px} .tr-scroll{padding:14px 8px} }

/* ---------- top nav ---------- */
.topnav{display:flex;gap:22px;margin-left:14px}
.navlink{background:transparent;border:none;font-family:'Inter',sans-serif;font-size:14px;font-weight:600;
  color:var(--muted);cursor:pointer;padding:6px 0;border-radius:0;transition:color .12s}
.navlink:hover{color:var(--navy)}
.navlink.on{color:var(--navy)}
.navlink.on::after{content:"";display:block;height:2.5px;background:var(--red);border-radius:2px;margin-top:6px}

/* ---------- calendar ---------- */
.cal-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.cal-tz{display:inline-block;font-size:12px;color:var(--navy-soft);font-weight:600;margin-left:6px}
.cal-switch{display:inline-flex;background:var(--paper);border:1px solid var(--line);border-radius:10px;
  padding:3px;box-shadow:var(--shadow);flex-shrink:0}
.cal-tab{background:transparent;border:none;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;
  padding:7px 16px;border-radius:7px;transition:background .12s,color .12s}
.cal-tab.on{background:var(--navy);color:#F6F6E9}
html[data-theme="dark"] .cal-tab.on{color:var(--cream)}
.cal-tab:not(.on):hover{color:var(--navy)}

.cal-nav{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.cal-month{font-family:'Source Serif 4',serif;font-size:21px;font-weight:600;color:var(--navy);min-width:170px}
.cal-arrow{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:var(--paper);
  color:var(--navy);font-size:20px;line-height:1;cursor:pointer;transition:background .12s}
.cal-arrow:hover{background:var(--cream)}
.cal-today{margin-left:auto;border:1px solid var(--line);background:var(--paper);color:var(--navy);
  font-size:13px;font-weight:600;border-radius:9px;padding:7px 15px;cursor:pointer}
.cal-today:hover{background:var(--cream)}

.cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.cal-wd{background:var(--paper);text-align:center;font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;
  letter-spacing:.08em;font-size:11px;font-weight:700;color:var(--navy-soft);padding:10px 0}
.cal-cell{background:var(--paper);min-height:104px;min-width:0;padding:6px 7px;display:flex;flex-direction:column;gap:4px}
.cal-cell.out{background:var(--cream);opacity:.5}
.cal-day{font-size:13px;font-weight:600;color:var(--ink);width:26px;height:26px;display:flex;
  align-items:center;justify-content:center;border-radius:50%}
.cal-day.is-today{background:var(--red);color:#fff}
.cal-ev{display:block;width:100%;max-width:100%;text-align:left;border:none;cursor:pointer;background:var(--red);color:#fff;
  font-size:11.5px;font-weight:600;line-height:1.3;border-radius:6px;padding:4px 7px;
  white-space:normal;overflow-wrap:anywhere;transition:filter .12s}
.cal-ev:hover{filter:brightness(1.08)}
.cal-ev .ev-t{font-weight:800}
.cal-ev.alt{background:#343F56;color:#F6F6E9}

/* card / list view */
.evcard{display:flex;gap:18px;justify-content:space-between;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px;margin-bottom:14px;cursor:pointer;
  transition:transform .12s,box-shadow .12s}
.evcard:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(52,63,86,.14)}
.evc-l{flex:1;min-width:0}
.evc-when{font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:.06em;font-size:12.5px;
  font-weight:700;color:var(--red);margin-bottom:5px}
.evc-title{font-family:'Source Serif 4',serif;font-size:21px;color:var(--navy);line-height:1.2;margin-bottom:9px}
.evc-meta{display:flex;align-items:center;gap:9px;margin-bottom:13px;flex-wrap:wrap}
.evc-series{font-size:12px;color:var(--muted);font-weight:600}
.evc-zoom{display:inline-flex;align-items:center;gap:8px;background:#343F56;color:#F6F6E9;border-radius:9px;
  padding:9px 16px;font-size:13.5px;font-weight:700}
.evc-zoom:hover{text-decoration:none;filter:brightness(1.18)}
.evc-zoom svg{width:17px;height:17px;fill:#F6F6E9}
html[data-theme="dark"] .evc-zoom{background:#46536f}
.evc-r{flex-shrink:0;width:190px}
.evc-img{width:190px;height:107px;border-radius:10px;object-fit:cover;display:block;border:1px solid var(--line)}
.evc-ph{background:linear-gradient(135deg,#343F56,#46536f);display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;padding:14px 12px;gap:8px;border-color:#46536f}
.evc-ph-logo{height:20px;opacity:.92}
.evc-ph-title{font-family:'Source Serif 4',serif;font-size:11.5px;color:#F6F6E9;line-height:1.2;padding:0 6px}
.evc-ph-ce{font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:.06em;font-size:9.5px;
  font-weight:700;color:#7ee0ab;border:1px solid rgba(126,224,171,.5);border-radius:20px;padding:2px 9px}

/* session detail modal — branded card (mirrors the Skool event popup) */
.sess-box{width:min(420px,100%);border-radius:18px;overflow:hidden;position:relative;
  box-shadow:0 24px 70px rgba(0,0,0,.55);background:var(--paper)}
.sess-box .pdf-close{position:absolute;top:12px;right:12px;z-index:3;background:rgba(0,0,0,.25);border:none;
  color:#F6F6E9;width:30px;height:30px;border-radius:50%}
.sess-box .pdf-close:hover{background:rgba(0,0,0,.45)}
.sess-head{background:linear-gradient(135deg,#343F56,#46536f);padding:30px 26px 24px;text-align:center;position:relative;overflow:hidden}
.sess-ribbon{position:absolute;top:16px;left:-42px;transform:rotate(-45deg);background:var(--red);color:#fff;
  font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:10.5px;font-weight:700;
  padding:4px 48px;box-shadow:0 2px 6px rgba(0,0,0,.3)}
.sess-logo{height:46px;margin:0 auto 14px;display:block}
.sess-series{font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:.12em;
  font-size:12px;font-weight:700;color:rgba(246,246,233,.78);margin-bottom:14px}
.sess-chip{background:#F6F6E9;color:#343F56;font-weight:600;font-size:14.5px;border-radius:8px;padding:9px 14px;display:inline-block;max-width:100%}
.sess-body{padding:22px 24px 26px}
.sess-title{font-family:'Source Serif 4',serif;font-size:23px;color:var(--navy);line-height:1.18;margin:0 0 16px}
.sess-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px}
.sess-ic{width:20px;height:20px;fill:var(--navy-soft);flex-shrink:0;margin-top:1px}
.sess-ic.zic{fill:#2D8CFF}
.sess-when{font-size:15px;font-weight:600;color:var(--ink);line-height:1.3}
.sess-sub{font-size:13px;color:var(--muted)}
.sess-zoom{text-decoration:none;align-items:center}
.sess-zoom .sess-link{font-size:14.5px;color:#2D8CFF;font-weight:600;line-height:1.35}
.sess-zoom:hover .sess-link{text-decoration:underline}
.sess-add{width:100%;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:9px;
  background:#343F56;color:#F6F6E9;border:none;border-radius:11px;padding:13px;font-size:14.5px;font-weight:700;cursor:pointer}
.sess-add:hover{filter:brightness(1.18)}
.sess-add svg{width:18px;height:18px;fill:#F6F6E9}
html[data-theme="dark"] .sess-add{background:#46536f}
.sess-subhint{display:block;width:100%;margin-top:12px;background:transparent;border:none;cursor:pointer;
  color:var(--navy-soft);font-size:12.5px;font-weight:600;text-align:center;line-height:1.4;padding:4px;text-decoration:underline;text-underline-offset:2px}
.sess-subhint:hover{color:var(--navy)}
.sess-lib{width:100%;margin-top:10px;background:transparent;border:1px solid var(--line);border-radius:10px;
  padding:11px;font-size:14px;font-weight:600;color:var(--navy);cursor:pointer}
.sess-lib:hover{background:var(--cream)}

/* subscribe modal */
.sub-box{background:var(--paper);width:min(460px,100%);border-radius:18px;padding:30px 30px 30px;position:relative;
  box-shadow:0 24px 70px rgba(0,0,0,.55)}
.sub-box .pdf-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:8px;
  border:1px solid var(--line);background:transparent;color:var(--navy);cursor:pointer}
.sub-box .pdf-close:hover{background:var(--cream)}
.sub-h{font-family:'Source Serif 4',serif;font-size:23px;color:var(--navy);margin:0 6px 8px 0;line-height:1.2}
.sub-sub{font-size:13.5px;color:var(--muted);line-height:1.55;margin:0 0 20px}
.sub-opts{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.sub-opt{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:11px;padding:13px 16px;
  font-size:14.5px;font-weight:600;color:var(--navy);background:var(--paper);transition:background .12s,border-color .12s}
.sub-opt:hover{text-decoration:none;background:var(--cream);border-color:var(--navy-soft)}
.sub-ic{width:9px;height:9px;border-radius:50%;background:var(--red);flex-shrink:0}
.sub-url{display:flex;gap:8px}
.sub-url input{flex:1;min-width:0;border:1px solid var(--line);border-radius:9px;padding:10px 12px;font-size:12.5px;
  color:var(--muted);background:var(--cream);font-family:'Roboto Condensed',monospace}
.sub-copy{border:none;background:#343F56;color:#F6F6E9;border-radius:9px;padding:10px 16px;
  font-size:13px;font-weight:700;cursor:pointer;flex-shrink:0}
.sub-copy:hover{filter:brightness(1.18)}
html[data-theme="dark"] .sub-copy{background:#46536f}
.sub-note{font-size:12px;color:var(--muted);line-height:1.5;margin:16px 0 0;padding-top:14px;border-top:1px solid var(--line)}

/* calendar header actions */
.cal-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.cal-sub{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;border:none;border-radius:10px;
  padding:9px 16px;font-size:13.5px;font-weight:700;cursor:pointer;box-shadow:var(--shadow)}
.cal-sub:hover{filter:brightness(1.07)}
.cal-sub svg{width:16px;height:16px;fill:#fff}

@media (max-width:820px){
  .layout{grid-template-columns:1fr}
  .cls-title{font-size:24px}
  .pdf-modal{padding:0}
  .pdf-box{height:100%;border-radius:0}
  .topnav{margin-left:0;gap:0}
  .navlink{padding:7px 9px;font-size:13px}
  .cal-cell{min-height:74px;padding:4px}
  .cal-ev{font-size:10px;padding:3px 5px}
  .cal-day{width:22px;height:22px;font-size:12px}
  .evcard{flex-direction:column-reverse;gap:12px}
  .evc-r,.evc-img,.evc-ph{width:100%}
  .evc-img{height:170px}
}

/* ---- login states + messages (magic link) ---- */
.login-msg{font-size:12.5px;line-height:1.5;margin:12px 0 0}
.login-msg.err{color:var(--red)}
.login-msg.ok{color:#2e7d46}
.login-state{text-align:center}
.login-state h2{font-family:'Source Serif 4',serif;color:var(--navy);font-size:19px;margin:8px 0 8px}
.login-state p{color:var(--muted);font-size:13.5px;line-height:1.6;margin:0 0 6px}
.login-state .btn-primary{display:inline-block;width:auto;padding:11px 30px;margin-top:0}

/* ---- gated PDF viewer body (loading / error states) ---- */
.pdf-body{flex:1;min-height:0;display:flex;flex-direction:column;background:#525659}
.pdf-loading,.pdf-err{margin:auto;text-align:center;padding:30px;color:#fff;font-size:14.5px;line-height:1.6;max-width:440px}
.pdf-err{color:#ffd9db}

/* ---- account / settings ---- */
.acct-form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.acct-form label{display:block;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--navy-soft);margin:0 0 5px}
.acct-form input{width:100%;box-sizing:border-box;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:14.5px;background:#fff;color:#343F56;font-family:inherit}
.acct-form input::placeholder{color:#8893a8}
.acct-form input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(52,63,86,.12)}
.acct-form input:disabled{background:var(--cream);color:var(--muted)}
.acct-hint{display:block;margin-top:5px;font-size:11px;color:var(--muted);line-height:1.4}
.acct-form-actions{grid-column:1/-1;display:flex;align-items:center;gap:14px}
.acct-form-actions .btn-primary{width:auto;margin-top:0;padding:11px 28px}
.acct-savemsg{font-size:13px}.acct-savemsg.ok{color:#2e7d46}.acct-savemsg.err{color:var(--red)}
.acct-ce{width:100%;border-collapse:collapse;font-size:13.5px}
.acct-ce th{text-align:left;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);padding:0 10px 9px;border-bottom:1px solid var(--line)}
.acct-ce td{padding:11px 10px;border-bottom:1px solid var(--line);vertical-align:middle;color:var(--ink)}
.acct-ce tr:last-child td{border-bottom:none}
.ce-pid{color:var(--muted);font-size:10.5px}
.ce-cert{color:var(--red);font-weight:700;white-space:nowrap}
.acct-links{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:22px}
.acct-link{display:block;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;color:var(--ink);text-decoration:none}
.acct-link:hover{border-color:var(--navy);text-decoration:none}
.acct-link:hover .al-h,.acct-link:hover .al-p,.acct-link:hover .al-cta{text-decoration:none}
.al-h{font-family:'Source Serif 4',serif;color:var(--navy);font-size:16px;font-weight:600;margin:0 0 5px}
.al-p{font-size:13px;color:var(--muted);line-height:1.45;margin:0 0 10px}
.al-cta{font-size:13px;font-weight:700;color:var(--red)}
@media(max-width:620px){.acct-form{grid-template-columns:1fr}.acct-links{grid-template-columns:1fr}}

/* ---- upcoming (scheduled, not-yet-recorded) classes ---- */
.up-note{color:var(--muted);font-size:13px;margin:-4px 0 14px;line-height:1.5}
.card.upcoming{cursor:pointer;opacity:.8;transition:opacity .15s,transform .15s,box-shadow .15s}
.card.upcoming:hover{opacity:1}
.card.upcoming .card-tile{filter:saturate(.8) brightness(.96);position:relative}
.up-sec{margin-bottom:32px}
.up-tags{display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}
.pill.scheduled{background:transparent;color:var(--navy-soft);border:1px solid var(--line)}
.up-when{display:flex;align-items:center;gap:7px;font-weight:600;color:var(--navy-soft)}
.card-when2{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted);margin-top:5px;line-height:1.35}
.up-cal{width:14px;height:14px;fill:currentColor;flex:none}
.pill.sched{background:#e7eaf0;color:#46536f}
[data-theme=dark] .pill.sched{background:#2a3346;color:#aeb7cc}

/* ===========================================================================
   PHONE LAYOUT (<=600px) — app-like home-screen experience.
   Primary nav drops to a fixed bottom tab bar (the way Skool's app feels);
   the top bar slims to just the brand + log out. Fixes the horizontal
   overflow caused by the desktop top bar not fitting phone width.
   =========================================================================== */
@media (max-width:600px){
  /* --- slim top bar: brand + log out only --- */
  .topbar-in{padding:10px 15px;gap:10px}
  .topbar-logo{height:26px}
  .who{display:none}                         /* email shown on the Account tab instead */
  .btn-ghost{padding:7px 12px;font-size:12.5px}

  /* --- primary nav -> fixed bottom tab bar --- */
  .topnav{position:fixed;left:0;right:0;bottom:0;z-index:50;margin:0;gap:0;
    display:flex;justify-content:space-around;align-items:stretch;
    background:var(--paper);border-top:1px solid var(--line);
    padding:7px 4px calc(7px + env(safe-area-inset-bottom));
    box-shadow:0 -2px 14px rgba(52,63,86,.12)}
  .navlink{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:2px;padding:5px 2px;font-size:11px;line-height:1.15;text-align:center;
    white-space:normal;color:var(--muted)}
  .navlink::before{font-size:19px;line-height:1;font-weight:400}
  #navLibrary::before{content:"\1F4DA"}      /* books */
  #navCalendar::before{content:"\1F4C5"}      /* calendar */
  #navAccount::before{content:"\1F464"}       /* person */
  .navlink.on{color:var(--red)}
  .navlink.on::after{display:none}            /* underline doesn't belong in a tab bar */

  /* --- give content room above the bottom bar + lift the theme toggle --- */
  main{padding:18px 14px calc(86px + env(safe-area-inset-bottom))}
  .theme-toggle{bottom:calc(78px + env(safe-area-inset-bottom));width:38px;height:38px;font-size:16px}
  .foot{display:none}                         /* redundant with the tab bar on phone */

  /* --- single-column cards, comfortable tap targets --- */
  /* minmax(0,1fr) (not 1fr) so a grid item can't keep its intrinsic min-width
     and push the page wider than the phone viewport */
  .grid{grid-template-columns:minmax(0,1fr);gap:14px}
  .lib-h{font-size:22px}
  .lib-sub{margin-bottom:18px}
  .lib-search{min-width:0}
  .lib-search input{min-width:0}             /* let the search field shrink below its text width */
  .card-logo{width:64%}

  /* --- class page: align the pinned header to the slimmer top bar --- */
  .cls-sticky{top:46px}
  .cls-title{font-size:23px}
  .sec-h{font-size:20px}

  /* --- calendar: default to the readable list view feel; keep month usable --- */
  .cal-month{min-width:0;font-size:19px}
  .cal-grid{font-size:11px}
  .cal-cell{min-height:62px;padding:3px}
  .cal-ev{font-size:9.5px;padding:2px 4px}

  /* --- account: let the CE table scroll instead of squishing --- */
  .acct-ce{font-size:12.5px}
  .acct-ce th,.acct-ce td{padding:9px 7px}
}

/* ---- "How to earn your CE" steps card ---- */
.ce-steps{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:15px 20px 13px;margin:0 0 22px;box-shadow:var(--shadow)}
.ce-steps-h{font-family:'Source Serif 4',serif;font-size:16.5px;font-weight:600;color:var(--navy);margin:0 0 9px}
.ce-steplist{list-style:none;margin:0;padding:0}
.cstep{display:flex;align-items:center;gap:11px;padding:5px 0;font-size:14.5px;color:var(--ink)}
.cstep-ic{width:23px;height:23px;flex:none;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12.5px;font-weight:700;line-height:1}
.cstep-ic::before{content:attr(data-n)}
.cstep.todo .cstep-ic{background:var(--cream);border:1.5px solid var(--line);color:var(--navy-soft)}
.cstep.ready .cstep-ic{background:var(--red);color:#fff}
.cstep.done .cstep-ic{background:#3a9d68;color:#fff}
.cstep.done .cstep-ic::before{content:'✓'}
.cstep.done{color:var(--muted)}
.cstep.locked .cstep-ic{background:var(--cream);border:1.5px solid var(--line)}
.cstep.locked .cstep-ic::before{content:'🔒';font-size:11px}
.cstep.locked{color:var(--muted)}
.ce-steps-foot{font-size:12.5px;color:var(--muted);margin-top:9px;border-top:1px solid var(--line);padding-top:9px}
