/* Menti app — OLED-black design system (Phase 11, revised).
   high-end-visual-design "Ethereal Glass": deepest OLED black, vantablack
   cards w/ white-10 hairlines, glowing emerald. Fraunces + Plus Jakarta Sans.
   Built on CSS tokens so the whole app + inline var() markup flips by remap.
   Every selector the markup/JS relies on is preserved — only values changed. */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* surfaces (OLED) */
  --paper:#08080A;--paper-2:#19191C;--card-w:#121214;
  --night:#040405;--night-2:#0E0E11;
  /* ink */
  --ink:#F4F2EE;--ink-soft:#C9C5BD;
  --on-night:#F4F2EE;--on-night-muted:#948F86;
  /* brand — fill emerald keeps white text ≥4.5:1; bright emerald is accent text on black */
  --emerald:#0E7C5A;--emerald-strong:#0B6447;--emerald-bright:#3CE6AC;
  --emerald-tint:rgba(24,185,129,.13);--amber:#E8A33D;--amber-tint:rgba(232,163,61,.16);
  /* lines */
  --hair:rgba(255,255,255,.08);--hair-2:rgba(255,255,255,.14);--hair-night:rgba(255,255,255,.07);
  /* type / motion / radii / shadow */
  --serif:'Fraunces',Georgia,serif;--sans:'Plus Jakarta Sans',system-ui,sans-serif;
  --ease:cubic-bezier(.32,.72,0,1);
  --r-lg:18px;--r-md:14px;--r-sm:10px;--r-pill:999px;
  --shadow-soft:0 1px 0 rgba(255,255,255,.04) inset,0 18px 44px -22px rgba(0,0,0,.85);
  --shadow-lift:0 1px 0 rgba(255,255,255,.05) inset,0 34px 70px -30px rgba(0,0,0,.95);

  /* ── legacy token names (kept so inline var(--x) in markup still resolves) ── */
  --navy:#08080A;--navy2:#121214;
  --accent:#0E7C5A;--accent2:#3CE6AC;
  --red:#FF6B6B;--gold:#E8A33D;
  --green:#18B981;--yellow:#E8A33D;--danger:#FF6B6B;
  --text:#F4F2EE;--muted:#8C877E;--muted2:#5E5A53;
  --border:rgba(255,255,255,.08);--border2:rgba(255,255,255,.14);
  --card:#121214;--card2:#1C1C20;
  --sb:208px;
  /* semantic status (legible on OLED black) */
  --ok:#3CE6AC;--ok-bg:rgba(24,185,129,.14);
  --warn:#F0C674;--warn-bg:rgba(232,163,61,.16);
  --bad:#FF8585;--bad-bg:rgba(255,107,107,.14);
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);overflow-x:hidden;line-height:1.6;
  letter-spacing:-.01em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;letter-spacing:-.02em}
