/* ── TOKENS ─────────────────────────────────────────────── */
:root{
  --f:'Pretendard',-apple-system,BlinkMacSystemFont,sans-serif;
  --fm:'JetBrains Mono',monospace;
  --ease:cubic-bezier(.4,0,.2,1);
  --ease-bounce:cubic-bezier(.34,1.56,.64,1);

  --bg:#f4f6fb; --bg-card:#fff; --bg-card2:#f8f9fc; --bg-hover:#f0f3f9;
  --hdr:rgba(255,255,255,.93);
  --t1:#0f1623; --t2:#5a6278; --t3:#9ba3b8;
  --bd:#e8eaf0; --bd2:#d2d6e0;
  --ac:#3b6ef6; --ac-s:#eef2ff; --ac-t:#2952d9;
  --gr:#18a058; --gr-s:#edfbf0; --gr-t:#128743;
  --re:#e83a3a; --re-s:#fff1f1; --re-t:#c42b2b;
  --am:#e08a00; --am-s:#fff8e6; --am-t:#b86f00;
  --pu:#7c4dff; --pu-s:#f3f0ff; --pu-t:#5b35d9;
  --te:#00a99d;
  --sh0:0 1px 2px rgba(0,0,0,.04);
  --sh1:0 2px 8px rgba(0,0,0,.07),0 0 0 1px rgba(0,0,0,.03);
  --sh2:0 8px 32px rgba(0,0,0,.12),0 2px 8px rgba(0,0,0,.06);
  --sh3:0 20px 60px rgba(0,0,0,.18);
  --r:14px; --rs:9px; --rx:6px;
}
[data-theme="dark"]{
  --bg:#0c0e16; --bg-card:#151922; --bg-card2:#1b1f2c; --bg-hover:#212638;
  --hdr:rgba(21,25,34,.96);
  --t1:#e8eaf5; --t2:#8890a8; --t3:#484f65;
  --bd:#242838; --bd2:#2e3448;
  --ac:#5585f8; --ac-s:#1a2445; --ac-t:#7aa4fa;
  --gr:#2ed072; --gr-s:#0d2318; --gr-t:#5edd96;
  --re:#f97070; --re-s:#280f0f; --re-t:#faa0a0;
  --am:#ffc641; --am-s:#261800; --am-t:#ffd87a;
  --pu:#9d75ff; --pu-s:#1c1035; --pu-t:#bea0ff;
  --te:#38d9cf;
  --sh0:0 1px 2px rgba(0,0,0,.25);
  --sh1:0 2px 8px rgba(0,0,0,.35),0 0 0 1px rgba(255,255,255,.04);
  --sh2:0 8px 32px rgba(0,0,0,.5);
  --sh3:0 20px 60px rgba(0,0,0,.7);
}

/* ── RESET ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--f);background:var(--bg);color:var(--t1);font-size:14px;line-height:1.5;transition:background .3s,color .3s;-webkit-font-smoothing:antialiased}
button{font-family:var(--f);cursor:pointer;transition:all .18s var(--ease)}
input[type=range]{accent-color:var(--ac)}

/* ── SCROLLBAR ───────────────────────────────────────────── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:var(--t3)}

/* ── LAYOUT ──────────────────────────────────────────────── */
.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}

/* ── TOPBAR ──────────────────────────────────────────────── */
.topbar{
  height:54px;background:var(--hdr);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--bd);display:flex;align-items:center;padding:0 20px;gap:12px;
  flex-shrink:0;z-index:100;position:relative;
}
.topbar::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--ac),transparent);opacity:.25}

.logo{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:900;color:var(--ac);letter-spacing:-.7px;text-decoration:none;user-select:none}
.logo-mark{width:28px;height:28px;background:linear-gradient(135deg,var(--ac),var(--pu));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;box-shadow:0 2px 8px rgba(59,110,246,.35)}
.tb-sep{width:1px;height:20px;background:var(--bd)}
.tb-date{font-size:12px;color:var(--t2);font-weight:500;letter-spacing:.2px}
.tb-clock{font-family:var(--fm);font-size:13px;font-weight:700;color:var(--t1);letter-spacing:1.5px;background:var(--bg-card2);padding:3px 9px;border-radius:6px;border:1px solid var(--bd)}
.tb-sp{flex:1}

