/* ─────────────────────────────────────────────
   RESET & TOKENS
───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#F5F4EF;
  --sur:#FFFFFF;
  --sur2:#EEECEA;
  --sur3:#E4E2DC;
  --bdr:#DEDAD2;
  --bdr2:#C4C0B6;
  --ink:#111008;
  --ink2:#3A3930;
  --ink3:#787060;
  --ink4:#ACAA9F;
  --grn:#1A5C35;
  --grn2:#124022;
  --grns:#E5F2EB;
  --grnm:#B4D8C4;
  --red:#C0261A;--reds:#FEF2F0;
  --amb:#8A5A00;--ambs:#FFF8E6;
  --ora:#B84A14;--oras:#FFF3EC;
  --blu:#1B4FC0;--blus:#EEF3FE;
  --s0:0 1px 2px rgba(0,0,0,.04);
  --s1:0 2px 8px rgba(0,0,0,.07);
  --s2:0 4px 16px rgba(0,0,0,.09);
  --s3:0 8px 28px rgba(0,0,0,.10);
  --s4:0 20px 60px rgba(0,0,0,.13);
  --r6:6px;--r8:8px;--r10:10px;--r12:12px;--r16:16px;--r20:20px;--r99:99px;
  --sb:env(safe-area-inset-bottom,0px);
  --sidebar:240px;
}
html{height:100%;-webkit-font-smoothing:antialiased}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--ink);min-height:100%;font-size:15px;line-height:1.6;overflow-x:hidden}
button,input,select,textarea{font-family:inherit}
img{display:block;max-width:100%}
a{color:var(--grn);text-decoration:none}

/* ─────────────────────────────────────────────
   LOADER
───────────────────────────────────────────── */
#loader{
  position:fixed;inset:0;background:var(--grn);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  z-index:9000;transition:opacity .4s;
}
#loader.hide{opacity:0;pointer-events:none}
.ld-icon{width:60px;height:60px;border-radius:18px;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;animation:ldbounce 1.5s ease-in-out infinite}
@keyframes ldbounce{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
.ld-icon svg{width:32px;height:32px}
.ld-name{font-family:'Lora',serif;font-size:22px;color:rgba(255,255,255,.9);letter-spacing:-.3px}
.ld-bar{width:120px;height:2px;background:rgba(255,255,255,.2);border-radius:99px;overflow:hidden}
.ld-fill{height:100%;background:#fff;border-radius:99px;animation:ldbar 1.4s ease-in-out infinite}
@keyframes ldbar{0%{width:0;margin-left:0}50%{width:80px}100%{width:0;margin-left:120px}}

/* ─────────────────────────────────────────────
   AUTH PAGE
───────────────────────────────────────────── */
#auth{
  position:fixed;inset:0;z-index:800;
  background:var(--grn);overflow-y:auto;
  align-items:center;justify-content:center;padding:24px;
  display:none;
}
#auth.show{display:flex}
#auth::before{content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.07),transparent 65%);top:-200px;right:-200px;pointer-events:none}
#auth::after{content:'';position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.05),transparent 65%);bottom:-120px;left:-100px;pointer-events:none}
.acard{
  background:var(--sur);border-radius:24px;padding:36px 32px;
  width:100%;max-width:420px;box-shadow:var(--s4);
  position:relative;z-index:1;animation:slideup .4s cubic-bezier(.34,1.3,.64,1) both;
}
@keyframes slideup{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.alogo{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.alogo-mk{width:36px;height:36px;border-radius:10px;background:var(--grn);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(26,92,53,.25)}
.alogo-mk svg{width:20px;height:20px}
.alogo-nm{font-family:'Lora',serif;font-size:20px;letter-spacing:-.3px}
.trial-badge{display:inline-flex;align-items:center;gap:5px;background:var(--grns);color:var(--grn);font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:var(--r99);margin-bottom:20px;letter-spacing:.1px}
.trial-badge svg{width:12px;height:12px}
.a-title{font-family:'Lora',serif;font-size:22px;font-weight:600;letter-spacing:-.4px;margin-bottom:4px}
.a-sub{font-size:13.5px;color:var(--ink3);margin-bottom:22px}
.atabs{display:flex;background:var(--sur2);border-radius:var(--r10);padding:3px;gap:3px;margin-bottom:20px}
.atab{flex:1;padding:8px;border:none;background:none;font-size:13.5px;font-weight:700;color:var(--ink3);border-radius:var(--r8);cursor:pointer;transition:all .15s}
.atab.on{background:var(--sur);color:var(--ink);box-shadow:var(--s0)}
.g-btn{
  width:100%;padding:11px 16px;display:flex;align-items:center;justify-content:center;gap:9px;
  border:1.5px solid var(--bdr);border-radius:var(--r10);background:var(--sur);
  font-size:14px;font-weight:700;color:var(--ink2);cursor:pointer;transition:all .15s;
  margin-bottom:16px;box-shadow:var(--s0);
}
.g-btn:hover{background:var(--sur2);border-color:var(--bdr2)}
.g-btn:active{transform:scale(.98)}
.g-btn svg{width:18px;height:18px;flex-shrink:0}
.or-row{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.or-line{flex:1;height:1px;background:var(--bdr)}
.or-row span{font-size:11px;color:var(--ink4);font-weight:700;letter-spacing:.4px;text-transform:uppercase}
.fld{margin-bottom:12px}
.fld label{display:block;font-size:11px;font-weight:700;color:var(--ink3);letter-spacing:.5px;text-transform:uppercase;margin-bottom:5px}
.fld input,.fld select{
  width:100%;padding:11px 13px;border:1.5px solid var(--bdr);border-radius:var(--r10);
  font-size:14.5px;color:var(--ink);background:var(--sur);
  transition:border-color .15s,box-shadow .15s;outline:none;
  -webkit-appearance:none;appearance:none;
}
.fld input:focus,.fld select:focus{border-color:var(--grn);box-shadow:0 0 0 3px rgba(26,92,53,.08)}
.fld input::placeholder{color:var(--ink4)}
.pw-wrap{position:relative}
.pw-wrap input{padding-right:44px}
.pw-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--ink4);display:flex;align-items:center;padding:4px;-webkit-tap-highlight-color:transparent}
.pw-eye:hover{color:var(--ink2)}
.pw-eye svg{width:17px;height:17px}
.fld2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.abtn{
  width:100%;padding:12px;margin-top:4px;background:var(--grn);color:#fff;border:none;
  border-radius:var(--r10);font-size:15px;font-weight:700;cursor:pointer;
  transition:all .15s;box-shadow:0 2px 10px rgba(26,92,53,.25);
}
.abtn:hover{background:var(--grn2);box-shadow:0 4px 16px rgba(26,92,53,.3)}
.abtn:active{transform:scale(.98)}
.abtn:disabled{opacity:.55;cursor:not-allowed;transform:none}
.forgot{display:block;text-align:right;font-size:12px;color:var(--ink3);margin-top:-4px;margin-bottom:12px;cursor:pointer}
.forgot:hover{color:var(--grn)}
.a-foot{text-align:center;font-size:13px;color:var(--ink3);margin-top:14px}
.a-foot a{font-weight:700;color:var(--grn)}
.aerr{background:var(--reds);color:var(--red);border:1px solid rgba(192,38,26,.12);border-radius:var(--r8);padding:9px 12px;font-size:13px;margin-bottom:12px;display:none}

/* ─────────────────────────────────────────────
   APP SHELL — works on both mobile and desktop
───────────────────────────────────────────── */
#app{display:none;min-height:100vh}
#app.show{display:flex;flex-direction:column}
@media(min-width:960px){#app.show{display:flex;flex-direction:row}}

/* Mobile: stacked layout with topbar + bottom nav */
/* Desktop: sidebar + main content side by side */

/* TOPBAR (mobile) */
.topbar{
  background:var(--sur);border-bottom:1px solid var(--bdr);
  height:56px;padding:0 16px;
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:200;box-shadow:var(--s0);
}
.tb-brand{display:flex;align-items:center;gap:8px}
.tb-mk{width:28px;height:28px;border-radius:8px;background:var(--grn);display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px rgba(26,92,53,.2)}
.tb-mk svg{width:15px;height:15px}
.tb-nm{font-family:'Lora',serif;font-size:17px;letter-spacing:-.3px}
.tb-right{display:flex;align-items:center;gap:8px}
.tb-av{width:32px;height:32px;border-radius:50%;background:var(--grn);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;overflow:hidden;cursor:pointer;border:2px solid var(--grnm);flex-shrink:0}
.tb-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.tb-notif{width:32px;height:32px;border-radius:50%;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;color:var(--ink3)}
.tb-notif svg{width:18px;height:18px}
.ndot{position:absolute;top:5px;right:5px;width:7px;height:7px;border-radius:50%;background:var(--red);border:1.5px solid var(--sur);display:none}
.ndot.on{display:block}
.badge-adm{background:var(--oras);color:var(--ora);font-size:9px;font-weight:800;padding:2px 6px;border-radius:var(--r99);letter-spacing:.4px;text-transform:uppercase}

/* BOTTOM NAV (mobile) */
.bnav{
  position:fixed;bottom:0;left:0;right:0;
  background:var(--sur);border-top:1px solid var(--bdr);
  display:flex;align-items:stretch;
  padding-bottom:var(--sb);
  z-index:200;box-shadow:0 -2px 12px rgba(0,0,0,.06);
}
.bn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:7px 4px 9px;border:none;background:none;cursor:pointer;color:var(--ink4);transition:color .15s;min-height:54px;position:relative;-webkit-tap-highlight-color:transparent}
.bn svg{width:22px;height:22px;transition:transform .15s}
.bn span{font-size:9.5px;font-weight:700;letter-spacing:.2px;text-transform:uppercase}
.bn.on{color:var(--grn)}
.bn.on svg{transform:scale(1.1)}
.bn-pip{position:absolute;top:7px;right:calc(50% - 14px);width:6px;height:6px;border-radius:50%;background:var(--red);border:1.5px solid var(--sur);display:none}
.bn-pip.on{display:block}

/* MAIN CONTENT */
.main-wrap{flex:1;padding-bottom:calc(60px + var(--sb));overflow-y:auto;-webkit-overflow-scrolling:touch}
.view{display:none;animation:fdin .2s ease}
.view.on{display:block}
@keyframes fdin{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}

/* ─────────────────────────────────────────────
   HERO (tasks page top)
───────────────────────────────────────────── */
.hero{background:var(--grn);padding:20px 20px 0;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;width:260px;height:260px;border-radius:50%;border:1px solid rgba(255,255,255,.06);right:-60px;top:-60px;pointer-events:none}
.hero-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:18px;position:relative;z-index:1}
.hero-greet{font-size:12px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:3px}
.hero-name{font-family:'Lora',serif;font-size:22px;font-weight:600;color:#fff;letter-spacing:-.3px;line-height:1.2}
.hero-date{font-size:12px;color:rgba(255,255,255,.4);margin-top:2px}
.ring-wrap{width:64px;height:64px;position:relative;flex-shrink:0}
.ring-wrap svg{transform:rotate(-90deg)}
.rbg{fill:none;stroke:rgba(255,255,255,.15);stroke-width:5}
.rfill{fill:none;stroke:rgba(255,255,255,.9);stroke-width:5;stroke-linecap:round;transition:stroke-dashoffset .8s cubic-bezier(.34,1,.64,1)}
.rlabel{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.rpct{font-size:14px;font-weight:800;color:#fff;line-height:1}
.rdone{font-size:8.5px;color:rgba(255,255,255,.4);font-weight:700;letter-spacing:.3px;text-transform:uppercase;margin-top:1px}
.hero-stats{display:flex;background:rgba(255,255,255,.09);border-radius:var(--r12) var(--r12) 0 0;margin:0 -20px;padding:12px 20px;position:relative;z-index:1}
.hs{flex:1;text-align:center}
.hs-n{font-family:'Lora',serif;font-size:20px;font-weight:600;color:#fff;line-height:1}
.hs-l{font-size:10px;color:rgba(255,255,255,.4);font-weight:700;letter-spacing:.5px;text-transform:uppercase;margin-top:2px}
.hs-sep{width:1px;background:rgba(255,255,255,.12);margin:2px 0}

/* ─────────────────────────────────────────────
   TASKS
───────────────────────────────────────────── */
.tv-pad{padding:16px}
.sec-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.sec-title{font-family:'Lora',serif;font-size:19px;font-weight:600;letter-spacing:-.3px}
.btn-add{display:flex;align-items:center;gap:5px;padding:8px 16px;background:var(--grn);color:#fff;border:none;border-radius:var(--r10);font-size:13px;font-weight:700;cursor:pointer;transition:all .15s;box-shadow:0 1px 4px rgba(26,92,53,.2);white-space:nowrap}
.btn-add:active{transform:scale(.96)}
.btn-add svg{width:14px;height:14px}
.chips{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px;margin-bottom:14px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{padding:6px 14px;border-radius:var(--r99);font-size:12.5px;font-weight:700;color:var(--ink3);border:1.5px solid var(--bdr);background:var(--sur);cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0;-webkit-tap-highlight-color:transparent}
.chip.on{background:var(--grn);color:#fff;border-color:var(--grn)}
.chip:active{transform:scale(.95)}
.tasks{display:flex;flex-direction:column;gap:8px}
.tcard{
  background:var(--sur);border:1px solid var(--bdr);
  border-radius:var(--r16);display:flex;overflow:hidden;
  box-shadow:var(--s0);transition:box-shadow .15s,transform .12s;
  -webkit-tap-highlight-color:transparent;
}
.tcard:hover{box-shadow:var(--s1)}
.tcard:active{transform:scale(.99)}
.tcard.done{opacity:.42}
.tcard.done .t-title{text-decoration:line-through;color:var(--ink3)}
.tstripe{width:4px;flex-shrink:0}
.tcard.hi .tstripe{background:var(--red)}
.tcard.med .tstripe{background:var(--amb)}
.tcard.lo .tstripe{background:var(--grn)}
.tinner{display:flex;align-items:flex-start;gap:12px;padding:14px 12px 14px 12px;flex:1;min-width:0}
.tck{
  width:22px;height:22px;border-radius:7px;border:2px solid var(--bdr2);
  background:none;flex-shrink:0;margin-top:1px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .15s;
  -webkit-tap-highlight-color:transparent;
}
.tck:active{transform:scale(.88)}
.tck.on{background:var(--grn);border-color:var(--grn);box-shadow:0 0 0 3px rgba(26,92,53,.12)}
.tck.on::after{content:'';display:block;width:10px;height:6px;border-left:2.5px solid #fff;border-bottom:2.5px solid #fff;transform:rotate(-45deg) translate(.5px,-.5px)}
.tbody{flex:1;min-width:0}
.t-title{font-size:14.5px;font-weight:700;color:var(--ink);line-height:1.4;margin-bottom:4px}
.t-desc{font-size:13px;color:var(--ink3);line-height:1.5;margin-bottom:7px}
.t-tags{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.tag{display:inline-flex;align-items:center;gap:3px;padding:2.5px 8px;border-radius:var(--r99);font-size:11px;font-weight:700}
.tag.hi{background:var(--reds);color:var(--red)}
.tag.med{background:var(--ambs);color:var(--amb)}
.tag.lo{background:var(--grns);color:var(--grn)}
.tag.due{background:var(--sur2);color:var(--ink3)}
.tag.ov{background:var(--reds);color:var(--red)}
.tag.file{background:var(--blus);color:var(--blu);cursor:pointer}
.tacts{display:flex;flex-direction:column;justify-content:center;gap:4px;padding:10px 10px 10px 0;flex-shrink:0}
.iabtn{width:30px;height:30px;border-radius:var(--r8);border:1px solid var(--bdr);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--ink3);transition:all .15s}
.iabtn.del{color:var(--red)}
.empty-st{text-align:center;padding:52px 20px;background:var(--sur);border-radius:var(--r16);border:1px solid var(--bdr)}
.empty-st .eico{font-size:40px;margin-bottom:10px}
.empty-st p{font-size:14px;color:var(--ink3)}



/* ─────────────────────────────────────────────
   REMINDERS
───────────────────────────────────────────── */
.rem-pad{padding:16px;display:flex;flex-direction:column;gap:14px}
.rem-hd{display:flex;align-items:center;justify-content:space-between}
.rem-title{font-family:'Lora',serif;font-size:20px;font-weight:600;letter-spacing:-.3px}
.btn-sm{display:flex;align-items:center;gap:4px;padding:7px 14px;background:var(--grn);color:#fff;border:none;border-radius:var(--r10);font-size:12.5px;font-weight:700;cursor:pointer;transition:all .15s}
.btn-sm svg{width:12px;height:12px}
.notif-banner{background:var(--ambs);border:1px solid rgba(138,90,0,.18);border-radius:var(--r12);padding:12px 14px;display:none;align-items:center;gap:10px}
.notif-banner.on{display:flex}
.notif-banner p{font-size:13px;color:var(--amb);flex:1;line-height:1.4}
.notif-allow{padding:6px 13px;background:var(--amb);color:#fff;border:none;border-radius:var(--r8);font-size:12.5px;font-weight:700;cursor:pointer;white-space:nowrap}
.rem-list-card{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r16);overflow:hidden}
.rem-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--bdr)}
.rem-item:last-child{border-bottom:none}
.rem-ico{width:36px;height:36px;border-radius:var(--r10);background:var(--grns);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.rem-info{flex:1;min-width:0}
.rem-name{font-size:14px;font-weight:700;color:var(--ink)}
.rem-time{font-size:12px;color:var(--ink3);margin-top:1px}
.toggle-wrap{position:relative;width:40px;height:24px;flex-shrink:0}
.toggle-wrap input{opacity:0;width:0;height:0;position:absolute}
.toggle-slider{position:absolute;inset:0;background:var(--bdr2);border-radius:99px;cursor:pointer;transition:background .2s}
.toggle-slider::before{content:'';position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;left:3px;top:3px;transition:transform .2s;box-shadow:var(--s0)}
.toggle-wrap input:checked+.toggle-slider{background:var(--grn)}
.toggle-wrap input:checked+.toggle-slider::before{transform:translateX(16px)}
.rmdel{background:none;border:none;color:var(--ink4);font-size:20px;cursor:pointer;padding:0 4px;line-height:1;flex-shrink:0}
.rmdel:hover{color:var(--red)}
.rem-empty{text-align:center;padding:36px 20px;background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r16)}
.rem-empty .eico{font-size:36px;margin-bottom:8px;opacity:.5}
.rem-empty p{font-size:14px;color:var(--ink3)}

/* ─────────────────────────────────────────────
   RECURRENCE CHIPS
───────────────────────────────────────────── */
.rec-opts{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.rec-opt{padding:5px 12px;border-radius:var(--r99);font-size:12px;font-weight:700;border:1.5px solid var(--bdr);background:var(--sur);cursor:pointer;transition:all .15s;color:var(--ink3);-webkit-tap-highlight-color:transparent}
.rec-opt.on{background:var(--grn);color:#fff;border-color:var(--grn)}
.rec-days{display:flex;gap:5px;margin-top:8px;display:none}
.rec-day{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--bdr);background:var(--sur);cursor:pointer;font-size:11px;font-weight:800;color:var(--ink3);display:flex;align-items:center;justify-content:center;transition:all .15s}
.rec-day.on{background:var(--grn);color:#fff;border-color:var(--grn)}
.tag.rec{background:var(--blus);color:var(--blu)}

/* ─────────────────────────────────────────────
   PERFORMANCE (admin) — redesigned matrix
───────────────────────────────────────────── */
.perf-pad{padding:16px;display:flex;flex-direction:column;gap:14px}
.perf-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.pstat{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r12);padding:14px 12px;box-shadow:var(--s0);text-align:center}
.pstat-n{font-family:'Lora',serif;font-size:26px;font-weight:600;color:var(--ink);line-height:1}
.pstat-l{font-size:10px;color:var(--ink3);font-weight:800;text-transform:uppercase;letter-spacing:.4px;margin-top:3px}
.perf-sec-title{font-family:'Lora',serif;font-size:17px;font-weight:600;letter-spacing:-.3px;margin-bottom:8px}
/* Student cards */
.scard{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r16);overflow:hidden;box-shadow:var(--s0)}
.scard-hd{display:flex;align-items:center;gap:10px;padding:14px 16px;cursor:pointer;transition:background .15s;user-select:none}
.scard-hd:active{background:var(--sur2)}
.sav{width:40px;height:40px;border-radius:50%;background:var(--grn);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;flex-shrink:0;overflow:hidden}
.sav img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.scard-info{flex:1;min-width:0}
.sname{font-size:15px;font-weight:700;color:var(--ink)}
.semail{font-size:11px;color:var(--ink3);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.scard-pct{font-size:13px;font-weight:800;color:var(--ink);white-space:nowrap}
.sbar-wrap{height:4px;background:var(--sur2);margin:0 16px 0}
.sbar{height:100%;border-radius:99px;background:var(--grn);transition:width .7s cubic-bezier(.34,1,.64,1)}
.scard-tasks{display:none;padding:0 16px 14px;border-top:1px solid var(--bdr)}
.scard-tasks.open{display:block}
.task-matrix{margin-top:10px;display:flex;flex-direction:column;gap:5px}
.tm-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r8);background:var(--sur2);transition:background .15s}
.tm-row.done-row{background:var(--grns)}
.tm-row.ov-row{background:var(--reds)}
.tm-status{width:22px;height:22px;border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px}
.tm-status.done{background:var(--grn);color:#fff}
.tm-status.todo{background:var(--bdr2);color:#fff}
.tm-status.ov{background:var(--red);color:#fff}
.tm-info{flex:1;min-width:0}
.tm-title{font-size:13px;font-weight:700;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tm-meta{font-size:11px;color:var(--ink3);margin-top:1px}
.tm-pri{font-size:10px;font-weight:800;padding:2px 7px;border-radius:var(--r99);white-space:nowrap}
.tm-pri.hi{background:var(--reds);color:var(--red)}
.tm-pri.med{background:var(--ambs);color:var(--amb)}
.tm-pri.lo{background:var(--grns);color:var(--grn)}
.scard-chevron{width:18px;height:18px;color:var(--ink4);transition:transform .2s;flex-shrink:0}
.scard-hd.open .scard-chevron{transform:rotate(180deg)}
.perf-empty{text-align:center;padding:48px 20px;background:var(--sur);border-radius:var(--r16);border:1px solid var(--bdr)}
.perf-search{width:100%;padding:10px 14px;border:1.5px solid var(--bdr);border-radius:var(--r10);font-size:14px;color:var(--ink);background:var(--sur);outline:none;font-family:inherit;transition:border-color .15s}
.perf-search:focus{border-color:var(--grn);box-shadow:0 0 0 3px rgba(26,92,53,.07)}
.perf-filter-row{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}
.perf-filter-row::-webkit-scrollbar{display:none}

/* ─────────────────────────────────────────────
   TIMER
───────────────────────────────────────────── */
.timer-pad{padding:16px;display:flex;flex-direction:column;gap:14px}
.tcard-main{background:var(--grn);border-radius:var(--r20);padding:24px 20px 20px;text-align:center;position:relative;overflow:hidden}
.tcard-main::before{content:'';position:absolute;width:280px;height:280px;border-radius:50%;border:1px solid rgba(255,255,255,.06);right:-70px;top:-70px;pointer-events:none}
/* Mode tabs */
.tmodes{display:flex;background:rgba(255,255,255,.12);border-radius:var(--r10);padding:3px;gap:3px;margin-bottom:20px;position:relative;z-index:1}
.tmbtn{flex:1;padding:7px 4px;border:none;background:none;border-radius:var(--r8);font-size:11.5px;font-weight:700;color:rgba(255,255,255,.5);cursor:pointer;transition:all .18s}
.tmbtn.on{background:rgba(255,255,255,.22);color:#fff}
/* Ring */
.tring-wrap{width:196px;height:196px;margin:0 auto 18px;position:relative;z-index:1}
.tring-wrap svg{position:absolute;inset:0;transform:rotate(-90deg)}
.trbg{fill:none;stroke:rgba(255,255,255,.12);stroke-width:9}
.trfill{fill:none;stroke:rgba(255,255,255,.9);stroke-width:9;stroke-linecap:round;transition:stroke-dashoffset .6s ease,stroke .4s}
.tring-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px}
.tdisplay{font-family:'Lora',serif;font-size:52px;font-weight:600;color:#fff;letter-spacing:-2px;line-height:1}
.tlabel{font-size:11px;color:rgba(255,255,255,.5);font-weight:700;letter-spacing:.4px;text-transform:uppercase;margin-top:2px}
/* Time input row — hours : minutes */
.tinput-row{display:flex;align-items:flex-end;justify-content:center;gap:0;margin-bottom:10px;position:relative;z-index:1;transition:opacity .25s}
.tinput-col{display:flex;flex-direction:column;align-items:center;gap:5px}
.tinput-lbl{font-size:9px;font-weight:800;color:rgba(255,255,255,.45);letter-spacing:.8px;text-transform:uppercase}
.tinput-field{
  width:80px;height:64px;
  font-family:'Lora',serif;font-size:44px;font-weight:600;
  color:#fff;background:rgba(255,255,255,.1);
  border:1.5px solid rgba(255,255,255,.18);border-radius:var(--r10);
  text-align:center;outline:none;
  -moz-appearance:textfield;appearance:textfield;
  letter-spacing:-1px;line-height:1;
  transition:background .15s,border-color .15s;
  -webkit-tap-highlight-color:transparent;
}
.tinput-field::-webkit-inner-spin-button,
.tinput-field::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.tinput-field:focus{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.55)}
.tinput-sep{font-family:'Lora',serif;font-size:44px;font-weight:600;color:rgba(255,255,255,.35);line-height:1;padding:0 4px;margin-bottom:2px}
/* Nudge row */
.tnudge-row{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:16px;position:relative;z-index:1;transition:opacity .25s}
.tnudge{padding:7px 14px;border-radius:var(--r99);background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.8);font-size:12.5px;font-weight:800;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent;font-family:inherit}
.tnudge:active{background:rgba(255,255,255,.28);transform:scale(.92)}
.tnudge.pos{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.3);color:#fff}
/* Warn banner */
.twarn{display:none;align-items:center;gap:8px;background:rgba(255,200,0,.15);border:1px solid rgba(255,200,0,.3);border-radius:var(--r8);padding:8px 12px;margin-bottom:12px;position:relative;z-index:1;text-align:left}
.twarn.on{display:flex}
.twarn-ico{font-size:16px;flex-shrink:0}
.twarn-txt{font-size:12px;color:rgba(255,240,150,.9);font-weight:600;line-height:1.4}
/* Presets */
.tpresets{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin-bottom:18px;position:relative;z-index:1;transition:opacity .25s}
.tpreset{padding:5px 14px;border-radius:var(--r99);background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.65);font-size:12px;font-weight:700;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}
.tpreset.on,.tpreset:hover{background:rgba(255,255,255,.24);border-color:rgba(255,255,255,.4);color:#fff}
.tpreset:active{transform:scale(.92)}
/* Controls */
.tcontrols{display:flex;align-items:center;justify-content:center;gap:14px;position:relative;z-index:1}
.tcbtn{border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;-webkit-tap-highlight-color:transparent}
.tcbtn:active{transform:scale(.9)}
.tcplay{width:66px;height:66px;background:#fff;box-shadow:0 4px 18px rgba(0,0,0,.22)}
.tcplay svg{width:26px;height:26px;color:var(--grn)}
.tcside{width:48px;height:48px;background:rgba(255,255,255,.15)}
.tcside svg{width:19px;height:19px;color:rgba(255,255,255,.85)}
/* Session dots */
.sdots{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;position:relative;z-index:1}
.sdot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.2);transition:all .35s}
.sdot.done{background:rgba(255,255,255,.85)}
.sdot.cur{background:rgba(255,255,255,.55);transform:scale(1.35)}
/* Task selector */
.ttsel{background:var(--sur);border-radius:var(--r16);border:1px solid var(--bdr);overflow:hidden}
.ttsel-hd{padding:12px 16px;font-size:11.5px;font-weight:800;color:var(--ink3);border-bottom:1px solid var(--bdr);text-transform:uppercase;letter-spacing:.5px}
.ttitem{display:flex;align-items:center;gap:12px;padding:13px 16px;border-bottom:1px solid var(--bdr);cursor:pointer;transition:background .15s;-webkit-tap-highlight-color:transparent}
.ttitem:last-child{border-bottom:none}
.ttitem:active{background:var(--sur2)}
.ttitem.sel{background:var(--grns)}
.ttstripe{width:3px;height:28px;border-radius:99px;flex-shrink:0}
.ttnm{font-size:14px;font-weight:600;color:var(--ink);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ttck{width:20px;height:20px;border-radius:50%;background:var(--grn);display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;transition:opacity .15s}
.ttitem.sel .ttck{opacity:1}
.ttck svg{width:11px;height:11px}
/* Today stats */
.tstats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.tstat{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r12);padding:14px 10px;box-shadow:var(--s0);text-align:center}
.tstat-n{font-family:'Lora',serif;font-size:22px;font-weight:600;color:var(--ink)}
.tstat-l{font-size:10px;color:var(--ink3);font-weight:800;text-transform:uppercase;letter-spacing:.4px;margin-top:2px}

/* ─────────────────────────────────────────────
   ACHIEVEMENTS — improved
───────────────────────────────────────────── */
.ach-pad{padding:16px;display:flex;flex-direction:column;gap:14px}
.ach-hdr{background:var(--grn);border-radius:var(--r16);padding:20px;position:relative;overflow:hidden}
.ach-hdr::before{content:'';position:absolute;width:200px;height:200px;border-radius:50%;border:1px solid rgba(255,255,255,.07);right:-40px;bottom:-40px;pointer-events:none}
.ach-hdr-title{font-family:'Lora',serif;font-size:20px;font-weight:600;color:#fff;margin-bottom:4px;position:relative;z-index:1}
.ach-hdr-sub{font-size:13px;color:rgba(255,255,255,.55);position:relative;z-index:1}
.xpbar-wrap{margin-top:14px;position:relative;z-index:1}
.xpbar-labels{display:flex;justify-content:space-between;margin-bottom:6px;font-size:12px;color:rgba(255,255,255,.6);font-weight:700}
.xptrack{height:8px;background:rgba(255,255,255,.15);border-radius:99px;overflow:hidden}
.xpfill{height:100%;background:#fff;border-radius:99px;transition:width .8s cubic-bezier(.34,1,.64,1)}
.streak-card{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r16);padding:16px 20px;box-shadow:var(--s0);display:flex;align-items:center;gap:14px}
.streak-n{font-family:'Lora',serif;font-size:36px;font-weight:600;color:var(--ora);line-height:1}
.streak-lbl{font-size:11.5px;color:var(--ink3);font-weight:700;text-transform:uppercase;letter-spacing:.4px;margin-top:2px}
.ach-cats{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none;margin-bottom:4px}
.ach-cats::-webkit-scrollbar{display:none}
.ach-cat{padding:5px 13px;border-radius:var(--r99);border:1.5px solid var(--bdr);background:var(--sur);font-size:12px;font-weight:700;color:var(--ink3);cursor:pointer;transition:all .15s;white-space:nowrap}
.ach-cat.on{background:var(--grn);color:#fff;border-color:var(--grn)}
.ach-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.acard{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r16);padding:16px;box-shadow:var(--s0);position:relative;overflow:hidden;transition:all .15s}
.acard.locked{opacity:.45;filter:grayscale(.65)}
.acard.unlocked{border-color:var(--grnm);box-shadow:0 0 0 1px var(--grnm),var(--s0)}
.acard.unlocked::after{content:'✓';position:absolute;top:10px;right:10px;background:var(--grn);color:#fff;font-size:9px;font-weight:800;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.acard-ico{font-size:28px;margin-bottom:8px;line-height:1}
.acard-name{font-size:13px;font-weight:800;color:var(--ink);margin-bottom:2px}
.acard-desc{font-size:11.5px;color:var(--ink3);line-height:1.4}
.acard-xp{font-size:11px;color:var(--grn);font-weight:800;margin-top:6px}
.acard-prog{margin-top:7px;height:3px;background:var(--bdr);border-radius:99px;overflow:hidden}
.acard-prog-fill{height:100%;background:var(--grn);border-radius:99px;transition:width .6s}
.acard-prog-lbl{font-size:10px;color:var(--ink4);margin-top:3px}
.xp-hist{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r16);padding:16px;box-shadow:var(--s0)}
.xp-hist-title{font-size:11px;font-weight:800;color:var(--ink3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.xp-evt{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid var(--bdr)}
.xp-evt:last-child{border-bottom:none}
.xp-evt-ico{font-size:16px;width:28px;text-align:center;flex-shrink:0}
.xp-evt-txt{flex:1;font-size:13px;color:var(--ink2);line-height:1.3}
.xp-evt-pts{font-size:12px;font-weight:800;color:var(--grn);white-space:nowrap}

/* ─────────────────────────────────────────────
   PROFILE DRAWER
───────────────────────────────────────────── */
.doverlay{position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:400;opacity:0;pointer-events:none;transition:opacity .22s}
.doverlay.on{opacity:1;pointer-events:all}
.drawer{position:fixed;top:0;right:0;bottom:0;width:82%;max-width:300px;background:var(--sur);z-index:401;transform:translateX(100%);transition:transform .26s cubic-bezier(.34,1,.64,1);display:flex;flex-direction:column;box-shadow:var(--s4)}
.drawer.on{transform:translateX(0)}
.drw-hd{padding:20px;border-bottom:1px solid var(--bdr)}
.drw-av-row{display:flex;align-items:center;gap:12px;margin-bottom:4px}
.drw-av{width:48px;height:48px;border-radius:50%;background:var(--grn);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;overflow:hidden;border:2px solid var(--grnm);flex-shrink:0}
.drw-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.drw-name{font-size:16px;font-weight:800;color:var(--ink)}
.drw-email{font-size:12px;color:var(--ink3);margin-top:1px}
.drw-body{flex:1;overflow-y:auto;padding:8px 0}
.drw-item{display:flex;align-items:center;gap:12px;padding:14px 20px;cursor:pointer;transition:background .15s;-webkit-tap-highlight-color:transparent}
.drw-item:active{background:var(--sur2)}
.drw-ico{width:36px;height:36px;border-radius:var(--r10);background:var(--sur2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.drw-ico svg{width:18px;height:18px;color:var(--ink3)}
.drw-lbl{font-size:14.5px;font-weight:600;color:var(--ink)}
.drw-sub{font-size:12px;color:var(--ink3);margin-top:1px}
.drw-sep{height:1px;background:var(--bdr);margin:4px 20px}
.drw-trial{display:flex;align-items:center;gap:12px;padding:12px 20px;background:var(--grns);margin:0 12px;border-radius:var(--r10)}
.drw-trial-ico{font-size:20px;flex-shrink:0}
.drw-trial-txt{font-size:12.5px;color:var(--grn);font-weight:700;line-height:1.4}
.drw-foot{padding:16px 20px;border-top:1px solid var(--bdr)}
.btn-logout{width:100%;padding:11px;border:1.5px solid var(--bdr);border-radius:var(--r10);background:none;font-size:14px;font-weight:700;color:var(--red);cursor:pointer;transition:all .15s;font-family:inherit}
.btn-logout:active{background:var(--reds)}

/* ─────────────────────────────────────────────
   MODALS (bottom sheet on mobile)
───────────────────────────────────────────── */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:500;display:flex;align-items:flex-end;opacity:0;pointer-events:none;transition:opacity .18s}
.overlay.on{opacity:1;pointer-events:all}
.modal{
  background:var(--sur);border-radius:var(--r20) var(--r20) 0 0;
  padding:18px 20px calc(20px + var(--sb));
  width:100%;max-height:94vh;overflow-y:auto;
  transform:translateY(100%);transition:transform .26s cubic-bezier(.34,1.08,.64,1);
}
.overlay.on .modal{transform:translateY(0)}
.modal-handle{width:36px;height:4px;border-radius:99px;background:var(--bdr2);margin:0 auto 16px}
.modal-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.modal-title{font-family:'Lora',serif;font-size:20px;font-weight:600;letter-spacing:-.3px}
.modal-x{width:28px;height:28px;border-radius:var(--r8);background:var(--sur2);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink3);font-size:16px}
.modal .fld textarea{width:100%;padding:11px 13px;border:1.5px solid var(--bdr);border-radius:var(--r10);resize:vertical;outline:none;font-size:14px;color:var(--ink);line-height:1.55;background:var(--sur);transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;appearance:none;font-family:inherit}
.modal .fld textarea:focus{border-color:var(--grn);box-shadow:0 0 0 3px rgba(26,92,53,.07)}
.modal .fld textarea::placeholder{color:var(--ink4)}
.attach-zone{border:2px dashed var(--bdr);border-radius:var(--r10);padding:18px;text-align:center;cursor:pointer;background:var(--sur2);transition:all .15s}
.attach-zone:active,.attach-zone.drag{border-color:var(--grn);background:var(--grns)}
.az-ico{font-size:22px;margin-bottom:4px;opacity:.5}
.attach-zone p{font-size:12.5px;color:var(--ink3)}
.attach-zone p strong{color:var(--grn);font-weight:700}
#file-input{display:none}
.flist{margin-top:8px;display:flex;flex-direction:column;gap:5px}
.frow{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-radius:var(--r8);background:var(--blus);font-size:12.5px}
.fname{color:var(--blu);font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.frm{background:none;border:none;color:var(--ink4);font-size:16px;cursor:pointer;padding:0 2px;line-height:1}
.uptrack{background:var(--bdr);border-radius:99px;height:3px;margin-top:8px;overflow:hidden;display:none}
.upfill{height:100%;border-radius:99px;background:var(--grn);width:0;transition:width .3s}
.modal-btns{display:flex;gap:8px;margin-top:18px}
.btn-cancel{flex:1;padding:12px;border:1.5px solid var(--bdr);border-radius:var(--r10);background:none;font-size:14px;font-weight:700;color:var(--ink2);cursor:pointer;transition:all .15s;font-family:inherit}
.btn-save{flex:2;padding:12px;background:var(--grn);color:#fff;border:none;border-radius:var(--r10);font-size:14px;font-weight:700;cursor:pointer;transition:all .15s;box-shadow:0 1px 4px rgba(26,92,53,.25);font-family:inherit}
.btn-save:disabled{opacity:.5;cursor:not-allowed}
.btn-cancel:active{background:var(--sur2)}
.btn-save:active{transform:scale(.98)}

/* ─────────────────────────────────────────────
   PAYMENT WALL
───────────────────────────────────────────── */
#paywall{display:none;position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);align-items:flex-end}
#paywall.on{display:flex;animation:fdin .22s ease}
.pw-sheet{background:var(--sur);border-radius:var(--r20) var(--r20) 0 0;width:100%;padding:18px 22px calc(24px + var(--sb))}
.pw-handle{width:36px;height:4px;border-radius:99px;background:var(--bdr2);margin:0 auto 20px}
.pw-top{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.pw-icon{width:54px;height:54px;border-radius:16px;background:var(--grn);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 12px rgba(26,92,53,.25);flex-shrink:0}
.pw-icon svg{width:28px;height:28px}
.pw-price{font-family:'Lora',serif;font-size:36px;font-weight:600;color:var(--ink);letter-spacing:-.5px;line-height:1}
.pw-price span{font-size:14px;color:var(--ink3);font-family:'Plus Jakarta Sans',sans-serif;font-weight:400}
.pw-title{font-size:14px;color:var(--ink2);margin-top:2px}
.pw-trial-box{background:var(--grns);border:1px solid var(--grnm);border-radius:var(--r10);padding:12px 14px;margin-bottom:18px;display:flex;align-items:center;gap:10px}
.pw-trial-ico{font-size:22px;flex-shrink:0}
.pw-trial-txt{font-size:13px;color:var(--grn);font-weight:700;line-height:1.4}
.pw-perks{display:flex;flex-direction:column;gap:9px;margin-bottom:20px}
.pw-perk{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--ink2)}
.pw-perk svg{color:var(--grn);flex-shrink:0;width:16px;height:16px}
.pw-btn{width:100%;padding:14px;background:var(--grn);color:#fff;border:none;border-radius:var(--r12);font-size:15px;font-weight:800;cursor:pointer;transition:all .15s;box-shadow:0 3px 12px rgba(26,92,53,.28);letter-spacing:.1px;font-family:inherit}
.pw-btn:active{transform:scale(.98)}
.pw-btn:disabled{opacity:.6;cursor:not-allowed}
.pw-secure{text-align:center;font-size:11.5px;color:var(--ink4);margin-top:10px;display:flex;align-items:center;justify-content:center;gap:4px}
.pw-secure svg{width:11px;height:11px}
.pw-logout{display:block;width:100%;padding:11px;background:none;border:none;font-size:13px;color:var(--ink3);cursor:pointer;margin-top:8px;font-family:inherit}

/* ─────────────────────────────────────────────
   ACHIEVEMENT POPUP & TOAST
───────────────────────────────────────────── */
#achpop{
  position:fixed;top:68px;left:50%;
  transform:translateX(-50%) translateY(-16px);
  background:var(--ink);color:#fff;border-radius:var(--r12);
  padding:11px 18px;display:flex;align-items:center;gap:10px;
  box-shadow:var(--s4);z-index:900;
  opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.34,1.3,.64,1);
  min-width:220px;max-width:320px;
}
#achpop.on{opacity:1;transform:translateX(-50%) translateY(0)}
.ap-ico{font-size:24px;flex-shrink:0}
.ap-txt strong{display:block;font-size:13.5px;font-weight:800}
.ap-txt span{font-size:12px;color:rgba(255,255,255,.55)}
#toast{
  position:fixed;bottom:calc(70px + var(--sb));left:50%;
  transform:translateX(-50%) translateY(16px);
  background:var(--ink);color:#fff;padding:10px 18px;
  border-radius:var(--r10);font-size:13.5px;font-weight:600;
  z-index:9999;transition:transform .25s cubic-bezier(.34,1.4,.64,1),opacity .25s;
  pointer-events:none;white-space:nowrap;box-shadow:var(--s3);opacity:0;
}
#toast.on{transform:translateX(-50%) translateY(0);opacity:1}
.confetti{position:fixed;width:8px;height:8px;border-radius:2px;pointer-events:none;z-index:9998;animation:cfall linear forwards}
@keyframes cfall{0%{opacity:1;transform:translateY(0) rotate(0deg)}100%{opacity:0;transform:translateY(100vh) rotate(720deg)}}

/* ─────────────────────────────────────────────
   DESKTOP LAYOUT (960px+)
───────────────────────────────────────────── */
/* Sidebar hidden on mobile/tablet by default */
.sidebar{display:none}

@media(min-width:960px){
  body{background:var(--sur2)}

  /* Overlay modals center on desktop */
  .overlay{align-items:center;padding:24px}
  .modal{border-radius:var(--r20);max-width:500px;margin:auto;padding:28px;transform:translateY(12px) scale(.98)}
  .overlay.on .modal{transform:translateY(0) scale(1)}
  .modal-handle{display:none}
  #paywall{align-items:center}
  .pw-sheet{border-radius:var(--r20);max-width:420px;margin:auto;padding:32px}
  .pw-handle{display:none}

  /* App: sidebar + scrollable main */
  #app{
    display:flex!important;flex-direction:row;
    min-height:100vh;max-width:1200px;margin:0 auto;
    background:var(--bg);
    box-shadow:0 0 80px rgba(0,0,0,.08);
  }

  /* Topbar hidden — sidebar takes over */
  .topbar{display:none}

  /* Sidebar */
  .sidebar{
    display:flex;flex-direction:column;
    width:var(--sidebar);flex-shrink:0;
    background:var(--sur);border-right:1px solid var(--bdr);
    position:sticky;top:0;height:100vh;overflow-y:auto;
  }
  .sb-logo{display:flex;align-items:center;gap:10px;padding:22px 20px 18px;border-bottom:1px solid var(--bdr)}
  .sb-logo-mk{width:30px;height:30px;border-radius:8px;background:var(--grn);display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px rgba(26,92,53,.2)}
  .sb-logo-mk svg{width:17px;height:17px}
  .sb-logo-nm{font-family:'Lora',serif;font-size:17px;letter-spacing:-.3px;color:var(--ink)}
  .sb-nav{display:flex;flex-direction:column;padding:8px 0;flex:1}
  .sb-btn{display:flex;align-items:center;gap:12px;padding:11px 20px;border:none;background:none;cursor:pointer;color:var(--ink3);font-size:14px;font-weight:600;transition:all .15s;text-align:left;font-family:inherit;border-radius:0;position:relative}
  .sb-btn svg{width:20px;height:20px;flex-shrink:0}
  .sb-btn:hover{background:var(--sur2);color:var(--ink2)}
  .sb-btn.on{background:var(--grns);color:var(--grn)}
  .sb-btn.on svg{color:var(--grn)}
  .sb-pip{position:absolute;right:16px;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:var(--red);display:none}
  .sb-pip.on{display:block}
  .sb-foot{padding:16px 20px;border-top:1px solid var(--bdr)}
  .sb-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r10);cursor:pointer;transition:background .15s;margin-bottom:10px}
  .sb-user:hover{background:var(--sur2)}
  .sb-av{width:32px;height:32px;border-radius:50%;background:var(--grn);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;overflow:hidden;flex-shrink:0;border:2px solid var(--grnm)}
  .sb-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
  .sb-uname{font-size:13.5px;font-weight:700;color:var(--ink);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .sb-logout{width:100%;padding:9px;border:1.5px solid var(--bdr);border-radius:var(--r8);background:none;font-size:13px;font-weight:700;color:var(--red);cursor:pointer;transition:all .15s;font-family:inherit}
  .sb-logout:hover{background:var(--reds)}

  /* Main content scrolls independently */
  .main-wrap{flex:1;overflow-y:auto;height:100vh;padding-bottom:0}

  /* Hide mobile nav on desktop */
  .bnav{display:none}
  .topbar{display:none}

  /* Toast adjusts for sidebar */
  #toast{bottom:28px}
  #achpop{left:calc(var(--sidebar) + 50%);transform:translateX(-50%) translateY(-16px)}
  #achpop.on{transform:translateX(-50%) translateY(0)}

  /* Drawer hidden — sidebar has profile */
  .doverlay,.drawer{display:none!important}

  /* Content width cap */
  .hero,.tv-pad,.timer-pad,.ach-pad,.rem-pad,.perf-pad{max-width:700px;margin-left:auto;margin-right:auto}
  .hero{border-radius:0}
}

/* Tablet tweaks */
@media(min-width:640px) and (max-width:959px){
  .overlay{align-items:center;padding:24px}
  .modal{border-radius:var(--r20);max-width:500px;margin:auto;padding:28px}
  .modal-handle{display:none}
  #paywall{align-items:center}
  .pw-sheet{border-radius:var(--r20);max-width:420px;margin:auto;padding:28px}
  .pw-handle{display:none}
}
/* ─────────────────────────────────────────────
   TASK SECTION TABS (Assigned / My Tasks)
───────────────────────────────────────────── */
.task-tabs{
  display:flex;background:var(--sur2);border-radius:var(--r12);padding:3px;gap:3px;
  margin-bottom:16px;
}
.task-tab{
  flex:1;padding:9px 6px;border:none;background:none;
  font-size:13px;font-weight:700;color:var(--ink3);
  border-radius:var(--r10);cursor:pointer;transition:all .15s;
  display:flex;align-items:center;justify-content:center;gap:6px;
  font-family:inherit;-webkit-tap-highlight-color:transparent;
}
.task-tab svg{width:15px;height:15px;flex-shrink:0}
.task-tab.on{background:var(--sur);color:var(--ink);box-shadow:var(--s0)}
.task-tab:active{transform:scale(.97)}

.mytasks-note{
  display:flex;align-items:center;gap:6px;
  font-size:11.5px;color:var(--ink3);font-weight:600;
  background:var(--sur);border:1px solid var(--bdr);
  border-radius:var(--r8);padding:7px 12px;
  margin-bottom:12px;
}
.mytasks-note svg{color:var(--grn);flex-shrink:0}
.mytask-local-note{
  display:flex;align-items:center;gap:6px;
  font-size:11.5px;color:var(--ink3);font-weight:600;
  background:var(--grns);border:1px solid var(--grnm);
  border-radius:var(--r8);padding:7px 12px;
  margin-bottom:12px;
}
.mytask-local-note svg{color:var(--grn);flex-shrink:0}

/* My Tasks card — same .tcard but with personal indicator */
.tcard.personal .tstripe{background:var(--blu)}
.tcard.personal.hi .tstripe{background:var(--red)}
.tcard.personal.med .tstripe{background:var(--amb)}
.tcard.personal.lo .tstripe{background:var(--blu)}

/* ─────────────────────────────────────────────
   MENTORSHIP SECTION
───────────────────────────────────────────── */
.mentor-pad{padding:16px;display:flex;flex-direction:column;gap:14px}

/* Admin sub-tabs */
.mentor-admin-tabs{
  display:flex;gap:0;border-bottom:1.5px solid var(--bdr);
  padding:0 16px;background:var(--sur);
}
.mentor-admin-tabs .task-tab{
  background:none;box-shadow:none;border-radius:0;
  border-bottom:2.5px solid transparent;padding:12px 10px;
  flex:unset;gap:7px;font-size:13px;color:var(--ink3);
  margin-bottom:-1.5px;
}
.mentor-admin-tabs .task-tab.on{
  color:var(--grn);border-bottom-color:var(--grn);background:none;box-shadow:none;
}

/* Slot cards (student view) */
.slot-card{
  background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r16);
  overflow:hidden;box-shadow:var(--s0);transition:box-shadow .15s;
}
.slot-card:hover{box-shadow:var(--s1)}
.slot-card.booked{border-color:var(--grnm)}
.slot-card.full{opacity:.6}

.slot-top{display:flex;align-items:flex-start;gap:14px;padding:16px 16px 12px}
.slot-avatar{
  width:48px;height:48px;border-radius:50%;background:var(--grn);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:16px;font-weight:800;flex-shrink:0;overflow:hidden;
  border:2px solid var(--grnm);
}
.slot-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.slot-info{flex:1;min-width:0}
.slot-title{font-size:15px;font-weight:800;color:var(--ink);line-height:1.3;margin-bottom:4px}
.slot-teacher{font-size:12.5px;font-weight:700;color:var(--grn);margin-bottom:3px}
.slot-bio{font-size:12px;color:var(--ink3);line-height:1.4}
.slot-meta{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:0 16px 12px;
}
.slot-tag{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 9px;border-radius:var(--r99);
  font-size:11px;font-weight:700;
  background:var(--sur2);color:var(--ink3);
}
.slot-tag.date{background:var(--blus);color:var(--blu)}
.slot-tag.time{background:var(--grns);color:var(--grn)}
.slot-tag.dur{background:var(--sur2);color:var(--ink3)}
.slot-tag.free{background:var(--grns);color:var(--grn)}
.slot-tag.paid{background:var(--ambs);color:var(--amb)}
.slot-tag.full{background:var(--reds);color:var(--red)}
.slot-tag.seats{background:var(--grns);color:var(--grn)}
.slot-tag.booked{background:var(--grns);color:var(--grn)}

.slot-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;border-top:1px solid var(--bdr);
  background:var(--sur2);
}
.slot-price{font-family:'Lora',serif;font-size:20px;font-weight:600;color:var(--ink)}
.slot-price .free-lbl{font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;color:var(--grn)}
.btn-book-slot{
  padding:9px 20px;background:var(--grn);color:#fff;border:none;
  border-radius:var(--r10);font-size:13.5px;font-weight:700;cursor:pointer;
  transition:all .15s;box-shadow:0 2px 8px rgba(26,92,53,.2);
  font-family:inherit;-webkit-tap-highlight-color:transparent;
}
.btn-book-slot:hover{background:var(--grn2)}
.btn-book-slot:active{transform:scale(.97)}
.btn-book-slot:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-booked{
  padding:9px 20px;background:var(--grns);color:var(--grn);
  border:1.5px solid var(--grnm);border-radius:var(--r10);
  font-size:13px;font-weight:700;cursor:default;font-family:inherit;
}
.btn-full{
  padding:9px 16px;background:var(--reds);color:var(--red);
  border:1.5px solid rgba(192,38,26,.2);border-radius:var(--r10);
  font-size:13px;font-weight:700;cursor:not-allowed;font-family:inherit;
}

/* My bookings strip */
.my-booking-card{
  background:var(--grns);border:1px solid var(--grnm);border-radius:var(--r12);
  padding:12px 14px;display:flex;align-items:center;gap:12px;
}
.mbc-icon{font-size:22px;flex-shrink:0}
.mbc-info{flex:1;min-width:0}
.mbc-title{font-size:14px;font-weight:700;color:var(--ink);line-height:1.3}
.mbc-meta{font-size:12px;color:var(--grn);margin-top:2px;font-weight:600}
.mbc-status{
  font-size:10px;font-weight:800;padding:3px 8px;
  border-radius:var(--r99);text-transform:uppercase;letter-spacing:.3px;
}
.mbc-status.confirmed{background:var(--grn);color:#fff}
.mbc-status.pending_payment{background:var(--ambs);color:var(--amb)}
.mbc-status.cancelled{background:var(--reds);color:var(--red)}

.mentor-divider{height:1px;background:var(--bdr);margin:4px 0 12px}

/* Admin slot management cards */
.admin-slot-card{
  background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r12);
  overflow:hidden;box-shadow:var(--s0);
}
.asc-head{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--bdr)}
.asc-head-info{flex:1;min-width:0}
.asc-title{font-size:14px;font-weight:700;color:var(--ink)}
.asc-meta{font-size:12px;color:var(--ink3);margin-top:2px}
.asc-acts{display:flex;align-items:center;gap:6px;flex-shrink:0}
.asc-act{
  width:30px;height:30px;border-radius:var(--r8);border:1px solid var(--bdr);
  background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:13px;color:var(--ink3);transition:all .15s;
}
.asc-act.del{color:var(--red)}
.asc-act:hover{background:var(--sur2)}
.asc-stats{display:flex;gap:0;padding:10px 14px}
.asc-stat{flex:1;text-align:center}
.asc-stat-n{font-size:18px;font-weight:800;color:var(--ink)}
.asc-stat-l{font-size:10px;color:var(--ink3);font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.inactive-badge{
  font-size:9px;font-weight:800;padding:2px 7px;
  border-radius:var(--r99);background:var(--reds);color:var(--red);
  text-transform:uppercase;letter-spacing:.3px;
}
.active-badge{
  font-size:9px;font-weight:800;padding:2px 7px;
  border-radius:var(--r99);background:var(--grns);color:var(--grn);
  text-transform:uppercase;letter-spacing:.3px;
}

/* Admin bookings list */
.booking-row{
  background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r12);
  overflow:hidden;box-shadow:var(--s0);
}
.booking-row-head{display:flex;align-items:center;gap:10px;padding:12px 14px;cursor:pointer;transition:background .15s}
.booking-row-head:active{background:var(--sur2)}
.brow-av{
  width:38px;height:38px;border-radius:50%;background:var(--grn);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;
  flex-shrink:0;
}
.brow-info{flex:1;min-width:0}
.brow-name{font-size:14px;font-weight:700;color:var(--ink)}
.brow-slot{font-size:12px;color:var(--ink3);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.brow-status{font-size:10px;font-weight:800;padding:3px 8px;border-radius:var(--r99);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}
.brow-status.confirmed{background:var(--grns);color:var(--grn)}
.brow-status.pending_payment{background:var(--ambs);color:var(--amb)}
.brow-status.cancelled{background:var(--reds);color:var(--red)}
.booking-detail{display:none;padding:12px 14px;border-top:1px solid var(--bdr);background:var(--sur2)}
.booking-detail.open{display:block}
.bd-row{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink2);padding:3px 0}
.bd-lbl{font-size:11px;font-weight:800;color:var(--ink3);text-transform:uppercase;letter-spacing:.3px;width:80px;flex-shrink:0}

/* Booking confirmation modal */
.booking-slot-summary{
  background:var(--grns);border:1px solid var(--grnm);border-radius:var(--r12);
  padding:14px;margin-bottom:16px;
}
.bss-title{font-size:15px;font-weight:800;color:var(--ink);margin-bottom:4px}
.bss-meta{font-size:12.5px;color:var(--grn);font-weight:600;display:flex;flex-wrap:wrap;gap:8px}
.booking-pay-summary{
  background:var(--ambs);border:1px solid rgba(138,90,0,.18);
  border-radius:var(--r10);padding:12px 14px;margin-bottom:4px;
}
.bps-row{display:flex;align-items:center;justify-content:space-between;font-size:14px;color:var(--amb);padding:3px 0}
.bps-total{font-weight:800;font-size:16px;border-top:1px solid rgba(138,90,0,.18);margin-top:6px;padding-top:8px}

/* Mentor stats row */
.mentor-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:4px}

/* Slot filter empty states */
.slot-empty{
  text-align:center;padding:52px 20px;
  background:var(--sur);border-radius:var(--r16);border:1px solid var(--bdr);
}
.slot-empty .eico{font-size:40px;margin-bottom:10px}
.slot-empty p{font-size:14px;color:var(--ink3)}

/* Recurrence sub-elements (missing from original) */
.rec-days-label,.rec-end-label{font-size:11px;font-weight:800;color:var(--ink3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.rec-day-row{display:flex;gap:5px;flex-wrap:wrap}
.rec-end{display:none;background:var(--sur2);border-radius:var(--r8);padding:10px 12px;margin-top:8px}
.rec-end-opts{display:flex;flex-direction:column;gap:7px}
.rec-end-opt{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink2);cursor:pointer}
.rec-end-date-inp{height:28px;border:1.5px solid var(--bdr);border-radius:var(--r6);padding:2px 8px;font-size:12px;background:var(--sur);outline:none;font-family:inherit;margin-left:4px}
.rec-end-count-inp{width:56px;height:28px;border:1.5px solid var(--bdr);border-radius:var(--r6);padding:2px 8px;font-size:12px;background:var(--sur);outline:none;font-family:inherit;text-align:center;margin:0 4px}
.rec-preview{font-size:12px;font-weight:700;color:var(--grn);margin-top:8px;padding:5px 10px;background:var(--grns);border-radius:var(--r6);display:none}

/* ─────────────────────────────────────────────
   BOTTOM NAV – accommodate more items gracefully
───────────────────────────────────────────── */
@media(max-width:959px){
  .bnav{overflow-x:auto;scrollbar-width:none}
  .bnav::-webkit-scrollbar{display:none}
  .bn{min-width:52px}
}

/* ─────────────────────────────────────────────
   DESKTOP – extend content max-width for mentor
───────────────────────────────────────────── */
@media(min-width:960px){
  .mentor-pad{max-width:700px;margin-left:auto;margin-right:auto}
  .mentor-admin-tabs{max-width:700px;margin-left:auto;margin-right:auto}
}