button{cursor:pointer;font-family:var(--sans)}
input,textarea,select{font-family:var(--sans)}
:focus-visible{outline:2.5px solid var(--emerald);outline-offset:2px;border-radius:4px}
::selection{background:var(--emerald);color:#fff}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-thumb{background:var(--hair-2);border-radius:3px}

/* ── demo bar (deep-ink) ── */
.demo-bar{background:var(--night);border-bottom:1px solid var(--hair-night);padding:8px 16px;display:flex;align-items:center;gap:9px;flex-wrap:wrap;justify-content:center;position:fixed;top:0;left:0;right:0;z-index:999}
.demo-bar span{font-size:11px;color:var(--on-night-muted);font-weight:600;letter-spacing:1px}
.dbtn{background:rgba(255,255,255,.06);border:1px solid var(--hair-night);color:var(--on-night);padding:5px 13px;border-radius:var(--r-pill);font-size:12px;font-weight:600;transition:all .25s var(--ease)}
.dbtn:hover,.dbtn.active{background:var(--emerald);border-color:var(--emerald);color:#fff}
.dbtn.m:hover,.dbtn.m.active{background:var(--emerald);border-color:var(--emerald)}
.dbtn.p:hover,.dbtn.p.active{background:var(--amber);border-color:var(--amber);color:#3d2c08}
.dbtn.a:hover,.dbtn.a.active{background:var(--emerald);border-color:var(--emerald);color:#fff}

/* ── views ── */
.view{display:none;min-height:100vh;padding-top:44px}
.view.active{display:flex}
#vlogin{display:none;align-items:center;justify-content:center;
  background:radial-gradient(ellipse 760px 520px at 50% -5%,var(--emerald-tint),transparent 70%)}
#vlogin.active{display:flex}

/* ── auth card ── */
.lbox{background:var(--card-w);border:1px solid var(--hair);border-radius:var(--r-lg);padding:36px;width:380px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-lift)}
.llogo{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--ink);margin-bottom:4px;letter-spacing:-.02em}
.llogo span{color:var(--emerald)}
.lsub{font-size:13px;color:var(--muted);margin-bottom:22px}
.llbl{font-size:10px;font-weight:600;color:var(--muted);margin-bottom:5px;display:block;text-transform:uppercase;letter-spacing:.5px}
.linp{width:100%;background:var(--paper);border:1px solid var(--hair-2);border-radius:var(--r-sm);padding:12px 13px;color:var(--ink);font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s;margin-bottom:11px}
.linp:focus{border-color:var(--emerald);box-shadow:0 0 0 3px var(--emerald-tint)}
.linp::placeholder{color:var(--muted2)}
.lbtn{width:100%;background:var(--emerald);color:#fff;padding:13px;border-radius:var(--r-pill);font-size:14px;font-weight:600;border:none;cursor:pointer;transition:background .25s var(--ease),transform .25s var(--ease),box-shadow .25s var(--ease);box-shadow:0 10px 24px -12px rgba(14,124,90,.6)}
.lbtn:hover{background:var(--emerald-strong);box-shadow:0 14px 30px -12px rgba(14,124,90,.7)}
.lbtn:active{transform:scale(.985)}
.lerr{background:var(--bad-bg);border:1px solid rgba(220,38,38,.2);border-radius:var(--r-sm);padding:9px 12px;font-size:12px;color:var(--bad);margin-bottom:10px;display:none}

/* ── sidebar (deep-ink) ── */
.sidebar{width:var(--sb);flex-shrink:0;background:var(--night);border-right:1px solid var(--hair-night);display:flex;flex-direction:column;position:fixed;top:44px;left:0;bottom:0;z-index:100;overflow-y:auto}
.sblogo{padding:18px 14px 14px;border-bottom:1px solid var(--hair-night)}
.logo{font-family:var(--serif);font-size:19px;font-weight:700;color:#fff;letter-spacing:-.02em}
.logo span{color:var(--emerald-bright)}
.sbrole{font-size:9px;color:var(--on-night-muted);font-weight:600;letter-spacing:1.5px;text-transform:uppercase;margin-top:3px}
.sbnav{flex:1;padding:12px 8px}
.sbsec{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--on-night-muted);padding:0 7px;margin:13px 0 5px;opacity:.7}
.sbi{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:var(--r-sm);color:var(--on-night-muted);font-size:12.5px;font-weight:500;transition:all .2s var(--ease);cursor:pointer;border:none;background:transparent;width:100%;text-align:left;margin-bottom:2px}
.sbi:hover{color:#fff;background:rgba(255,255,255,.06)}
.sbi.active{color:#fff;background:var(--emerald)}
.sbi .ic{font-size:14px;width:15px;text-align:center;flex-shrink:0}
.sbbadge{margin-left:auto;background:var(--amber);color:#3d2c08;font-size:9px;font-weight:700;padding:1px 6px;border-radius:var(--r-pill)}
.sbb{padding:10px 8px;border-top:1px solid var(--hair-night)}
.sbuser{background:rgba(255,255,255,.05);border:1px solid var(--hair-night);border-radius:var(--r-sm);padding:9px;display:flex;align-items:center;gap:8px}
.sbav{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}
.sbun{font-size:11px;font-weight:600;color:#fff}
.sbup{font-size:10px;color:var(--on-night-muted)}
.sbout{background:transparent;border:none;color:var(--on-night-muted);font-size:10px;margin-top:5px;padding:3px 0;cursor:pointer;text-align:left;transition:color .2s;width:100%}
.sbout:hover{color:#FCA5A5}

/* ── main / topbar ── */
.main{margin-left:var(--sb);flex:1;overflow-y:auto;background:var(--paper)}
.topbar{position:sticky;top:0;z-index:50;background:rgba(10,10,12,.72);backdrop-filter:blur(16px) saturate(150%);-webkit-backdrop-filter:blur(16px) saturate(150%);border-bottom:1px solid var(--hair);padding:12px 24px;display:flex;align-items:center;justify-content:space-between}
.tbtitle{font-family:var(--serif);font-size:17px;font-weight:600;color:var(--ink);letter-spacing:-.02em}
.tbr{display:flex;align-items:center;gap:9px}
.bsm{padding:8px 15px;border-radius:var(--r-pill);font-size:12px;font-weight:600;border:none;transition:all .25s var(--ease);cursor:pointer}
.bsm.pri{background:var(--emerald);color:#fff;box-shadow:0 8px 20px -12px rgba(14,124,90,.6)}
.bsm.pri:hover{background:var(--emerald-strong)}
.bsm.gh{background:transparent;border:1px solid var(--hair-2);color:var(--ink)}
.bsm.gh:hover{background:var(--ink);color:var(--paper)}
.nbtn{background:transparent;border:1px solid var(--hair-2);color:var(--muted);padding:7px 9px;border-radius:var(--r-sm);font-size:13px;position:relative;transition:all .2s;cursor:pointer}
.nbtn:hover{color:var(--ink);border-color:var(--ink)}
.ndot{position:absolute;top:3px;right:3px;width:6px;height:6px;border-radius:50%;background:var(--red);border:1.5px solid var(--paper)}

/* ── pages / cards ── */
.page{display:none;padding:24px}
.page.active{display:block}
.card{background:var(--card-w);border:1px solid var(--hair);border-radius:var(--r-md);padding:18px;box-shadow:var(--shadow-soft)}
.chd{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:13px;display:flex;align-items:center;justify-content:space-between}
.clink{font-size:11px;color:var(--emerald-bright);cursor:pointer;font-weight:600}
.clink:hover{color:#fff}

/* ── KPI row ── */
.kr{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.kc{background:var(--card-w);border:1px solid var(--hair);border-radius:var(--r-md);padding:16px;box-shadow:var(--shadow-soft)}
.kv{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--ink);margin-bottom:2px;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.kl{font-size:11px;color:var(--muted)}
.kch{font-size:10px;margin-top:3px}
.kch.up{color:var(--emerald-bright)}
.kch.w{color:var(--warn)}

/* ── welcome band ── */
.wband{background:linear-gradient(135deg,var(--emerald-tint),transparent 70%);border:1px solid var(--hair);border-radius:var(--r-md);padding:22px 26px;margin-bottom:18px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-soft)}
.wband h2{font-family:var(--serif);font-size:21px;font-weight:600;margin-bottom:3px;letter-spacing:-.02em}
.wband p{font-size:12.5px;color:var(--muted)}

/* ── dashboard grid + uni rows ── */
.dgrid{display:grid;grid-template-columns:1fr 300px;gap:16px}
.urow{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--hair)}
.urow:last-child{border-bottom:none}
.uflag{font-size:18px;width:24px;text-align:center}
.uiw{flex:1}
.unm{font-size:12.5px;font-weight:600;margin-bottom:1px}
.upt{font-size:10px;color:var(--muted)}
.cp{padding:2px 9px;border-radius:var(--r-pill);font-size:10px;font-weight:600;display:inline-block}
.cp.h{background:var(--ok-bg);color:var(--ok)}
.cp.m{background:var(--warn-bg);color:var(--warn)}
.cp.l{background:var(--bad-bg);color:var(--bad)}

/* ── checklist ── */
.chi{display:flex;align-items:flex-start;gap:9px;padding:9px 0;border-bottom:1px solid var(--hair)}
.chi:last-child{border-bottom:none}
.chk{width:17px;height:17px;border-radius:5px;border:1.5px solid var(--hair-2);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;cursor:pointer;transition:all .2s}
.chk.done{background:var(--emerald);border-color:var(--emerald);color:#fff;font-size:9px}
.chl{font-size:12px;flex:1}
.chl.done{color:var(--muted);text-decoration:line-through}
.chd2{font-size:10px;color:var(--muted);margin-top:1px}

/* ── deadline list ── */
.dli{margin-bottom:10px}
.dlt{display:flex;justify-content:space-between;margin-bottom:5px}
.dlu{font-size:11px;font-weight:600}
.dld{font-size:10px;color:var(--muted)}
.pb{height:5px;background:var(--paper-2);border-radius:3px;overflow:hidden}
.pbf{height:100%;border-radius:3px}
.pbf.b{background:var(--emerald)}
.pbf.w{background:var(--amber)}
.pbf.d{background:var(--danger)}

/* ── search row / filters ── */
.sr{display:flex;gap:9px;margin-bottom:16px;flex-wrap:wrap}
.sinp{flex:1;min-width:160px;background:var(--card-w);border:1px solid var(--hair-2);border-radius:var(--r-sm);padding:9px 12px;color:var(--ink);font-size:12px;outline:none;transition:border-color .2s,box-shadow .2s}
.sinp:focus{border-color:var(--emerald);box-shadow:0 0 0 3px var(--emerald-tint)}
.sinp::placeholder{color:var(--muted2)}
.fsel{background:var(--card-w);border:1px solid var(--hair-2);border-radius:var(--r-sm);padding:9px 12px;color:var(--ink-soft);font-size:12px;outline:none;cursor:pointer}
.fsel option{background:#141416;color:var(--ink)}

/* ── university cards ── */
.ucg{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.uc{background:var(--card-w);border:1px solid var(--hair);border-radius:var(--r-md);padding:16px;transition:all .3s var(--ease);cursor:pointer;box-shadow:var(--shadow-soft);display:flex;flex-direction:column}
.uc .addb{margin-top:auto}
.uc:hover{border-color:rgba(14,124,90,.3);transform:translateY(-3px);box-shadow:var(--shadow-lift)}
.ucn{font-size:13px;font-weight:600;margin-bottom:1px}
.ucl{font-size:10px;color:var(--muted)}
.ucs{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:10px 0}
.usv{font-size:12px;font-weight:600;text-align:center}
.usl{font-size:9px;color:var(--muted);text-align:center;margin-top:1px}
.addb{width:100%;padding:7px;border-radius:var(--r-pill);border:1px solid var(--hair-2);background:transparent;color:var(--ink-soft);font-size:11px;font-weight:600;transition:all .2s;cursor:pointer}
.addb:hover{border-color:var(--emerald);color:var(--emerald-bright);background:var(--emerald-tint)}
.addb.added{background:var(--ok-bg);border-color:var(--emerald);color:var(--ok)}

/* ── chance form / results ── */
.cf{background:var(--card-w);border:1px solid var(--hair);border-radius:var(--r-md);padding:22px;margin-bottom:18px;box-shadow:var(--shadow-soft)}
.fg{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.fg3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:12px}
.fl{display:flex;flex-direction:column;gap:5px}
.fl label{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.fl input,.fl select,.fl textarea{background:var(--paper);border:1px solid var(--hair-2);border-radius:var(--r-sm);padding:10px 11px;color:var(--ink);font-size:12px;outline:none;transition:border-color .2s,box-shadow .2s}
.fl input:focus,.fl select:focus,.fl textarea:focus{border-color:var(--emerald);box-shadow:0 0 0 3px var(--emerald-tint)}
.fl input::placeholder,.fl textarea::placeholder{color:var(--muted2)}
.fl select option{background:#141416;color:var(--ink)}
.fl input[type=range]{accent-color:var(--emerald);width:100%;padding:0;background:transparent;border:none;height:22px;cursor:pointer}
.fl input[type=range]:focus{box-shadow:none}
.cres{background:var(--card-w);border:1px solid var(--hair);border-radius:var(--r-md);padding:22px;box-shadow:var(--shadow-soft)}
.rhd{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:9px}
.frow{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.flbl{width:185px;font-size:11px;color:var(--muted);flex-shrink:0}
.fbw{flex:1;height:5px;background:var(--paper-2);border-radius:3px;overflow:hidden}
.fbar{height:100%;border-radius:3px;transition:width .6s var(--ease)}
.fbar.g{background:var(--emerald)}
.fbar.y{background:var(--amber)}
.fbar.r{background:var(--danger)}
.fp{width:28px;font-size:10px;color:var(--muted);text-align:right}
.aibox{background:var(--emerald-tint);border:1px solid rgba(14,124,90,.2);border-radius:var(--r-sm);padding:13px;margin-top:14px}
.ailbl{font-size:9px;font-weight:700;color:var(--emerald-bright);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.typing{display:inline-flex;gap:3px}
.typing span{width:5px;height:5px;border-radius:50%;background:var(--emerald);animation:bnc .8s infinite}
.typing span:nth-child(2){animation-delay:.15s}
.typing span:nth-child(3){animation-delay:.3s}
@keyframes bnc{0%,80%,100%{transform:translateY(0)}40%{transform:translateY(-5px)}}

/* ── essay editor ── */
.egrid{display:grid;grid-template-columns:1fr 280px;gap:16px}
.eed{background:var(--card-w);border:1px solid var(--hair);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-soft)}
.etop{padding:11px 14px;border-bottom:1px solid var(--hair);display:flex;align-items:center;justify-content:space-between}
.emeta{font-size:11px;color:var(--muted)}
.eta{width:100%;min-height:320px;background:transparent;border:none;padding:16px;color:var(--ink);font-size:14px;line-height:1.8;resize:none;outline:none;font-family:var(--sans)}
.eta::placeholder{color:var(--muted2)}
.efoot{padding:9px 14px;border-top:1px solid var(--hair);display:flex;align-items:center;justify-content:space-between}
.wct{font-size:10px;color:var(--muted)}
.mfb{background:var(--ok-bg);border:1px solid rgba(14,124,90,.2);border-radius:var(--r-sm);padding:12px;margin-bottom:8px}
.mfbh{display:flex;align-items:center;gap:7px;margin-bottom:5px}
.mfbn{font-size:11px;font-weight:600;color:var(--ok)}
.mfbd{font-size:10px;color:var(--muted)}
.mfbt{font-size:12px;color:var(--ink-soft);line-height:1.5}
.fsg{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:10px}
.fsc{background:var(--paper-2);border-radius:var(--r-sm);padding:9px;text-align:center}
.fsv{font-size:18px;font-weight:600;font-family:var(--serif)}
.fsv.g{color:var(--emerald-bright)}
.fsv.y{color:var(--warn)}
.fsv.r{color:var(--bad)}
.fsl{font-size:9px;color:var(--muted);margin-top:2px}
.fbit{display:flex;gap:6px;font-size:11px;color:var(--muted);margin-bottom:5px;line-height:1.4}

/* ── documents ── */
.dgr{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:11px}
.dc{background:var(--card-w);border:1px solid var(--hair);border-radius:var(--r-md);padding:15px;box-shadow:var(--shadow-soft)}
.dic{font-size:24px;margin-bottom:8px}
.dn{font-size:11.5px;font-weight:600;margin-bottom:2px}
.dm{font-size:10px;color:var(--muted);margin-bottom:9px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.ds{display:inline-flex;align-items:center;font-size:10px;font-weight:600;padding:2px 9px;border-radius:var(--r-pill)}
.ds.r{background:var(--ok-bg);color:var(--ok)}
.ds.p{background:var(--warn-bg);color:var(--warn)}
.ds.m{background:var(--bad-bg);color:var(--bad)}
.upz{border:2px dashed var(--hair-2);border-radius:var(--r-md);padding:24px;text-align:center;cursor:pointer;transition:all .2s;margin-top:12px}
.upz:hover{border-color:var(--emerald);background:var(--emerald-tint)}
.upz p{font-size:11px;color:var(--muted);margin-top:4px}

/* ── student list (mentor) ── */
.sl{display:flex;flex-direction:column;gap:9px}
.si{background:var(--card-w);border:1px solid var(--hair);border-radius:var(--r-md);padding:13px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .25s var(--ease);box-shadow:var(--shadow-soft)}
.si:hover{border-color:rgba(14,124,90,.3);transform:translateY(-2px);box-shadow:var(--shadow-lift)}
.sav{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;color:#fff}
.sinfo{flex:1}
.sname{font-size:12.5px;font-weight:600;margin-bottom:1px}
.suni{font-size:10px;color:var(--muted)}
.spb{height:4px;background:var(--paper-2);border-radius:2px;overflow:hidden;margin-top:4px;width:90px}
.spbf{height:100%;background:var(--emerald);border-radius:2px}
.sd{background:var(--card-w);border:1px solid var(--hair);border-radius:var(--r-md);padding:18px;margin-top:18px;box-shadow:var(--shadow-soft)}

/* ── tasks ── */
.ti{display:flex;align-items:flex-start;gap:9px;padding:8px 0;border-bottom:1px solid var(--hair)}
.ti:last-child{border-bottom:none}
.ts{padding:2px 7px;border-radius:var(--r-pill);font-size:9px;font-weight:700;text-transform:uppercase;flex-shrink:0;margin-top:2px}
.ts.td{background:var(--paper-2);color:var(--muted)}
.ts.dn{background:var(--ok-bg);color:var(--ok)}
.ts.lt{background:var(--bad-bg);color:var(--bad)}

/* ── feedback form / ratings ── */
.fbf{background:var(--card-w);border:1px solid var(--hair);border-radius:var(--r-md);padding:18px;box-shadow:var(--shadow-soft)}
.fbta{width:100%;background:var(--paper);border:1px solid var(--hair-2);border-radius:var(--r-sm);padding:11px;color:var(--ink);font-size:12px;line-height:1.6;resize:none;outline:none;min-height:80px;margin-bottom:9px;font-family:var(--sans)}
.fbta:focus{border-color:var(--emerald);box-shadow:0 0 0 3px var(--emerald-tint)}
.rrow{display:flex;gap:6px;margin-bottom:11px;align-items:center}
.rl{font-size:11px;color:var(--muted);font-weight:600}
.rb{width:27px;height:27px;border-radius:50%;border:1px solid var(--hair-2);background:transparent;color:var(--muted);font-size:10px;font-weight:700;transition:all .2s;cursor:pointer}
.rb.sel{background:var(--emerald);border-color:var(--emerald);color:#fff}

/* ── admin tables ── */
.atbl{background:var(--card-w);border:1px solid var(--hair);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-soft)}
.thd{display:grid;padding:10px 15px;background:var(--paper-2);border-bottom:1px solid var(--hair);font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.tr{display:grid;padding:11px 15px;border-bottom:1px solid var(--hair);align-items:center;transition:background .2s;cursor:pointer}
.tr:last-child{border-bottom:none}
.tr:hover{background:var(--paper-2)}
.badge{padding:2px 8px;border-radius:var(--r-pill);font-size:10px;font-weight:600}
.badge.pro{background:var(--emerald-tint);color:var(--emerald-bright)}
.badge.max{background:var(--amber-tint);color:var(--warn)}
.badge.act{background:var(--ok-bg);color:var(--ok)}
.badge.pnd{background:var(--warn-bg);color:var(--warn)}
.badge.rev{background:var(--paper-2);color:var(--ink-soft)}
.badge.rej{background:var(--bad-bg);color:var(--bad)}
.badge.draft{background:var(--paper-2);color:var(--muted)}

/* ── pgrid / timeline ── */
.pgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.tlitem{display:flex;gap:12px;margin-bottom:13px;position:relative}
.tlitem::before{content:'';position:absolute;left:13px;top:28px;bottom:-4px;width:2px;background:var(--hair-2)}
.tlitem:last-child::before{display:none}
.tldot{width:26px;height:26px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;z-index:1}
.tldot.dn{background:var(--emerald);color:#fff}
.tldot.ac{background:var(--amber);color:#3d2c08}
.tldot.td{background:var(--paper-2);color:var(--muted)}
.tlc{flex:1;padding-top:3px}
.tlt{font-size:12px;font-weight:600;margin-bottom:1px}
.tld{font-size:10px;color:var(--muted);line-height:1.4}

/* ── notification feed panel (10.9) ── */
.notif-pop{position:fixed;top:62px;right:24px;z-index:600;width:330px;max-width:calc(100vw - 32px);
  background:var(--card-w);border:1px solid var(--hair-2);border-radius:var(--r-md);
  box-shadow:var(--shadow-lift);padding:6px;display:none;max-height:72vh;overflow-y:auto}
.notif-pop.open{display:block}
.np-h{font-size:12px;font-weight:700;padding:9px 10px 7px;color:var(--ink)}
.np-i{display:flex;gap:10px;padding:9px 10px;border-top:1px solid var(--hair)}
.np-ic{font-size:16px;flex-shrink:0;line-height:1.3}
.np-t{font-size:12px;color:var(--ink);line-height:1.4}
.np-s{font-size:10px;color:var(--muted);margin-top:2px}
.np-empty{font-size:12px;color:var(--muted);padding:16px 10px;text-align:center}

/* ── toast ── */
#toast{position:fixed;top:14px;left:50%;transform:translateX(-50%) translateY(-80px);z-index:9999;background:var(--emerald);color:#fff;padding:10px 22px;border-radius:var(--r-pill);font-size:12px;font-weight:700;box-shadow:var(--shadow-lift);transition:transform .4s cubic-bezier(.34,1.56,.64,1);white-space:nowrap}

/* ── responsive ── */
@media(max-width:768px){
  .sidebar{width:54px}
  .logo,.sbrole,.sbun,.sbup,.sbout,.sbsec{display:none}
  .sbi{justify-content:center;padding:10px}
  .sbi span:not(.ic){display:none}
  .sbbadge{display:none}
  :root{--sb:54px}
  .kr{grid-template-columns:1fr 1fr}
  .dgrid,.egrid,.pgrid{grid-template-columns:1fr}
  .fg,.fg3{grid-template-columns:1fr}
  .page{padding:16px}
  .topbar{padding:10px 14px}
}

/* ── parent portal read-only rows (10.6) ── */
.prow{display:flex;align-items:center;gap:10px;padding:9px 2px;border-bottom:1px solid var(--hair)}
.prow:last-child{border-bottom:none}
.pic{flex-shrink:0;font-size:15px;width:20px;text-align:center}
.pnm{flex:1;font-size:12px;color:var(--ink);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.prow .ds,.prow .badge{flex-shrink:0}

/* ── reduced motion ── */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important;scroll-behavior:auto}
}
