*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#0a0a12;--bg2:#13132a;--bg3:#1e1e3a;--accent:#7c5cfc;--accent2:#a78bfa;--green:#10b981;--yellow:#f59e0b;--red:#ef4444;--blue:#3b82f6;--pink:#ec4899;--cyan:#06b6d4;--text:#e2e8f0;--text2:#94a3b8;--text3:#64748b;--border:rgba(255,255,255,0.06);--r:12px}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}
a{color:var(--accent2);text-decoration:none}a:hover{text-decoration:underline}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-thumb{background:var(--bg3);border-radius:4px}
button,input,select,textarea{font-family:inherit}

/* ── Header ─────────────────────────────────────────────────── */
.header{background:var(--bg2);padding:14px 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.logo{font-size:1.3rem;font-weight:800;background:linear-gradient(135deg,var(--accent2),var(--pink),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hdr-right{display:flex;align-items:center;gap:10px}
.badges{display:flex;gap:8px}
.badge{padding:4px 12px;border-radius:16px;font-weight:700;font-size:.75rem}
.b-day{background:var(--accent);color:#fff}
.b-str{background:var(--green);color:#000}

/* ── User avatar button ──────────────────────────────────────── */
.uavt{display:flex;align-items:center;gap:7px;background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:4px 11px 4px 4px;cursor:pointer;color:var(--text);font-size:.78rem;font-weight:600;transition:border-color .12s;border:none}
.uavt:hover{border:1px solid var(--accent)!important}
.u-av{width:24px;height:24px;border-radius:50%;object-fit:cover;background:var(--accent);display:block}
.u-init{width:24px;height:24px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:.65rem;color:#fff;font-weight:700;flex-shrink:0}

/* ── Modal / overlay ─────────────────────────────────────────── */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;display:flex;align-items:center;justify-content:center}
.modal{background:var(--bg2);border-radius:var(--r);padding:22px;max-width:380px;width:calc(100% - 32px);border:1px solid var(--border)}
.modal-title{font-size:1rem;font-weight:700;margin-bottom:14px;color:var(--accent2)}
.urow{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:8px;border:1px solid var(--border);cursor:pointer;transition:all .12s;margin-bottom:5px}
.urow:hover{border-color:var(--accent);background:var(--bg3)}
.urow.active{border-color:var(--green)}
.urow-av{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}
.urow-init{width:32px;height:32px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:.8rem;color:#fff;font-weight:700;flex-shrink:0}

/* ── Nav ─────────────────────────────────────────────────────── */
.nav{display:flex;gap:2px;padding:8px 24px;background:var(--bg2);border-bottom:1px solid var(--border);overflow-x:auto}
.nav button{padding:8px 16px;border:none;background:none;color:var(--text2);cursor:pointer;border-radius:8px;font-size:.82rem;white-space:nowrap;transition:all .15s}
.nav button:hover{background:var(--bg3);color:var(--text)}
.nav button.on{background:var(--accent);color:#fff}

/* ── Layout ──────────────────────────────────────────────────── */
.wrap{max-width:1340px;margin:0 auto;padding:20px 24px 60px}
.card{background:var(--bg2);border-radius:var(--r);padding:20px;margin-bottom:12px;border:1px solid var(--border)}
.ct{font-size:1.1rem;font-weight:700;margin-bottom:12px;color:var(--accent2)}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:800px){.g2,.g3,.g4{grid-template-columns:1fr}}

/* ── Stat cards ──────────────────────────────────────────────── */
.stat{background:var(--bg3);border-radius:var(--r);padding:16px;text-align:center}
.stat .v{font-size:1.8rem;font-weight:800}
.stat .l{font-size:.72rem;color:var(--text2);margin-top:2px}
.pbar{background:var(--bg);border-radius:6px;height:7px;overflow:hidden;margin-top:5px}
.pfill{height:100%;border-radius:6px;transition:width .3s}

/* ── Schedule blocks ─────────────────────────────────────────── */
.sched{display:flex;gap:12px;padding:11px 13px;border-radius:8px;margin-bottom:6px;align-items:flex-start;border-left:3px solid var(--accent);background:rgba(124,92,252,.03)}
.sched .tm{font-size:.8rem;color:var(--accent2);font-weight:700;min-width:100px;padding-top:1px}
.sched .dt h4{font-size:.88rem;margin-bottom:2px}
.sched .dt p{font-size:.78rem;color:var(--text2)}

/* ── Week tabs ───────────────────────────────────────────────── */
.wtabs{display:flex;gap:4px;margin-bottom:12px;flex-wrap:wrap}
.wtab{padding:6px 13px;border:1px solid var(--bg3);background:none;color:var(--text2);border-radius:7px;cursor:pointer;font-size:.8rem;transition:all .15s}
.wtab:hover{border-color:var(--accent)}
.wtab.on{background:var(--accent);border-color:var(--accent);color:#fff}

/* ── Task items ──────────────────────────────────────────────── */
.ti{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg);border-radius:7px;margin-bottom:4px;cursor:pointer;transition:background .12s;border:1px solid transparent}
.ti:hover{background:var(--bg3);border-color:var(--border)}
.ti input[type=checkbox]{width:16px;height:16px;accent-color:var(--green);cursor:pointer;flex-shrink:0}
.ti .tn{flex:1;font-size:.85rem}
.ti .tt{font-size:.66rem;padding:2px 6px;border-radius:3px;font-weight:700}
.te{background:rgba(16,185,129,.12);color:var(--green)}
.tm2{background:rgba(245,158,11,.12);color:var(--yellow)}
.th{background:rgba(239,68,68,.12);color:var(--red)}
.tth{background:rgba(59,130,246,.12);color:var(--blue)}
.tp{background:rgba(124,92,252,.12);color:var(--accent2)}

/* ── Resource items ──────────────────────────────────────────── */
.ri{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg);border-radius:7px;margin-bottom:4px}
.ri .ic{font-size:1.1rem;flex-shrink:0}
.ri .inf{flex:1}
.ri .tl{font-size:.85rem}
.ri .ds{font-size:.72rem;color:var(--text2)}

/* ── Quiz ────────────────────────────────────────────────────── */
.qc{background:var(--bg);border-radius:var(--r);padding:18px;margin-bottom:12px}
.qc .qq{font-size:.92rem;margin-bottom:12px;font-weight:600;line-height:1.4}
.qo{display:block;width:100%;text-align:left;padding:10px 13px;margin-bottom:5px;background:var(--bg2);border:1px solid var(--bg3);border-radius:7px;cursor:pointer;transition:all .12s;font-size:.84rem;color:var(--text)}
.qo:hover{border-color:var(--accent)}
.qo.sel{border-color:var(--accent);background:rgba(124,92,252,.1)}
.qo.ok{border-color:var(--green);background:rgba(16,185,129,.1)}
.qo.no{border-color:var(--red);background:rgba(239,68,68,.1)}

/* ── Claude prompt box ───────────────────────────────────────── */
.pb{background:linear-gradient(135deg,rgba(124,92,252,.07),rgba(236,72,153,.07));border:1px solid rgba(124,92,252,.2);border-radius:var(--r);padding:16px;margin-top:10px}
.pb h4{color:var(--accent2);margin-bottom:5px;font-size:.85rem}
.pb pre{background:var(--bg);padding:10px;border-radius:7px;font-size:.76rem;overflow-x:auto;color:var(--text2);white-space:pre-wrap;line-height:1.4;position:relative}
.cpb{position:absolute;top:5px;right:5px;background:var(--bg3);border:none;color:var(--text2);padding:3px 9px;border-radius:4px;cursor:pointer;font-size:.7rem}
.cpb:hover{background:var(--accent);color:#fff}

/* ── Recap cards ─────────────────────────────────────────────── */
.rc{background:var(--bg3);border-radius:var(--r);padding:16px;margin-bottom:8px;border-left:3px solid var(--accent)}
.rc h4{color:var(--accent2);margin-bottom:6px;font-size:.88rem}
.rc ul{list-style:none}
.rc li{padding:4px 0;font-size:.82rem;color:var(--text2);border-bottom:1px solid rgba(255,255,255,.02)}

/* ── Profile cards ───────────────────────────────────────────── */
.pc{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg);border-radius:var(--r);text-decoration:none;color:var(--text);transition:background .12s}
.pc:hover{background:var(--bg3);text-decoration:none}
.pc .av{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;flex-shrink:0}

/* ── Heatmap ─────────────────────────────────────────────────── */
.hm{display:grid;grid-template-columns:repeat(10,1fr);gap:2px;max-width:380px}
.hc{aspect-ratio:1;border-radius:2px;background:var(--bg);transition:opacity .1s}
.hc[data-hd]{cursor:pointer}
.hc[data-hd]:hover{opacity:.65}
.h1{background:rgba(16,185,129,.2)}
.h2{background:rgba(16,185,129,.4)}
.h3{background:rgba(16,185,129,.6)}
.h4{background:rgba(16,185,129,.85)}

/* ── Journal textarea ────────────────────────────────────────── */
.ja{width:100%;min-height:100px;background:var(--bg);border:1px solid var(--bg3);border-radius:7px;padding:12px;color:var(--text);font-size:.85rem;resize:vertical;line-height:1.4}
.ja:focus{outline:none;border-color:var(--accent)}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn{padding:8px 16px;border:none;border-radius:7px;cursor:pointer;font-size:.82rem;font-weight:600;transition:all .12s}
.bp{background:var(--accent);color:#fff}
.bp:hover{background:var(--accent2)}
.bg{background:var(--green);color:#000}
.bo{background:none;border:1px solid var(--bg3);color:var(--text2)}
.bo:hover{border-color:var(--accent);color:var(--accent2)}
.bs{padding:5px 11px;font-size:.76rem}

/* ── Inputs ──────────────────────────────────────────────────── */
.inp{padding:8px 12px;background:var(--bg);border:1px solid var(--bg3);border-radius:7px;color:var(--text);font-size:.83rem}
.inp:focus{outline:none;border-color:var(--accent)}

/* ── Toast ───────────────────────────────────────────────────── */
.toast{position:fixed;bottom:20px;right:20px;background:var(--green);color:#000;padding:9px 20px;border-radius:7px;font-weight:700;font-size:.82rem;z-index:999;transform:translateY(70px);opacity:0;transition:all .2s;pointer-events:none}
.toast.vis{transform:translateY(0);opacity:1}