/* day tabs */
.day-tabs{display:flex;background:var(--bg-card2);border:1px solid var(--bd);border-radius:9px;padding:3px;gap:2px}
.day-tab{
  padding:4px 12px;border-radius:7px;font-size:12px;font-weight:700;border:none;background:transparent;
  color:var(--t2);position:relative;overflow:hidden;letter-spacing:.2px;
}
.day-tab::before{content:'';position:absolute;inset:0;background:var(--ac);opacity:0;border-radius:6px;transition:opacity .15s}
.day-tab:hover:not(.active)::before{opacity:.08}
.day-tab.active{background:var(--ac);color:#fff;box-shadow:0 2px 6px rgba(59,110,246,.35)}
.day-tab.today-mark::after{content:'';position:absolute;top:4px;right:4px;width:5px;height:5px;background:var(--gr);border-radius:50%;border:1.5px solid var(--bg-card)}
.day-tab.active.today-mark::after{border-color:rgba(255,255,255,.5)}

/* icon buttons */
.ib{
  width:36px;height:36px;border-radius:9px;border:1px solid var(--bd);background:var(--bg-card);
  color:var(--t2);font-size:15px;display:flex;align-items:center;justify-content:center;
}
.ib:hover{border-color:var(--bd2);color:var(--t1);background:var(--bg-hover);transform:translateY(-1px);box-shadow:var(--sh1)}
.ib.on{background:var(--ac-s);border-color:var(--ac);color:var(--ac)}
.ib:active{transform:translateY(0)}

/* nav pill */
.nav-pill{display:flex;background:var(--bg-card2);border:1px solid var(--bd);border-radius:9px;padding:3px;gap:2px}
.np-btn{padding:4px 11px;border-radius:7px;font-size:12px;font-weight:700;border:none;background:transparent;color:var(--t2)}
.np-btn:hover:not(.active){background:var(--bg-hover);color:var(--t1)}
.np-btn.active{background:var(--t1);color:var(--bg)}

/* ── BODY ────────────────────────────────────────────────── */
.body-wrap{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px}

/* ── PAGES ───────────────────────────────────────────────── */
.page{display:none;flex-direction:column;gap:12px}
.page.active{display:flex}

/* ── BANNER ──────────────────────────────────────────────── */
.banner{
  background:var(--bg-card);border:1px solid var(--bd);border-radius:var(--r);
  box-shadow:var(--sh1);overflow:hidden;transition:box-shadow .2s;
}
.banner:hover{box-shadow:var(--sh2)}
.banner-shine{height:3px;background:var(--bd);transition:background .4s}
.banner.s-study .banner-shine{background:linear-gradient(90deg,var(--gr) 0%,var(--te) 100%)}
.banner.s-brk .banner-shine{background:linear-gradient(90deg,var(--am),#f97316)}
.banner.s-opt .banner-shine{background:linear-gradient(90deg,var(--pu),var(--ac))}
.banner.s-end .banner-shine{background:linear-gradient(90deg,var(--t3),var(--bd))}
.banner-body{padding:14px 18px;display:flex;align-items:center;gap:14px}
.bn-icon{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:21px;flex-shrink:0;transition:transform .2s var(--ease-bounce)}
.banner:hover .bn-icon{transform:scale(1.08)}
.banner.s-study .bn-icon{background:var(--gr-s);box-shadow:0 3px 10px rgba(24,160,88,.18)}
.banner.s-brk .bn-icon{background:var(--am-s);box-shadow:0 3px 10px rgba(224,138,0,.18)}
.banner.s-opt .bn-icon{background:var(--pu-s);box-shadow:0 3px 10px rgba(124,77,255,.18)}
.banner.s-end .bn-icon{background:var(--bg-card2)}
.bn-txt{flex:1;min-width:0}
.bn-txt h2{font-size:16px;font-weight:800;letter-spacing:-.3px;color:var(--t1)}
.bn-txt p{font-size:11.5px;color:var(--t2);margin-top:2px}
.bn-right{display:flex;align-items:center;gap:12px;flex-shrink:0}
.cd{text-align:right}
.cd-v{font-family:var(--fm);font-size:28px;font-weight:700;line-height:1;letter-spacing:-1px}
.banner.s-study .cd-v{color:var(--gr)}
.banner.s-brk .cd-v{color:var(--am)}
.banner.s-opt .cd-v{color:var(--pu)}
.cd-l{font-size:10px;color:var(--t3);margin-top:3px;text-align:right;letter-spacing:.3px;text-transform:uppercase}

/* attend btn */
.ab{height:36px;padding:0 16px;border-radius:8px;font-size:12.5px;font-weight:700;border:none;display:flex;align-items:center;gap:6px;white-space:nowrap;position:relative;overflow:hidden;letter-spacing:.2px}
.ab::after{content:'';position:absolute;inset:0;background:#fff;opacity:0;transition:opacity .15s}
.ab:hover:not(.dis):not(.wd)::after{opacity:.1}
.ab:active:not(.dis):not(.wd){transform:scale(.97)}
.ab.ok{background:linear-gradient(135deg,var(--gr),#0d9e6e);color:#fff;box-shadow:0 3px 10px rgba(24,160,88,.3)}
.ab.lte{background:linear-gradient(135deg,var(--am),#e07b00);color:#fff;box-shadow:0 3px 10px rgba(224,138,0,.3)}
.ab.done{background:var(--gr-s);color:var(--gr-t);border:1.5px solid rgba(24,160,88,.25)}
.ab.dis{background:var(--bg-card2);color:var(--t3);border:1px solid var(--bd);cursor:not-allowed}
.ab.wd{background:var(--re-s);color:var(--re-t);border:1px solid rgba(232,58,58,.2);cursor:not-allowed}
.ab-pulse{animation:abp 2s ease-in-out infinite}
@keyframes abp{0%,100%{box-shadow:0 3px 10px rgba(24,160,88,.3)}50%{box-shadow:0 3px 18px rgba(24,160,88,.6)}}

/* ── WRONG DAY NOTICE ───────────────────────────────────── */
.wd-bar{background:linear-gradient(90deg,var(--am-s),transparent);border:1px solid rgba(224,138,0,.25);border-radius:9px;padding:8px 14px;font-size:12px;color:var(--am-t);display:flex;align-items:center;gap:8px}

/* ── STATS ───────────────────────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.st{
  background:var(--bg-card);border:1px solid var(--bd);border-radius:var(--rs);padding:13px 14px;
  box-shadow:var(--sh0);transition:all .2s var(--ease);cursor:default;position:relative;overflow:hidden;
}
.st::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--rs) var(--rs) 0 0;opacity:.7}
.st-a::before{background:var(--ac)} .st-b::before{background:var(--re)} .st-p::before{background:var(--gr)} .st-m::before{background:var(--re)}
.st:hover{transform:translateY(-2px);box-shadow:var(--sh1)}
.st-v{font-family:var(--fm);font-size:24px;font-weight:800;line-height:1;margin-top:2px}
.st-l{font-size:11px;color:var(--t2);margin-top:4px;font-weight:500}
.cv-a{color:var(--ac)} .cv-b{color:var(--re)} .cv-p{color:var(--gr)} .cv-m{color:var(--re)}

/* ── MAIN GRID ───────────────────────────────────────────── */
.mgrid{display:grid;grid-template-columns:1fr 308px;gap:12px}

/* ── CARD ────────────────────────────────────────────────── */
.card{background:var(--bg-card);border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh0);overflow:hidden;transition:box-shadow .2s}
.card:hover{box-shadow:var(--sh1)}
.ch{padding:12px 16px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between}
.ch h3{font-size:11px;font-weight:800;color:var(--t2);text-transform:uppercase;letter-spacing:1px}

/* ── SCHEDULE ────────────────────────────────────────────── */
.sch-scroll{max-height:400px;overflow-y:auto}
.sch-row{
  display:grid;grid-template-columns:80px 1fr auto auto;align-items:center;
  padding:9px 16px;gap:10px;border-bottom:1px solid var(--bd);
  transition:background .15s;cursor:default;
}
.sch-row:last-child{border-bottom:none}
.sch-row:hover:not(.cur):not(.past){background:var(--bg-hover)}
.sch-row.cur{background:var(--gr-s);border-left:2.5px solid var(--gr);padding-left:13.5px}
.sch-row.cur.brk{background:var(--am-s);border-left-color:var(--am)}
.sch-row.past{opacity:.4}
.sch-row.brk-bg:not(.cur){background:rgba(0,0,0,.018)}
[data-theme="dark"] .sch-row.brk-bg:not(.cur){background:rgba(255,255,255,.02)}
.sn{font-size:12.5px;font-weight:700;color:var(--t1)}
.st2{font-family:var(--fm);font-size:10px;color:var(--t3)}
.sic{font-size:13px}
/* badges */
.bdg{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.2px}
.bdg-live{background:var(--gr-s);color:var(--gr-t)}
.bdg-ok{background:var(--gr-s);color:var(--gr-t)}
.bdg-lte{background:var(--am-s);color:var(--am-t)}
.bdg-miss{background:var(--re-s);color:var(--re-t)}
.bdg-wait{background:var(--bg-card2);color:var(--t3);border:1px solid var(--bd)}
.bdg-brk{background:var(--am-s);color:var(--am-t)}
.bdg-opt{background:var(--pu-s);color:var(--pu-t)}
.bdg-no{background:var(--bg-card2);color:var(--t3);border:1px solid var(--bd)}

/* ── SIDEBAR ─────────────────────────────────────────────── */
.sidebar{display:flex;flex-direction:column;gap:10px}

/* score card */
.sc-card{background:var(--bg-card);border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh0);overflow:hidden;transition:box-shadow .2s}
.sc-card:hover{box-shadow:var(--sh1)}
.sc-hero{padding:18px 16px 14px;text-align:center;background:linear-gradient(160deg,var(--bg-card2),var(--bg-card));border-bottom:1px solid var(--bd);position:relative;overflow:hidden}
.sc-hero::before{content:'';position:absolute;top:-30px;left:50%;transform:translateX(-50%);width:140px;height:140px;background:radial-gradient(circle,rgba(59,110,246,.06) 0%,transparent 70%)}
.sc-lbl{font-size:10px;color:var(--t3);font-weight:800;text-transform:uppercase;letter-spacing:.8px}
.sc-val{font-family:var(--fm);font-size:40px;font-weight:800;line-height:1.1;margin-top:4px;letter-spacing:-2px;transition:color .3s,transform .15s}
.sc-val.pos{color:var(--gr)} .sc-val.neg{color:var(--re)} .sc-val.z{color:var(--t2)}
.sc-bd{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--bd)}
.sc-part{padding:9px 14px;text-align:center;transition:background .15s}
.sc-part:hover{background:var(--bg-hover)}
.sc-part:first-child{border-right:1px solid var(--bd)}
.sc-pv{font-family:var(--fm);font-size:16px;font-weight:800}
.sp-p{color:var(--gr)} .sp-m{color:var(--re)}
.sc-pl{font-size:10px;color:var(--t3);margin-top:2px}

/* pts section */
.pts-s{padding:10px 12px}
.pts-t{font-size:10px;font-weight:800;color:var(--t3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px}
.pts-list{display:flex;flex-direction:column;gap:3px}
.pb{
  display:flex;align-items:center;justify-content:space-between;padding:7px 10px;
  border-radius:8px;font-size:11.5px;font-weight:600;border:none;
  transition:all .15s var(--ease);position:relative;overflow:hidden;
}
.pb::after{content:'';position:absolute;inset:0;background:#fff;opacity:0;transition:opacity .15s}
.pb:hover::after{opacity:.08}
.pb:hover{transform:translateX(2px)}
.pb:active{transform:scale(.98)}
.pv{font-family:var(--fm);font-size:11px;font-weight:800}
.pb-p{background:var(--gr-s);color:var(--gr-t)}
.pb-m{background:var(--re-s);color:var(--re-t)}
.sdiv{height:1px;background:var(--bd);margin:2px 12px}

/* log */
.log-s{max-height:160px;overflow-y:auto;padding:3px 0}
.le{display:flex;align-items:center;gap:8px;padding:5px 14px;border-bottom:1px solid var(--bd);transition:background .1s}
.le:last-child{border-bottom:none}
.le:hover{background:var(--bg-hover)}
.lt{font-family:var(--fm);font-size:9.5px;color:var(--t3);min-width:36px;flex-shrink:0}
.lm{flex:1;font-size:11px;color:var(--t2)}
.lp{font-family:var(--fm);font-size:10.5px;font-weight:800}
.lp-p{color:var(--gr)} .lp-m{color:var(--re)}

/* ── NOISE BAR ───────────────────────────────────────────── */
.noise-bar{
  background:var(--bg-card);border:1px solid var(--bd);border-radius:var(--rs);
  padding:10px 15px;display:flex;align-items:center;gap:10px;
  box-shadow:var(--sh0);overflow:hidden;position:relative;
}
.noise-bar::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--ac),var(--pu))}
.nl{font-size:12px;font-weight:700;color:var(--t2);flex:1}
.nt-tabs{display:flex;gap:3px}
.nt{padding:3px 8px;border-radius:6px;font-size:11px;font-weight:700;border:1px solid var(--bd);background:transparent;color:var(--t2)}
.nt:hover{background:var(--bg-hover);color:var(--t1)}
.nt.on{background:var(--ac-s);border-color:var(--ac);color:var(--ac-t)}
.nv-wrap{display:flex;align-items:flex-end;gap:2px;height:20px;margin:0 2px}
.nvb{width:3px;background:linear-gradient(var(--pu),var(--ac));border-radius:2px;transition:height .12s var(--ease)}

/* ── SUNDAY SETUP CARD ───────────────────────────────────── */
.su-card{
  background:linear-gradient(135deg,var(--pu-s),var(--bg-card));
  border:1px solid rgba(124,77,255,.2);border-radius:var(--r);
  padding:15px 17px;box-shadow:var(--sh0);transition:all .2s;
}
.su-card:hover{box-shadow:var(--sh1)}
.su-top{display:flex;align-items:flex-start;gap:12px}
.su-ico{font-size:28px;flex-shrink:0;margin-top:2px}
.su-info h3{font-size:14px;font-weight:800;letter-spacing:-.3px}
.su-info p{font-size:11px;color:var(--t2);margin-top:3px}
.su-pills{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}
.su-pill{font-size:10px;padding:2px 8px;background:var(--pu-s);color:var(--pu-t);border-radius:20px;border:1px solid rgba(124,77,255,.2);font-weight:700}
.btn-setup{
  margin-left:auto;padding:8px 16px;border-radius:8px;border:none;
  background:linear-gradient(135deg,var(--pu),#9b59ff);color:#fff;font-size:12px;font-weight:700;
  white-space:nowrap;flex-shrink:0;box-shadow:0 3px 10px rgba(124,77,255,.3);letter-spacing:.2px;
}
.btn-setup:hover{opacity:.88;transform:translateY(-1px)}
.btn-setup:active{transform:scale(.97)}
.btn-setup:disabled{opacity:.35;cursor:not-allowed;transform:none}

/* ── MODAL ───────────────────────────────────────────────── */
.mo{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:moIn .2s var(--ease)}
@keyframes moIn{from{opacity:0}to{opacity:1}}
.md{
  background:var(--bg-card);border:1px solid var(--bd2);border-radius:18px;
  box-shadow:var(--sh3);width:480px;max-width:100%;max-height:90vh;
  overflow:hidden;display:flex;flex-direction:column;
  animation:mdIn .25s var(--ease-bounce);
}
@keyframes mdIn{from{transform:scale(.92) translateY(16px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.md-hd{padding:20px 22px 14px;border-bottom:1px solid var(--bd);flex-shrink:0}
.md-hd h2{font-size:16px;font-weight:900;letter-spacing:-.4px}
.md-hd p{font-size:11.5px;color:var(--t2);margin-top:4px}
.md-bd{padding:16px 20px;overflow-y:auto;flex:1}
.m-lbl{font-size:11px;font-weight:700;color:var(--t2);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.pc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:14px}
.pci{
  border:1.5px solid var(--bd);border-radius:10px;padding:10px 8px;cursor:pointer;
  transition:all .15s var(--ease);text-align:center;background:var(--bg-card2);user-select:none;
}
.pci:hover{border-color:var(--pu);background:var(--pu-s);transform:translateY(-1px)}
.pci.sel{border-color:var(--pu);background:var(--pu-s);box-shadow:0 0 0 3px rgba(124,77,255,.12)}
.pci .pcn{font-size:12.5px;font-weight:800;color:var(--t1)}
.pci .pct{font-size:9.5px;color:var(--t3);font-family:var(--fm);margin-top:3px}
.pci.sel .pcn{color:var(--pu-t)}
.md-note{font-size:11px;color:var(--t2);line-height:1.7;padding:10px 13px;background:var(--bg-card2);border-radius:9px;border:1px solid var(--bd)}
.md-ft{padding:12px 20px;border-top:1px solid var(--bd);display:flex;gap:8px;justify-content:flex-end;flex-shrink:0}
.btn-x{padding:9px 16px;border-radius:8px;border:1px solid var(--bd);background:transparent;color:var(--t2);font-size:12.5px;font-weight:600}
.btn-x:hover{background:var(--bg-hover);border-color:var(--bd2);color:var(--t1)}
.btn-ok{padding:9px 20px;border-radius:8px;border:none;background:linear-gradient(135deg,var(--pu),#9b59ff);color:#fff;font-size:12.5px;font-weight:700;box-shadow:0 3px 10px rgba(124,77,255,.3)}
.btn-ok:hover{opacity:.88}
.btn-ok:disabled{opacity:.35;cursor:not-allowed}

/* ── CALENDAR ────────────────────────────────────────────── */
.cal-wrap{display:flex;flex-direction:column;gap:12px}
.cal-nav{display:flex;align-items:center;gap:10px}
.cal-nav h2{font-size:16px;font-weight:900;letter-spacing:-.4px;flex:1;text-align:center}
.cal-arrow{width:32px;height:32px;border-radius:8px;border:1px solid var(--bd);background:var(--bg-card);color:var(--t2);font-size:14px;display:flex;align-items:center;justify-content:center}
.cal-arrow:hover{background:var(--bg-hover);color:var(--t1);border-color:var(--bd2);transform:scale(1.05)}
.cal-grid{background:var(--bg-card);border:1px solid var(--bd);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh1)}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--bd)}
.cdow{padding:8px 0;text-align:center;font-size:11px;font-weight:800;color:var(--t3);text-transform:uppercase;letter-spacing:.5px}
.cdow:first-child{color:var(--re)} .cdow:last-child{color:var(--ac)}
.cal-days{display:grid;grid-template-columns:repeat(7,1fr)}
.cday{
  border-right:1px solid var(--bd);border-bottom:1px solid var(--bd);
  min-height:82px;padding:8px 6px 6px;cursor:pointer;transition:all .15s;
  display:flex;flex-direction:column;gap:3px;position:relative;
}
.cday:nth-child(7n){border-right:none}
.cday:hover{background:var(--bg-hover)}
.cday.today{background:var(--ac-s)}
.cday.today .cdn{background:var(--ac);color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center}
.cday.other-m .cdn{color:var(--t3)}
.cday.sun .cdn{color:var(--re)}
.cday.sat .cdn{color:var(--ac)}
.cdn{font-size:12px;font-weight:800;color:var(--t1);width:22px;height:22px;display:flex;align-items:center;justify-content:center}
.c-pts-row{display:flex;gap:3px;flex-wrap:wrap}
.c-chip{font-size:9.5px;padding:1px 6px;border-radius:10px;font-weight:700;white-space:nowrap}
.c-chip-p{background:var(--gr-s);color:var(--gr-t)}
.c-chip-m{background:var(--re-s);color:var(--re-t)}
.c-chip-a{background:var(--ac-s);color:var(--ac-t);font-size:9px}
.cal-detail{background:var(--bg-card);border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh1);overflow:hidden}
.cal-detail-empty{padding:24px;text-align:center;color:var(--t3);font-size:13px}
.cd-day-title{padding:14px 18px;border-bottom:1px solid var(--bd);font-size:14px;font-weight:800}
.cd-log-list{max-height:300px;overflow-y:auto}
.cd-log-item{display:flex;align-items:center;gap:10px;padding:9px 18px;border-bottom:1px solid var(--bd);transition:background .1s}
.cd-log-item:last-child{border-bottom:none}
.cd-log-item:hover{background:var(--bg-hover)}
.cd-li-t{font-family:var(--fm);font-size:10px;color:var(--t3);min-width:38px}
.cd-li-m{flex:1;font-size:12px;color:var(--t2)}
.cd-li-p{font-family:var(--fm);font-size:11px;font-weight:800}

/* ── TOAST ───────────────────────────────────────────────── */
.tw{position:fixed;top:63px;right:16px;z-index:300;display:flex;flex-direction:column;gap:5px;pointer-events:none}
.toast{
  background:var(--bg-card);border:1px solid var(--bd2);border-radius:10px;
  padding:10px 14px;font-size:12px;font-weight:600;color:var(--t1);
  min-width:210px;max-width:290px;box-shadow:var(--sh2);
  animation:tI .28s var(--ease-bounce),tO .3s ease 3.4s forwards;
  display:flex;align-items:center;gap:8px;
}
.t-ic{font-size:15px;flex-shrink:0}
.toast.tg{border-left:3px solid var(--gr)}
.toast.tr{border-left:3px solid var(--re)}
.toast.tb{border-left:3px solid var(--ac)}
.toast.ta{border-left:3px solid var(--am)}
@keyframes tI{from{transform:translateX(20px) scale(.88);opacity:0}to{transform:translateX(0) scale(1);opacity:1}}
@keyframes tO{to{transform:translateX(10px) scale(.96);opacity:0}}

@media(max-width:800px){.mgrid{grid-template-columns:1fr}.stats{grid-template-columns:repeat(2,1fr)}}

/* ── AUTH ────────────────────────────────────────────────── */
.auth-slide-panel {
  position: fixed;
  top: 0;
  right: 0;
  height: 100vh;
  display: flex;
  z-index: 999;
  pointer-events: none;
}
.auth-trigger-area {
  width: 40px;
  height: 100%;
  pointer-events: auto;
}
.auth-content {
  width: 250px;
  height: 100%;
  background: var(--bg-card);
  border-left: 1px solid var(--bd);
  box-shadow: var(--sh2);
  padding: 20px;
  transform: translateX(100%);
  transition: transform 0.3s var(--ease-bounce);
  pointer-events: auto;
}
.auth-slide-panel:hover .auth-content,
.auth-trigger-area:hover + .auth-content,
.auth-content:hover {
  transform: translateX(0);
}

.btn-auth{
  padding:8px 16px;border-radius:8px;border:1px solid var(--bd);
  background:var(--bg-card);color:var(--t2);font-size:12px;font-weight:700;
  width:100%;text-align:left;
}
.btn-auth:hover{background:var(--bg-hover);color:var(--t1);border-color:var(--bd2)}
.user-info{font-size:13px;color:var(--t1);font-weight:700;padding:8px 4px;}

.auth-form{display:flex;flex-direction:column;gap:12px}
.auth-input{
  width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--bd);
  background:var(--bg-card2);color:var(--t1);font-family:var(--f);font-size:13px;
}
.auth-input:focus{outline:none;border-color:var(--ac);box-shadow:0 0 0 3px var(--ac-s)}

