/* === CSS Block (original lines 16–2268) === */
:root{--bg:#0a0a0f;--sf:#111118;--sf2:#18181f;--sf3:#1e1e28;--bd:rgba(255,255,255,0.07);--bd2:rgba(255,255,255,0.12);--tx:#f0eff5;--mu:#7a7990;--mu2:#4a4960;--ac:#7c6af7;--ac2:#a695ff;--gn:#34d399;--gd:rgba(52,211,153,0.12);--am:#fbbf24;--ad:rgba(251,191,36,0.1);--rd:#f87171;--rdm:rgba(248,113,113,0.1);--bl:#60a5fa;--bld:rgba(96,165,250,0.1);--tl:#2dd4bf;--pk:#f472b6;--r:12px;--rs:8px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--tx);min-height:100vh;overflow-x:hidden;font-size:14px}
/* Numeric font applied to all data numbers — Space Grotesk: premium bold geometric */
.sp,.sv,.prem-stat-val,.prem-stat-num,
[data-num],
.stat-number{font-family:'Space Grotesk',sans-serif!important}
/* Apply Space Grotesk to table data cells with numbers */
td{font-family:'Space Grotesk',sans-serif}
.app{display:flex;min-height:100vh}
.sb{width:224px;flex-shrink:0;background:var(--sf);border-right:1px solid var(--bd);display:flex;flex-direction:column;padding:1.25rem .9rem 0;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}
/* Premium sidebar glow */
.sb::before{content:'';position:absolute;top:0;left:0;right:0;height:180px;background:radial-gradient(ellipse 140% 100% at 50% 0%,rgba(124,106,247,.08) 0%,transparent 70%);pointer-events:none;z-index:0}
.sb::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E") 0 0/150px 150px;opacity:.018;pointer-events:none;z-index:0}
/* Sidebar top shimmer line */
.sb .logo{position:relative;z-index:1}
.sb .ns{position:relative;z-index:1}
.sb .wm{position:relative;z-index:1}
.wm{padding:.8rem .4rem;border-top:1px solid var(--bd);font-size:10px;color:var(--mu2);margin-top:auto;position:sticky;bottom:0;background:var(--sf)}
body.sb-open{overflow:hidden!important}
.main{margin-left:224px;flex:1;padding:1.25rem;min-height:100vh}
.logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.05rem;letter-spacing:-.02em;margin-bottom:1.5rem;padding:0 .4rem;color:var(--tx)}
.logo span{background:linear-gradient(135deg,#a695ff,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.logo span{color:var(--ac2)}
.wm strong{display:block;font-family:'Syne',sans-serif;font-size:11px;color:var(--mu);font-weight:600;margin-bottom:1px}
.ns{margin-bottom:1.25rem}
.nl{font-size:9px;font-weight:600;letter-spacing:.1em;color:var(--mu2);text-transform:uppercase;padding:0 .4rem;margin-bottom:.4rem}
.ni{display:flex;align-items:center;gap:7px;padding:.45rem .6rem;border-radius:var(--rs);cursor:pointer;transition:all .18s;font-size:12.5px;color:var(--mu);border:none;background:none;width:100%;text-align:left;position:relative}
.ni:hover{background:var(--sf2);color:var(--tx);transform:translateX(2px)}
.ni.active{background:linear-gradient(135deg,rgba(124,106,247,.15),rgba(166,149,255,.08));color:var(--ac2);font-weight:500;box-shadow:0 2px 14px rgba(124,106,247,.18),inset 0 1px 0 rgba(166,149,255,.1)}
.ni .ico{display:inline-flex;align-items:center;font-size:14px;width:17px;text-align:center}
.nbadge{position:absolute;right:7px;top:50%;transform:translateY(-50%);background:var(--rd);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:99px;min-width:15px;text-align:center}
/* layout */
.ph{margin-bottom:1.25rem;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:8px}
.pt{font-family:'Syne',sans-serif;font-weight:700;font-size:1.4rem;letter-spacing:-.02em}
.ps{color:var(--mu);font-size:12px;margin-top:2px}
.fr{display:flex;gap:7px;margin-bottom:1rem;flex-wrap:wrap;align-items:center}
.g2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:10px}
.g3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:10px}
.g4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:10px}
.g5{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-bottom:10px}
.card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);padding:.9rem 1rem;transition:border-color .2s,box-shadow .2s}
.card:hover{border-color:rgba(124,106,247,.2);box-shadow:0 4px 24px rgba(0,0,0,.3)}
.ch{display:flex;justify-content:space-between;align-items:center;margin-bottom:.7rem}
.ct{font-size:11px;font-weight:600;color:var(--mu);text-transform:uppercase;letter-spacing:.06em}
.sc{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);padding:.9rem 1rem;transition:border-color .2s,transform .15s,box-shadow .2s}
.sc:hover{border-color:rgba(124,106,247,.18);transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,.25)}
.sl{font-size:11px;color:var(--mu);margin-bottom:3px}
.sv{font-family:'Space Grotesk',sans-serif;font-size:1.7rem;font-weight:700;color:var(--tx);line-height:1;letter-spacing:-.02em}
.ss{font-size:11px;color:var(--mu);margin-top:3px}
.sbadge{display:inline-block;font-size:10px;padding:2px 6px;border-radius:4px;font-weight:600;margin-top:3px}
.bg{background:var(--gd);color:var(--gn)}.br{background:var(--rdm);color:var(--rd)}.ba{background:var(--ad);color:var(--am)}.bb{background:var(--bld);color:var(--bl)}.bac{background:rgba(124,106,247,.12);color:var(--ac2)}.bpk{background:rgba(244,114,182,.12);color:var(--pk)}
.cw{position:relative}
/* tables */
.tw{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:11.5px}
th{font-size:9.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--mu2);padding:.45rem .7rem;text-align:left;border-bottom:1px solid var(--bd)}
td{padding:.55rem .7rem;border-bottom:1px solid var(--bd);color:var(--tx);vertical-align:middle;transition:background .15s}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(124,106,247,.06)}
.sp{display:inline-block;padding:2px 7px;border-radius:5px;font-family:'DM Mono',monospace;font-size:10.5px;font-weight:500}
/* forms */
.fg{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:9px;margin-bottom:.9rem}
.fgr{display:flex;flex-direction:column;gap:4px}
.fl{font-size:10.5px;color:var(--mu);font-weight:500}
.fi,.fs{background:var(--sf2);border:1px solid var(--bd2);color:var(--tx);border-radius:var(--rs);padding:6px 9px;font-family:'DM Sans',sans-serif;font-size:13px;outline:none;transition:border-color .15s;width:100%}
.fi.fi-error{border-color:var(--rd)!important;background:rgba(248,113,113,.06)!important}
.fi-err-msg{font-size:11px;color:var(--rd);margin-top:3px;display:none}
.fi-err-msg.show{display:block;animation:errFadeIn .2s ease both}
@keyframes errFadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

/* pmo-input error state (used in score modals) */
.pmo-input.pmo-inp-error,.pmo-score-inp.pmo-inp-error,.pmo-input-total.pmo-inp-error{
  border-color:rgba(248,113,113,.7)!important;
  background:rgba(248,113,113,.07)!important;
  box-shadow:0 0 0 3px rgba(248,113,113,.14)!important;
  color:#fca5a5!important;
}
.pmo-input.pmo-inp-error::placeholder,.pmo-score-inp.pmo-inp-error::placeholder{color:rgba(252,165,165,.5)!important}

/* Shake animation for invalid fields */
@keyframes pmoShake{
  0%,100%{transform:translateX(0)}
  15%{transform:translateX(-7px)}
  30%{transform:translateX(6px)}
  45%{transform:translateX(-5px)}
  60%{transform:translateX(4px)}
  75%{transform:translateX(-2px)}
  90%{transform:translateX(1px)}
}
.pmo-inp-shake{animation:pmoShake .38s cubic-bezier(.36,.07,.19,.97) both}
.fi:focus,.fs:focus{border-color:var(--ac)}
.fs{cursor:pointer}
/* buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--rs);border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:500;transition:all .15s;touch-action:manipulation}
.btn:hover{filter:brightness(1.1)}
.btn:active{transform:scale(.96)}
.bp{background:var(--ac);color:#fff}.bp:hover{background:var(--ac2)}
.bg2{background:var(--sf2);color:var(--tx);border:1px solid var(--bd2)}.bg2:hover{border-color:var(--ac);color:var(--ac2)}
.brd{background:var(--rdm);color:var(--rd);border:1px solid var(--rdm)}.brd:hover{background:rgba(248,113,113,.2)}
.bam{background:var(--ad);color:var(--am);border:1px solid var(--ad)}
.bsm{padding:3px 9px;font-size:10.5px}
/* filter chips */
.fc{padding:4px 11px;border-radius:99px;border:1px solid var(--bd2);background:none;color:var(--mu);font-size:11.5px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s}
.fc:focus{outline:none;border-color:var(--ac);box-shadow:none}
select.fc:focus{outline:none;border-color:var(--ac);box-shadow:none}
.fc.active{border-color:var(--ac)}
select.fc.active{border-color:var(--ac)}
.fc.active{background:var(--ac);border-color:var(--ac);color:#fff;font-weight:500}
.fc:hover:not(.active){border-color:var(--bd2);color:var(--tx)}
select.fc{appearance:none;-webkit-appearance:none;padding-right:26px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237a7990' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-color:var(--sf);cursor:pointer;min-width:0;text-overflow:ellipsis;overflow:hidden}
/* mode toggle */
.mt{display:flex;background:var(--sf2);border-radius:5px;padding:2px;gap:2px}
.mb{padding:2px 9px;border-radius:4px;border:none;cursor:pointer;font-size:10.5px;font-weight:500;font-family:'DM Sans',sans-serif;background:none;color:var(--mu);transition:all .15s}
.mb.active{background:var(--sf3);color:var(--tx)}
/* subject color classes */
.cphy{background:rgba(96,165,250,.12);color:var(--bl)}
.cche{background:rgba(52,211,153,.12);color:var(--gn)}
.cmat{background:rgba(251,191,36,.1);color:var(--am)}
.blphy{border-left:3px solid var(--bl)}.blche{border-left:3px solid var(--gn)}.blmat{border-left:3px solid var(--am)}
.chip{display:inline-block;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600;letter-spacing:.03em}
.tt{font-size:10px;padding:2px 5px;border-radius:4px;font-weight:600}
.tf{background:var(--gd);color:var(--gn)}.tp{background:var(--ad);color:var(--am)}
/* task items */
.ti{background:var(--sf2);border:1px solid var(--bd);border-radius:var(--rs);padding:.65rem .85rem;margin-bottom:5px;transition:border-color .15s;display:flex;align-items:flex-start;gap:9px}
.ti:hover{border-color:var(--bd2)}
.tck{width:15px;height:15px;border-radius:4px;border:1.5px solid var(--bd2);cursor:pointer;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.tck.done{background:var(--gn);border-color:var(--gn)}
/* heatmap */
.hmg{display:grid;grid-template-columns:repeat(13,1fr);gap:3px}
.hmc{aspect-ratio:1;border-radius:3px;cursor:pointer;transition:transform .15s,filter .15s,box-shadow .15s;position:relative}
.hmc:hover{transform:scale(1.4);filter:brightness(1.3);box-shadow:0 2px 8px rgba(0,0,0,.4);z-index:2}
.hmc[title]:hover::after{content:attr(title);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--sf3);border:1px solid var(--bd2);color:var(--tx);font-size:9.5px;padding:3px 7px;border-radius:5px;white-space:nowrap;pointer-events:none;z-index:99;font-family:'DM Sans',sans-serif}
/* modals */
.mo{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:200;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.mo.open{display:flex;animation:moFadeIn .2s ease}
@keyframes moFadeIn{from{opacity:0}to{opacity:1}}
.md{position:relative;background:var(--sf);border:1px solid var(--bd2);border-radius:var(--r);padding:1.4rem;width:500px;max-width:95vw;max-height:90vh;overflow-y:auto;animation:mdSlideUp .25s cubic-bezier(.34,1.1,.64,1)}
@keyframes mdSlideUp{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}
.md-close{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;background:var(--sf3);border:1px solid var(--bd2);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--mu);font-size:14px;transition:all .15s;z-index:1}
.md-close:hover{background:rgba(248,113,113,.15);color:var(--rd);border-color:rgba(248,113,113,.3)}
.mt2{font-family:'Syne',sans-serif;font-weight:700;font-size:1.05rem;margin-bottom:.9rem}
.ma{display:flex;gap:7px;justify-content:flex-end;margin-top:.9rem}
/* toast — pro system */
.toast{position:fixed;bottom:1.4rem;right:1.4rem;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:12px;padding:0;font-size:13px;z-index:500;transform:translateY(130%) scale(.94);transition:transform .38s cubic-bezier(.34,1.18,.64,1),opacity .2s;color:var(--tx);max-width:320px;min-width:220px;box-shadow:0 12px 40px rgba(0,0,0,.5),0 2px 8px rgba(0,0,0,.3);opacity:0;pointer-events:none}
.toast.show{transform:translateY(0) scale(1);opacity:1;pointer-events:auto}
/* Top warning toast for low-data AI insights */
.toast-top-warn{position:fixed;top:1.1rem;left:50%;transform:translateX(-50%) translateY(-120%) scale(.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:12px;padding:0;font-size:13px;z-index:600;transition:transform .4s cubic-bezier(.34,1.18,.64,1),opacity .25s;color:var(--tx);max-width:460px;min-width:280px;width:max-content;box-shadow:0 12px 40px rgba(0,0,0,.6),0 2px 8px rgba(0,0,0,.4);opacity:0;pointer-events:none;background:rgba(28,22,8,.97);border:1px solid rgba(251,191,36,.4)}
.toast-top-warn.show{transform:translateX(-50%) translateY(0) scale(1);opacity:1;pointer-events:auto}
.toast-top-warn .toast-bar{background:linear-gradient(90deg,#fbbf24,#fde68a)!important}
.toast-inner{display:flex;align-items:center;gap:10px;padding:.72rem 1rem}
.toast-icon{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:12px;font-weight:700}
.toast-msg{flex:1;font-size:12.5px;font-weight:500;line-height:1.4}
.toast-bar{height:2.5px;border-radius:0 0 12px 12px;width:100%;transform-origin:left;animation:toastBarShrink 2.8s linear forwards}
@keyframes toastBarShrink{from{transform:scaleX(1)}to{transform:scaleX(0)}}
/* default */
.toast{background:rgba(24,24,32,.97);border:1px solid rgba(255,255,255,.1)}
.toast .toast-icon{background:rgba(255,255,255,.1);color:var(--mu)}
.toast .toast-bar{background:rgba(255,255,255,.2)}
/* success */
.toast-success{background:rgba(15,30,22,.97)!important;border:1px solid rgba(52,211,153,.3)!important}
.toast-success .toast-icon{background:rgba(52,211,153,.18);color:#34d399}
.toast-success .toast-bar{background:linear-gradient(90deg,#34d399,#6ee7b7)!important}
/* error */
.toast-error{background:rgba(30,12,12,.97)!important;border:1px solid rgba(248,113,113,.3)!important}
.toast-error .toast-icon{background:rgba(248,113,113,.15);color:#f87171}
.toast-error .toast-bar{background:linear-gradient(90deg,#f87171,#fca5a5)!important}
/* info */
.toast-info{background:rgba(12,20,32,.97)!important;border:1px solid rgba(96,165,250,.3)!important}
.toast-info .toast-icon{background:rgba(96,165,250,.15);color:#60a5fa}
.toast-info .toast-bar{background:linear-gradient(90deg,#60a5fa,#93c5fd)!important}
/* warning */
.toast-warning{background:rgba(28,22,8,.97)!important;border:1px solid rgba(251,191,36,.3)!important}
.toast-warning .toast-icon{background:rgba(251,191,36,.12);color:#fbbf24}
.toast-warning .toast-bar{background:linear-gradient(90deg,#fbbf24,#fde68a)!important}
/* saving */
.toast-saving{background:rgba(20,18,34,.97)!important;border:1px solid rgba(124,106,247,.3)!important}
.toast-saving .toast-icon{background:rgba(124,106,247,.15);color:var(--ac2)}
.toast-saving .toast-bar{background:linear-gradient(90deg,var(--ac),var(--ac2))!important}
.toast-spinner{width:13px;height:13px;border:2px solid rgba(124,106,247,.3);border-top-color:var(--ac2);border-radius:50%;animation:toastSpin .7s linear infinite;flex-shrink:0}
@keyframes toastSpin{to{transform:rotate(360deg)}}
/* notifications */
.nb{border-radius:var(--rs);padding:.45rem .8rem;display:flex;align-items:center;gap:7px;font-size:12px;margin-bottom:5px;cursor:pointer;transition:background .15s}
.nb.am{background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.2)}.nb.am:hover{background:rgba(251,191,36,.14)}
.nb.rd{background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.2)}.nb.rd:hover{background:rgba(248,113,113,.14)}
.nb.bl{background:rgba(96,165,250,.08);border:1px solid rgba(96,165,250,.2)}.nb.bl:hover{background:rgba(96,165,250,.14)}
.nb.gn{background:rgba(52,211,153,.08);border:1px solid rgba(52,211,153,.2)}
.nb-x{margin-left:auto;flex-shrink:0;background:none;border:none;color:var(--mu);cursor:pointer;font-size:13px;padding:0 2px;line-height:1;transition:color .15s}
.nb-x:hover{color:var(--tx)}
/* pages */
.page{display:none;opacity:0;content-visibility:auto}.page.active{display:block;will-change:opacity,transform;animation:pageIn .18s ease forwards}.page.active.anim-done{will-change:auto}
@keyframes pageIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.page-inner{width:100%}

/* ── Card hover lift ── */
.card{transition:box-shadow .2s,border-color .2s}
.card:hover{box-shadow:0 4px 24px rgba(0,0,0,.25);border-color:rgba(255,255,255,.1)}
.sc{transition:box-shadow .2s,border-color .2s,transform .2s}
.sc:hover{box-shadow:0 4px 20px rgba(0,0,0,.2);border-color:rgba(255,255,255,.1);transform:translateY(-1px)}

/* ── Button micro-interactions ── */
.btn{transition:all .15s cubic-bezier(.4,0,.2,1)}
.btn:hover{transform:translateY(-1px);filter:brightness(1.1)}
.btn:active{transform:translateY(0) scale(.97)}
.bp:hover{box-shadow:0 4px 16px rgba(124,106,247,.35)}
.bg2:hover{box-shadow:0 4px 12px rgba(0,0,0,.3)}
.brd:hover{box-shadow:0 4px 12px rgba(248,113,113,.25)}

/* ── Stat number count-up ── */
.sv{transition:color .3s}
.sv.updated{animation:statPop .4s cubic-bezier(.34,1.56,.64,1)}
@keyframes statPop{0%{transform:scale(.85)}60%{transform:scale(1.08)}100%{transform:scale(1)}}

/* ── Progress bar animated fill ── */
.bbf{transition:width .8s cubic-bezier(.4,0,.2,1)}
.ai-score-fill{transition:width 1s cubic-bezier(.4,0,.2,1)}

/* ── List item entrance ── */
.citem,.ti,.nb{animation:itemIn .25s ease both}
@keyframes itemIn{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:none}}

/* ── Modal entrance ── */
.mo.open .md{animation:modalIn .3s cubic-bezier(.34,1.4,.64,1)}
@keyframes modalIn{from{opacity:0;transform:scale(.94) translateY(12px)}to{opacity:1;transform:none}}
@media(max-width:768px){
  .mo.open .md{animation:sheetIn .3s cubic-bezier(.4,0,.2,1)}
  @keyframes sheetIn{from{transform:translateY(100%)}to{transform:translateY(0)}}
  /* Hide table delete button on mobile — use detail modal instead */
  .mob-no-del{display:none!important}
}

/* ── Nav active indicator ── */
.ni.active{position:relative;overflow:hidden}
.ni.active::before{content:'';position:absolute;left:0;top:20%;bottom:20%;width:3px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,#7c6af7,#f472b6);box-shadow:0 0 8px rgba(124,106,247,.6);animation:navPip .2s ease}
@keyframes navPip{from{opacity:0;transform:scaleY(0)}to{opacity:1;transform:scaleY(1)}}

/* ── Skeleton loader ── */
.skeleton{background:linear-gradient(90deg,var(--sf2) 25%,var(--sf3) 50%,var(--sf2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--rs)}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── Chip entrance ── */
.chip{transition:all .15s;cursor:default}

/* ── Filter chip active ── */
.fc{transition:all .18s cubic-bezier(.4,0,.2,1)}
.fc.active{transform:scale(1.02)}
.fc:active{transform:scale(.95)}

/* ── Checkbox bounce ── */
.cbx.checked{animation:cbxBounce .3s cubic-bezier(.34,1.56,.64,1)}
@keyframes cbxBounce{0%{transform:scale(0)}60%{transform:scale(1.15)}100%{transform:scale(1)}}

/* ── Toast slide ── (handled above) */

/* ── Sidebar smooth ── */
.sb{transition:transform .28s cubic-bezier(.4,0,.2,1)!important}
.sb-overlay{transition:opacity .28s ease!important}

/* Mobile-only Get Started CTA on landing */
.mob-land-cta-btn{display:none;width:calc(100% - 2.8rem);padding:15px;border-radius:14px;border:none;background:linear-gradient(135deg,#7c6af7,#a67af5);color:#fff;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .25s;box-shadow:0 0 0 1px rgba(255,255,255,.1),0 4px 22px rgba(124,106,247,.45);letter-spacing:.01em;position:fixed;bottom:1.4rem;left:1.4rem;z-index:50}
.mob-land-cta-btn:hover{background:linear-gradient(135deg,#8d7df9,#b68bf9);box-shadow:0 0 0 1px rgba(255,255,255,.14),0 6px 32px rgba(124,106,247,.6);transform:translateY(-2px)}
.mob-land-cta-btn:active{transform:scale(.98)}

/* ── Auth box entrance ── */
@keyframes authIn{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}

/* ── Progress bar entrance — animate from width:0 to real width ── */
.bbt .bbf{animation:barReveal .85s cubic-bezier(.4,0,.2,1) both}
@keyframes barReveal{from{max-width:0;opacity:.4}to{max-width:100%;opacity:1}}
.empty{text-align:center;padding:2.5rem 1rem;color:var(--mu);font-size:13px;line-height:1.6;animation:pageIn .3s ease}
.empty-icon{font-size:2.2rem;margin-bottom:10px;display:block;opacity:.7}
.empty-title{font-weight:600;color:var(--tx);font-size:14px;margin-bottom:4px}
.empty-sub{font-size:12px;color:var(--mu2)}
.divider{height:1px;background:var(--bd);margin:.9rem 0}
/* bars */
.bbar{margin-bottom:9px}
.bbh{display:flex;justify-content:space-between;font-size:12px;margin-bottom:3px}
.bbt{height:5px;background:var(--sf3);border-radius:99px;overflow:hidden}
.bbf{height:100%;border-radius:99px;transition:width .5s ease}
/* syllabus */
.citem{background:var(--sf2);border:1px solid var(--bd);border-radius:var(--rs);padding:.6rem .85rem;margin-bottom:5px;display:flex;align-items:center;gap:9px;transition:border-color .2s,transform .15s,box-shadow .2s}
.citem:hover{border-color:rgba(124,106,247,.22);transform:translateX(2px);box-shadow:2px 2px 12px rgba(0,0,0,.2)}
.citem:hover{border-color:var(--bd2)}
.citem.complete{border-color:rgba(52,211,153,.3);background:rgba(52,211,153,.04)}
.cbx{width:14px;height:14px;border-radius:3px;border:1.5px solid var(--bd2);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.cbx.checked{background:var(--gn);border-color:var(--gn)}
/* celebration overlay */
.celoverlay{position:fixed;inset:0;z-index:900;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.85);flex-direction:column}
.celoverlay.show{display:flex}
.celbox{text-align:center;padding:2.5rem;border-radius:20px;border:1px solid var(--bd2);background:var(--sf);max-width:420px;width:90%;position:relative;overflow:hidden}
.confetti-wrap{position:fixed;inset:0;pointer-events:none;z-index:901}
/* undo bar — toast style */
.undobar{position:fixed;bottom:1.4rem;left:50%;transform:translateX(-50%) translateY(130%) scale(.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:12px;padding:0;font-size:13px;z-index:400;transition:transform .38s cubic-bezier(.34,1.18,.64,1),opacity .2s;color:var(--tx);max-width:320px;min-width:240px;box-shadow:0 12px 40px rgba(0,0,0,.5),0 2px 8px rgba(0,0,0,.3);opacity:0;background:rgba(30,12,12,.97);border:1px solid rgba(248,113,113,.3)}
.undobar.show{transform:translateX(-50%) translateY(0) scale(1);opacity:1}
.undobar.green{background:rgba(10,25,18,.97)!important;border:1px solid rgba(52,211,153,.3)!important}
/* month table */
.mtbl{font-size:12px;width:100%}
.mtbl td,.mtbl th{padding:.4rem .6rem}
/* scrollbar */
::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--sf3);border-radius:99px}
/* notification dismiss button */
.nb-x{background:none;border:none;cursor:pointer;color:var(--mu);font-size:13px;line-height:1;padding:2px 4px;border-radius:4px;margin-left:6px;transition:color .15s,background .15s;flex-shrink:0}
.nb-x:hover{color:var(--tx);background:rgba(255,255,255,.08)}
/* subj bar colors */
.hphy{color:var(--bl)}.hche{color:var(--gn)}.hmat{color:var(--am)}.hac{color:var(--ac2);font-weight:600}.hgn{color:var(--gn);font-weight:600}.hrd{color:var(--rd);font-weight:600}.ham{color:var(--am);font-weight:600}
/* ===== AUTH SCREEN ===== */
#auth-screen{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem;overflow:hidden}
#auth-screen.hidden{display:none}
.auth-bg-glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(124,106,247,.13) 0%,transparent 65%);top:50%;left:50%;transform:translate(-50%,-55%);pointer-events:none;animation:glowPulse 5s ease-in-out infinite}
@keyframes glowPulse{0%,100%{opacity:.5;transform:translate(-50%,-55%) scale(1)}50%{opacity:1;transform:translate(-50%,-55%) scale(1.08)}}
.auth-box{position:relative;background:linear-gradient(160deg,rgba(26,26,36,.98),rgba(15,15,22,.99));border:1px solid rgba(124,106,247,.2);border-radius:20px;padding:2.2rem 2.1rem 1.8rem;width:100%;max-width:380px;box-shadow:0 40px 100px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.03) inset;animation:authIn .5s cubic-bezier(.34,1.1,.64,1)}
@keyframes authIn{from{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:none;margin-top:20px;}}
/* ===== SPLASH SCREEN ===== */
#splash{position:fixed;inset:0;background:#06060d;z-index:99999;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}
#splash.fade-out{animation:splashFade .7s cubic-bezier(.4,0,.2,1) forwards;pointer-events:none}
@keyframes splashFade{0%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(1.05)}}

/* Ambient background orbs */
.splash-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;animation:orbFloat 6s ease-in-out infinite}
.splash-orb-1{width:400px;height:400px;background:radial-gradient(circle,rgba(124,106,247,.18) 0%,transparent 70%);top:-100px;left:-80px;animation-delay:0s}
.splash-orb-2{width:350px;height:350px;background:radial-gradient(circle,rgba(244,114,182,.12) 0%,transparent 70%);bottom:-80px;right:-60px;animation-delay:-2s}
.splash-orb-3{width:250px;height:250px;background:radial-gradient(circle,rgba(52,211,153,.1) 0%,transparent 70%);top:40%;left:60%;animation-delay:-4s}
@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(12px,-18px) scale(1.04)}66%{transform:translate(-8px,10px) scale(.97)}}

/* Grid noise overlay */
.splash-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);background-size:40px 40px;mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 0%,transparent 100%)}

/* Logo area */
.splash-logo-wrap{position:relative;width:110px;height:110px;margin-bottom:28px;animation:splashLogoIn .8s cubic-bezier(.34,1.3,.64,1) .1s both}
@keyframes splashLogoIn{from{opacity:0;transform:scale(.5) rotate(-15deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}

/* Hexagon shape behind logo */
.splash-hex{position:absolute;inset:0;background:linear-gradient(135deg,rgba(124,106,247,.15),rgba(244,114,182,.1));border:1px solid rgba(124,106,247,.25);border-radius:28px;animation:hexPulse 2.5s ease-in-out infinite}
@keyframes hexPulse{0%,100%{box-shadow:0 0 0 0 rgba(124,106,247,.0),0 0 30px rgba(124,106,247,.15)}50%{box-shadow:0 0 0 12px rgba(124,106,247,.0),0 0 50px rgba(124,106,247,.25)}}

/* Outer glow ring */
.splash-glow-ring{position:absolute;inset:-10px;border-radius:36px;background:conic-gradient(from 0deg,transparent 0%,rgba(124,106,247,.4) 15%,rgba(244,114,182,.4) 35%,rgba(52,211,153,.3) 55%,transparent 70%);animation:ringRotate 3s linear infinite;-webkit-mask:radial-gradient(circle,transparent 48px,black 50px,black 52px,transparent 54px);mask:radial-gradient(circle,transparent 48px,black 50px,black 52px,transparent 54px)}
@keyframes ringRotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* Corner accent dots */
.splash-corner{position:absolute;width:4px;height:4px;border-radius:50%;background:rgba(166,149,255,.6)}
.splash-corner-tl{top:12px;left:12px;animation:cornerBlink 2s .0s infinite}
.splash-corner-tr{top:12px;right:12px;animation:cornerBlink 2s .5s infinite}
.splash-corner-bl{bottom:12px;left:12px;animation:cornerBlink 2s 1s infinite}
.splash-corner-br{bottom:12px;right:12px;animation:cornerBlink 2s 1.5s infinite}
@keyframes cornerBlink{0%,100%{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.6)}}

/* J letter */
.splash-j{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:800;font-size:2.6rem;background:linear-gradient(135deg,#a695ff,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.02em}
.hero-logo-img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;z-index:2;border-radius:inherit;}

/* Title */
.splash-title{font-family:'Syne',sans-serif;font-weight:800;font-size:2rem;letter-spacing:-.04em;color:var(--tx);animation:splashUp .6s cubic-bezier(.34,1.2,.64,1) .4s both;line-height:1}
.splash-title span{background:linear-gradient(135deg,#a695ff,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent}

/* Tagline */
.splash-sub{color:var(--mu);font-size:12px;margin-top:8px;letter-spacing:.06em;text-transform:uppercase;font-weight:500;animation:splashUp .6s cubic-bezier(.34,1.2,.64,1) .55s both}

/* Progress bar */
.splash-progress-wrap{width:160px;height:2px;background:rgba(255,255,255,.07);border-radius:99px;margin-top:36px;overflow:hidden;animation:splashUp .4s ease .7s both}
.splash-progress-bar{height:100%;width:0%;background:linear-gradient(90deg,#7c6af7,#f472b6,#34d399);border-radius:99px;animation:progressFill 1.8s cubic-bezier(.4,0,.2,1) .8s forwards}
@keyframes progressFill{0%{width:0%}60%{width:75%}85%{width:90%}100%{width:100%}}

/* Loading text */
.splash-loading-text{font-size:10px;color:var(--mu2);letter-spacing:.1em;text-transform:uppercase;margin-top:10px;animation:splashUp .4s ease .7s both;font-family:'DM Mono',monospace}

/* Version / credit */
.splash-credit{position:absolute;bottom:28px;font-size:10px;color:var(--mu2);letter-spacing:.05em;animation:splashUp .4s ease .9s both}
.splash-credit strong{color:var(--mu);font-weight:500}

/* Floating particles */
.splash-particle{position:absolute;width:3px;height:3px;border-radius:50%;pointer-events:none}
.splash-particle:nth-child(1){background:#a695ff;top:25%;left:15%;animation:particleDrift 4s 0s ease-in-out infinite alternate}
.splash-particle:nth-child(2){background:#f472b6;top:70%;left:20%;animation:particleDrift 5s .8s ease-in-out infinite alternate}
.splash-particle:nth-child(3){background:#34d399;top:30%;right:18%;animation:particleDrift 4.5s 1.2s ease-in-out infinite alternate}
.splash-particle:nth-child(4){background:#60a5fa;top:65%;right:22%;animation:particleDrift 3.8s .4s ease-in-out infinite alternate}
.splash-particle:nth-child(5){background:#fbbf24;top:15%;left:45%;animation:particleDrift 5.2s 1.6s ease-in-out infinite alternate}
.splash-particle:nth-child(6){width:2px;height:2px;background:#a695ff;top:80%;left:50%;animation:particleDrift 4.2s .6s ease-in-out infinite alternate}
@keyframes particleDrift{from{transform:translate(0,0) scale(1);opacity:.3}to{transform:translate(20px,-30px) scale(1.5);opacity:.8}}

@keyframes spinRing{to{transform:rotate(360deg)}}
.splash-title{font-family:'Syne',sans-serif;font-weight:800;font-size:2rem;letter-spacing:-.04em;color:var(--tx);animation:splashUp .6s cubic-bezier(.34,1.2,.64,1) .4s both;line-height:1}
.splash-title span{background:linear-gradient(135deg,#a695ff,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.splash-sub{color:var(--mu);font-size:12px;margin-top:8px;letter-spacing:.06em;text-transform:uppercase;font-weight:500;animation:splashUp .6s cubic-bezier(.34,1.2,.64,1) .55s both}
/* Auth elements */
.auth-logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.55rem;letter-spacing:-.025em;text-align:center;margin-bottom:.25rem}
.auth-logo span{background:linear-gradient(135deg,#a695ff,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.auth-logo-wrap{position:relative;width:64px;height:64px;margin:0 auto 14px}
.auth-logo-ring{position:absolute;border-radius:50%;border:2px solid transparent}
.auth-logo-ring-1{inset:0;border-top-color:#7c6af7;border-right-color:rgba(124,106,247,.12);animation:spinRing 2s linear infinite}
.auth-logo-ring-2{inset:8px;border-right-color:#f472b6;border-left-color:rgba(244,114,182,.1);animation:spinRing 3.2s linear infinite reverse}
.auth-logo-j{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:800;font-size:1.4rem;background:linear-gradient(135deg,#a695ff,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.auth-sub{text-align:center;color:var(--mu);font-size:12px;margin-bottom:1.6rem;line-height:1.5}
.auth-tabs{display:flex;background:rgba(0,0,0,.3);border-radius:10px;padding:4px;gap:4px;margin-bottom:1.4rem;border:1px solid rgba(255,255,255,.05)}
.auth-tab{flex:1;padding:8px;border-radius:7px;border:none;background:none;color:var(--mu);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}
.auth-tab.active{background:linear-gradient(135deg,#7c6af7,#9d8df5);color:#fff;font-weight:600;box-shadow:0 2px 14px rgba(124,106,247,.4)}
.auth-field{margin-bottom:14px}
.auth-field label{display:block;font-size:10px;color:rgba(255,255,255,.35);font-weight:600;margin-bottom:6px;text-transform:uppercase;letter-spacing:.08em}
.auth-field .fi{background:rgba(0,0,0,.35);border-color:rgba(255,255,255,.07);transition:border-color .2s,box-shadow .2s}
.auth-field .fi:focus{border-color:rgba(124,106,247,.6);box-shadow:0 0 0 3px rgba(124,106,247,.12),inset 0 1px 2px rgba(0,0,0,.2)}
.auth-err{background:rgba(248,113,113,.07);border:1px solid rgba(248,113,113,.2);border-radius:8px;padding:.6rem .85rem;font-size:12px;color:var(--rd);margin-bottom:12px;display:none;line-height:1.5}
.auth-info{background:rgba(96,165,250,.07);border:1px solid rgba(96,165,250,.18);border-radius:8px;padding:.6rem .85rem;font-size:12px;color:var(--bl);margin-bottom:12px;display:none;line-height:1.5}
.auth-submit-btn{width:100%;justify-content:center;padding:12px;font-size:14px;font-weight:700;margin-bottom:13px;background:linear-gradient(135deg,#7c6af7,#9d8df5)!important;border:none!important;box-shadow:0 0 0 1px rgba(255,255,255,.1),0 4px 22px rgba(124,106,247,.45)!important;letter-spacing:.01em;border-radius:11px!important}
.auth-submit-btn:hover{box-shadow:0 0 0 1px rgba(255,255,255,.14),0 6px 30px rgba(124,106,247,.6)!important;transform:translateY(-2px)!important}
.auth-divider{display:flex;align-items:center;gap:10px;margin:0 0 13px;color:rgba(255,255,255,.15);font-size:11px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.06)}
.auth-google{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;padding:11px;border:1px solid rgba(255,255,255,.07);border-radius:11px;background:rgba(255,255,255,.03);color:rgba(255,255,255,.6);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}
.auth-google:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.14);color:#fff;transform:translateY(-1px)}
.auth-footer{text-align:center;margin-top:18px;font-size:10.5px;color:var(--mu2);line-height:1.7}
/* profile */
.profile-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:32px;min-height:32px;max-width:32px;max-height:32px;border-radius:50%;background:linear-gradient(135deg,#7c6af7,#f472b6);border:2px solid transparent;cursor:pointer;font-family:'Syne',sans-serif;font-weight:700;font-size:12px;color:#fff;flex-shrink:0;box-shadow:0 2px 8px rgba(124,106,247,.4);transition:border-color .2s,transform .15s;padding:0;line-height:1}
.profile-btn.av-open{border-color:var(--ac2);transform:scale(1.08)}
/* ── Profile Popover Card (top-right near avatar) ── */
.av-menu-overlay{display:none;position:fixed;inset:0;z-index:295;background:transparent}
.av-menu-overlay.open{display:block}
.av-menu{position:fixed;top:52px;right:10px;z-index:296;width:240px;background:var(--sf);border:1px solid var(--bd2);border-radius:16px;overflow:hidden;transform:scale(.92) translateY(-8px);transform-origin:top right;opacity:0;transition:transform .22s cubic-bezier(.34,1.4,.64,1),opacity .18s;pointer-events:none;box-shadow:0 16px 48px rgba(0,0,0,.55),0 2px 8px rgba(0,0,0,.3)}
.av-menu.open{transform:scale(1) translateY(0);opacity:1;pointer-events:auto}
/* avatar + info block */
.av-menu-av-wrap{display:flex;flex-direction:column;align-items:center;padding:20px 16px 14px;background:linear-gradient(160deg,rgba(124,106,247,.12),rgba(244,114,182,.07));border-bottom:1px solid rgba(255,255,255,.06)}
.av-menu-av{width:62px;height:62px;border-radius:50%;background:linear-gradient(135deg,#7c6af7,#f472b6);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:800;font-size:22px;color:#fff;box-shadow:0 4px 18px rgba(124,106,247,.45);position:relative;overflow:hidden;flex-shrink:0;margin-bottom:10px}
.av-menu-av img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:50%}
.av-menu-name{font-family:'Syne',sans-serif;font-weight:700;font-size:14px;color:var(--tx);text-align:center;letter-spacing:-.01em;line-height:1.2}
.av-menu-email{font-size:10.5px;color:var(--mu);margin-top:3px;text-align:center;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.av-menu-tag{display:inline-block;font-size:9px;font-weight:800;padding:2px 8px;border-radius:99px;margin-top:7px;background:rgba(52,211,153,.14);color:#34d399;letter-spacing:.09em;text-transform:uppercase;border:1px solid rgba(52,211,153,.22)}
/* action button */
.av-menu-actions{padding:10px}
.av-menu-view-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:10px;border-radius:10px;border:none;background:linear-gradient(135deg,#7c6af7,#a695ff);color:#fff;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:all .18s;box-shadow:0 3px 14px rgba(124,106,247,.38)}
.av-menu-view-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}
.av-menu-view-btn:active{transform:scale(.97)}
/* Avatar card quick-stats */
.av-stats-row{display:flex;align-items:center;justify-content:space-around;padding:10px 12px 8px;border-bottom:1px solid rgba(255,255,255,.06);gap:4px}
.av-stat-item{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1;min-width:0}
.av-stat-val{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:700;color:var(--ac2);line-height:1;letter-spacing:-.01em}
.av-stat-lbl{font-size:9px;color:var(--mu2);font-weight:500;text-align:center;white-space:nowrap;letter-spacing:.03em}
.av-stat-divider{width:1px;height:28px;background:rgba(255,255,255,.07);flex-shrink:0}
/* ── Todo/Backlog compact filter chips ── */
.td-filter-row{align-items:center;flex-wrap:nowrap!important;overflow:hidden}
.td-chip{display:inline-flex;align-items:center;gap:3px;padding:4px 7px;font-size:10.5px;font-weight:500;flex-shrink:1;white-space:nowrap}
.td-status-sel{margin-left:auto;flex-shrink:0;min-width:0;width:90px;font-size:10.5px;padding:4px 22px 4px 7px!important;height:27px;background-color:var(--sf)}
@media(max-width:420px){
  .td-chip{padding:3px 5px;font-size:9.5px;gap:2px}
  .td-chip .td-chip-fullname{display:none}
  .td-chip .td-chip-shortname{display:inline}
  .td-status-sel{width:82px;font-size:9.5px}
}
@media(min-width:421px){
  .td-chip .td-chip-fullname{display:inline}
  .td-chip .td-chip-shortname{display:none}
}
/* ── Mobile back button (tests sub-pages) ── */
.mob-back-btn{
  display:none;align-items:center;gap:6px;
  padding:6px 12px 6px 8px;margin-bottom:10px;
  border-radius:8px;border:1px solid var(--bd2);
  background:var(--sf2);color:var(--mu);
  font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;
  cursor:pointer;transition:all .18s;
  -webkit-tap-highlight-color:transparent;
}
.mob-back-btn:hover{color:var(--ac2);border-color:rgba(124,106,247,.35);background:rgba(124,106,247,.08)}
.mob-back-btn:active{transform:scale(.96)}
@media(max-width:768px){
  .mob-back-btn{display:inline-flex}
}
/* ── Mobile settings: icons-only sidebar (no borders) ── */
@media(max-width:768px){
  .settings-layout{display:flex!important;gap:0!important;max-width:100%!important;align-items:flex-start!important}
  .settings-sidebar{position:static!important;top:auto!important;border-radius:0!important;padding:.5rem .3rem!important;display:flex!important;flex-direction:column!important;gap:3px!important;box-shadow:none!important;width:50px!important;flex-shrink:0!important;align-items:center!important;min-height:300px!important;background:var(--sf)!important;border:none!important;border-right:1px solid var(--bd)!important}
  .settings-nav-item{width:38px!important;height:38px!important;padding:0!important;border-radius:9px!important;justify-content:center!important;gap:0!important;font-size:0!important;color:transparent!important;background:transparent!important;border:none!important}
  .settings-nav-item svg{width:17px!important;height:17px!important;flex-shrink:0!important;stroke:var(--mu)!important;display:block!important}
  .settings-nav-item span.snl{display:none!important}
  .settings-nav-item:hover{background:rgba(108,92,231,.12)!important}
  .settings-nav-item:hover svg{stroke:var(--ac2)!important}
  .settings-nav-item.active{background:rgba(108,92,231,.18)!important}
  .settings-nav-item.active svg{stroke:var(--ac2)!important}
  .settings-nav-sep{width:24px!important;margin:.3rem 0!important;background:var(--bd)!important;height:1px!important;border:none!important;flex-shrink:0!important}
  .settings-nav-label{display:none!important}
  .settings-panel-area{flex:1;min-width:0;overflow:hidden}
}
/* ── Mobile FAB for To-Do & Backlog ── */
.mob-fab{display:none;position:fixed;bottom:calc(72px + env(safe-area-inset-bottom) + 12px);right:16px;z-index:140;width:48px;height:48px;border-radius:50%;border:none;cursor:pointer;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.4);transition:transform .18s,box-shadow .18s;-webkit-tap-highlight-color:transparent}
.mob-fab:active{transform:scale(.92)}
.mob-fab-todo{background:linear-gradient(135deg,var(--ac),var(--ac2));box-shadow:0 4px 18px rgba(124,106,247,.5)}
.mob-fab-todo:hover{box-shadow:0 6px 24px rgba(124,106,247,.65)}
.mob-fab-backlog{background:linear-gradient(135deg,#f59e0b,#fbbf24);box-shadow:0 4px 18px rgba(251,191,36,.4)}
.mob-fab-backlog:hover{box-shadow:0 6px 24px rgba(251,191,36,.55)}
.mob-fab-hours{background:linear-gradient(135deg,var(--ac),var(--pk));box-shadow:0 4px 18px rgba(124,106,247,.45)}
.mob-fab-hours:hover{box-shadow:0 6px 24px rgba(244,114,182,.55)}
@media(max-width:768px){
  /* Hide hero on mobile for hours page — FAB handles the action */
  #page-hours .mob-hide-hero{display:none!important}
}
.profile-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#7c6af7,#f472b6);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:700;font-size:13px;color:#fff;flex-shrink:0}
.profile-avatar-lg{width:54px;height:54px;font-size:22px;border-radius:50%;background:linear-gradient(135deg,#7c6af7,#f472b6);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 4px 16px rgba(124,106,247,.35)}
.profile-sb-btn{display:flex;align-items:center;gap:10px;width:100%;padding:.6rem .55rem;border-radius:var(--rs);border:1px solid var(--bd);background:var(--sf2);cursor:pointer;text-align:left;transition:all .15s}
.profile-sb-btn:hover{background:var(--sf3);border-color:rgba(124,106,247,.2)}
/* pdf/notif */
.pdf-btn{background:rgba(45,212,191,.08);color:#2dd4bf;border:1px solid rgba(45,212,191,.2)}
.pdf-btn:hover{background:rgba(45,212,191,.15)}
.notif-bell{background:none;border:none;cursor:pointer;color:var(--mu);font-size:16px;padding:4px;line-height:1}
.notif-bell.active{color:var(--am)}
/* AI Insights */
.ai-card{background:linear-gradient(135deg,rgba(124,106,247,.08),rgba(244,114,182,.05));border:1px solid rgba(124,106,247,.25);border-radius:var(--r);padding:1rem 1.1rem;margin-bottom:10px}
/* AI button animated gradient border + shimmer — thin 1.5px border */
.ai-btn-wrap{position:relative;display:inline-flex;border-radius:var(--rs);padding:1.5px;background:linear-gradient(135deg,#c8a44e,#ffd700,#f5c842,#e8a020,#ffd700,#c8a44e);background-size:300% 300%;animation:borderFlow 2.5s linear infinite;overflow:hidden}
.ai-btn-wrap::before{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.28) 50%,transparent 70%);background-size:200% 100%;animation:shimmerSlide 2s ease-in-out infinite;pointer-events:none;z-index:3}
.ai-btn-wrap .btn{position:relative;z-index:2;margin:0;border-radius:calc(var(--rs) - 1.5px);background:var(--sf)!important;color:var(--ac2)!important;font-weight:600}
@keyframes shimmerSlide{0%{background-position:200% 0}100%{background-position:-200% 0}}
@keyframes borderFlow{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
/* AI sidebar nav item — thin shimmer border, same animation style */
.ni-ai{background:rgba(200,164,78,.08)!important;border:1px solid rgba(200,164,78,.3)!important;color:#e8c96a!important;position:relative;overflow:hidden}
.ni-ai::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);animation:niAiShimmer 2.2s ease-in-out infinite;pointer-events:none}
@keyframes niAiShimmer{0%{left:-100%}100%{left:200%}}
.ni-ai:hover{background:rgba(124,106,247,.15)!important}
/* AI Generate button glow pulse */
@keyframes glowPulseBtn{0%,100%{box-shadow:0 4px 20px rgba(200,164,78,.5)}50%{box-shadow:0 4px 32px rgba(255,215,0,.7),0 0 0 3px rgba(200,164,78,.2)}}
/* Bell ring animation for notification button */
@keyframes bellRing{0%{transform:rotate(0)}10%{transform:rotate(14deg)}20%{transform:rotate(-10deg)}30%{transform:rotate(14deg)}40%{transform:rotate(-8deg)}50%{transform:rotate(8deg)}60%{transform:rotate(0)}100%{transform:rotate(0)}}
.notif-btn-on svg{animation:bellRing 1s ease forwards;transform-origin:top center}
.notif-btn-on{background:rgba(251,191,36,.12)!important;border:1px solid rgba(251,191,36,.35)!important;color:var(--am)!important}
.ai-section{border-left:3px solid var(--ac);padding-left:.8rem;margin-bottom:1rem}
.ai-section.good{border-color:var(--gn)}
.ai-section.warn{border-color:var(--am)}
.ai-section.bad{border-color:var(--rd)}
.ai-section.info{border-color:var(--bl)}
.ai-tag{display:inline-block;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600;margin:2px}
.ai-typing::after{content:'▌';animation:blink .7s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.ai-score-bar{height:8px;border-radius:99px;background:var(--sf3);overflow:hidden;margin:4px 0 8px}
.ai-score-fill{height:100%;border-radius:99px;transition:width 1s ease}
/* ====== MOBILE RESPONSIVE ====== */
/* inline top bar */
/* ─── Mobile Topbar ─── */
.mob-topbar{display:none;align-items:center;justify-content:space-between;padding:.55rem .9rem;background:rgba(10,10,15,.85);border-bottom:1px solid var(--bd);margin:-.9rem -.7rem .9rem -.7rem;position:sticky;top:0;z-index:90;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);gap:8px}
.mob-topbar-text{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0;overflow:hidden;align-items:flex-start}
.mob-topbar-title{font-family:'Syne',sans-serif;font-weight:800;font-size:1rem;letter-spacing:-.02em;color:var(--tx);line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mob-topbar-title span{background:linear-gradient(135deg,#a695ff,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.mob-topbar-title span.tt-plain{background:none!important;-webkit-background-clip:unset!important;-webkit-text-fill-color:#fff!important}
.mob-topbar-sub{font-size:10.5px;color:var(--mu);font-weight:500;font-family:'DM Sans',sans-serif;line-height:1;letter-spacing:.01em;display:block;width:100%;text-align:left;margin-left:0;padding-left:0}
/* sidebar overlay (desktop only now) */
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:155;backdrop-filter:blur(4px)}
/* ─── Bottom Nav Shell ─── */
.mob-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:150;background:rgba(10,10,15,.98);border-top:1px solid rgba(255,255,255,.06);padding:.35rem .4rem calc(.35rem + env(safe-area-inset-bottom));flex-direction:row;justify-content:space-around;align-items:flex-start;will-change:transform;transform:translateZ(0);-webkit-transform:translateZ(0)}
/* ─── Nav Item ─── */
.mob-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;padding:.25rem .3rem .2rem;border-radius:12px;border:none;background:none;color:var(--mu);font-family:'DM Sans',sans-serif;font-size:9.5px;font-weight:500;transition:color .2s;min-width:52px;position:relative;-webkit-tap-highlight-color:transparent;outline:none;touch-action:manipulation}
.mob-nav-item:active .mico{transform:scale(.85);transition:transform .1s}
.mob-nav-item .mico{display:flex;align-items:center;justify-content:center;width:40px;height:28px;border-radius:14px;position:relative;transition:transform .2s cubic-bezier(.34,1.4,.64,1)}
.mni-pill{position:absolute;inset:0;border-radius:14px;background:rgba(124,106,247,.14);opacity:0;transform:scale(.7);transition:opacity .2s,transform .22s cubic-bezier(.34,1.4,.64,1)}
.mob-nav-item.active .mni-pill{opacity:1;transform:scale(1)}
.mob-nav-item.active{color:var(--ac2)}
.mob-nav-item.active .mico{transform:translateY(-1px)}
.mni-label{position:relative;z-index:1;font-size:9.5px;line-height:1;transition:color .2s}
/* ─── More Drawer Overlay ─── */
/* ─── Mobile Settings Tab Strip ─── */
.mob-settings-tabs{display:none;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:6px;padding:.1rem 0 .75rem;margin-bottom:.5rem;border-bottom:1px solid var(--bd)}
.mob-settings-tabs::-webkit-scrollbar{display:none}
.mob-settings-tab{flex-shrink:0;display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:99px;border:1px solid var(--bd2);background:none;color:var(--mu);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;cursor:pointer;transition:all .18s;white-space:nowrap;-webkit-tap-highlight-color:transparent}
.mob-settings-tab svg{flex-shrink:0;opacity:.7}
.mob-settings-tab.active{background:rgba(124,106,247,.14);border-color:rgba(124,106,247,.35);color:var(--ac2);font-weight:600}
.mob-settings-tab.active svg{opacity:1}
/* ─── Tests Choice Screen ─── */
.mob-tests-choice{display:none;flex-direction:column;gap:12px;padding-top:.25rem}
.mob-test-card{display:flex;align-items:center;gap:14px;background:var(--sf);border:1px solid var(--bd);border-radius:16px;padding:1rem 1rem;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent;text-align:left;width:100%;box-sizing:border-box}
.mob-test-card:active{transform:scale(.97)}
.mob-test-card:hover{border-color:rgba(124,106,247,.25);box-shadow:0 4px 20px rgba(0,0,0,.25)}
.mob-test-card-icon{width:46px;height:46px;min-width:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;align-self:center}
.mob-test-card-body{flex:1;min-width:0;align-self:center}
.mob-test-card-title{font-family:'Syne',sans-serif;font-weight:700;font-size:.95rem;color:var(--tx);margin-bottom:3px}
.mob-test-card-sub{font-size:11px;color:var(--mu);line-height:1.4}
.mob-test-card-arrow{color:var(--mu2);flex-shrink:0;display:flex;align-items:center;align-self:center}
.mob-tests-choice-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mu2);margin-bottom:6px;padding:0 2px}
/* ─── Mobile More Drawer ─── */
.mob-drawer-overlay.open{display:block;opacity:1}
/* ─── More Drawer Sheet ─── */
.mob-drawer{position:fixed;bottom:0;left:0;right:0;z-index:201;background:var(--sf);border-radius:20px 20px 0 0;border-top:1px solid var(--bd2);padding:0 0 calc(1.2rem + env(safe-area-inset-bottom));transform:translateY(110%);transition:transform .32s cubic-bezier(.32,0,.15,1);max-height:85vh;overflow-y:auto}
.mob-drawer.open{transform:translateY(0)}
.mob-drawer-handle{width:36px;height:4px;background:var(--bd2);border-radius:99px;margin:10px auto 0;flex-shrink:0}
.mob-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1rem .5rem}
.mob-drawer-title{font-family:'Syne',sans-serif;font-weight:700;font-size:1rem;color:var(--tx)}
.mob-drawer-close{background:var(--sf2);border:1px solid var(--bd);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--mu)}
.mob-drawer-section-label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mu2);padding:.5rem 1rem .25rem}
.mob-drawer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:0 .8rem .4rem}
.mob-drawer-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:.9rem .4rem .75rem;background:var(--sf2);border:1px solid var(--bd);border-radius:12px;cursor:pointer;transition:background .15s,border-color .15s,transform .15s;-webkit-tap-highlight-color:transparent}
.mob-drawer-item:active{transform:scale(.95);background:var(--sf3)}
.mob-drawer-item:hover{border-color:var(--bd2);background:var(--sf3)}
.mob-drawer-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mob-drawer-item-label{font-size:11px;font-weight:500;color:var(--tx);font-family:'DM Sans',sans-serif;text-align:center;line-height:1.2;display:flex;align-items:center;gap:4px}
.mob-drawer-badge{background:var(--rd);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:99px;min-width:15px;text-align:center}
@media(max-width:768px){
  .mob-topbar{display:flex}
  /* Sidebar hidden on mobile — bottom nav is the only navigation */
  .sb{display:none!important}
  .sb-overlay{display:none!important}
  .main{margin-left:0;padding:.9rem .7rem;padding-bottom:calc(72px + env(safe-area-inset-bottom))}
  .mob-nav{display:flex}
  /* Hide duplicate page title on mobile — topbar shows it */
  .ph{display:none!important}
  /* Settings: full-width vertical sidebar on mobile */
  .settings-layout{grid-template-columns:1fr!important;gap:12px!important}
  .settings-sidebar{position:static!important;top:auto!important;border-radius:12px!important;padding:.5rem .45rem!important;display:flex!important;flex-direction:column!important;gap:2px!important;box-shadow:0 2px 12px rgba(0,0,0,.28)!important}
  .settings-nav-item{padding:.6rem .8rem!important;border-radius:10px!important;font-size:12.5px!important}
  .settings-nav-item span.snl{display:inline!important}
  .settings-nav-item svg{width:14px!important;height:14px!important}
  .mob-settings-tabs{display:none!important}
  /* Tests choice screen */
  .mob-tests-choice{display:flex}
  /* grids */
  .g5{grid-template-columns:repeat(2,minmax(0,1fr))}
  /* donut card spans full bottom row */
  .g5 .jee-donut-card{grid-column:span 2;width:100%;display:flex;flex-direction:column;align-items:center}
  .g5 .jee-donut-card canvas{width:150px!important;height:150px!important}
  .g4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .g3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .g2{grid-template-columns:1fr}
  /* page headers */
  .ph{flex-direction:column;gap:6px}
  .pt{font-size:1.15rem}
  /* filter rows */
  .fr{gap:5px;row-gap:5px;flex-wrap:wrap}
  .fc{font-size:11px;padding:3px 8px}
  /* cards */
  .card,.sc{padding:.7rem .8rem}
  /* tables */
  table{font-size:10.5px}
  th,td{padding:.35rem .4rem}
  /* mains/adv: tight layout, no transform scale */
  #page-mains,#page-advanced{max-width:100%;overflow-x:hidden;width:100%}
  #page-mains .page-inner,#page-advanced .page-inner{width:100%}
  #page-mains *,#page-advanced *{max-width:100%}
  #page-mains canvas,#page-advanced canvas{max-width:100%!important}
  #page-mains .pt,#page-advanced .pt{font-size:.92rem}
  #page-mains .sv,#page-advanced .sv{font-size:1.1rem!important}
  #page-mains .sl,#page-advanced .sl{font-size:9px}
  #page-mains .card,#page-mains .sc,#page-advanced .card,#page-advanced .sc{padding:.38rem .48rem}
  #page-mains .ct,#page-advanced .ct{font-size:9px}
  #page-mains table,#page-advanced table{font-size:9px}
  #page-mains th,#page-mains td,#page-advanced th,#page-advanced td{padding:.22rem .28rem}
  #page-mains .ph,#page-advanced .ph{gap:4px}
  #page-mains .btn,#page-advanced .btn{font-size:10px;padding:4px 8px}
  /* uniform height for all filter elements */
  #page-mains .fc,#page-advanced .fc{font-size:10px;padding:0 7px;height:26px;box-sizing:border-box;display:inline-flex;align-items:center;white-space:nowrap}
  /* adv filters - proper padding to prevent arrow overlap */
  #page-advanced select.fc{font-size:10px!important;padding:0 20px 0 7px!important;height:26px!important}
  #mn-subj-sel{min-width:86px!important;flex-shrink:0}

  /* filter rows with dropdowns above cards */
  #page-mains .fr,#page-advanced .fr{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;scrollbar-width:none;position:relative;z-index:20;overflow-y:visible}
  #page-mains .fr select,#page-advanced .fr select{position:relative;z-index:30;height:26px;font-size:10px;padding:0 5px}
  #page-mains .fr::-webkit-scrollbar,#page-advanced .fr::-webkit-scrollbar{display:none}
  /* stat cards 2-col */
  #mn-stats,#adv-stats{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  /* charts stack */
  #page-mains .g2,#page-advanced .g2{grid-template-columns:1fr!important}
  /* table: horizontal scroll, hide extra cols */
  #mn-unified .tw,#adv-unified .tw{overflow-x:auto;-webkit-overflow-scrolling:touch;display:block}
  #mn-unified table,#adv-unified table{min-width:0;width:100%}
  /* hide notes, phy, chem, math cols on mobile - show only Date, Type, Total, % */
  #mn-unified table th:nth-child(5),#mn-unified table td:nth-child(5),
  #mn-unified table th:nth-child(6),#mn-unified table td:nth-child(6),
  #mn-unified table th:nth-child(7),#mn-unified table td:nth-child(7),
  #mn-unified table th:nth-child(8),#mn-unified table td:nth-child(8),
  #adv-unified table th:nth-child(2),#adv-unified table td:nth-child(2),
  #adv-unified table th:nth-child(6),#adv-unified table td:nth-child(6),
  #adv-unified table th:nth-child(7),#adv-unified table td:nth-child(7),
  #adv-unified table th:nth-child(8),#adv-unified table td:nth-child(8),
  #adv-unified table th:nth-child(9),#adv-unified table td:nth-child(9){display:none}
  /* charts shorter */
  .cw[style*="height:190px"]{height:150px!important}
  .cw[style*="height:185px"]{height:150px!important}
  .cw[style*="height:150px"]{height:130px!important}
  /* undo bar — just above bottom nav */
  .undobar{left:.7rem;right:.7rem;transform:translateY(200%) scale(.94);width:auto;max-width:none;bottom:calc(72px + env(safe-area-inset-bottom) + .5rem);min-width:0}
  .undobar.show{transform:translateY(0) scale(1)}
  /* toast — sits above undo bar so they never overlap */
  .toast{left:.7rem;right:.7rem;max-width:none;bottom:calc(72px + env(safe-area-inset-bottom) + .5rem);min-width:0}
  .toast.show{transform:translateY(0)}
  /* when undo is also showing, push toast higher via JS class */
  .toast.above-undo{bottom:calc(72px + env(safe-area-inset-bottom) + 5rem)}
  /* modals bottom sheet */
  .md{width:100%;max-width:100%;border-radius:var(--r) var(--r) 0 0;position:fixed;bottom:0;left:0;right:0;max-height:92vh}
  /* mini cel */
  #mini-cel{top:.7rem;right:.7rem;left:.7rem}
  #mini-cel-inner{min-width:0;width:100%}
  /* g3 span-2 */
  .g3 .card[style*="grid-column:span 2"]{grid-column:span 2}
  /* Backlog: stat cards 2x2 on mobile */
  #page-backlog .g4{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  /* Backlog prem-stat: tighter padding on mobile */
  #page-backlog .prem-stat{padding:.7rem .8rem}
  #page-backlog .prem-stat-val{font-size:1.5rem}
  /* Subject streak grid: stay 3 cols on 768, collapse later */
  #bl-subj-streaks{grid-template-columns:repeat(3,minmax(0,1fr))}
  /* bl-subj-card: reduce padding/font on mobile */
  .bl-subj-card{padding:.7rem .6rem}
  .bl-subj-count{font-size:1.2rem}
  .bl-subj-orb{width:30px;height:30px}
  .bl-subj-streak{font-size:10px}
}
@media(max-width:480px){
  .g3{grid-template-columns:1fr}
  .g3 .card[style*="grid-column:span 2"]{grid-column:span 1}
  .g5{grid-template-columns:1fr 1fr}
  .main{padding:.8rem .6rem;padding-bottom:calc(72px + env(safe-area-inset-bottom))}
  .mob-topbar{margin:-.8rem -.6rem .8rem -.6rem}
  /* Backlog stat cards: 2x2 grid on very small screens */
  #page-backlog .g4{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  /* Subject streak grid: 1 column on very small screens */
  #bl-subj-streaks{grid-template-columns:1fr!important}
  /* Make bl-subj-card horizontal on small screens */
  #bl-subj-streaks .bl-subj-card{display:flex;align-items:center;gap:12px;text-align:left;padding:.7rem .9rem}
  #bl-subj-streaks .bl-subj-orb{margin:0;flex-shrink:0}
  #bl-subj-streaks .bl-subj-streak{justify-content:flex-start;margin-top:2px}
  #bl-subj-streaks .bl-subj-count{font-size:1.2rem}
  #bl-subj-streaks .bl-subj-card > div:not(.bl-subj-orb){flex:1;min-width:0}
}

/* ── Noise grain overlay for premium feel ── */
#landing::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px 200px}

/* ══════════════════════════════════════════════════════════════
   ULTRA PREMIUM TODO & BACKLOG SYSTEM
══════════════════════════════════════════════════════════════ */

/* ── Page ambient ── */
#page-todo,#page-backlog{position:relative;overflow:hidden}
#page-todo::before,#page-backlog::before{
  content:'';position:fixed;top:-40%;left:-20%;width:140%;height:140%;
  pointer-events:none;z-index:0;
  animation:tdAmbient 10s ease-in-out infinite alternate;
}
#page-todo::before{
  background:radial-gradient(ellipse 50% 40% at 20% 20%,rgba(96,165,250,.055) 0%,transparent 55%),
             radial-gradient(ellipse 40% 35% at 80% 70%,rgba(124,106,247,.04) 0%,transparent 55%);
}
#page-backlog::before{
  background:radial-gradient(ellipse 50% 40% at 25% 25%,rgba(251,191,36,.04) 0%,transparent 55%),
             radial-gradient(ellipse 40% 35% at 80% 75%,rgba(52,211,153,.04) 0%,transparent 55%);
}
@keyframes tdAmbient{0%{transform:translate(0,0)}100%{transform:translate(1.5%,2%)}}
#page-todo .ph,#page-todo .fr,#page-todo #td-stats,#page-todo #td-list,
#page-backlog .ph,#page-backlog .fr,#page-backlog .g4,#page-backlog #bl-subj-streaks,
#page-backlog #bl-celebrate,#page-backlog #bl-list,.bl-subj-card-wrap{position:relative;z-index:1}

/* ── Premium stat card ── */
.prem-stat{
  background:var(--sf);border:1px solid var(--bd);border-radius:14px;
  padding:1rem 1.1rem;position:relative;overflow:hidden;
  transition:border-color .25s,box-shadow .25s,transform .2s;
  cursor:default;
}
.prem-stat::before{
  content:'';position:absolute;inset:0;border-radius:14px;
  background:linear-gradient(135deg,rgba(255,255,255,.025) 0%,transparent 50%);
  pointer-events:none;
}
.prem-stat:hover{
  border-color:rgba(255,255,255,.13);
  box-shadow:0 8px 32px rgba(0,0,0,.35),0 1px 0 rgba(255,255,255,.06) inset;
  transform:translateY(-2px);
}
.prem-stat-glow{
  position:absolute;width:100px;height:100px;border-radius:50%;
  filter:blur(36px);top:-24px;right:-18px;opacity:.55;
  transition:opacity .3s;pointer-events:none;
}
.prem-stat:hover .prem-stat-glow{opacity:.85}
.prem-stat-label{font-size:10.5px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--mu);margin-bottom:6px}
.prem-stat-val{
  font-family:'Space Grotesk',sans-serif;font-size:2rem;font-weight:700;
  line-height:1;letter-spacing:-.03em;
  animation:statReveal .5s cubic-bezier(.34,1.4,.64,1) both;
}
@keyframes statReveal{from{opacity:0;transform:translateY(8px) scale(.9)}to{opacity:1;transform:none}}
.prem-stat-sub{font-size:10.5px;color:var(--mu);margin-top:5px;display:flex;align-items:center;gap:4px}
.prem-stat-icon{
  position:absolute;right:12px;bottom:12px;opacity:.12;
  transition:opacity .25s,transform .25s;
}
.prem-stat:hover .prem-stat-icon{opacity:.2;transform:scale(1.08) rotate(-4deg)}

/* ── Premium Task Item ── */
.prem-task{
  background:var(--sf);border:1px solid var(--bd);border-radius:14px;
  padding:.9rem 1rem;margin-bottom:7px;
  display:flex;align-items:flex-start;gap:11px;
  position:relative;overflow:hidden;
  transition:border-color .22s,box-shadow .22s,transform .18s,background .18s;
  animation:taskSlideIn .32s cubic-bezier(.34,1.1,.64,1) both;
}
@keyframes taskSlideIn{
  from{opacity:0;transform:translateX(-14px) scale(.98)}
  to{opacity:1;transform:none}
}
.prem-task::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:2px 0 0 2px;
  transition:width .2s,opacity .2s;
}
.prem-task.sub-physics::before{background:linear-gradient(180deg,#60a5fa,#3b82f6)}
.prem-task.sub-chemistry::before{background:linear-gradient(180deg,#34d399,#059669)}
.prem-task.sub-maths::before{background:linear-gradient(180deg,#fbbf24,#f59e0b)}
.prem-task:hover{
  border-color:rgba(255,255,255,.1);
  box-shadow:0 6px 24px rgba(0,0,0,.28);
  transform:translateX(2px);
  background:var(--sf2);
}
.prem-task.done-task{opacity:.55}
.prem-task.done-task:hover{opacity:.7;transform:none}

/* Sweep shimmer on completion */
.prem-task.completing::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(52,211,153,.12),transparent);
  animation:taskComplete .45s ease forwards;
  pointer-events:none;
}
@keyframes taskComplete{
  from{transform:translateX(-100%)}
  to{transform:translateX(100%)}
}

/* ── Custom checkbox ── */
.prem-check{
  width:20px;height:20px;border-radius:6px;flex-shrink:0;
  border:1.5px solid var(--bd2);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .22s cubic-bezier(.34,1.56,.64,1);
  margin-top:1px;position:relative;overflow:hidden;
  background:transparent;
}
.prem-check::before{
  content:'';position:absolute;inset:0;border-radius:5px;
  background:var(--gn);transform:scale(0);
  transition:transform .2s cubic-bezier(.34,1.56,.64,1);
}
.prem-check.checked::before{transform:scale(1)}
.prem-check:hover:not(.checked){border-color:var(--ac2);background:rgba(124,106,247,.08)}
.prem-check svg{position:relative;z-index:1;opacity:0;transform:scale(0);transition:all .18s .05s cubic-bezier(.34,1.56,.64,1)}
.prem-check.checked svg{opacity:1;transform:scale(1)}
.prem-check.checked{border-color:var(--gn);box-shadow:0 0 12px rgba(52,211,153,.35)}

/* ── Task content ── */
.prem-task-title{
  font-size:13.5px;font-weight:500;line-height:1.4;
  transition:color .2s,text-decoration .2s;
}
.done-task .prem-task-title{text-decoration:line-through;color:var(--mu)}
.prem-task-meta{display:flex;gap:5px;flex-wrap:wrap;margin-top:5px;align-items:center}

/* ── Priority badge ── */
.prio-badge{
  display:inline-flex;align-items:center;gap:3px;
  padding:2px 7px;border-radius:99px;font-size:10px;font-weight:600;
  letter-spacing:.03em;
}
.prio-high{background:rgba(248,113,113,.12);color:#f87171;border:1px solid rgba(248,113,113,.18)}
.prio-medium{background:rgba(251,191,36,.1);color:#fbbf24;border:1px solid rgba(251,191,36,.16)}
.prio-low{background:rgba(96,165,250,.1);color:#60a5fa;border:1px solid rgba(96,165,250,.16)}

/* ── Subject chip ── */
.subj-chip{
  display:inline-flex;align-items:center;gap:3px;
  padding:2px 7px;border-radius:5px;font-size:10px;font-weight:600;letter-spacing:.03em;
}
.subj-phy{background:rgba(96,165,250,.12);color:#60a5fa}
.subj-che{background:rgba(52,211,153,.12);color:#34d399}
.subj-mat{background:rgba(251,191,36,.1);color:#fbbf24}

/* ── Date meta ── */
.task-date{font-size:10.5px;color:var(--mu);display:inline-flex;align-items:center;gap:3px}
.task-date.overdue{color:var(--am)}
.task-date.done-date{color:var(--gn)}
.task-pending-age{font-size:10.5px;color:var(--rd);display:inline-flex;align-items:center;gap:3px}
.task-note{font-size:10.5px;color:var(--mu);display:inline-flex;align-items:center;gap:3px}

/* ── Delete button ── */
.prem-del{
  width:26px;height:26px;border-radius:7px;border:none;cursor:pointer;
  background:transparent;color:var(--mu2);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:all .15s;margin-left:auto;
}
.prem-del:hover{background:rgba(248,113,113,.14);color:var(--rd);transform:scale(1.08)}
.prem-del:active{transform:scale(.93)}

/* ── Empty state ── */
.prem-empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:3.5rem 1rem;text-align:center;
}
.prem-empty-orb{
  width:72px;height:72px;border-radius:50%;margin-bottom:1.2rem;
  display:flex;align-items:center;justify-content:center;position:relative;
  background:linear-gradient(135deg,rgba(52,211,153,.08),rgba(124,106,247,.06));
  border:1px solid rgba(52,211,153,.12);
  animation:emptyPulse 3s ease-in-out infinite;
}
@keyframes emptyPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(52,211,153,.15)}
  50%{box-shadow:0 0 0 14px rgba(52,211,153,.0)}
}
.prem-empty-ring{
  position:absolute;inset:-12px;border-radius:50%;
  border:1px dashed rgba(52,211,153,.1);
  animation:emptyRingSpin 12s linear infinite;
}
@keyframes emptyRingSpin{to{transform:rotate(360deg)}}
.prem-empty-title{
  font-family:'Syne',sans-serif;font-weight:700;font-size:1rem;
  color:var(--tx);margin-bottom:5px;
}
.prem-empty-sub{font-size:12px;color:var(--mu);line-height:1.6;max-width:220px}

/* ── Backlog subject card ── */
.bl-subj-card{
  background:var(--sf);border:1px solid var(--bd);border-radius:14px;
  padding:.9rem;text-align:center;position:relative;overflow:hidden;
  transition:border-color .22s,transform .2s,box-shadow .22s;
}
.bl-subj-card:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.3)}
.bl-subj-card::before{
  content:'';position:absolute;inset:0;border-radius:14px;
  background:linear-gradient(135deg,rgba(255,255,255,.02) 0%,transparent 60%);
  pointer-events:none;
}
.bl-subj-orb{
  width:36px;height:36px;border-radius:50%;margin:0 auto 8px;
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.bl-subj-orb::after{
  content:'';position:absolute;inset:-4px;border-radius:50%;
  border:1.5px solid currentColor;opacity:.15;
  animation:orbitPulse 2.5s ease-in-out infinite;
}
@keyframes orbitPulse{0%,100%{transform:scale(1);opacity:.15}50%{transform:scale(1.12);opacity:.25}}
.bl-subj-count{
  font-family:'Space Grotesk',sans-serif;font-size:1.5rem;font-weight:700;
  line-height:1;margin-bottom:3px;
}
.bl-subj-label{font-size:9.5px;color:var(--mu);text-transform:uppercase;letter-spacing:.07em}
.bl-subj-streak{font-size:11px;color:var(--mu);margin-top:6px;display:flex;align-items:center;justify-content:center;gap:4px}

/* ── Celebration Banner ── */
#bl-celebrate .prem-celebrate{
  background:linear-gradient(135deg,rgba(52,211,153,.07),rgba(45,212,191,.04));
  border:1px solid rgba(52,211,153,.2);border-radius:16px;
  padding:1.5rem;text-align:center;position:relative;overflow:hidden;
  margin-bottom:10px;
}
#bl-celebrate .prem-celebrate::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(52,211,153,.06),transparent);
  animation:celebShimmer 3s ease infinite;
}
@keyframes celebShimmer{
  0%{background-position:-200% 0}100%{background-position:200% 0}
}
.celebrate-ring{
  width:60px;height:60px;border-radius:50%;margin:0 auto 12px;
  border:1.5px solid rgba(52,211,153,.3);
  display:flex;align-items:center;justify-content:center;
  position:relative;
  animation:celebBounce .8s cubic-bezier(.34,1.56,.64,1);
}
.celebrate-ring::before{
  content:'';position:absolute;inset:-10px;border-radius:50%;
  border:1px solid rgba(52,211,153,.15);
  animation:emptyRingSpin 8s linear infinite;
}
@keyframes celebBounce{
  from{transform:scale(0) rotate(-30deg)}
  to{transform:scale(1) rotate(0)}
}
.celebrate-title{
  font-family:'Syne',sans-serif;font-weight:800;font-size:1.1rem;
  color:var(--gn);margin-bottom:4px;
}
.celebrate-sub{font-size:11.5px;color:var(--mu)}

/* ── Section header ── */
.prem-section-head{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:.9rem;padding:.1rem 0;
}
.prem-section-title{
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--mu);
  display:flex;align-items:center;gap:6px;
}
.prem-section-title::before{
  content:'';display:inline-block;width:3px;height:14px;border-radius:2px;
  background:linear-gradient(180deg,var(--ac),var(--pk));
}
.prem-count-badge{
  background:rgba(124,106,247,.12);color:var(--ac2);
  font-size:10px;font-weight:700;padding:2px 7px;border-radius:99px;
  border:1px solid rgba(124,106,247,.18);
  font-family:'Space Grotesk',sans-serif;
}

/* ── Progress ring in stat card ── */
.stat-ring{transform:rotate(-90deg);overflow:visible}
.stat-ring-bg{fill:none;stroke:rgba(255,255,255,.06);stroke-width:4}
.stat-ring-fill{fill:none;stroke-width:4;stroke-linecap:round;
  transition:stroke-dashoffset 1s cubic-bezier(.4,0,.2,1);
}

/* Staggered entry for task list items */
.prem-task:nth-child(1){animation-delay:.04s}
.prem-task:nth-child(2){animation-delay:.09s}
.prem-task:nth-child(3){animation-delay:.13s}
.prem-task:nth-child(4){animation-delay:.17s}
.prem-task:nth-child(5){animation-delay:.21s}
.prem-task:nth-child(6){animation-delay:.25s}
.prem-task:nth-child(7){animation-delay:.29s}
.prem-task:nth-child(8){animation-delay:.33s}

/* Done indicator flash */
@keyframes doneFlash{0%{box-shadow:0 0 0 0 rgba(52,211,153,.5)}100%{box-shadow:0 0 0 12px rgba(52,211,153,.0)}}
.prem-check.just-done{animation:doneFlash .6s ease forwards}

/* ══════════════════════════════════════════════════════════════
   ULTRA PREMIUM LANDING PAGE
══════════════════════════════════════════════════════════════ */

/* ── Noise texture overlay ── */
#landing::before{
  content:'';position:fixed;inset:0;z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events:none;opacity:.4;
}

/* ── Animated mesh gradient background ── */
@keyframes landGradShift{
  0%{background-position:0% 0%}
  25%{background-position:100% 0%}
  50%{background-position:100% 100%}
  75%{background-position:0% 100%}
  100%{background-position:0% 0%}
}
@keyframes auraPulse{
  0%,100%{opacity:.7;transform:scale(1) rotate(0deg)}
  33%{opacity:1;transform:scale(1.08) rotate(2deg)}
  66%{opacity:.85;transform:scale(.95) rotate(-1deg)}
}
@keyframes auraMove{
  0%,100%{transform:translate(0,0) scale(1)}
  25%{transform:translate(60px,-40px) scale(1.1)}
  50%{transform:translate(-30px,50px) scale(.9)}
  75%{transform:translate(-60px,-30px) scale(1.05)}
}
#landing{
  position:fixed;inset:0;
  background:#020208;
  z-index:9998;display:flex;flex-direction:column;overflow-y:auto;
}
#landing.hidden{display:none!important}

/* ── Animated aura blobs behind everything ── */
.land-aura-wrap{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.land-aura{position:absolute;border-radius:50%;filter:blur(100px)}
.land-aura-1{
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(100,80,240,.22) 0%,rgba(140,80,220,.1) 40%,transparent 70%);
  top:-200px;left:-200px;
  animation:auraMove 18s ease-in-out infinite;
}
.land-aura-2{
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(220,80,160,.15) 0%,rgba(200,80,200,.08) 40%,transparent 70%);
  bottom:-180px;right:-150px;
  animation:auraMove 22s ease-in-out infinite reverse 3s;
}
.land-aura-3{
  width:450px;height:450px;
  background:radial-gradient(circle,rgba(40,180,150,.1) 0%,transparent 70%);
  top:35%;left:40%;
  animation:auraMove 15s ease-in-out infinite 6s;
}
.land-aura-4{
  width:300px;height:300px;
  background:radial-gradient(circle,rgba(80,120,255,.12) 0%,transparent 70%);
  top:60%;right:35%;
  animation:auraPulse 12s ease-in-out infinite 2s;
}

/* ── Star field ── */
.land-stars{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.land-star{position:absolute;background:#fff;border-radius:50%;animation:starTwinkle var(--d,4s) ease-in-out infinite var(--del,0s)}
@keyframes starTwinkle{0%,100%{opacity:var(--min,.1);transform:scale(1);filter:blur(0px) drop-shadow(0 0 0px transparent)}50%{opacity:var(--max,.8);transform:scale(1.4);filter:blur(0px) drop-shadow(0 0 var(--glow,3px) var(--gc,rgba(162,155,254,.9)))}}

/* ── Navbar ── */
.land-nav{
  position:sticky;top:0;z-index:10;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 2.5rem;height:68px;
  border-bottom:1px solid rgba(255,255,255,.05);
  background:rgba(2,2,8,.82);
  backdrop-filter:blur(32px) saturate(180%);
  -webkit-backdrop-filter:blur(32px) saturate(180%);
  flex-shrink:0;
  position:relative;z-index:100;
}
/* shimmer line on nav bottom border */
.land-nav::after{
  content:'';position:absolute;bottom:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(124,106,247,.4),rgba(244,114,182,.3),transparent);
  pointer-events:none;
}

.land-nav-logo{
  font-family:'Syne',sans-serif;font-weight:800;font-size:1.15rem;
  letter-spacing:-.025em;color:#fff;display:flex;align-items:center;gap:10px;
  text-decoration:none;
}
.land-nav-logo-mark{
  width:32px;height:32px;border-radius:10px;
  background:linear-gradient(145deg,#6c5ce7,#a29bfe,#fd79a8);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:900;color:#fff;
  box-shadow:0 0 0 1px rgba(255,255,255,.15),0 4px 22px rgba(108,92,231,.55),0 1px 4px rgba(0,0,0,.5);
  position:relative;overflow:hidden;
}
.land-nav-logo-mark::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.25) 0%,transparent 60%);
  border-radius:inherit;
}
.land-nav-logo span{background:linear-gradient(135deg,#a29bfe,#fd79a8);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.land-nav-links{display:flex;align-items:center;gap:2px}
.land-nav-links a{
  font-size:12.5px;color:rgba(255,255,255,.35);text-decoration:none;
  padding:7px 15px;border-radius:8px;transition:all .25s;font-weight:500;letter-spacing:.01em;
  position:relative;
}
.land-nav-links a::after{
  content:'';position:absolute;bottom:5px;left:15px;right:15px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(162,155,254,.5),transparent);
  transform:scaleX(0);transition:transform .3s cubic-bezier(.4,0,.2,1);
}
.land-nav-links a:hover{color:rgba(255,255,255,.9);background:rgba(255,255,255,.04)}
.land-nav-links a:hover::after{transform:scaleX(1)}

.land-nav-cta{display:flex;align-items:center;gap:8px}
.land-btn-ghost{
  padding:8px 18px;border-radius:10px;
  border:1px solid rgba(255,255,255,.1);background:transparent;
  color:rgba(255,255,255,.65);font-family:'DM Sans',sans-serif;font-size:12.5px;
  font-weight:500;cursor:pointer;transition:all .25s;letter-spacing:.01em;
}
.land-btn-ghost:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.22);color:#fff;transform:translateY(-1.5px)}
.land-btn-primary{
  padding:8px 20px;border-radius:10px;border:none;
  background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff;
  font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:600;cursor:pointer;
  transition:all .25s;
  box-shadow:0 2px 20px rgba(108,92,231,.4),0 0 0 1px rgba(255,255,255,.08);
  letter-spacing:.01em;position:relative;overflow:hidden;
}
.land-btn-primary::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 50%);
  opacity:0;transition:opacity .25s;
}
.land-btn-primary:hover{
  background:linear-gradient(135deg,#7d6ef0,#b0a8ff);
  box-shadow:0 4px 28px rgba(108,92,231,.6),0 0 0 1px rgba(255,255,255,.12);
  transform:translateY(-2px);
}
.land-btn-primary:hover::before{opacity:1}
.land-btn-primary:active,.land-btn-ghost:active{transform:scale(.97) translateY(0)}

/* ── Main body ── */
.land-body{flex:1;display:flex;overflow:hidden;position:relative;z-index:1}
.land-left{flex:1;position:relative;display:flex;flex-direction:column;justify-content:center;padding:3rem 4.5rem;overflow:hidden}

/* Premium grid bg with perspective */
.land-grid-bg{
  position:absolute;inset:-50px;
  background-image:
    linear-gradient(rgba(108,92,231,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(108,92,231,.06) 1px,transparent 1px);
  background-size:56px 56px;
  pointer-events:none;
  transform:perspective(800px) rotateX(12deg);
  transform-origin:center top;
  mask-image:radial-gradient(ellipse 85% 90% at 40% 50%,black 20%,transparent 80%);
}

/* Premium orbs replaced by aura system above */
.land-orb,.land-orb-1,.land-orb-2,.land-orb-3{display:none}

/* ── Feature badge ── */
@keyframes badgeShimmer{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}
.land-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:5px 16px 5px 8px;
  background:linear-gradient(135deg,rgba(108,92,231,.12),rgba(162,155,254,.08),rgba(253,121,168,.08));
  border:1px solid rgba(162,155,254,.2);
  border-radius:99px;font-size:10.5px;font-weight:700;
  color:rgba(162,155,254,.9);letter-spacing:.07em;
  margin-bottom:1.6rem;position:relative;z-index:1;
  animation:fadeSlideUp .6s ease both;width:fit-content;
  box-shadow:0 0 20px rgba(108,92,231,.15),inset 0 1px 0 rgba(255,255,255,.05);
}
.land-badge-dot{
  width:7px;height:7px;border-radius:50%;background:#a29bfe;
  box-shadow:0 0 8px #a29bfe,0 0 16px rgba(162,155,254,.4);
  animation:pulseDot 2s ease-in-out infinite;flex-shrink:0;
}
@keyframes pulseDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.5)}}
/* Animated border on badge */
.land-badge::before{
  content:'';position:absolute;inset:-1px;border-radius:99px;
  background:linear-gradient(135deg,rgba(162,155,254,.3),rgba(253,121,168,.2),rgba(162,155,254,.1));
  z-index:-1;opacity:0;animation:badgeGlow 3s ease-in-out infinite;
}
@keyframes badgeGlow{0%,100%{opacity:0}50%{opacity:1}}

/* ── Slides ── */
.slides-wrap{position:relative;z-index:1;height:300px;margin-bottom:2.5rem;overflow:hidden;}
.slide{
  position:absolute;inset:0;opacity:0;
  transform:translateY(28px) scale(.98);
  transition:opacity .65s cubic-bezier(.4,0,.2,1),transform .65s cubic-bezier(.34,1,.64,1);
  pointer-events:none;will-change:opacity,transform;
}
.slide.active{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.slide-eyebrow{
  font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  margin-bottom:1.1rem;display:flex;align-items:center;gap:10px;
}
.slide-eyebrow::before{
  content:'';width:28px;height:2px;border-radius:99px;
  background:linear-gradient(90deg,currentColor,transparent);
  display:inline-block;
}
.slide-title{
  font-family:'Syne',sans-serif;font-weight:800;font-size:3rem;
  line-height:1.06;color:#fff;margin-bottom:1.1rem;letter-spacing:-.04em;
}
.slide-title em{
  font-style:normal;
  background:linear-gradient(135deg,#a29bfe 10%,#fd79a8 60%,#fdcb6e 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.slide-desc{font-size:14.5px;color:rgba(255,255,255,.38);line-height:1.9;max-width:450px;font-weight:400}

/* ── Slide controls ── */
.slide-controls{display:flex;align-items:center;gap:16px;position:relative;z-index:1}
.slide-dots{display:flex;gap:6px;align-items:center}
.slide-dot{
  height:3px;border-radius:99px;background:rgba(255,255,255,.1);cursor:pointer;
  transition:all .45s cubic-bezier(.4,0,.2,1);width:20px;
}
.slide-dot.active{width:44px;background:linear-gradient(90deg,#a29bfe,#fd79a8)}
.slide-dot:hover:not(.active){background:rgba(255,255,255,.28);width:28px}
.slide-progress-bar{flex:1;height:1px;background:rgba(255,255,255,.04);border-radius:99px;overflow:hidden;max-width:200px}
.slide-progress-fill{height:100%;background:linear-gradient(90deg,#6c5ce7,#fd79a8);width:0%;transition:none}

/* ── Stats strip ── */
.land-stats{display:flex;gap:2.5rem;position:relative;z-index:1;margin-top:.5rem}
.land-stat{
  display:flex;flex-direction:column;gap:4px;
  animation:fadeSlideUp .7s ease both;position:relative;
}
.land-stat:not(:last-child)::after{
  content:'';position:absolute;right:-1.25rem;top:10%;height:80%;width:1px;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.08),transparent);
}
.land-stat:nth-child(2){animation-delay:.1s}.land-stat:nth-child(3){animation-delay:.2s}
.land-stat-num{
  font-family:'Syne',sans-serif;font-size:1.6rem;font-weight:800;color:#fff;line-height:1;
  background:linear-gradient(135deg,#fff 40%,rgba(162,155,254,.8));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.land-stat-label{font-size:10px;color:rgba(255,255,255,.28);font-weight:500;letter-spacing:.04em}

@keyframes fadeSlideUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

/* ── Trusted by strip ── */
.land-trusted{display:flex;align-items:center;gap:14px;margin-top:2.5rem;position:relative;z-index:1;animation:fadeSlideUp .8s .3s ease both}
.land-trusted-label{font-size:10px;color:rgba(255,255,255,.2);font-weight:500;letter-spacing:.04em;white-space:nowrap}
.land-trusted-avatars{display:flex;align-items:center}
.land-trusted-av{
  width:27px;height:27px;border-radius:50%;
  border:2px solid rgba(2,2,8,.95);margin-left:-8px;
  font-family:'Syne',sans-serif;font-size:10px;font-weight:700;color:#fff;
  display:flex;align-items:center;justify-content:center;
  transition:transform .2s;
}
.land-trusted-av:first-child{margin-left:0}
.land-trusted-av:hover{transform:translateY(-3px) scale(1.1);z-index:5}
.land-trusted-count{font-size:11px;color:rgba(255,255,255,.32);margin-left:8px;font-weight:500}

/* ── Trust badges marquee ── */
.trust-badges-wrap{margin-top:2rem;position:relative;z-index:1;overflow:hidden;width:100%;animation:fadeSlideUp .9s .4s ease both}
.trust-badges-track{display:flex;gap:8px;width:max-content;animation:trustSwipe 24s linear infinite}
.trust-badges-track:hover{animation-play-state:paused}
@keyframes trustSwipe{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.trust-badge{
  display:inline-flex;align-items:center;gap:7px;
  padding:5px 14px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  border-radius:99px;font-size:10.5px;color:rgba(255,255,255,.38);
  font-weight:500;white-space:nowrap;flex-shrink:0;
  transition:border-color .25s,background .25s,color .25s,transform .25s;
}
.trust-badge:hover{
  background:rgba(162,155,254,.08);border-color:rgba(162,155,254,.2);
  color:rgba(162,155,254,.9);transform:translateY(-1px);
}
.trust-badge-icon{font-size:11px;flex-shrink:0;opacity:.7}
.trust-badges-wrap::before,.trust-badges-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:64px;z-index:2;pointer-events:none;
}
.trust-badges-wrap::before{left:0;background:linear-gradient(90deg,#020208,transparent)}
.trust-badges-wrap::after{right:0;background:linear-gradient(-90deg,#020208,transparent)}
@media(max-width:768px){
  .trust-badges-wrap::before{background:linear-gradient(90deg,rgba(2,2,8,.98),transparent)}
  .trust-badges-wrap::after{background:linear-gradient(-90deg,rgba(2,2,8,.98),transparent)}
}

/* ── Nav desktop-only ── */
@media(max-width:640px){.land-nav-desktop-only{display:none!important}}

/* ── Auth panel (right) ── */
.land-right{
  width:480px;
  background:rgba(6,5,16,.97);
  backdrop-filter:blur(60px) saturate(180%);
  -webkit-backdrop-filter:blur(60px) saturate(180%);
  border-left:1px solid rgba(255,255,255,.04);
  display:flex;align-items:center;justify-content:center;
  padding:2.5rem;position:relative;flex-shrink:0;overflow:hidden;
}
/* Multi-layer depth on auth panel */
.land-right::before{
  content:'';position:absolute;top:-150px;right:-100px;width:380px;height:380px;
  background:radial-gradient(circle,rgba(108,92,231,.18) 0%,transparent 60%);
  pointer-events:none;animation:auraPulse 10s ease-in-out infinite;
}
.land-right::after{
  content:'';position:absolute;bottom:-120px;left:-80px;width:300px;height:300px;
  background:radial-gradient(circle,rgba(253,121,168,.12) 0%,transparent 60%);
  pointer-events:none;animation:auraPulse 14s ease-in-out infinite 3s;
}
/* Shimmer line */
.land-right .land-right-shimmer{
  position:absolute;left:0;top:8%;bottom:8%;width:1px;
  background:linear-gradient(180deg,transparent,rgba(108,92,231,.5),rgba(253,121,168,.35),rgba(108,92,231,.2),transparent);
  pointer-events:none;
  animation:shimmerPulse 6s ease-in-out infinite;
}
@keyframes shimmerPulse{0%,100%{opacity:.4}50%{opacity:1}}

/* ── Auth modal state ── */
.land-auth-inner{width:100%;max-width:350px;position:relative;z-index:1}
.mob-auth-close{
  display:none;position:absolute;top:16px;right:16px;width:36px;height:36px;
  border-radius:50%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.6);font-size:15px;cursor:pointer;z-index:10;
  transition:all .22s;align-items:center;justify-content:center;font-family:'DM Sans',sans-serif;
}
.mob-auth-close:hover{background:rgba(255,255,255,.13);color:#fff}
@media(max-width:768px){
  .land-right.mob-visible .mob-auth-close{
    display:flex;
    position:fixed;
    top:calc(68px + 10px);
    right:14px;
    z-index:9999;
    width:40px;height:40px;
    background:rgba(15,10,30,.92);
    border:1px solid rgba(255,255,255,.18);
    box-shadow:0 4px 20px rgba(0,0,0,.6);
    backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);
    color:#fff;
  }
}

/* Hero CTA state */
@keyframes authIn{from{opacity:0;transform:scale(.95) translateY(12px)}to{opacity:1;transform:none}}
.land-hero-cta{display:flex;flex-direction:column;align-items:center;text-align:center;animation:authIn .55s cubic-bezier(.34,1.1,.64,1)}

/* Premium logo mark */
.land-hero-logo{
  width:80px;height:80px;border-radius:24px;
  background:linear-gradient(145deg,#6c5ce7 0%,#a29bfe 50%,#fd79a8 100%);
  display:flex;align-items:center;justify-content:center;
  font-family:'Syne',sans-serif;font-weight:900;font-size:2rem;color:#fff;
  margin:0 auto 1.4rem;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.14),
    0 8px 40px rgba(108,92,231,.5),
    0 2px 8px rgba(0,0,0,.5),
    inset 0 1px 0 rgba(255,255,255,.3);
  position:relative;overflow:hidden;
  animation:logoFloat 6s ease-in-out infinite;
}
@keyframes logoFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.land-hero-logo::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(135deg,rgba(255,255,255,.3) 0%,transparent 50%);
}
.land-hero-logo::after{
  content:'';position:absolute;inset:-1px;border-radius:25px;
  border:1px solid rgba(255,255,255,.2);pointer-events:none;
}
/* Orbiting ring */
.land-hero-logo-ring{
  position:absolute;inset:-12px;border-radius:50%;
  border:1px solid rgba(162,155,254,.2);
  animation:ringRotate 12s linear infinite;
}
.land-hero-logo-ring::before{
  content:'';position:absolute;top:-3px;left:50%;transform:translateX(-50%);
  width:6px;height:6px;border-radius:50%;
  background:linear-gradient(135deg,#a29bfe,#fd79a8);
  box-shadow:0 0 8px rgba(162,155,254,.8);
}
@keyframes ringRotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

.land-hero-title{
  font-family:'Syne',sans-serif;font-weight:800;font-size:1.65rem;color:#fff;
  margin-bottom:.6rem;letter-spacing:-.028em;line-height:1.18;
}
.land-hero-sub{
  font-size:13px;color:rgba(255,255,255,.32);line-height:1.7;
  margin-bottom:2.1rem;max-width:280px;
}

/* Feature pills */
.land-hero-pills{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:1.8rem}
.land-hero-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 11px;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);border-radius:99px;
  font-size:10.5px;color:rgba(255,255,255,.42);font-weight:500;
  transition:all .2s;cursor:default;
}
.land-hero-pill:hover{background:rgba(162,155,254,.08);border-color:rgba(162,155,254,.2);color:rgba(162,155,254,.9)}
.land-hero-pill-dot{width:5px;height:5px;border-radius:50%}

/* CTA buttons */
.land-hero-actions{display:flex;flex-direction:column;gap:9px;width:100%}
.land-hero-btn-main{
  width:100%;padding:14px;border-radius:14px;border:none;
  background:linear-gradient(135deg,#6c5ce7,#9b59b6,#fd79a8);
  background-size:200% 200%;
  color:#fff;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;
  cursor:pointer;transition:all .3s;
  box-shadow:0 0 0 1px rgba(255,255,255,.12),0 4px 28px rgba(108,92,231,.5);
  letter-spacing:.01em;position:relative;overflow:hidden;
  animation:gradientShift 4s ease infinite;
}
@keyframes gradientShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.land-hero-btn-main::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.18) 0%,transparent 50%);
  opacity:0;transition:opacity .3s;
}
.land-hero-btn-main:hover{
  box-shadow:0 0 0 1px rgba(255,255,255,.16),0 6px 36px rgba(108,92,231,.65);
  transform:translateY(-2.5px);
}
.land-hero-btn-main:hover::before{opacity:1}
.land-hero-btn-main:active{transform:scale(.98)}

.land-hero-btn-ghost{
  width:100%;padding:13px;border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.55);
  font-family:'DM Sans',sans-serif;font-size:14px;font-weight:500;cursor:pointer;
  transition:all .25s;letter-spacing:.01em;
}
.land-hero-btn-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16);color:#fff;transform:translateY(-2px)}
.land-hero-btn-ghost:active{transform:scale(.98)}

.land-hero-divider{display:flex;align-items:center;gap:10px;width:100%;color:rgba(255,255,255,.1);font-size:11px;margin:.1rem 0}
.land-hero-divider::before,.land-hero-divider::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.05)}

.land-google-btn{
  display:flex;align-items:center;justify-content:center;gap:9px;width:100%;
  padding:13px;border:1px solid rgba(255,255,255,.07);border-radius:14px;
  background:rgba(255,255,255,.025);color:rgba(255,255,255,.48);
  font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;cursor:pointer;
  transition:all .25s;
}
.land-google-btn:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.13);color:rgba(255,255,255,.85);transform:translateY(-1.5px)}

/* Auth form */
.land-auth-form{animation:authIn .45s cubic-bezier(.34,1.1,.64,1);display:none}
.land-auth-form.show{display:block}
.land-auth-back{
  background:none;border:none;color:rgba(255,255,255,.28);font-family:'DM Sans',sans-serif;
  font-size:12px;cursor:pointer;padding:0;margin-bottom:1.4rem;
  display:flex;align-items:center;gap:6px;transition:color .2s;letter-spacing:.02em;
}
.land-auth-back:hover{color:rgba(255,255,255,.7)}
.land-auth-welcome{font-family:'Syne',sans-serif;font-weight:800;font-size:1.4rem;color:#fff;margin-bottom:.3rem;letter-spacing:-.022em}
.land-auth-sub{font-size:12.5px;color:rgba(255,255,255,.3);margin-bottom:1.7rem}
.land-auth-tabs{
  display:flex;background:rgba(0,0,0,.5);border-radius:12px;padding:3px;gap:3px;
  margin-bottom:1.5rem;border:1px solid rgba(255,255,255,.04);
}
.land-auth-tab{
  flex:1;padding:10px;border-radius:9px;border:none;background:none;
  color:rgba(255,255,255,.35);font-family:'DM Sans',sans-serif;font-size:12.5px;
  font-weight:500;cursor:pointer;transition:all .25s;
}
.land-auth-tab.active{
  background:linear-gradient(135deg,rgba(108,92,231,.9),rgba(162,155,254,.85));
  color:#fff;font-weight:600;
  box-shadow:0 0 0 1px rgba(255,255,255,.1),0 2px 16px rgba(108,92,231,.45);
}

@media(max-width:900px){
  .land-nav-links{display:none}
  .land-right{width:420px}
}
@media(max-width:768px){
  #landing{position:relative;height:auto;flex-direction:column;overflow-y:auto;background:#020208;min-height:100vh}
  .land-nav{padding:0 1.2rem;height:58px}
  .land-nav-cta-btns{display:none!important}
  .land-body{flex-direction:column;overflow:visible;background:transparent}
  .land-left{padding:2.2rem 1.4rem 6rem;flex:none;justify-content:flex-start;background:transparent}
  .land-right{display:none;width:100%;flex:none;border-left:none;border-top:1px solid rgba(255,255,255,.05);padding:1.8rem 1.4rem 2rem;min-height:auto}
  .land-right.mob-visible{display:flex;position:fixed;inset:0;z-index:200;background:rgba(2,2,8,.98);border:none;align-items:center;justify-content:center;padding:1.5rem;animation:mobAuthIn .35s cubic-bezier(.34,1.1,.64,1);overflow-y:auto}
  @keyframes mobAuthIn{from{opacity:0;transform:translateY(35px) scale(.96)}to{opacity:1;transform:none}}
  .slide-title{font-size:2rem;letter-spacing:-.03em}.slides-wrap{height:240px}
  .land-aura-1{width:300px;height:300px}.land-aura-2{width:250px;height:250px}.land-aura-3{display:none}
  .land-stats{gap:1.6rem}
  .land-badge{margin-bottom:1rem}
  .land-hero-pills{display:none}
  .land-trusted{margin-top:1.5rem}
  #landing::after{display:none}
  .mob-land-cta-btn{display:block}
}
@media(max-width:400px){
  .land-left{padding:1.8rem 1rem 1.4rem}
  .land-right{padding:1.5rem 1rem}
  .slide-title{font-size:1.65rem}
  .land-trusted{display:flex;flex-wrap:wrap;gap:10px;margin-top:1rem}
}

/* Navbar styles already defined in landing section above */

/* Main body/orbs already in premium section */

/* Feature badge already in premium section */

/* Slides, controls, stats, trust badges already in premium section */

/* Nav desktop-only already in premium section */


/* Auth panel already in premium section */
/* ═══════════════════════════════════════════════════════════════
   ULTRA PREMIUM ONBOARDING
═══════════════════════════════════════════════════════════════ */
#onboarding{
  position:fixed;inset:0;z-index:9997;display:none;align-items:center;justify-content:center;
  overflow-y:auto;overflow-x:hidden;
  background:radial-gradient(ellipse 120% 80% at 50% -10%, rgba(108,92,231,.18) 0%, transparent 60%),
             radial-gradient(ellipse 80% 60% at 80% 100%, rgba(253,121,168,.1) 0%, transparent 60%),
             #020208;
}
#onboarding.show{display:flex}
/* Animated bg particles for onboarding */
#ob-bg-canvas{position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5}

@keyframes obShake{0%,100%{transform:translateX(0)}18%{transform:translateX(-7px)}36%{transform:translateX(7px)}54%{transform:translateX(-5px)}72%{transform:translateX(5px)}88%{transform:translateX(-2px)}}
@keyframes obFadeUp{from{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:none}}
@keyframes obSlideRight{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:none}}
@keyframes obPulseRing{0%{transform:scale(.85);opacity:.6}100%{transform:scale(1.6);opacity:0}}
@keyframes obGradShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes obStepIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes obOptPop{from{opacity:0;transform:scale(.9) translateY(8px)}to{opacity:1;transform:none}}
@keyframes obAvatarFloat{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-6px) rotate(1deg)}}
@keyframes obShimmer{0%{left:-100%}100%{left:180%}}
@keyframes obCountUp{from{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}

.ob-wrap{
  width:100%;max-width:520px;
  position:relative;z-index:1;
  padding:1.5rem 1rem;
  animation:obFadeUp .6s cubic-bezier(.34,1.1,.64,1);
}

/* ── Progress track ── */
.ob-progress-wrap{margin-bottom:2.2rem;position:relative}
.ob-progress-track{
  height:4px;background:rgba(255,255,255,.06);border-radius:99px;
  position:relative;overflow:visible;
}
.ob-progress-fill{
  height:100%;border-radius:99px;
  background:linear-gradient(90deg,#6c5ce7,#a29bfe,#fd79a8);
  background-size:200% 100%;
  transition:width .6s cubic-bezier(.4,0,.2,1);
  animation:obGradShift 3s ease infinite;
  position:relative;
  max-width:100%;
}
/* Remove the old moving ::after dot */
.ob-progress-fill::after{ display:none; }
/* Step dots sit ON the track, absolutely positioned */
.ob-steps-labels{
  display:flex;justify-content:space-between;
  position:absolute;top:50%;left:0;right:0;
  transform:translateY(-50%);
  pointer-events:none;
}
.ob-step-label{
  font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.18);transition:color .3s,opacity .3s;cursor:pointer;
  pointer-events:auto;
  display:flex;flex-direction:column;align-items:center;gap:0;
  position:relative;
}
/* Labels sit below the track */
.ob-step-label::after{
  content:attr(data-label);
  position:absolute;top:calc(100% + 8px);
  font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:inherit;white-space:nowrap;
}
.ob-step-label.done{color:rgba(162,155,254,.7)}
.ob-step-label.current{color:#a29bfe}
.ob-step-dot{
  width:10px;height:10px;border-radius:50%;
  background:rgba(255,255,255,.15);
  border:2px solid rgba(255,255,255,.1);
  transition:all .35s cubic-bezier(.34,1.4,.64,1);
  position:relative;z-index:2;
  flex-shrink:0;
}
.ob-step-label.done .ob-step-dot{
  background:linear-gradient(135deg,#6c5ce7,#a29bfe);
  border-color:rgba(162,155,254,.5);
  box-shadow:0 0 6px rgba(162,155,254,.5);
}
.ob-step-label.current .ob-step-dot{
  background:linear-gradient(135deg,#a29bfe,#fd79a8);
  border-color:rgba(162,155,254,.8);
  box-shadow:0 0 0 4px rgba(162,155,254,.18),0 0 14px rgba(162,155,254,.7);
  transform:scale(1.25);
}
/* Extra margin below track to make room for labels */
.ob-progress-track{ margin-bottom:26px; }

/* ── Main card ── */
.ob-card-shell{
  position:relative;border-radius:24px;overflow:hidden;
  background:linear-gradient(160deg,rgba(18,15,32,.98) 0%,rgba(12,10,22,.99) 100%);
  border:1px solid rgba(255,255,255,.07);
  box-shadow:0 40px 80px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.04),inset 0 1px 0 rgba(255,255,255,.06);
}
/* animated gradient border */
.ob-card-shell::before{
  content:'';position:absolute;inset:-1px;border-radius:25px;z-index:-1;
  background:linear-gradient(135deg,rgba(108,92,231,.4),rgba(162,155,254,.2),rgba(253,121,168,.3),rgba(108,92,231,.1));
  background-size:300% 300%;
  animation:obGradShift 5s ease infinite;
}
/* shimmer sweep */
.ob-card-shell::after{
  content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;pointer-events:none;z-index:2;
  background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.025) 50%,transparent 60%);
  animation:obShimmer 5s ease-in-out infinite;
}
.ob-card-inner{padding:2rem 1.8rem 1.8rem;position:relative;z-index:1}

/* ── Step header ── */
.ob-step-header{margin-bottom:1.8rem;position:relative}
.ob-step-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(162,155,254,.6);margin-bottom:.8rem;
}
.ob-step-eyebrow-line{width:20px;height:1.5px;background:currentColor;border-radius:99px}
.ob-step-title{
  font-family:'Syne',sans-serif;font-weight:800;font-size:1.6rem;
  color:#fff;letter-spacing:-.03em;line-height:1.1;margin-bottom:.45rem;
}
.ob-step-title em{
  font-style:normal;
  background:linear-gradient(135deg,#a29bfe 10%,#fd79a8 80%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.ob-step-desc{font-size:12.5px;color:rgba(255,255,255,.32);line-height:1.65}

/* ── Step transition ── */
.ob-step{display:none}
.ob-step.active{display:block;animation:obStepIn .4s cubic-bezier(.34,1.1,.64,1)}

/* ── Avatar upload ── */
.ob-avatar-zone{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  margin-bottom:1.6rem;
}
.ob-av-stage{position:relative;cursor:pointer}
.ob-av-ring{
  position:absolute;inset:-10px;border-radius:50%;
  border:1.5px solid rgba(162,155,254,.2);
  animation:obPulseRing 2.5s ease-out infinite;
  pointer-events:none;
}
.ob-av-ring2{
  position:absolute;inset:-20px;border-radius:50%;
  border:1px solid rgba(253,121,168,.12);
  animation:obPulseRing 2.5s ease-out infinite 0.8s;
  pointer-events:none;
}
.ob-av{
  width:92px;height:92px;border-radius:50%;
  background:linear-gradient(135deg,#6c5ce7,#a29bfe,#fd79a8);
  display:flex;align-items:center;justify-content:center;
  font-family:'Syne',sans-serif;font-weight:800;font-size:30px;color:#fff;
  position:relative;overflow:hidden;
  border:2px solid rgba(255,255,255,.12);
  box-shadow:0 0 0 4px rgba(108,92,231,.15),0 8px 32px rgba(108,92,231,.4),0 0 40px rgba(253,121,168,.15);
  transition:transform .25s,box-shadow .25s;
  animation:obAvatarFloat 5s ease-in-out infinite;
}
.ob-av:hover{
  transform:scale(1.05);
  box-shadow:0 0 0 6px rgba(108,92,231,.2),0 12px 40px rgba(108,92,231,.5),0 0 60px rgba(253,121,168,.2);
}
.ob-av img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ob-av-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(108,92,231,.7),rgba(253,121,168,.6));
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .25s;border-radius:50%;
}
.ob-av-overlay svg{filter:drop-shadow(0 0 6px rgba(255,255,255,.5))}
.ob-av:hover .ob-av-overlay{opacity:1}
.ob-av-hint{font-size:10.5px;color:rgba(255,255,255,.25);text-align:center;letter-spacing:.03em}

/* ── Name input ── */
.ob-name-wrap{position:relative}
.ob-name-input{
  width:100%;background:rgba(0,0,0,.4);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;padding:13px 16px;
  font-family:'DM Sans',sans-serif;font-size:15px;font-weight:500;
  color:#fff;outline:none;
  transition:border-color .2s,box-shadow .2s,background .2s;
  letter-spacing:.01em;
}
.ob-name-input::placeholder{color:rgba(255,255,255,.2)}
.ob-name-input:focus{
  border-color:rgba(162,155,254,.5);
  background:rgba(108,92,231,.05);
  box-shadow:0 0 0 3px rgba(108,92,231,.12),0 0 20px rgba(108,92,231,.1);
}

/* ── Option grid ── */
.ob-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:.5rem}
.ob-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:.5rem}

.ob-opt{
  border:1px solid rgba(255,255,255,.07);
  border-radius:16px;
  padding:1rem .75rem;cursor:pointer;
  transition:all .25s cubic-bezier(.4,0,.2,1);
  background:rgba(255,255,255,.03);
  text-align:center;position:relative;overflow:hidden;
  animation:obOptPop .35s cubic-bezier(.34,1.1,.64,1) both;
}
.ob-opt:nth-child(1){animation-delay:.06s}
.ob-opt:nth-child(2){animation-delay:.12s}
.ob-opt:nth-child(3){animation-delay:.18s}
.ob-opt:nth-child(4){animation-delay:.24s}
.ob-opt::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(108,92,231,.12),rgba(253,121,168,.08));
  opacity:0;transition:opacity .25s;
}
.ob-opt:hover{
  border-color:rgba(162,155,254,.3);
  background:rgba(108,92,231,.08);
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(108,92,231,.2);
}
.ob-opt:hover::before{opacity:1}
.ob-opt.sel{
  border-color:rgba(162,155,254,.6)!important;
  background:rgba(108,92,231,.15)!important;
  box-shadow:0 0 0 2px rgba(108,92,231,.2),0 8px 28px rgba(108,92,231,.25)!important;
  transform:translateY(-2px);
}
.ob-opt.sel::before{opacity:1}
.ob-opt.sel::after{
  content:'';position:absolute;top:8px;right:8px;
  width:16px;height:16px;border-radius:50%;
  background:linear-gradient(135deg,#a29bfe,#fd79a8);
  box-shadow:0 0 8px rgba(162,155,254,.6);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;background-size:10px;
}
.ob-opt-icon{
  margin-bottom:.6rem;
  display:flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:12px;
  background:rgba(255,255,255,.05);
  margin:0 auto .7rem;
  transition:all .25s;
  position:relative;z-index:1;
}
.ob-opt:hover .ob-opt-icon,.ob-opt.sel .ob-opt-icon{
  background:rgba(108,92,231,.18);
  box-shadow:0 4px 14px rgba(108,92,231,.25);
}
.ob-opt-label{font-size:12px;font-weight:700;color:rgba(255,255,255,.85);line-height:1.3;position:relative;z-index:1}
.ob-opt-sub{font-size:9.5px;color:rgba(255,255,255,.3);margin-top:3px;position:relative;z-index:1}

/* ── Section label ── */
.ob-section-lbl{
  font-size:9px;font-weight:700;color:rgba(255,255,255,.25);
  text-transform:uppercase;letter-spacing:.12em;margin-bottom:10px;
  display:flex;align-items:center;gap:8px;
}
.ob-section-lbl::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.05)}

/* ── Actions bar ── */
.ob-actions{
  display:flex;gap:10px;justify-content:space-between;align-items:center;
  margin-top:1.8rem;padding-top:1.4rem;
  border-top:1px solid rgba(255,255,255,.05);
}
.ob-btn-back{
  display:flex;align-items:center;gap:7px;
  background:none;border:1px solid rgba(255,255,255,.08);border-radius:12px;
  color:rgba(255,255,255,.38);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;
  padding:10px 18px;cursor:pointer;transition:all .22s;
}
.ob-btn-back:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16);color:rgba(255,255,255,.75);transform:translateX(-2px)}
.ob-btn-next{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 24px;border-radius:14px;border:none;cursor:pointer;
  background:linear-gradient(135deg,#6c5ce7,#a29bfe 50%,#fd79a8);
  background-size:200% 200%;animation:obGradShift 4s ease infinite;
  color:#fff;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;
  transition:all .25s;letter-spacing:.01em;
  box-shadow:0 4px 24px rgba(108,92,231,.45),0 0 0 1px rgba(255,255,255,.08);
  position:relative;overflow:hidden;
}
.ob-btn-next::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.18) 0%,transparent 50%);
  opacity:0;transition:opacity .25s;
}
.ob-btn-next:hover{
  box-shadow:0 6px 32px rgba(108,92,231,.6),0 0 0 1px rgba(255,255,255,.14);
  transform:translateY(-2px);
}
.ob-btn-next:hover::before{opacity:1}
.ob-btn-next:active{transform:scale(.97)}
.ob-btn-finish{
  flex:1;display:flex;align-items:center;justify-content:center;gap:9px;
  padding:13px 24px;border-radius:14px;border:none;cursor:pointer;
  background:linear-gradient(135deg,#fbbf24,#f97316,#fd79a8);
  background-size:200% 200%;animation:obGradShift 3s ease infinite;
  color:#fff;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:800;
  transition:all .25s;letter-spacing:.01em;
  box-shadow:0 4px 28px rgba(251,191,36,.4),0 0 0 1px rgba(255,255,255,.1);
  position:relative;overflow:hidden;
}
.ob-btn-finish:hover{transform:translateY(-2px);box-shadow:0 8px 36px rgba(251,191,36,.55),0 0 0 1px rgba(255,255,255,.15)}
.ob-btn-finish:active{transform:scale(.97)}

/* ── Coaching grid ── */
#coaching-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:7px;
  max-height:220px;overflow-y:auto;padding-right:2px;
  scrollbar-width:thin;scrollbar-color:rgba(162,155,254,.2) transparent;
}
#coaching-grid::-webkit-scrollbar{width:3px}
#coaching-grid::-webkit-scrollbar-track{background:transparent}
#coaching-grid::-webkit-scrollbar-thumb{background:rgba(162,155,254,.2);border-radius:99px}

/* ── Summary card at step 4 ── */
.ob-summary{
  background:rgba(108,92,231,.06);border:1px solid rgba(162,155,254,.12);
  border-radius:16px;padding:1.2rem;margin-bottom:1rem;
}
.ob-summary-row{display:flex;align-items:center;gap:10px;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.04)}
.ob-summary-row:last-child{border-bottom:none}
.ob-summary-icon{
  width:30px;height:30px;border-radius:8px;
  background:rgba(162,155,254,.1);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.ob-summary-label{font-size:10.5px;color:rgba(255,255,255,.3);margin-bottom:1px;letter-spacing:.03em}
.ob-summary-val{font-size:13px;font-weight:600;color:#fff}

/* ── Finish flourish ── */
.ob-finish-glow{
  text-align:center;margin-bottom:1.4rem;
}
.ob-finish-icon{
  width:72px;height:72px;border-radius:50%;
  background:linear-gradient(135deg,rgba(251,191,36,.2),rgba(253,121,168,.15));
  border:1.5px solid rgba(251,191,36,.35);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto .9rem;
  box-shadow:0 0 40px rgba(251,191,36,.25),inset 0 0 20px rgba(251,191,36,.08);
  animation:obAvatarFloat 4s ease-in-out infinite;
}
.ob-finish-title{
  font-family:'Syne',sans-serif;font-weight:800;font-size:1.1rem;
  background:linear-gradient(135deg,#fde68a,#fbbf24,#fd79a8);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:.3rem;
}
.ob-finish-sub{font-size:12px;color:rgba(255,255,255,.28);line-height:1.5}

@media(max-width:480px){
  .ob-grid{grid-template-columns:1fr 1fr}
  .ob-card-inner{padding:1.5rem 1.2rem}
  .ob-step-title{font-size:1.35rem}
  .ob-wrap{padding:1rem .75rem}
}
/* ═══════════════════════════════════════════════════════════════
   ULTRA PREMIUM SETTINGS & PROFILE
═══════════════════════════════════════════════════════════════ */

/* ── Settings Layout ── */
.settings-layout{display:grid;grid-template-columns:260px 1fr;gap:24px;max-width:1100px;margin:0 auto}

/* ── Settings Sidebar ── */
.settings-sidebar{
  background:linear-gradient(160deg,var(--sf) 0%,rgba(17,17,24,.98) 100%);
  border:1px solid var(--bd);border-radius:20px;padding:.9rem;
  height:fit-content;position:sticky;top:1rem;
  box-shadow:0 8px 32px rgba(0,0,0,.28),0 1px 0 rgba(255,255,255,.03) inset;
  overflow:hidden;
}
/* Ambient glow on sidebar */
.settings-sidebar::before{
  content:'';position:absolute;top:-60px;left:-40px;width:200px;height:200px;
  background:radial-gradient(circle,rgba(108,92,231,.08) 0%,transparent 65%);
  pointer-events:none;z-index:0;
}

.settings-nav-item{
  display:flex;align-items:center;gap:11px;padding:.7rem .9rem;border-radius:12px;cursor:pointer;
  font-size:13px;color:var(--mu);border:none;background:none;width:100%;text-align:left;
  transition:background .2s,color .2s,transform .15s,box-shadow .2s;
  font-family:'DM Sans',sans-serif;position:relative;z-index:1;overflow:hidden;
}
.settings-nav-item::before{
  content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(108,92,231,.12),rgba(162,155,254,.06));
  opacity:0;transition:opacity .2s;border-radius:12px;
}
.settings-nav-item:hover{background:var(--sf2);color:var(--tx);transform:translateX(3px)}
.settings-nav-item:hover::before{opacity:1}
.settings-nav-item.active{
  background:linear-gradient(135deg,rgba(108,92,231,.15),rgba(162,155,254,.08));
  color:var(--ac2);font-weight:600;
  box-shadow:0 2px 12px rgba(108,92,231,.15),inset 0 1px 0 rgba(162,155,254,.1);
}
.settings-nav-item.active::before{opacity:1}
/* Active indicator bar */
.settings-nav-item.active::after{
  content:'';position:absolute;left:0;top:20%;bottom:20%;width:3px;border-radius:0 3px 3px 0;
  background:linear-gradient(180deg,#a29bfe,#fd79a8);
  box-shadow:0 0 8px rgba(162,155,254,.5);
}
.settings-nav-item svg{transition:stroke .2s,transform .2s;flex-shrink:0;width:15px;height:15px}
.settings-nav-item:hover svg{transform:scale(1.15)}
.settings-nav-item.active svg{stroke:var(--ac2)}
.settings-nav-sep{height:1px;background:linear-gradient(90deg,transparent,var(--bd),transparent);margin:.55rem 0}
.settings-nav-label{
  font-size:9px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:var(--mu2);padding:.5rem .9rem .15rem;pointer-events:none;
  background:linear-gradient(90deg,var(--mu2),rgba(122,121,144,.4));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* ── Settings Panels ── */
.settings-panel{display:none}
.settings-panel.active{display:block;animation:settingsPanelIn .28s cubic-bezier(.34,1.1,.64,1)}
@keyframes settingsPanelIn{from{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:none}}

/* ── Settings Section Cards ── */
.settings-section{
  background:linear-gradient(145deg,var(--sf) 0%,rgba(17,17,24,.99) 100%);
  border:1px solid var(--bd);border-radius:20px;overflow:hidden;
  margin-bottom:16px;
  box-shadow:0 4px 24px rgba(0,0,0,.18),0 1px 0 rgba(255,255,255,.03) inset;
  transition:box-shadow .25s,border-color .25s,transform .2s;
  position:relative;
}
.settings-section::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(162,155,254,.12),transparent);
  pointer-events:none;
}
.settings-section:hover{
  box-shadow:0 8px 36px rgba(0,0,0,.25),0 0 0 1px rgba(162,155,254,.08);
  border-color:rgba(162,155,254,.1);
}

/* Section header — cinematic bar */
.settings-section-hdr{
  padding:.9rem 1.6rem;
  background:linear-gradient(90deg,rgba(17,17,24,.98),rgba(20,18,32,.95));
  border-bottom:1px solid var(--bd);
  font-size:10px;font-weight:800;color:var(--mu);
  text-transform:uppercase;letter-spacing:.12em;
  display:flex;align-items:center;gap:8px;
  position:relative;overflow:hidden;
}
.settings-section-hdr::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,#a29bfe,#fd79a8);
  box-shadow:0 0 10px rgba(162,155,254,.4);
}
.settings-section-hdr svg{flex-shrink:0;opacity:.7}

/* ── Settings Rows ── */
.settings-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.15rem 1.6rem;border-bottom:1px solid rgba(255,255,255,.04);
  gap:16px;transition:background .18s;cursor:default;
  position:relative;overflow:hidden;
}
.settings-row:last-child{border-bottom:none}
/* Hover shimmer */
.settings-row::after{
  content:'';position:absolute;left:-100%;top:0;bottom:0;width:100%;
  background:linear-gradient(90deg,transparent,rgba(162,155,254,.04),transparent);
  transition:left .5s ease;
}
.settings-row.clickable{cursor:pointer}
.settings-row.clickable:hover{background:rgba(108,92,231,.04)}
.settings-row.clickable:hover::after{left:100%}
.settings-row.clickable:hover .settings-row-title{color:var(--ac2)}
.settings-row-l{min-width:0;flex:1}
.settings-row-title{font-size:14px;font-weight:500;color:var(--tx);transition:color .18s}
.settings-row-sub{font-size:12px;color:var(--mu);margin-top:3px;line-height:1.45}
.settings-row-chevron{color:var(--mu2);transition:transform .18s,color .18s}
.settings-row.clickable:hover .settings-row-chevron{transform:translateX(4px);color:var(--ac2)}

/* ── Mobile settings fixes ── */
@media(max-width:640px){
  /* Avatar preset grid: 4 columns to prevent any overflow */
  #preset-avatar-grid,#ob-preset-grid{
    grid-template-columns:repeat(4,1fr) !important;
    gap:7px !important;
  }
  /* Preset picker: ensure it doesn't overflow the card */
  #preset-avatar-picker,#ob-preset-picker{
    padding:.75rem !important;
    box-sizing:border-box;
    width:100%;
    overflow:hidden;
  }
  /* Onboarding card inner: tighten padding so grid fits */
  .ob-card-inner{padding:1.5rem 1rem 1.4rem !important}
  /* Settings row: allow wrapping for long content */
  .settings-row{
    flex-wrap:wrap;
    gap:8px;
  }
  .settings-row .fi[style*="width:200px"]{
    width:100% !important;
  }
  /* Academic info dropdowns: compact so label + select fit on one row */
  .settings-row .fs[style*="width:175px"],
  .settings-row .fi[style*="width:175px"]{
    width:120px !important;
    padding:6px 24px 6px 8px !important;
    font-size:12px !important;
    flex-shrink:0;
  }
  /* Email read-only badge: shrink to fit, never overflow */
  #settings-email-ro{
    max-width:100% !important;
    width:100% !important;
    box-sizing:border-box;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
    white-space:nowrap !important;
    display:block !important;
  }
  /* Avatar area: constrain right-side text, wrap buttons */
  .settings-avatar-area{
    min-width:0;
    overflow:hidden;
  }
  .settings-avatar-area > div[style*="flex:1"]{
    min-width:0 !important;
    overflow:hidden;
  }
  /* Name & email display in avatar area: never overflow */
  #settings-name-display{
    white-space:normal !important;
    word-break:break-word !important;
    overflow:visible !important;
    text-overflow:unset !important;
  }
  #settings-email-display{
    white-space:normal !important;
    word-break:break-all !important;
    overflow:visible !important;
    text-overflow:unset !important;
    max-width:100% !important;
  }
  /* Upload / Avatars buttons row: wrap on tiny screens */
  .settings-avatar-area > div[style*="flex:1"] > div[style*="display:flex"]{
    flex-wrap:wrap !important;
  }
}

/* ── Premium Avatar Area ── */
.settings-avatar-area{
  display:flex;align-items:center;gap:1.8rem;
  padding:2rem 1.6rem;border-bottom:1px solid rgba(255,255,255,.05);
  transition:background .25s;
  background:linear-gradient(135deg,rgba(108,92,231,.03) 0%,transparent 60%);
  position:relative;overflow:hidden;
}
/* Aurora behind avatar area */
.settings-avatar-area::before{
  content:'';position:absolute;top:-60px;left:-40px;width:220px;height:220px;
  background:radial-gradient(circle,rgba(108,92,231,.1) 0%,transparent 65%);
  pointer-events:none;transition:opacity .3s;opacity:0;
}
.settings-avatar-area:hover::before,.settings-avatar-area.drag-over::before{opacity:1}
.settings-avatar-area.drag-over{background:rgba(108,92,231,.06)}
.settings-avatar-area.drag-over .settings-av{
  transform:scale(1.1);border-color:var(--ac);
  box-shadow:0 0 0 8px rgba(108,92,231,.15),0 8px 32px rgba(108,92,231,.4);
}

/* Premium avatar circle */
.settings-av{
  width:90px;height:90px;border-radius:50%;
  background:linear-gradient(145deg,#6c5ce7,#a29bfe,#fd79a8);
  display:flex;align-items:center;justify-content:center;
  font-family:'Syne',sans-serif;font-weight:800;font-size:32px;color:#fff;
  position:relative;overflow:hidden;
  border:3px solid rgba(108,92,231,.25);
  cursor:pointer;flex-shrink:0;
  transition:transform .25s cubic-bezier(.34,1.4,.64,1),border-color .25s,box-shadow .25s;
  box-shadow:0 6px 28px rgba(108,92,231,.3),0 2px 8px rgba(0,0,0,.4);
}
.settings-av::before{
  content:'';position:absolute;inset:0;border-radius:50%;
  background:linear-gradient(135deg,rgba(255,255,255,.25) 0%,transparent 50%);
  z-index:1;pointer-events:none;
}
/* Orbiting ring on avatar */
.settings-av::after{
  content:'';position:absolute;inset:-8px;border-radius:50%;
  border:1px solid rgba(162,155,254,.2);
  animation:ringRotate 10s linear infinite;
  opacity:0;transition:opacity .3s;
}
.settings-av:hover{
  transform:scale(1.08) rotate(-2deg);
  border-color:rgba(108,92,231,.7);
  box-shadow:0 0 0 6px rgba(108,92,231,.12),0 8px 36px rgba(108,92,231,.35);
}
.settings-av:hover::after{opacity:1}
.settings-av img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.settings-av-overlay{
  position:absolute;inset:0;z-index:2;
  background:rgba(0,0,0,.55);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .22s;
  backdrop-filter:blur(2px);
}
.settings-av:hover .settings-av-overlay{opacity:1}

/* ── Toggle Switches ── */
.sw-wrap{position:relative;display:inline-flex;width:44px;height:25px;cursor:pointer;flex-shrink:0}
.sw-wrap input{opacity:0;width:0;height:0;position:absolute}
.sw-track{
  position:absolute;inset:0;background:var(--sf3);border-radius:99px;
  transition:background .25s,box-shadow .25s;border:1px solid var(--bd2);
}
.sw-thumb{
  position:absolute;left:3px;top:3px;width:17px;height:17px;background:#fff;
  border-radius:50%;transition:transform .25s cubic-bezier(.34,1.4,.64,1);
  box-shadow:0 2px 5px rgba(0,0,0,.35),0 0 0 1px rgba(0,0,0,.1);
}
.sw-wrap input:checked~.sw-track{
  background:linear-gradient(135deg,#6c5ce7,#a29bfe);
  box-shadow:0 0 12px rgba(108,92,231,.35);border-color:transparent;
}
.sw-wrap input:checked~.sw-thumb{transform:translateX(19px)}

/* ── Mobile settings — vertical sidebar with full labels ── */
@media(max-width:768px){
  .settings-layout{grid-template-columns:1fr!important;gap:12px!important;align-items:start;min-width:0;overflow:hidden}
  .settings-sidebar{position:static!important;top:auto!important;padding:.5rem .45rem!important;border-radius:12px!important;display:flex!important;flex-direction:column!important;gap:2px!important;box-shadow:0 2px 12px rgba(0,0,0,.28)!important}
  .settings-nav-label{display:block}
  .settings-nav-sep{height:1px;background:var(--bd);margin:.35rem 0;display:block}
  .settings-nav-item{padding:.6rem .8rem!important;border-radius:10px!important;justify-content:flex-start!important;gap:9px!important;width:100%!important;font-size:12.5px!important}
  .settings-nav-item::after{display:block!important}
  .settings-nav-item span.snl{display:inline!important}
  .settings-nav-item svg{width:14px!important;height:14px!important;flex-shrink:0}
  .settings-nav-item.active{background:rgba(108,92,231,.15)!important}
  .settings-section{border-radius:14px}
  .settings-row{padding:.9rem 1rem}
  .settings-avatar-area{padding:1.4rem 1rem;gap:1rem}
  .settings-av{width:72px;height:72px;font-size:26px}
  .settings-section-hdr{padding:.7rem 1rem}
}
.settings-signout-row:hover{background:rgba(248,113,113,.07)!important;border-radius:0}
.btn.settings-save-btn{transition:all .22s cubic-bezier(.4,0,.2,1)}
.btn.settings-save-btn:disabled,.btn.settings-save-btn[disabled]{opacity:.28;cursor:not-allowed;pointer-events:none;transform:none!important;filter:none!important;box-shadow:none!important}
.btn.settings-save-btn.dirty{animation:savePulse .4s cubic-bezier(.34,1.4,.64,1)}
@keyframes savePulse{0%{transform:scale(.95)}60%{transform:scale(1.06)}100%{transform:scale(1)}}

/* ── Appearance panel mobile fixes ── */
@media(max-width:768px){
  /* Prevent the whole settings area from causing horizontal scroll */
  #page-settings{overflow-x:hidden;width:100%}
  .settings-layout{overflow-x:hidden;width:100%}
  /* Settings panel must not overflow */
  .settings-panel,#sp-appearance{min-width:0;max-width:100%;overflow-x:hidden}
  /* settings-row wraps on small screens */
  .settings-row{flex-wrap:wrap;gap:8px;padding:.7rem .85rem}
  /* Size/density/radius button groups wrap and stay within bounds */
  .settings-row > div[style*="display:flex"]{flex-wrap:wrap;max-width:100%}
  /* The button strip for S/M/L, Compact/Normal/Relaxed, Sharp/Rounded/Pill */
  .settings-row .size-btn{padding:4px 8px;font-size:10.5px}
  /* Theme grid: 3 cols still works but make it responsive */
  #sp-appearance .settings-row > div[style*="grid-template-columns"]{
    grid-template-columns:repeat(3,1fr) !important;
    width:100%;
  }
  /* Accent dots row: allow wrapping */
  #sp-appearance .settings-row[style*="flex-wrap"]{flex-wrap:wrap;row-gap:10px}
  /* accent dots container */
  #sp-appearance .settings-row > div[style*="gap:9px"]{flex-wrap:wrap;gap:8px}
  /* Ensure settings sections don't overflow */
  .settings-section{overflow-x:hidden;max-width:100%}
  /* Extra bottom padding so last setting isn't hidden behind bottom nav */
  #page-settings{padding-bottom:90px}
}

/* ═══════════════════════ APPEARANCE SETTINGS ═══════════════════════ */
.theme-card{background:var(--sf2);border:2px solid var(--bd);border-radius:10px;padding:0;cursor:pointer;transition:all .18s;overflow:hidden;text-align:left;width:100%}
.theme-card:hover{border-color:var(--bd2);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.3)}
.theme-card.active{border-color:var(--ac)!important;box-shadow:0 0 0 1px var(--ac)}
.theme-card-preview{height:52px;width:100%;display:flex;flex-direction:column;justify-content:center;padding:10px 12px}
.theme-card-label{font-size:11px;font-weight:600;color:var(--mu);padding:5px 10px 7px;text-align:center}
.theme-card.active .theme-card-label{color:var(--ac2)}
.accent-dot{width:26px;height:26px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .18s;position:relative;flex-shrink:0}
.accent-dot:hover{transform:scale(1.15)}
.accent-dot.active{border-color:#fff;box-shadow:0 0 0 2px currentColor,0 2px 8px rgba(0,0,0,.4)}
.accent-dot.active::after{content:'✓';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700}
.size-btn{padding:4px 10px;border-radius:4px;border:none;cursor:pointer;font-size:11px;font-weight:500;font-family:'DM Sans',sans-serif;background:none;color:var(--mu);transition:all .15s}
.size-btn.active{background:var(--sf3);color:var(--tx);box-shadow:0 1px 4px rgba(0,0,0,.3)}
.size-btn:hover:not(.active){color:var(--tx)}
@keyframes sbGrad{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.sb.gradient-on{background:linear-gradient(160deg,#0d0c14,#0f0e1a,#0a0a0f,#110d1c)!important;background-size:300% 300%!important;animation:sbGrad 8s ease infinite!important}
.sb.blur-on{backdrop-filter:blur(20px);background:rgba(17,17,24,.85)!important}

/* === CSS Block (original lines 2850–3069) === */
/* ═══════════════ ULTRA PREMIUM DASHBOARD ═══════════════ */

/* Dashboard ambient background */
#page-overview {
  position: relative;
}
#page-overview::before {
  content: '';
  position: fixed; top: 0; left: 224px; right: 0; height: 300px;
  background: radial-gradient(ellipse 60% 100% at 70% 0%, rgba(124,106,247,.07) 0%, transparent 70%),
              radial-gradient(ellipse 40% 60% at 20% 0%, rgba(244,114,182,.04) 0%, transparent 60%);
  pointer-events: none; z-index: 0;
}

/* Header area */
.dash-header-wrap {
  position: relative; z-index: 1;
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 1.1rem; flex-wrap: wrap; gap: 10px;
}
.dash-greeting-block {}
.dash-greeting-name {
  font-family: 'Syne', sans-serif; font-weight: 800;
  font-size: 1.5rem; letter-spacing: -.025em; color: var(--tx);
  line-height: 1.1;
}
.dash-greeting-name em {
  background: linear-gradient(135deg, #a695ff, #f472b6);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  font-style: normal;
}
.dash-greeting-date {
  font-size: 11.5px; color: var(--mu); margin-top: 3px;
  display: flex; align-items: center; gap: 5px;
}
.dash-greeting-dot {
  width: 5px; height: 5px; border-radius: 50%; background: var(--gn);
  animation: dashDotPulse 2s ease-in-out infinite;
}
@keyframes dashDotPulse { 0%,100%{opacity:.5;transform:scale(1)} 50%{opacity:1;transform:scale(1.4)} }

/* AI button — premium */
.dash-ai-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 16px; border-radius: 10px; border: none;
  background: linear-gradient(135deg, rgba(124,106,247,.15), rgba(166,149,255,.08));
  color: var(--ac2); font-family: 'DM Sans', sans-serif;
  font-size: 12px; font-weight: 600; cursor: pointer;
  border: 1px solid rgba(124,106,247,.25);
  transition: all .2s;
  position: relative; overflow: hidden;
  box-shadow: 0 2px 12px rgba(124,106,247,.15);
}
.dash-ai-btn::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,.07) 50%, transparent 60%);
  animation: dashAIShim 2.8s ease-in-out infinite;
}
@keyframes dashAIShim { 0%{left:-100%} 100%{left:180%} }
.dash-ai-btn:hover {
  background: linear-gradient(135deg, rgba(124,106,247,.25), rgba(166,149,255,.15));
  border-color: rgba(124,106,247,.4);
  transform: translateY(-1px);
  box-shadow: 0 4px 20px rgba(124,106,247,.25);
}
.dash-ai-btn-dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--ac2);
  animation: dashDotPulse 1.5s ease-in-out infinite;
}

/* Stat cards — ultra premium */
.dash-stat-grid {
  display: grid; grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 9px; margin-bottom: 10px; position: relative; z-index: 1;
}
@media(max-width:1100px){ .dash-stat-grid { grid-template-columns: repeat(3, 1fr); } }
@media(max-width:640px) { .dash-stat-grid { grid-template-columns: repeat(2, 1fr); } .dash-stat.donut-card { grid-column: 1 / -1; } }

.dash-stat {
  position: relative; overflow: hidden;
  background: var(--sf);
  border: 1px solid var(--bd);
  border-radius: 14px;
  padding: .85rem 1rem;
  transition: all .22s cubic-bezier(.4,0,.2,1);
  cursor: default;
}
.dash-stat::before {
  content: ''; position: absolute; inset: 0; border-radius: 14px;
  opacity: 0; transition: opacity .3s;
}
.dash-stat:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(0,0,0,.35);
}
.dash-stat:hover::before { opacity: 1; }

/* Per-card accent glow */
.dash-stat.purple { border-color: rgba(124,106,247,.14); }
.dash-stat.purple::before { background: radial-gradient(circle at 50% 0%, rgba(124,106,247,.08), transparent 70%); }
.dash-stat.purple:hover { border-color: rgba(124,106,247,.28); box-shadow: 0 8px 32px rgba(0,0,0,.35), 0 0 40px rgba(124,106,247,.08); }

.dash-stat.pink { border-color: rgba(244,114,182,.14); }
.dash-stat.pink::before { background: radial-gradient(circle at 50% 0%, rgba(244,114,182,.07), transparent 70%); }
.dash-stat.pink:hover { border-color: rgba(244,114,182,.28); box-shadow: 0 8px 32px rgba(0,0,0,.35), 0 0 40px rgba(244,114,182,.07); }

.dash-stat.amber { border-color: rgba(251,191,36,.14); }
.dash-stat.amber::before { background: radial-gradient(circle at 50% 0%, rgba(251,191,36,.07), transparent 70%); }
.dash-stat.amber:hover { border-color: rgba(251,191,36,.28); }

.dash-stat.red { border-color: rgba(248,113,113,.14); }
.dash-stat.red::before { background: radial-gradient(circle at 50% 0%, rgba(248,113,113,.07), transparent 70%); }
.dash-stat.red:hover { border-color: rgba(248,113,113,.28); }

/* Stat icon — absolute on desktop, flows on mobile */
.dash-stat-icon {
  position: absolute; top: .75rem; right: .8rem;
  width: 28px; height: 28px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  opacity: .6;
}
.dash-stat-label {
  font-size: 10px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .07em; color: var(--mu); margin-bottom: .45rem;
}
.dash-stat-value {
  font-family: 'Space Grotesk', sans-serif; font-weight: 700;
  font-size: 1.75rem; line-height: 1; letter-spacing: -.025em;
  margin-bottom: .3rem;
}
.dash-stat-sub {
  font-size: 10.5px; color: var(--mu);
}
@media(max-width:640px){
  .dash-stat { display: flex; flex-direction: column; }
  .dash-stat-icon { position: static; margin-bottom: .4rem; opacity: .7; align-self: flex-start; }
}
.dash-stat-bar {
  position: absolute; bottom: 0; left: 0; right: 0;
  height: 2px; border-radius: 0 0 14px 14px; overflow: hidden;
}
.dash-stat-bar-fill {
  height: 100%; border-radius: 99px;
  width: 0%; transition: width 1.2s cubic-bezier(.4,0,.2,1) .2s;
}

/* Donut card special */
.dash-stat.donut-card {
  padding: .7rem; border-color: rgba(124,106,247,.12);
}
.dash-stat.donut-card:hover { border-color: rgba(124,106,247,.25); }

/* Quote banner */
.dash-quote-banner {
  position: relative; z-index: 1;
  background: linear-gradient(135deg, rgba(124,106,247,.07), rgba(244,114,182,.04));
  border: 1px solid rgba(124,106,247,.14);
  border-radius: 12px; padding: .75rem 1rem .75rem 1.2rem;
  margin-bottom: 10px; display: flex; align-items: center; gap: 10px;
  overflow: hidden;
}
.dash-quote-banner::before {
  content:''; position:absolute; left:0; top:15%; bottom:15%;
  width:3px; border-radius:0 3px 3px 0;
  background: linear-gradient(180deg, #7c6af7, #f472b6);
}
.dash-quote-text {
  font-size: 11.5px; color: var(--mu); font-style: italic; line-height: 1.5; flex: 1;
}
.dash-quote-icon {
  font-size: 1.1rem; flex-shrink: 0; opacity: .7;
}

/* Card headers — enhanced */
.ch .ct {
  font-size: 10.5px; font-weight: 700; color: var(--mu);
  text-transform: uppercase; letter-spacing: .08em;
  display: flex; align-items: center; gap: 6px;
}
.ch .ct::before {
  content:''; display:inline-block;
  width:6px; height:6px; border-radius:50%;
  background: linear-gradient(135deg, var(--ac), var(--ac2));
  opacity: .8;
}

/* Premium card styles */
.dash-card-premium {
  background: var(--sf); border: 1px solid var(--bd); border-radius: 14px;
  padding: .9rem 1rem; position: relative; overflow: hidden;
  transition: border-color .2s, box-shadow .2s, transform .2s;
}
.dash-card-premium:hover {
  border-color: rgba(124,106,247,.18);
  box-shadow: 0 6px 24px rgba(0,0,0,.28);
  transform: translateY(-1px);
}
.dash-card-premium .glow-line {
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(124,106,247,.25), transparent);
  pointer-events: none;
}

/* Quick-log buttons */
.ql-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 11px; border-radius: 8px;
  border: 1px solid var(--bd2); background: var(--sf2);
  color: var(--mu); font-family: 'DM Sans', sans-serif;
  font-size: 11px; font-weight: 500; cursor: pointer;
  transition: all .18s;
}
.ql-btn:hover {
  border-color: var(--ac); color: var(--ac2);
  background: rgba(124,106,247,.08);
  transform: translateY(-1px);
}
.ql-btn:active { transform: scale(.95); }

/* === CSS Block (original lines 3265–3660) === */
/* ── Shared premium page shell ── */
.prem-page { position: relative; }
.prem-page::before {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(ellipse 55% 70% at 85% 0%, rgba(124,106,247,.06) 0%, transparent 65%),
    radial-gradient(ellipse 35% 50% at 5% 100%, rgba(244,114,182,.04) 0%, transparent 60%);
}

/* ── Page hero header ── */
.prem-hero {
  position: relative; z-index: 1;
  padding: 0 0 1.1rem;
  display: flex; align-items: flex-start; justify-content: space-between;
  flex-wrap: wrap; gap: 12px;
}
.prem-hero-left { display: flex; align-items: center; gap: 14px; }
.prem-hero-icon {
  width: 44px; height: 44px; border-radius: 14px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}
.prem-hero-icon::before {
  content: ''; position: absolute; inset: -1px; border-radius: 15px;
  background: inherit; filter: blur(8px); opacity: .4; z-index: -1;
}
.prem-hero-title {
  font-family: 'Syne', sans-serif; font-weight: 800;
  font-size: 1.45rem; letter-spacing: -.028em; line-height: 1.1; color: var(--tx);
}
.prem-hero-sub {
  font-size: 11.5px; color: var(--mu); margin-top: 2px;
  display: flex; align-items: center; gap: 6px;
}
.prem-hero-sub-dot {
  width: 4px; height: 4px; border-radius: 50%; background: currentColor; opacity: .5;
}
.prem-hero-actions { display: flex; gap: 7px; align-items: center; flex-wrap: wrap; }

/* ── Premium action buttons ── */
.prem-btn-primary {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 9px 18px; border-radius: 10px; border: none; cursor: pointer;
  font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 600;
  background: linear-gradient(135deg, #7c6af7, #a695ff);
  color: #fff; transition: all .2s; position: relative; overflow: hidden;
  box-shadow: 0 2px 16px rgba(124,106,247,.3);
}
.prem-btn-primary::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,.12) 50%, transparent 60%);
  transition: left .5s; left: -100%;
}
.prem-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 6px 24px rgba(124,106,247,.4); }
.prem-btn-primary:hover::before { left: 100%; }
.prem-btn-primary:active { transform: scale(.97); }

.prem-btn-secondary {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 16px; border-radius: 10px; cursor: pointer;
  font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 500;
  background: var(--sf2); color: var(--tx);
  border: 1px solid var(--bd2); transition: all .2s;
}
.prem-btn-secondary:hover {
  border-color: rgba(124,106,247,.35); color: var(--ac2);
  background: rgba(124,106,247,.07); transform: translateY(-1px);
}
.prem-btn-secondary:active { transform: scale(.97); }

/* ── Filter bar ── */
.prem-filter-bar {
  position: relative; z-index: 1;
  display: flex; align-items: center; gap: 7px; flex-wrap: nowrap;
  background: var(--sf); border: 1px solid var(--bd);
  border-radius: 12px; padding: 8px 12px; margin-bottom: 12px;
  box-shadow: 0 2px 12px rgba(0,0,0,.15);
}
/* Wider adv selects so dropdown arrow never overlaps text */
select.fc.adv-fc {
  padding-right: 22px !important;
  background-position: right 6px center !important;
}
/* Filter bar scrolls horizontally on very small screens */
.prem-filter-sep { width: 1px; height: 18px; background: var(--bd2); flex-shrink: 0; }
.prem-filter-label {
  font-size: 9.5px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; color: var(--mu2); flex-shrink: 0;
  padding-right: 7px; border-right: 1px solid var(--bd2); margin-right: 2px;
}
/* Mode toggle wrapper always pushes to right */
.prem-filter-end { margin-left: auto; flex-shrink: 0; }

/* Mobile filter fixes */
@media(max-width:640px) {
  .prem-filter-bar { gap: 6px; padding: 8px 10px; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .prem-filter-bar::-webkit-scrollbar { display: none; }
  /* Selects: ensure no arrow overlap */
  select.fc {
    padding-right: 28px !important;
    min-width: 0 !important;
    max-width: 120px;
    background-position: right 6px center !important;
    text-overflow: ellipsis;
    overflow: hidden;
  }
  /* Mode toggle: always sits at end without breaking layout */
  .prem-filter-end { margin-left: auto; }
  /* Separators hidden on mobile to save space */
  .prem-filter-sep { display: none; }
}

/* ── Stat cards grid ── */
.prem-stat-grid {
  display: grid; grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 10px; margin-bottom: 12px; position: relative; z-index: 1;
}
@media(max-width: 900px) { .prem-stat-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width: 480px) { .prem-stat-grid { grid-template-columns: repeat(2, 1fr); } }

.prem-stat-card {
  position: relative; overflow: hidden;
  background: var(--sf); border: 1px solid var(--bd);
  border-radius: 16px; padding: 1.1rem 1.1rem .9rem;
  transition: all .22s cubic-bezier(.4,0,.2,1); cursor: default;
}
.prem-stat-card::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
}
/* Colored bottom accent bar */
.prem-stat-card::before {
  content: ''; position: absolute; bottom: 0; left: 12%; right: 12%; height: 2px;
  border-radius: 99px; opacity: .7; transition: opacity .22s, left .22s, right .22s;
}
.prem-stat-card:hover::before { left: 6%; right: 6%; opacity: 1; }
.prem-stat-card:hover { transform: translateY(-2px); }
.prem-stat-card.violet { border-color: rgba(124,106,247,.16); }
.prem-stat-card.violet::before { background: linear-gradient(90deg,transparent,#7c6af7,transparent); }
.prem-stat-card.violet:hover { border-color: rgba(124,106,247,.3); box-shadow: 0 8px 32px rgba(124,106,247,.1); }
.prem-stat-card.green { border-color: rgba(52,211,153,.16); }
.prem-stat-card.green::before { background: linear-gradient(90deg,transparent,#34d399,transparent); }
.prem-stat-card.green:hover { border-color: rgba(52,211,153,.3); box-shadow: 0 8px 32px rgba(52,211,153,.08); }
.prem-stat-card.amber { border-color: rgba(251,191,36,.16); }
.prem-stat-card.amber::before { background: linear-gradient(90deg,transparent,#fbbf24,transparent); }
.prem-stat-card.amber:hover { border-color: rgba(251,191,36,.3); box-shadow: 0 8px 32px rgba(251,191,36,.08); }
.prem-stat-card.blue { border-color: rgba(96,165,250,.16); }
.prem-stat-card.blue::before { background: linear-gradient(90deg,transparent,#60a5fa,transparent); }
.prem-stat-card.blue:hover { border-color: rgba(96,165,250,.3); box-shadow: 0 8px 32px rgba(96,165,250,.08); }
.prem-stat-card.pink { border-color: rgba(244,114,182,.16); }
.prem-stat-card.pink::before { background: linear-gradient(90deg,transparent,#f472b6,transparent); }
.prem-stat-card.pink:hover { border-color: rgba(244,114,182,.3); box-shadow: 0 8px 32px rgba(244,114,182,.08); }
/* Hours-specific stat cards also get bottom bar via inline style border-color */
.prem-stat-card[style*="border-color:rgba(45,212,191"]::before { background: linear-gradient(90deg,transparent,#2dd4bf,transparent); }
.prem-stat-card[style*="border-color:rgba(96,165,250"]::before { background: linear-gradient(90deg,transparent,#60a5fa,transparent); }
.prem-stat-card[style*="border-color:rgba(52,211,153"]::before { background: linear-gradient(90deg,transparent,#34d399,transparent); }

.prem-stat-icon-row {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: .6rem;
}
.prem-stat-ico {
  width: 30px; height: 30px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
}
.prem-stat-trend {
  font-size: 9.5px; font-weight: 700; padding: 2px 7px; border-radius: 99px;
  display: inline-flex; align-items: center; gap: 3px;
}
.prem-stat-trend.up { background: rgba(52,211,153,.12); color: var(--gn); }
.prem-stat-trend.dn { background: rgba(248,113,113,.1); color: var(--rd); }
.prem-stat-trend.nt { background: var(--sf2); color: var(--mu); }

.prem-stat-lbl {
  font-size: 10px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .07em; color: var(--mu); margin-bottom: .3rem;
}
.prem-stat-val {
  font-family: 'Space Grotesk', sans-serif; font-weight: 700;
  font-size: 1.9rem; line-height: 1; letter-spacing: -.025em;
  margin-bottom: .25rem;
}
.prem-stat-sub { font-size: 10.5px; color: var(--mu); line-height: 1.4; }
.prem-stat-bar {
  position: absolute; bottom: 0; left: 0; right: 0; height: 2.5px;
  border-radius: 0 0 16px 16px; overflow: hidden;
}
.prem-stat-bar-fill {
  height: 100%; border-radius: 99px;
  width: 0%; transition: width 1.2s cubic-bezier(.4,0,.2,1) .3s;
}

/* ── Chart cards ── */
.prem-chart-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 12px; margin-bottom: 12px; position: relative; z-index: 1;
}
@media(max-width: 640px) { .prem-chart-grid { grid-template-columns: 1fr; } }

.prem-chart-card {
  background: var(--sf); border: 1px solid var(--bd); border-radius: 16px;
  padding: 1.1rem 1.1rem .9rem; position: relative; overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.prem-chart-card:hover { border-color: rgba(124,106,247,.15); box-shadow: 0 6px 28px rgba(0,0,0,.25); }
.prem-chart-card-hdr {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: .8rem;
}
.prem-chart-card-title {
  font-size: 10.5px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; color: var(--mu);
  display: flex; align-items: center; gap: 6px;
}
.prem-chart-card-title::before {
  content: ''; display: inline-block; width: 6px; height: 6px; border-radius: 50%;
  background: linear-gradient(135deg, var(--ac), var(--ac2)); opacity: .8;
}
.prem-chart-glow {
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(124,106,247,.2), transparent);
  pointer-events: none;
}

/* ── All tests table card ── */
.prem-table-card {
  background: var(--sf); border: 1px solid var(--bd); border-radius: 16px;
  overflow: hidden; position: relative; z-index: 1; margin-bottom: 12px;
  transition: border-color .2s, box-shadow .2s;
}
.prem-table-card:hover { border-color: rgba(124,106,247,.12); }
.prem-table-hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.2rem; border-bottom: 1px solid var(--bd);
  background: linear-gradient(90deg, rgba(17,17,24,.6), transparent);
  position: relative; gap: 8px; flex-wrap: wrap;
}
.prem-table-hdr::before {
  content: ''; position: absolute; left: 0; top: 15%; bottom: 15%; width: 3px;
  border-radius: 0 3px 3px 0;
  background: linear-gradient(180deg, var(--ac), var(--pk));
}
.prem-table-title {
  font-size: 10.5px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; color: var(--mu);
  display: flex; align-items: center; gap: 7px;
}
.prem-table-tabs {
  display: flex; background: var(--sf2); border-radius: 8px; padding: 3px; gap: 2px;
}
.prem-table-tab {
  padding: 4px 14px; border-radius: 6px; border: none; cursor: pointer;
  font-size: 11px; font-weight: 500; font-family: 'DM Sans', sans-serif;
  background: none; color: var(--mu); transition: all .18s;
}
.prem-table-tab.active { background: var(--sf3); color: var(--tx); }
.prem-table-tab:hover:not(.active) { color: var(--ac2); }
.prem-table-body { padding: 0; }

/* ── Notification banners ── */
.prem-notif {
  display: flex; align-items: center; gap: 10px;
  padding: .65rem 1rem; border-radius: 10px; margin-bottom: 7px;
  font-size: 12.5px; font-weight: 500;
  border: 1px solid; animation: itemIn .25s ease both;
}
.prem-notif.warn {
  background: rgba(251,191,36,.07); border-color: rgba(251,191,36,.2); color: var(--am);
}
.prem-notif.danger {
  background: rgba(248,113,113,.07); border-color: rgba(248,113,113,.2); color: var(--rd);
}
.prem-notif-icon {
  width: 22px; height: 22px; border-radius: 6px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.prem-notif.warn .prem-notif-icon { background: rgba(251,191,36,.15); }
.prem-notif.danger .prem-notif-icon { background: rgba(248,113,113,.12); }

/* ── Compare hero ── */
.cmp-hero {
  position: relative; z-index: 1;
  background: linear-gradient(135deg, rgba(124,106,247,.06), rgba(244,114,182,.04));
  border: 1px solid rgba(124,106,247,.14); border-radius: 16px;
  padding: 1.2rem 1.4rem; margin-bottom: 14px; overflow: hidden;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  flex-wrap: wrap;
}
.cmp-hero::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: linear-gradient(180deg, #7c6af7, #f472b6);
}
.cmp-hero-title {
  font-family: 'Syne', sans-serif; font-weight: 800;
  font-size: 1.3rem; letter-spacing: -.025em;
}
.cmp-hero-title em { font-style: normal; }
.cmp-hero-title em.violet { color: var(--ac2); }
.cmp-hero-title em.pink { color: var(--pk); }
.cmp-hero-sub { font-size: 11.5px; color: var(--mu); margin-top: 3px; }
.cmp-legend-row {
  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
}
.cmp-legend-item {
  display: flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 500; color: var(--mu);
}
.cmp-legend-dot {
  width: 10px; height: 10px; border-radius: 3px; flex-shrink: 0;
}

/* ── Compare chart cards ── */
.cmp-chart-grid-2 {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 12px; margin-bottom: 12px; position: relative; z-index: 1;
}
@media(max-width:640px) { .cmp-chart-grid-2 { grid-template-columns: 1fr; } }

.cmp-chart-card {
  background: var(--sf); border: 1px solid var(--bd); border-radius: 16px;
  padding: 1.1rem; position: relative; overflow: hidden;
  transition: border-color .2s, box-shadow .2s, transform .2s;
}
.cmp-chart-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(0,0,0,.28);
}
.cmp-chart-card.accent-violet:hover { border-color: rgba(124,106,247,.25); }
.cmp-chart-card.accent-pink:hover { border-color: rgba(244,114,182,.25); }
.cmp-chart-card.accent-teal:hover { border-color: rgba(45,212,191,.25); }
.cmp-chart-card.accent-amber:hover { border-color: rgba(251,191,36,.25); }

.cmp-chart-glow-v { position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(124,106,247,.25), transparent); }
.cmp-chart-glow-p { position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(244,114,182,.25), transparent); }
.cmp-chart-glow-t { position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(45,212,191,.25), transparent); }
.cmp-chart-glow-a { position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(251,191,36,.25), transparent); }

.cmp-chart-hdr {
  display: flex; align-items: flex-start; justify-content: space-between;
  margin-bottom: .85rem; gap: 8px;
}
.cmp-chart-title-block {}
.cmp-chart-title {
  font-size: 10.5px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; color: var(--mu); margin-bottom: 3px;
  display: flex; align-items: center; gap: 6px;
}
.cmp-chart-title::before {
  content: ''; display: inline-block; width: 6px; height: 6px; border-radius: 50%;
  background: linear-gradient(135deg, var(--ac), var(--ac2)); opacity: .7;
}
.cmp-chart-subtitle { font-size: 10px; color: var(--mu2); }

/* ── Mode toggle premium ── */
.prem-mode-tog {
  display: flex; background: var(--sf2); border-radius: 8px; padding: 3px; gap: 2px;
}
.prem-mode-btn {
  padding: 3px 11px; border-radius: 6px; border: none; cursor: pointer;
  font-size: 10.5px; font-weight: 500; font-family: 'DM Sans', sans-serif;
  background: none; color: var(--mu); transition: all .18s;
}
.prem-mode-btn.active {
  background: linear-gradient(135deg, rgba(124,106,247,.2), rgba(166,149,255,.1));
  color: var(--ac2); box-shadow: 0 1px 6px rgba(124,106,247,.15);
}
.prem-mode-btn:hover:not(.active) { color: var(--tx); }

/* Mobile responsive for prem-hero */
@media(max-width:640px) {
  .prem-hero { flex-direction: column; align-items: flex-start; gap: 10px; }
  .prem-hero-actions { width: 100%; }
  .prem-btn-primary, .prem-btn-secondary { flex: 1; justify-content: center; }
  .prem-stat-grid { grid-template-columns: repeat(2,1fr); }
  .prem-chart-grid { grid-template-columns: 1fr; }
  .cmp-chart-grid-2 { grid-template-columns: 1fr; }
  .cmp-hero { flex-direction: column; }
  /* Simplify hero subtitle on mobile — only for mains & advanced */
  #page-mains .prem-hero-sub .prem-hero-sub-dot,
  #page-mains .prem-hero-sub .prem-hero-sub-part,
  #page-advanced .prem-hero-sub .prem-hero-sub-dot,
  #page-advanced .prem-hero-sub .prem-hero-sub-part { display: none; }
  #page-mains .prem-hero-sub::after,
  #page-advanced .prem-hero-sub::after { content: 'Track all your mock tests'; font-size: 11px; color: var(--mu); }
  #page-mains .prem-hero-sub,
  #page-advanced .prem-hero-sub { font-size: 0; }
}
/* Study hours page — cyan/blue ambient glow */
#page-hours.prem-page::before {
  background:
    radial-gradient(ellipse 55% 70% at 85% 0%, rgba(45,212,191,.07) 0%, transparent 65%),
    radial-gradient(ellipse 35% 50% at 5% 100%, rgba(96,165,250,.05) 0%, transparent 60%);
}
/* hrs stat grid inherits prem-stat-grid */
.hrs-stat-grid { grid-template-columns: repeat(4, minmax(0,1fr)); }
@media(max-width:900px){ .hrs-stat-grid { grid-template-columns: repeat(2, 1fr); } }

/* === CSS Block (original lines 4270–4493) === */
/* ══════════════════════════════════════════════════════
   ULTRA PREMIUM SYLLABUS
══════════════════════════════════════════════════════ */

/* Ambient */
#page-syllabus{position:relative;overflow:hidden}
#page-syllabus::before{
  content:'';position:fixed;top:-40%;left:-20%;width:140%;height:140%;
  pointer-events:none;z-index:0;
  background:radial-gradient(ellipse 50% 40% at 25% 20%,rgba(124,106,247,.04) 0%,transparent 55%),
             radial-gradient(ellipse 40% 35% at 80% 75%,rgba(45,212,191,.04) 0%,transparent 55%);
  animation:tdAmbient 10s ease-in-out infinite alternate;
}
#page-syllabus .ph,#page-syllabus #syl-overall-card,
#page-syllabus #syl-overview,#page-syllabus #syl-list-wrap,
#page-syllabus #syl-list,#syl-filter-bar,
#syl-subj-bar,#syl-class-bar,#syl-chem-subfr{position:relative;z-index:1}

/* ── Filter tab bar ── */
.syl-filter-bar{
  display:inline-flex;align-items:center;gap:3px;
  background:var(--sf);border:1px solid var(--bd);border-radius:10px;padding:4px;
}
.syl-ftab{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 11px;border-radius:7px;border:none;cursor:pointer;
  font-family:'DM Sans',sans-serif;font-size:11.5px;font-weight:500;
  background:none;color:var(--mu);
  transition:all .18s cubic-bezier(.4,0,.2,1);
}
.syl-ftab:hover:not(.active){background:var(--sf2);color:var(--tx)}
.syl-ftab.active{background:var(--sf3);color:var(--tx);font-weight:600;
  box-shadow:0 1px 4px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.05)}
.syl-ftab:active{transform:scale(.95)}

/* ── Overall hero card ── */
.syl-hero{
  background:var(--sf);border:1px solid var(--bd);border-radius:16px;
  padding:1.2rem 1.3rem;overflow:hidden;position:relative;
}
.syl-hero::before{
  content:'';position:absolute;inset:0;border-radius:16px;
  background:linear-gradient(135deg,rgba(255,255,255,.022) 0%,transparent 55%);
  pointer-events:none;
}
.syl-hero-top{display:flex;align-items:center;gap:1.2rem;margin-bottom:1rem}
.syl-hero-ring{position:relative;flex-shrink:0}
.syl-hero-ring svg{display:block}
.syl-hero-pct{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk',sans-serif;font-size:1.05rem;font-weight:700;
  color:var(--tx);flex-direction:column;gap:1px;
}
.syl-hero-pct span{font-size:9px;color:var(--mu);font-family:'DM Sans',sans-serif;font-weight:500}
.syl-hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;flex:1}
.syl-hero-stat{text-align:center;padding:.5rem .3rem;background:var(--sf2);border:1px solid var(--bd);border-radius:10px}
.syl-hero-stat-num{font-family:'Space Grotesk',sans-serif;font-size:1.3rem;font-weight:700;line-height:1}
.syl-hero-stat-lbl{font-size:9.5px;color:var(--mu);margin-top:3px;text-transform:uppercase;letter-spacing:.05em}
.syl-hero-bar-wrap{margin-top:.2rem}
.syl-hero-bar-label{display:flex;justify-content:space-between;font-size:10.5px;color:var(--mu);margin-bottom:5px}
.syl-hero-bar{height:6px;background:var(--sf3);border-radius:99px;overflow:hidden}
.syl-hero-bar-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--ac),var(--pk));transition:width 1s cubic-bezier(.4,0,.2,1)}
/* Sub-subject progress bars inside hero */
.syl-subj-bars{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:.9rem}
.syl-subj-bar-item{background:var(--sf2);border:1px solid var(--bd);border-radius:10px;padding:.6rem .75rem}
.syl-subj-bar-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.syl-subj-bar-name{font-size:11px;font-weight:600}
.syl-subj-bar-pct{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:700}
.syl-subj-bar-track{height:4px;background:var(--sf3);border-radius:99px;overflow:hidden}
.syl-subj-bar-fill{height:100%;border-radius:99px;transition:width .9s cubic-bezier(.4,0,.2,1)}

/* ── Subject overview cards ── */
.syl-ov-card{
  background:var(--sf);border:1px solid var(--bd);border-radius:14px;
  padding:1rem 1.1rem;position:relative;overflow:hidden;
  transition:border-color .22s,transform .2s,box-shadow .22s;cursor:default;
}
.syl-ov-card:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.3);border-color:rgba(255,255,255,.1)}
.syl-ov-card-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.syl-ov-card-title{font-size:13px;font-weight:700}
.syl-ov-pct-badge{font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:700;padding:2px 9px;border-radius:99px;border:1px solid currentColor}
.syl-ov-sub{font-size:11px;color:var(--mu);margin-bottom:8px;display:flex;align-items:center;gap:5px}
.syl-ov-track{height:5px;background:var(--sf3);border-radius:99px;overflow:hidden}
.syl-ov-fill{height:100%;border-radius:99px;transition:width .9s cubic-bezier(.4,0,.2,1)}
/* Chemistry section sub-bars */
.syl-chem-sub-rows{margin-top:10px;display:flex;flex-direction:column;gap:6px}
.syl-chem-sub-row{}
.syl-chem-sub-hd{display:flex;justify-content:space-between;font-size:10px;margin-bottom:3px}

/* ── Chapter item ── */
.syl-chapter{
  background:var(--sf);border:1px solid var(--bd);border-radius:12px;
  padding:.75rem 1rem;margin-bottom:6px;
  display:flex;align-items:center;gap:12px;
  transition:border-color .2s,transform .18s,box-shadow .2s,background .2s;
  animation:chSlideIn .3s cubic-bezier(.34,1.1,.64,1) both;
  position:relative;overflow:hidden;
}
@keyframes chSlideIn{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:none}}
.syl-chapter::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  border-radius:2px 0 0 2px;
  transition:opacity .2s;
}
.syl-chapter.phy-ch::before{background:linear-gradient(180deg,#60a5fa,#3b82f6)}
.syl-chapter.che-ch::before{background:linear-gradient(180deg,#34d399,#059669)}
.syl-chapter.mat-ch::before{background:linear-gradient(180deg,#fbbf24,#f59e0b)}
.syl-chapter:hover{border-color:rgba(255,255,255,.1);transform:translateX(2px);box-shadow:0 4px 16px rgba(0,0,0,.22);background:var(--sf2)}
.syl-chapter.ch-complete{
  border-color:rgba(52,211,153,.25);
  background:rgba(52,211,153,.03);
}
.syl-chapter.ch-complete:hover{border-color:rgba(52,211,153,.35)}

/* Chapter number badge */
.ch-num{
  width:26px;height:26px;border-radius:7px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk',sans-serif;font-size:10px;font-weight:700;
  background:var(--sf2);border:1px solid var(--bd2);color:var(--mu);
  transition:all .2s;
}
.syl-chapter:hover .ch-num{background:var(--sf3)}
.syl-chapter.ch-complete .ch-num{background:rgba(52,211,153,.12);border-color:rgba(52,211,153,.25);color:var(--gn)}

/* Chapter info */
.ch-info{flex:1;min-width:0}
.ch-name{font-size:13px;font-weight:500;line-height:1.3;margin-bottom:4px;transition:color .2s}
.syl-chapter.ch-complete .ch-name{color:var(--gn)}
.ch-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.ch-class-badge{
  font-size:9.5px;font-weight:700;padding:1px 6px;border-radius:4px;
  letter-spacing:.04em;
}
.ch-class-11{background:rgba(124,106,247,.12);color:var(--ac2);border:1px solid rgba(124,106,247,.18)}
.ch-class-12{background:rgba(45,212,191,.1);color:var(--tl);border:1px solid rgba(45,212,191,.18)}

/* ADV-only badge */
.ch-adv-badge{
  display:inline-flex;align-items:center;gap:3px;
  font-size:9px;font-weight:800;padding:1px 6px;border-radius:4px;
  letter-spacing:.06em;
  background:linear-gradient(135deg,rgba(251,191,36,.15),rgba(251,191,36,.08));
  color:#fbbf24;border:1px solid rgba(251,191,36,.35);
  animation:badgeIn .3s cubic-bezier(.34,1.56,.64,1);
}
.ch-adv-badge svg{flex-shrink:0}

/* Subtle left-border highlight for adv-only chapters */
.ch-adv-only{border-left:2px solid rgba(251,191,36,.4)!important;}

/* Adv Only filter tab accent */
.syl-ftab-adv.active{
  background:linear-gradient(135deg,rgba(251,191,36,.18),rgba(251,191,36,.08))!important;
  color:#fbbf24!important;border-color:rgba(251,191,36,.35)!important;
}

/* Toggle pills */
.ch-toggles{display:flex;gap:6px;flex-shrink:0}
.ch-toggle{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 10px;border-radius:8px;border:1.5px solid var(--bd2);
  cursor:pointer;font-size:11px;font-weight:500;
  font-family:'DM Sans',sans-serif;
  background:transparent;color:var(--mu);
  transition:all .18s cubic-bezier(.34,1.4,.64,1);
}
.ch-toggle:hover{border-color:var(--ac2);color:var(--tx)}
.ch-toggle.tog-on{
  font-weight:600;
  animation:togPop .25s cubic-bezier(.34,1.56,.64,1);
}
@keyframes togPop{0%{transform:scale(.9)}60%{transform:scale(1.06)}100%{transform:scale(1)}}
.ch-toggle.tog-theory.tog-on{background:rgba(96,165,250,.12);border-color:rgba(96,165,250,.35);color:#60a5fa}
.ch-toggle.tog-practice.tog-on{background:rgba(244,114,182,.1);border-color:rgba(244,114,182,.3);color:var(--pk)}
.ch-toggle-dot{width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.5;transition:opacity .18s}
.ch-toggle.tog-on .ch-toggle-dot{opacity:1}

/* Completion badge */
.ch-done-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 8px;border-radius:6px;
  background:rgba(52,211,153,.12);color:var(--gn);
  border:1px solid rgba(52,211,153,.22);
  font-size:10px;font-weight:600;
  animation:badgeIn .3s cubic-bezier(.34,1.56,.64,1);
}
@keyframes badgeIn{from{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}

/* ── ADV include toggle ── */
.syl-adv-toggle{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;user-select:none;
}
.syl-adv-toggle input{display:none}
.syl-adv-track{
  position:relative;width:34px;height:20px;border-radius:99px;
  background:var(--sf3);border:1px solid var(--bd2);
  transition:background .2s,border-color .2s;flex-shrink:0;
}
.syl-adv-toggle input:checked ~ .syl-adv-track{
  background:rgba(251,191,36,.25);border-color:rgba(251,191,36,.5);
}
.syl-adv-thumb{
  position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;
  background:var(--mu);transition:transform .2s,background .2s;
}
.syl-adv-toggle input:checked ~ .syl-adv-track .syl-adv-thumb{
  transform:translateX(14px);background:#fbbf24;
}
.syl-adv-label{
  display:inline-flex;align-items:center;gap:4px;
  font-size:11.5px;font-weight:600;color:var(--mu);
  transition:color .2s;
}
.syl-adv-toggle:has(input:checked) .syl-adv-label{color:#fbbf24}

/* ── Unit accordion ── */
.syl-unit{margin-bottom:6px}
.syl-unit-hd{
  display:flex;align-items:center;justify-content:space-between;
  padding:.65rem .9rem;border-radius:12px;cursor:pointer;
  background:var(--sf);border:1px solid var(--bd);
  transition:border-color .18s,background .18s;
  user-select:none;
}
.syl-unit-hd:hover{background:var(--sf2);border-color:var(--bd2)}
.syl-unit-hd.open{border-radius:12px 12px 0 0;border-bottom-color:transparent}
.syl-unit-hd-left{display:flex;align-items:center;gap:10px}
.syl-unit-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.syl-unit-title{font-size:13px;font-weight:700;line-height:1.2}
.syl-unit-meta{font-size:10px;color:var(--mu);margin-top:2px}
.syl-unit-hd-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.syl-unit-prog-wrap{display:flex;align-items:center;gap:6px}
.syl-unit-prog-bar{width:56px;height:3px;border-radius:99px;background:var(--sf3)}
.syl-unit-prog-fill{height:100%;border-radius:99px;transition:width .4s}
.syl-unit-pct{font-size:10px;font-weight:700;font-family:'DM Mono',monospace;min-width:28px;text-align:right}
.syl-unit-chevron{opacity:.5;transition:transform .22s,opacity .18s;flex-shrink:0}
.syl-unit-hd.open .syl-unit-chevron{transform:rotate(180deg);opacity:.8}
.syl-unit-body{overflow:hidden;max-height:2000px;transition:max-height .28s cubic-bezier(.4,0,.2,1)}
.syl-unit-body.collapsed{max-height:0}
.syl-unit-body-inner{
  border:1px solid var(--bd);border-top:none;
  border-radius:0 0 12px 12px;
  overflow:hidden;
}
.syl-section-hd{
  display:flex;align-items:center;justify-content:space-between;
  padding:.6rem .85rem;border-radius:10px;cursor:pointer;
  background:var(--sf);border:1px solid var(--bd);
  margin-bottom:5px;margin-top:12px;
  transition:border-color .2s,background .2s;
  user-select:none;
}
.syl-section-hd:first-child{margin-top:0}
.syl-section-hd:hover{background:var(--sf2);border-color:rgba(255,255,255,.1)}
.syl-section-hd-left{display:flex;align-items:center;gap:9px}
.syl-section-hd-icon{
  width:30px;height:30px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.syl-section-hd-title{font-size:13px;font-weight:700}
.syl-section-hd-prog{
  display:inline-flex;align-items:center;gap:5px;
  font-family:'Space Grotesk',sans-serif;font-size:10.5px;font-weight:600;
  padding:2px 9px;border-radius:99px;
}
.syl-section-chevron{
  width:20px;height:20px;display:flex;align-items:center;justify-content:center;
  border-radius:5px;background:var(--sf2);color:var(--mu);
  transition:transform .25s cubic-bezier(.4,0,.2,1),background .18s;
  flex-shrink:0;
}
.syl-section-hd.expanded .syl-section-chevron{transform:rotate(90deg)}
.syl-section-body{overflow:hidden;transition:all .28s cubic-bezier(.4,0,.2,1)}
.syl-section-body.collapsed{display:none}
.syl-section-body-inner{padding:3px 0 3px 8px;border-left:2px solid transparent;margin-left:4px}

/* Stagger chapters */
.syl-chapter:nth-child(1){animation-delay:.03s}
.syl-chapter:nth-child(2){animation-delay:.06s}
.syl-chapter:nth-child(3){animation-delay:.09s}
.syl-chapter:nth-child(4){animation-delay:.12s}
.syl-chapter:nth-child(5){animation-delay:.15s}
.syl-chapter:nth-child(6){animation-delay:.18s}
.syl-chapter:nth-child(7){animation-delay:.21s}
.syl-chapter:nth-child(8){animation-delay:.24s}
.syl-chapter:nth-child(9){animation-delay:.27s}
.syl-chapter:nth-child(10){animation-delay:.3s}
.syl-chapter:nth-child(11){animation-delay:.33s}
.syl-chapter:nth-child(12){animation-delay:.36s}

@media(max-width:600px){
  .ch-toggles{flex-direction:column;gap:4px}
  .ch-toggle{padding:4px 8px;font-size:10.5px}
  .syl-hero-stats{grid-template-columns:repeat(2,1fr)}
  .syl-subj-bars{grid-template-columns:1fr}
}

/* === CSS Block (original lines 4496–4861) === */
/* ═══════════════════════════════════════════
   AI INSIGHTS — ULTRA PREMIUM
═══════════════════════════════════════════ */
#page-insights{position:relative;overflow:hidden}

/* Ambient animated background */
#page-insights::before{
  content:'';position:fixed;top:-40%;left:-20%;width:140%;height:140%;
  background:radial-gradient(ellipse 60% 50% at 20% 20%,rgba(124,106,247,.07) 0%,transparent 60%),
             radial-gradient(ellipse 50% 40% at 80% 80%,rgba(244,114,182,.06) 0%,transparent 55%),
             radial-gradient(ellipse 40% 35% at 50% 50%,rgba(45,212,191,.04) 0%,transparent 60%);
  pointer-events:none;z-index:0;animation:aiAmbient 8s ease-in-out infinite alternate;
}
@keyframes aiAmbient{
  0%{transform:translate(0,0) scale(1)}
  100%{transform:translate(1%,1.5%) scale(1.02)}
}
#page-insights .page-inner,
#page-insights>*:not(::before){position:relative;z-index:1}

/* ── Floating particles ── */
.ai-particle{position:absolute;border-radius:50%;pointer-events:none;animation:aiFloat linear infinite}
@keyframes aiFloat{0%{transform:translateY(100vh) rotate(0deg);opacity:0}10%{opacity:1}90%{opacity:.4}100%{transform:translateY(-120px) rotate(720deg);opacity:0}}

/* ── Empty State ── */
.ai-empty-wrap{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:70vh;text-align:center;padding:2rem 1rem;position:relative;
}
.ai-empty-orb{
  position:relative;width:130px;height:130px;margin:0 auto 2rem;
}
.ai-empty-orb-core{
  position:absolute;inset:0;border-radius:50%;
  background:linear-gradient(135deg,rgba(124,106,247,.18),rgba(244,114,182,.12));
  border:1px solid rgba(124,106,247,.25);
  display:flex;align-items:center;justify-content:center;
  animation:aiOrbPulse 3s ease-in-out infinite;
  box-shadow:0 0 60px rgba(124,106,247,.15),inset 0 0 30px rgba(124,106,247,.05);
}
.ai-empty-orb-ring{
  position:absolute;inset:-18px;border-radius:50%;
  border:1.5px solid rgba(124,106,247,.14);
  animation:aiOrbRing 3s ease-in-out infinite;
}
.ai-empty-orb-ring2{
  position:absolute;inset:-36px;border-radius:50%;
  border:1px solid rgba(244,114,182,.08);
  animation:aiOrbRing 3s ease-in-out infinite .6s;
}
.ai-empty-orb-ring3{
  position:absolute;inset:-54px;border-radius:50%;
  border:1px dashed rgba(124,106,247,.05);
  animation:aiOrbRing 4s ease-in-out infinite 1s;
}
@keyframes aiOrbPulse{
  0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(124,106,247,.2),0 0 60px rgba(124,106,247,.15)}
  50%{transform:scale(1.05);box-shadow:0 0 40px 12px rgba(124,106,247,.1),0 0 80px rgba(124,106,247,.12)}
}
@keyframes aiOrbRing{
  0%,100%{transform:scale(1) rotate(0deg);opacity:1}
  50%{transform:scale(1.1) rotate(180deg);opacity:.4}
}
.ai-hero-title{
  font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;
  background:linear-gradient(135deg,#c8b8ff,#a695ff 40%,#f472b6);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  margin-bottom:.6rem;letter-spacing:-.02em;
  filter:drop-shadow(0 0 30px rgba(124,106,247,.4));
}
.ai-hero-sub{
  color:var(--mu);font-size:13px;max-width:380px;margin:0 auto 2rem;line-height:1.8;
}
/* Generate button */
.ai-gen-btn-wrap{
  position:relative;display:inline-flex;border-radius:16px;padding:2px;
  background:linear-gradient(135deg,#7c6af7,#a695ff,#f472b6,#a695ff,#7c6af7);
  background-size:300% 300%;animation:aiBtnGrad 3s linear infinite;
  box-shadow:0 8px 40px rgba(124,106,247,.4),0 2px 8px rgba(0,0,0,.3),0 0 80px rgba(124,106,247,.1);
}
.ai-gen-btn-wrap::before{
  content:'';position:absolute;inset:0;border-radius:16px;
  background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,.25) 50%,transparent 65%);
  background-size:200% 100%;animation:aiShimmer 2.2s ease-in-out infinite;pointer-events:none;z-index:3;
}
.ai-gen-btn{
  position:relative;z-index:2;display:inline-flex;align-items:center;gap:9px;
  padding:14px 40px;border-radius:14px;border:none;cursor:pointer;
  font-family:'Syne',sans-serif;font-size:15px;font-weight:700;
  background:linear-gradient(135deg,#1a1628,#130f1e);color:#e8e0ff;
  letter-spacing:.02em;transition:all .18s;
}
.ai-gen-btn:hover{background:linear-gradient(135deg,#231a38,#1c1429);color:#fff;letter-spacing:.04em}
.ai-gen-btn:active{transform:scale(.97)}
.ai-gen-btn:disabled{opacity:.55;cursor:not-allowed}
@keyframes aiBtnGrad{
  0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}
}
@keyframes aiShimmer{
  0%{background-position:200% 0}100%{background-position:-200% 0}
}
/* Feature pills */
.ai-feature-pills{display:flex;gap:7px;justify-content:center;flex-wrap:wrap;margin-top:1.8rem}
.ai-fpill{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;border-radius:99px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);
  font-size:11.5px;color:var(--mu);transition:all .25s;cursor:default;
}
.ai-fpill:hover{background:rgba(124,106,247,.12);border-color:rgba(124,106,247,.35);color:var(--ac2);transform:translateY(-1px)}
.ai-fpill svg{width:11px;height:11px;flex-shrink:0}

/* ── Loading State ── */
.ai-loading-wrap{
  display:none;flex-direction:column;align-items:center;justify-content:center;
  min-height:60vh;text-align:center;padding:2rem;
}
.ai-loading-spinner{
  position:relative;width:80px;height:80px;margin:0 auto 1.5rem;
}
.ai-ls-ring{
  position:absolute;inset:0;border-radius:50%;
  border:2px solid transparent;
  border-top-color:var(--ac2);
  animation:aiSpin 1s linear infinite;
}
.ai-ls-ring2{
  position:absolute;inset:9px;border-radius:50%;
  border:2px solid transparent;
  border-top-color:var(--pk);
  animation:aiSpin .75s linear infinite reverse;
}
.ai-ls-ring3{
  position:absolute;inset:18px;border-radius:50%;
  border:1.5px solid transparent;
  border-top-color:var(--tl);
  animation:aiSpin .55s linear infinite;
}
.ai-ls-dot{
  position:absolute;inset:30px;border-radius:50%;
  background:radial-gradient(circle,rgba(124,106,247,.5),transparent);
  animation:aiOrbPulse 1.5s ease-in-out infinite;
}
@keyframes aiSpin{to{transform:rotate(360deg)}}
.ai-loading-msg{
  font-family:'Syne',sans-serif;font-size:15px;font-weight:700;
  color:var(--ac2);margin-bottom:.5rem;
  animation:aiTextPulse 2s ease-in-out infinite;
}
@keyframes aiTextPulse{0%,100%{opacity:1}50%{opacity:.6}}
.ai-loading-sub{font-size:11.5px;color:var(--mu2);margin-bottom:.5rem}
.ai-loading-steps{display:flex;flex-direction:column;gap:4px;margin:12px 0;text-align:left;min-width:200px}
.ai-loading-step{font-size:11px;color:var(--mu2);display:flex;align-items:center;gap:7px;opacity:.4;transition:opacity .4s}
.ai-loading-step.active{opacity:1;color:var(--ac2)}
.ai-loading-step.done{opacity:.7;color:var(--gn)}
.ai-loading-step-dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.ai-prog-track{
  width:240px;height:3px;background:rgba(255,255,255,.07);
  border-radius:99px;margin:14px auto 0;overflow:hidden;
}
.ai-prog-fill{
  height:100%;border-radius:99px;
  background:linear-gradient(90deg,var(--ac),var(--pk),var(--tl));
  background-size:200% 100%;animation:aiProgShimmer 1.5s linear infinite;
  transition:width .6s cubic-bezier(.4,0,.2,1);width:0%;
}
@keyframes aiProgShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── Content: Overall Score Card ── */
.ai-verdict-card{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,rgba(18,14,36,.97),rgba(12,9,24,.99));
  border:1px solid rgba(124,106,247,.3);border-radius:22px;
  padding:1.8rem 2rem;margin-bottom:16px;
  box-shadow:0 4px 60px rgba(124,106,247,.15),0 1px 0 rgba(255,255,255,.06) inset;
  animation:aiCardIn .6s cubic-bezier(.34,1.1,.64,1) both;
}
.ai-verdict-card::before{
  content:'';position:absolute;inset:0;border-radius:22px;pointer-events:none;
  background:radial-gradient(ellipse 90% 70% at 75% 50%,rgba(124,106,247,.1) 0%,transparent 65%);
}
.ai-verdict-card::after{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,.03) 50%,transparent 65%);
  animation:aiCardShimmer 5s ease-in-out infinite;pointer-events:none;
}
@keyframes aiCardShimmer{0%{left:-100%}100%{left:220%}}
@keyframes aiCardIn{
  0%{opacity:0;transform:translateY(18px) scale(.97)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}
.ai-verdict-label{
  font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  color:rgba(166,149,255,.6);margin-bottom:.6rem;display:flex;align-items:center;gap:6px;
}
.ai-verdict-label::before{content:'';display:block;width:16px;height:1px;background:rgba(166,149,255,.3)}
.ai-verdict-text{
  font-family:'Syne',sans-serif;font-weight:700;font-size:1.05rem;
  color:var(--tx);line-height:1.6;position:relative;z-index:1;
}
.ai-score-ring-wrap{
  position:relative;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.ai-score-ring-svg{transform:rotate(-90deg);filter:drop-shadow(0 0 10px rgba(124,106,247,.3))}
.ai-score-ring-num{
  position:absolute;text-align:center;
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.8rem;
  line-height:1;color:var(--tx);
}
.ai-score-ring-label{
  position:absolute;bottom:12px;text-align:center;width:100%;
  font-size:9px;color:var(--mu);letter-spacing:.04em;
}
.ai-mom-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 10px;border-radius:99px;font-size:10.5px;font-weight:700;
  margin-top:8px;
}

/* ── Section label ── */
.ai-section-label{
  font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  color:rgba(122,121,144,.7);margin-bottom:9px;padding-left:2px;
  display:flex;align-items:center;gap:6px;
}
.ai-section-label::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.05)}

/* ── Insight cards ── */
.ai-ins-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:9px;margin-bottom:14px}
.ai-ins-card{
  border-radius:14px;padding:1rem 1.1rem;position:relative;overflow:hidden;
  border:1px solid transparent;transition:transform .2s,box-shadow .2s;
  animation:aiCardIn .5s cubic-bezier(.34,1.1,.64,1) both;
}
.ai-ins-card:hover{transform:translateY(-2px)}
@keyframes aiCardIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.ai-ins-type-good{background:rgba(52,211,153,.07);border-color:rgba(52,211,153,.18)}
.ai-ins-type-bad{background:rgba(248,113,113,.07);border-color:rgba(248,113,113,.18)}
.ai-ins-type-warn{background:rgba(251,191,36,.06);border-color:rgba(251,191,36,.18)}
.ai-ins-type-info{background:rgba(96,165,250,.07);border-color:rgba(96,165,250,.18)}
.ai-ins-accent{
  position:absolute;top:0;left:0;width:3px;height:100%;border-radius:14px 0 0 14px;
}
.ai-ins-tag{
  font-size:9px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  padding:2px 8px;border-radius:4px;flex-shrink:0;
}
.ai-ins-title{font-size:12.5px;font-weight:700;color:var(--tx);line-height:1.3}
.ai-ins-body{font-size:12px;color:var(--mu);line-height:1.65;margin-top:6px}
.ai-ins-metric{
  font-family:'Space Grotesk',sans-serif;font-size:10.5px;font-weight:700;
  padding:3px 9px;border-radius:5px;margin-top:8px;display:inline-block;
}

/* ── Subject Report Card ── */
.ai-subj-card{
  background:var(--sf);border:1px solid var(--bd);border-radius:18px;
  overflow:hidden;margin-bottom:14px;
}
.ai-subj-row{
  padding:1.1rem 1.3rem;border-bottom:1px solid var(--bd);
  position:relative;overflow:hidden;transition:background .2s;
  animation:aiCardIn .5s cubic-bezier(.34,1.1,.64,1) both;
}
.ai-subj-row:last-child{border-bottom:none}
.ai-subj-row:hover{background:rgba(124,106,247,.04)}
.ai-subj-icon{
  width:32px;height:32px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.ai-grade-badge{
  font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:12px;padding:3px 10px;border-radius:6px;
}
.ai-subj-bar-bg{
  height:4px;background:rgba(255,255,255,.06);border-radius:99px;
  overflow:hidden;margin:8px 0;
}
.ai-subj-bar-fill{
  height:100%;border-radius:99px;
  transition:width 1.2s cubic-bezier(.4,0,.2,1) .4s;width:0%;
}
.ai-subj-pct{
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:16px;
}

/* ── Flag cards ── */
.ai-flag-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-bottom:14px}
.ai-flag-card{
  border-radius:14px;padding:1rem 1.1rem;
  position:relative;overflow:hidden;
  animation:aiCardIn .5s cubic-bezier(.34,1.1,.64,1) both;
}
.ai-flag-label{
  font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px;
  display:flex;align-items:center;gap:5px;
}
.ai-flag-label svg{width:11px;height:11px}
.ai-flag-text{font-size:13px;color:var(--tx);line-height:1.65}

/* ── Action Plan ── */
.ai-action-card{
  background:linear-gradient(135deg,rgba(124,106,247,.06),rgba(244,114,182,.04));
  border:1px solid rgba(124,106,247,.18);border-radius:18px;
  padding:1.2rem 1.4rem;margin-bottom:14px;
  animation:aiCardIn .5s cubic-bezier(.34,1.1,.64,1) both;
}
.ai-action-item{
  display:flex;gap:12px;align-items:flex-start;
  padding:9px 0;border-bottom:1px solid rgba(255,255,255,.05);
}
.ai-action-item:last-child{border-bottom:none}
.ai-action-num{
  width:24px;height:24px;border-radius:8px;flex-shrink:0;margin-top:1px;
  background:linear-gradient(135deg,var(--ac),var(--ac2));
  display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:700;color:#fff;
}
.ai-action-text{font-size:13px;color:var(--tx);line-height:1.6}

/* ── Weekly Strategy ── */
.ai-weekly-card{
  background:linear-gradient(135deg,rgba(45,212,191,.06),rgba(96,165,250,.04));
  border:1px solid rgba(45,212,191,.2);border-radius:14px;
  padding:1rem 1.2rem;margin-bottom:14px;
  animation:aiCardIn .5s cubic-bezier(.34,1.1,.64,1) both;
}
.ai-weekly-label{
  font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;
  color:var(--tl);margin-bottom:7px;display:flex;align-items:center;gap:5px;
}
.ai-weekly-text{font-size:13px;color:var(--tx);line-height:1.7}

/* ── Refresh bar ── */
.ai-refresh-bar{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:16px;flex-wrap:wrap;gap:8px;
}
.ai-refresh-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 16px;border-radius:8px;border:1px solid rgba(124,106,247,.25);
  background:rgba(124,106,247,.08);color:var(--ac2);
  font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;
  cursor:pointer;transition:all .18s;
}
.ai-refresh-btn:hover{background:rgba(124,106,247,.16);border-color:rgba(124,106,247,.4)}
.ai-refresh-btn:active{transform:scale(.96)}
.ai-refresh-btn:disabled{opacity:.5;cursor:not-allowed}
.ai-ts{font-size:10.5px;color:var(--mu2)}

/* Staggered card animation delays */
.ai-ins-card:nth-child(1){animation-delay:.05s}
.ai-ins-card:nth-child(2){animation-delay:.1s}
.ai-ins-card:nth-child(3){animation-delay:.15s}
.ai-ins-card:nth-child(4){animation-delay:.2s}
.ai-ins-card:nth-child(5){animation-delay:.25s}
.ai-ins-card:nth-child(6){animation-delay:.3s}
.ai-ins-card:nth-child(7){animation-delay:.35s}
.ai-ins-card:nth-child(8){animation-delay:.4s}
.ai-ins-card:nth-child(9){animation-delay:.45s}
.ai-subj-row:nth-child(1){animation-delay:.15s}
.ai-subj-row:nth-child(2){animation-delay:.25s}
.ai-subj-row:nth-child(3){animation-delay:.35s}

/* === CSS Block (original lines 5698–5876) === */
/* ═══════════════ ULTRA PREMIUM PERMISSION MODAL ═══════════════ */
#modal-welcome {
  background: rgba(0,0,2,.9) !important;
  backdrop-filter: blur(32px) saturate(160%) !important;
  -webkit-backdrop-filter: blur(32px) saturate(160%) !important;
}
.wm-card {
  position: relative;
  background: linear-gradient(160deg, rgba(18,16,36,.98) 0%, rgba(11,9,24,1) 100%);
  border: none !important;
  border-radius: 20px !important;
  padding: 0 !important;
  width: min(360px, calc(100vw - 2rem));
  max-height: 90vh;
  overflow: hidden;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.07),
    0 32px 80px rgba(0,0,0,.8),
    0 0 60px rgba(124,106,247,.1),
    inset 0 1px 0 rgba(255,255,255,.05);
  animation: wmCardIn .45s cubic-bezier(.22,1.2,.36,1) both;
}
@keyframes wmCardIn {
  from { opacity:0; transform: scale(.92) translateY(20px); }
  to   { opacity:1; transform: scale(1) translateY(0); }
}

/* Subtle top accent line instead of spinning border */
.wm-border {
  position: absolute; top: 0; left: 0; right: 0; height: 1px; z-index: 1; pointer-events: none;
  background: linear-gradient(90deg, transparent 5%, rgba(166,149,255,.5) 35%, rgba(244,114,182,.4) 65%, transparent 95%);
}

/* Header section */
.wm-header {
  position: relative; z-index: 1;
  padding: 2rem 1.75rem 1rem;
  text-align: center;
}
.wm-icon-ring {
  position: relative;
  width: 60px; height: 60px;
  margin: 0 auto 1.1rem;
}
.wm-icon-ring-pulse {
  position: absolute; inset: -5px; border-radius: 50%;
  border: 1px solid rgba(124,106,247,.25);
  animation: wmRingPulse 2.4s ease-in-out infinite;
}
.wm-icon-ring-pulse2 {
  position: absolute; inset: -12px; border-radius: 50%;
  border: 1px solid rgba(124,106,247,.1);
  animation: wmRingPulse 2.4s ease-in-out infinite .5s;
}
@keyframes wmRingPulse {
  0%,100% { opacity:.5; transform: scale(1); }
  50%      { opacity:1; transform: scale(1.03); }
}
.wm-icon-core {
  width: 60px; height: 60px; border-radius: 16px;
  background: linear-gradient(135deg, rgba(124,106,247,.2), rgba(166,149,255,.08));
  border: 1px solid rgba(124,106,247,.25);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 24px rgba(124,106,247,.18), inset 0 1px 0 rgba(255,255,255,.08);
  position: relative; overflow: hidden;
}
.wm-icon-shimmer {
  position: absolute; inset: 0; border-radius: 16px;
  background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,.05) 50%, transparent 60%);
  animation: wmShimmer 3s ease-in-out infinite;
}
@keyframes wmShimmer { 0%{left:-100%} 100%{left:180%} }
.wm-title {
  font-family: 'Syne', sans-serif; font-weight: 800;
  font-size: 1.1rem; color: var(--tx); letter-spacing: -.02em;
  margin-bottom: .35rem;
}
.wm-sub {
  font-size: 12px; color: var(--mu); line-height: 1.6;
  max-width: 220px; margin: 0 auto;
}

/* Progress bar */
.wm-progress-track {
  position: relative; z-index: 1;
  padding: .9rem 1.75rem .6rem;
  display: flex; gap: 6px;
}
.wm-prog-seg {
  flex: 1; height: 2px; border-radius: 99px;
  background: rgba(255,255,255,.07);
  overflow: hidden; transition: all .35s;
}
.wm-prog-fill {
  height: 100%; border-radius: 99px; width: 0%;
  transition: width .6s cubic-bezier(.4,0,.2,1);
}
.wm-prog-seg.active .wm-prog-fill {
  width: 100%;
  background: linear-gradient(90deg, var(--ac), var(--ac2));
}
.wm-prog-seg.done .wm-prog-fill {
  width: 100%;
  background: var(--gn);
}

/* Feature pills */
.wm-features {
  position: relative; z-index: 1;
  padding: .1rem 1.75rem .85rem;
  display: flex; flex-wrap: wrap; gap: 5px;
}
.wm-feat-pill {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 10px; border-radius: 99px;
  font-size: 10.5px; font-weight: 500;
  border: 1px solid; background: transparent;
}
.wm-feat-pill.purple { border-color:rgba(166,149,255,.2); color:var(--ac2); background:rgba(124,106,247,.07); }
.wm-feat-pill.blue   { border-color:rgba(96,165,250,.2); color:var(--bl); background:rgba(96,165,250,.07); }
.wm-feat-pill.green  { border-color:rgba(52,211,153,.2); color:var(--gn); background:rgba(52,211,153,.07); }
.wm-feat-pill.amber  { border-color:rgba(251,191,36,.2); color:var(--am); background:rgba(251,191,36,.07); }

/* Action row */
.wm-actions {
  position: relative; z-index: 1;
  padding: 0 1.5rem 1.5rem;
  display: flex; gap: 8px;
}
.wm-btn-skip {
  padding: 10px 16px;
  border-radius: 10px; border: 1px solid rgba(255,255,255,.07);
  background: rgba(255,255,255,.03);
  color: var(--mu); font-family: 'DM Sans',sans-serif;
  font-size: 12.5px; font-weight: 500; cursor: pointer;
  transition: all .18s; white-space: nowrap;
}
.wm-btn-skip:hover { background: rgba(255,255,255,.06); color: var(--tx); }
.wm-btn-enable {
  flex: 1; padding: 11px 16px;
  border-radius: 10px; border: none;
  background: linear-gradient(135deg, #7c6af7, #a695ff);
  color: #fff; font-family: 'DM Sans',sans-serif;
  font-size: 13px; font-weight: 700; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 7px;
  box-shadow: 0 4px 20px rgba(124,106,247,.35);
  transition: all .18s;
  position: relative; overflow: hidden;
}
.wm-btn-enable::after {
  content:''; position:absolute; inset:0; border-radius:10px;
  background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,.1) 50%, transparent 60%);
  animation: wmBtnShimmer 2.5s ease-in-out infinite;
}
@keyframes wmBtnShimmer { 0%{left:-100%} 100%{left:180%} }
.wm-btn-enable:hover { transform: translateY(-1px); box-shadow: 0 6px 28px rgba(124,106,247,.5); }
.wm-btn-enable.blue-theme {
  background: linear-gradient(135deg, #3b82f6, #60a5fa);
  box-shadow: 0 4px 20px rgba(96,165,250,.35);
}
.wm-btn-enable.blue-theme:hover { box-shadow: 0 6px 28px rgba(96,165,250,.5); }

/* Divider */
.wm-divider {
  position: relative; z-index: 1;
  height: 1px; margin: 0 1.75rem .9rem;
  background: rgba(255,255,255,.05);
}

/* Secure badge */
.wm-secure-badge {
  position: relative; z-index: 1;
  display: flex; align-items: center; justify-content: center;
  gap: 5px; padding-bottom: .5rem;
  font-size: 10px; color: rgba(255,255,255,.18);
  letter-spacing: .03em;
}

/* === CSS Block (original lines 6259–6549) === */
/* ═══════════════ GRAND CELEBRATION — PREMIUM ═══════════════ */

/* ── Overlay ── */
.cel-grand-overlay {
  position: fixed; inset: 0; z-index: 900;
  display: none; align-items: center; justify-content: center;
  background: rgba(4, 2, 18, 0.94);
  /* No backdrop-filter — GPU killer on mobile */
  touch-action: none; /* prevent scroll bleed-through */
}
.cel-grand-overlay.show { display: flex; animation: celOverlayIn .35s ease both; }
@keyframes celOverlayIn { from { opacity: 0 } to { opacity: 1 } }

/* ── Static backdrop glow (no animation) ── */
.cel-backdrop-glow {
  position: fixed; inset: 0; pointer-events: none; z-index: 901;
  background:
    radial-gradient(ellipse 70% 50% at 30% 20%, rgba(124,106,247,.15) 0%, transparent 65%),
    radial-gradient(ellipse 50% 40% at 75% 80%, rgba(244,114,182,.1) 0%, transparent 60%);
}

/* Confetti canvas — below card, truly no pointer events */
#confetti-canvas {
  position: fixed; inset: 0;
  pointer-events: none !important;
  touch-action: none !important;
  z-index: 902;
  width: 100%; height: 100%;
}

/* ── Main card ── */
.cel-card {
  position: relative; z-index: 910;
  width: min(420px, 90vw);
  max-height: 90vh; overflow-y: auto; -webkit-overflow-scrolling: touch;
  background: linear-gradient(165deg, rgba(16,10,34,.99) 0%, rgba(10,6,22,1) 55%, rgba(12,8,28,.99) 100%);
  border: 1px solid rgba(166,149,255,.2);
  border-radius: 24px;
  padding: 2rem 1.75rem 1.6rem;
  text-align: center;
  /* will-change tells GPU to promote this to its own layer */
  will-change: transform;
  box-shadow: 0 32px 80px rgba(0,0,0,.8), 0 0 50px rgba(124,106,247,.12), inset 0 1px 0 rgba(255,255,255,.06);
  /* Simple GPU-only entrance */
  animation: cardEntrance .45s cubic-bezier(.22,1.3,.36,1) both;
  animation-delay: .08s;
}
@keyframes cardEntrance {
  0%  { opacity:0; transform: translateY(36px) scale(.95); }
  100%{ opacity:1; transform: translateY(0) scale(1); }
}

/* ── Icon stage ── */
.cel-icon-stage {
  position: relative; width: 90px; height: 90px;
  margin: 0 auto 1.2rem;
  animation: iconPop .4s cubic-bezier(.34,1.6,.64,1) .25s both;
}
@keyframes iconPop { from { opacity:0; transform: scale(0.3) } to { opacity:1; transform: scale(1) } }

/* Single lightweight pulse ring — opacity+transform only */
.cel-pulse-ring {
  position: absolute; inset: -8px; border-radius: 50%;
  border: 1.5px solid rgba(166,149,255,.35);
  animation: pulseOut 2.4s ease-out infinite;
  pointer-events: none; touch-action: none;
}
.cel-pr1 { animation-delay: 0s; }
@keyframes pulseOut {
  0%  { transform: scale(.88); opacity: .6; }
  100%{ transform: scale(1.5); opacity: 0; }
}

/* Icon core — static, no looping glow */
.cel-icon-core {
  width: 90px; height: 90px; border-radius: 50%;
  background: linear-gradient(135deg, rgba(124,106,247,.25), rgba(244,114,182,.15));
  border: 1.5px solid rgba(166,149,255,.3);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 30px rgba(124,106,247,.25), inset 0 1px 0 rgba(255,255,255,.08);
}
.cel-svg-icon { width: 46px; height: 46px; }

/* ── Exam pill ── */
.cel-exam-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px; border-radius: 99px;
  background: rgba(166,149,255,.08);
  border: 1px solid rgba(166,149,255,.2);
  font-size: 9.5px; font-weight: 700; letter-spacing: .1em;
  color: #c4b5fd; margin-bottom: .85rem;
  animation: fadeUp .35s ease .4s both;
}
.cel-pill-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: #a695ff;
  box-shadow: 0 0 5px #a695ff;
}

/* ── Title ── */
.cel-title {
  font-family: 'Syne', sans-serif; font-weight: 800;
  font-size: 1.5rem; letter-spacing: -.03em; line-height: 1.15;
  margin-bottom: .7rem; position: relative; z-index: 2;
  background: linear-gradient(120deg, #ffffff 0%, #c4b5fd 40%, #f472b6 80%, #fbbf24 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: fadeUp .35s ease .45s both;
}

/* ── Score block ── */
.cel-score-block {
  margin: 0 auto .9rem;
  animation: fadeUp .35s cubic-bezier(.34,1.4,.64,1) .5s both;
}
.cel-score-inner {
  display: flex; align-items: baseline; justify-content: center; gap: 4px;
  margin-bottom: .5rem;
}
.cel-score-num {
  font-family: 'Syne', sans-serif; font-weight: 900; font-size: 3.8rem;
  line-height: 1; letter-spacing: -.05em;
  background: linear-gradient(135deg, #ffffff 0%, #e9d5ff 40%, #a695ff 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 0 16px rgba(166,149,255,.4));
}
.cel-score-sep {
  font-family: 'Syne', sans-serif; font-size: 1.8rem; font-weight: 300;
  color: rgba(255,255,255,.2); line-height: 1; padding-bottom: .2rem;
}
.cel-score-max {
  font-family: 'Syne', sans-serif; font-size: 1.4rem; font-weight: 600;
  color: rgba(255,255,255,.3); line-height: 1;
}
.cel-score-bar-wrap { padding: 0 .4rem; }
.cel-score-bar-bg {
  height: 3px; border-radius: 99px;
  background: rgba(255,255,255,.07); overflow: hidden;
}
.cel-score-bar-fill {
  height: 100%; border-radius: 99px; width: 0;
  background: linear-gradient(90deg, #a695ff, #f472b6, #fbbf24);
  animation: barGrow .9s cubic-bezier(.4,0,.2,1) .8s forwards;
}
@keyframes barGrow { to { width: var(--cel-bar-w, 80%); } }

/* ── Sub text ── */
.cel-sub {
  font-size: 12.5px; color: rgba(255,255,255,.38); line-height: 1.6;
  margin-bottom: 1.1rem; max-width: 280px; margin-left: auto; margin-right: auto;
  animation: fadeUp .35s ease .65s both;
}

/* ── Stats strip ── */
.cel-stats-strip {
  display: flex; align-items: center; justify-content: center;
  gap: 0; margin-bottom: 1.1rem;
  background: rgba(124,106,247,.05);
  border: 1px solid rgba(166,149,255,.09);
  border-radius: 12px; padding: .75rem .9rem;
  animation: fadeUp .35s ease .72s both;
}
.cel-stat-item {
  display: flex; flex-direction: column; align-items: center; gap: 4px; flex: 1;
}
.cel-stat-item svg { opacity: .8; }
.cel-stat-val {
  font-family: 'Syne', sans-serif; font-size: .95rem; font-weight: 700;
  color: #e9d5ff; line-height: 1;
}
.cel-stat-key {
  font-size: 9px; color: rgba(255,255,255,.28); letter-spacing: .05em;
  text-transform: uppercase; font-weight: 600;
}
.cel-stat-sep {
  width: 1px; height: 32px; background: rgba(255,255,255,.07); flex-shrink: 0; margin: 0 .2rem;
}

/* ── Gradient divider ── */
.cel-grad-divider {
  height: 1px; margin: 0 -.4rem 1.1rem;
  background: linear-gradient(90deg, transparent, rgba(166,149,255,.18) 30%, rgba(244,114,182,.13) 70%, transparent);
  animation: fadeUp .35s ease .8s both;
}

/* ── Action row — big tap targets for mobile ── */
.cel-action-row {
  display: flex; gap: 8px; justify-content: center;
  animation: fadeUp .35s ease .85s both;
}
.cel-cta {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 24px; border-radius: 14px; border: none; cursor: pointer;
  font-family: 'DM Sans', sans-serif; font-size: 14px; font-weight: 700;
  color: #fff; letter-spacing: .02em;
  background: linear-gradient(135deg, #6c5ce7 0%, #a695ff 55%, #f472b6 100%);
  box-shadow: 0 6px 20px rgba(108,92,231,.4), inset 0 1px 0 rgba(255,255,255,.15);
  transition: transform .15s ease, box-shadow .15s ease;
  /* Larger touch target */
  min-height: 48px; position: relative; overflow: hidden;
}
.cel-cta:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(108,92,231,.6); }
.cel-cta:active { transform: scale(.96); }

.cel-share {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 14px 20px; border-radius: 14px; cursor: pointer;
  font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 600;
  color: rgba(255,255,255,.7);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  min-height: 48px;
  transition: background .15s, color .15s, transform .15s;
}
.cel-share:hover { background: rgba(255,255,255,.11); color: #fff; border-color: rgba(166,149,255,.35); transform: translateY(-1px); }
.cel-share:active { transform: scale(.96); }

/* ── Change Goal link ── */
.cel-change-goal-wrap {
  margin-top: .8rem; margin-bottom: .2rem;
  animation: fadeUp .4s ease 1.2s both;
}
.cel-change-goal-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 16px; border-radius: 99px; border: none; cursor: pointer;
  font-family: 'DM Sans', sans-serif; font-size: 11.5px; font-weight: 600;
  color: rgba(166,149,255,.7);
  background: rgba(124,106,247,.08);
  border: 1px solid rgba(124,106,247,.18);
  letter-spacing: .02em;
  transition: all .2s;
}
.cel-change-goal-btn:hover { background: rgba(124,106,247,.15); color: #a695ff; border-color: rgba(166,149,255,.35); transform: translateY(-1px); }
.cel-change-goal-btn:active { transform: scale(.96); }

/* ── Dismiss hint ── */
.cel-dismiss-hint {
  margin-top: .7rem; font-size: 10.5px; color: rgba(255,255,255,.13);
  letter-spacing: .04em; animation: fadeUp .4s ease 1.3s both;
}

/* ── Mini celebration animations (keep working) ── */
@keyframes miniSlideIn{0%{transform:translateX(110%) scale(.85) rotate(4deg);opacity:0}60%{transform:translateX(-6%) scale(1.04) rotate(-1deg);opacity:1}100%{transform:translateX(0) scale(1) rotate(0);opacity:1}}
@keyframes miniSlideOut{0%{transform:translateX(0) scale(1);opacity:1}100%{transform:translateX(110%) scale(.85);opacity:0}}
@keyframes floatEmoji{0%{transform:translateY(0) scale(1) rotate(0deg);opacity:1}100%{transform:translateY(-110px) scale(.2) rotate(60deg);opacity:0}}
@keyframes floatUp{0%{transform:translateY(0);opacity:1}80%{opacity:.6}100%{transform:translateY(-110vh);opacity:0}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.cel-score-anim{animation:scoreIn .5s cubic-bezier(.34,1.56,.64,1) forwards}
.mini-pulse-ring{position:absolute;inset:-6px;border-radius:50%;border:2px solid;animation:pulseOut .8s ease-out forwards}


/* ═══════════════════════════════════════════════════
   ULTRA PREMIUM MODALS — PMO System
═══════════════════════════════════════════════════ */

/* Backdrop */
.mo { position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:200;display:none;align-items:center;justify-content:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:1rem }
.mo.open { display:flex;animation:moFadeIn .22s ease }

/* Card */
.pmo {
  position:relative;background:linear-gradient(160deg,rgba(24,24,32,.98),rgba(16,16,22,.99));
  border:1px solid rgba(255,255,255,.09);border-radius:22px;
  padding:1.6rem 1.6rem 1.4rem;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;
  box-shadow:0 32px 80px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.04),inset 0 1px 0 rgba(255,255,255,.06);
  animation:pmoSlideUp .3s cubic-bezier(.34,1.2,.64,1);
  scrollbar-width:none;
}
.pmo::-webkit-scrollbar{display:none}

/* Glows */
.pmo-glow {position:absolute;top:-60px;border-radius:50%;filter:blur(70px);opacity:.28;pointer-events:none;z-index:0}
.pmo-glow-violet {width:260px;height:160px;left:20%;background:radial-gradient(ellipse,#7c6af7,transparent 70%)}
.pmo-glow-blue   {width:260px;height:160px;left:20%;background:radial-gradient(ellipse,#3b82f6,transparent 70%)}
.pmo-glow-pink   {width:260px;height:160px;left:20%;background:radial-gradient(ellipse,#f472b6,transparent 70%)}
.pmo-glow-green  {width:260px;height:160px;left:20%;background:radial-gradient(ellipse,#34d399,transparent 70%)}
.pmo-glow-amber  {width:260px;height:160px;left:20%;background:radial-gradient(ellipse,#fbbf24,transparent 70%)}

/* Close btn */
.pmo-close {
  position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:50%;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);cursor:pointer;
  display:flex;align-items:center;justify-content:center;color:var(--mu);
  transition:all .15s;z-index:10
}
.pmo-close:hover {background:rgba(248,113,113,.15);color:#f87171;border-color:rgba(248,113,113,.3);transform:scale(1.08)}

/* Header */
.pmo-header { display:flex;align-items:center;gap:14px;margin-bottom:18px;position:relative;z-index:1 }
.pmo-icon-wrap {
  width:52px;height:52px;border-radius:16px;border:1px solid;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  position:relative;overflow:hidden
}
.pmo-icon-wrap::after {
  content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.08),transparent);
  border-radius:inherit;pointer-events:none
}
.pmo-title { font-family:'Syne',sans-serif;font-weight:800;font-size:1.1rem;color:var(--tx);letter-spacing:-.02em;line-height:1.2 }
.pmo-sub   { font-size:11.5px;color:var(--mu);margin-top:2px;line-height:1.4 }

/* Labels & Inputs */
.pmo-label {
  font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  color:var(--mu);margin-bottom:5px;display:block
}
.pmo-label-phy  { color:#60a5fa }
.pmo-label-chem { color:#34d399 }
.pmo-label-math { color:#fbbf24 }

.pmo-input {
  width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  color:var(--tx);border-radius:10px;padding:9px 12px;
  font-family:'DM Sans',sans-serif;font-size:13.5px;outline:none;
  transition:border-color .18s,box-shadow .18s,background .18s;box-sizing:border-box
}
.pmo-input:focus {
  border-color:rgba(124,106,247,.6);background:rgba(124,106,247,.06);
  box-shadow:0 0 0 3px rgba(124,106,247,.12)
}
.pmo-input::placeholder { color:rgba(255,255,255,.22) }
.pmo-input-lg  { font-size:14.5px;padding:10px 13px }
.pmo-input-xl  { font-size:28px;font-weight:700;font-family:'Syne',sans-serif;text-align:center;padding:12px;letter-spacing:-.02em }
.pmo-input-total { font-size:17px;font-weight:700;font-family:'Syne',sans-serif;letter-spacing:-.01em }
.pmo-score-inp { font-size:20px;font-weight:700;font-family:'Syne',sans-serif;text-align:center;letter-spacing:-.02em;padding:10px 8px }

/* Grids */
.pmo-field  { display:flex;flex-direction:column;position:relative;z-index:1 }
.pmo-field-full { grid-column:span 2 }
.pmo-grid2  { display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px }
.pmo-grid3  { display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px }

/* Pill row (exam selector etc) */
.pmo-pill-row { display:flex;gap:6px;flex-wrap:wrap }
.pmo-pill {
  flex:1;padding:7px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.04);color:var(--mu);font-family:'DM Sans',sans-serif;
  font-size:12.5px;font-weight:600;cursor:pointer;transition:all .18s;white-space:nowrap;
  -webkit-tap-highlight-color:transparent
}
.pmo-pill.active {
  background:linear-gradient(135deg,rgba(124,106,247,.25),rgba(166,149,255,.15));
  border-color:rgba(124,106,247,.5);color:var(--ac2);
  box-shadow:0 0 0 1px rgba(124,106,247,.2)
}
.pmo-pill-sm { flex:none;padding:5px 10px;font-size:11.5px }

/* Subject pills */
.pmo-subj-pills { display:flex;gap:6px }
.pmo-subj-pill {
  flex:1;padding:8px 6px;border-radius:10px;border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);color:var(--mu);font-family:'DM Sans',sans-serif;
  font-size:12px;font-weight:600;cursor:pointer;transition:all .18s;text-align:center;
  -webkit-tap-highlight-color:transparent
}
.pmo-subj-phy.active  { background:rgba(96,165,250,.15);border-color:rgba(96,165,250,.45);color:#60a5fa;box-shadow:0 0 16px rgba(96,165,250,.15) }
.pmo-subj-chem.active { background:rgba(52,211,153,.15);border-color:rgba(52,211,153,.45);color:#34d399;box-shadow:0 0 16px rgba(52,211,153,.15) }
.pmo-subj-math.active { background:rgba(251,191,36,.15);border-color:rgba(251,191,36,.45);color:#fbbf24;box-shadow:0 0 16px rgba(251,191,36,.15) }

/* Priority buttons */
.pmo-pri-row { display:flex;gap:5px }
.pmo-pri-btn {
  flex:1;padding:6px 4px;border-radius:8px;border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);color:var(--mu);font-size:11px;font-weight:600;
  cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent
}
.pmo-pri-high.active { background:rgba(248,113,113,.15);border-color:rgba(248,113,113,.45);color:#f87171 }
.pmo-pri-med.active  { background:rgba(251,191,36,.15);border-color:rgba(251,191,36,.45);color:#fbbf24 }
.pmo-pri-low.active  { background:rgba(52,211,153,.15);border-color:rgba(52,211,153,.45);color:#34d399 }

/* Score section */
.pmo-score-section {
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);
  border-radius:14px;padding:14px;margin-bottom:4px;position:relative;z-index:1
}
.pmo-score-header { display:flex;justify-content:space-between;align-items:center;margin-bottom:8px }
.pmo-section-label { font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--mu) }
.pmo-live-pct { font-family:'Syne',sans-serif;font-weight:800;font-size:1rem;background:linear-gradient(135deg,#a695ff,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text }
.pmo-score-bar-wrap { height:4px;background:rgba(255,255,255,.07);border-radius:99px;overflow:hidden;margin-bottom:12px }
.pmo-score-bar-fill { height:100%;background:linear-gradient(90deg,#7c6af7,#f472b6);border-radius:99px;transition:width .4s cubic-bezier(.34,1.2,.64,1);min-width:0 }

/* Hours cards */
.pmo-hours-grid { display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:8px }
.pmo-hrs-card {
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:12px;padding:10px 8px;display:flex;flex-direction:column;align-items:center;gap:4px;
  transition:border-color .18s
}
.pmo-hrs-lec:focus-within  { border-color:rgba(96,165,250,.4);background:rgba(96,165,250,.07) }
.pmo-hrs-prac:focus-within { border-color:rgba(52,211,153,.4);background:rgba(52,211,153,.07) }
.pmo-hrs-rev:focus-within  { border-color:rgba(166,149,255,.4);background:rgba(166,149,255,.07) }
.pmo-hrs-label { font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--mu);display:flex;align-items:center;gap:3px }
.pmo-hrs-inp {
  width:100%;background:transparent;border:none;color:var(--tx);
  font-family:'Syne',sans-serif;font-size:22px;font-weight:800;text-align:center;
  outline:none;padding:2px 0
}
.pmo-hrs-inp::placeholder { color:rgba(255,255,255,.18);font-size:22px }
.pmo-hrs-unit { font-size:10px;color:var(--mu);font-weight:600 }

.pmo-total-pill {
  display:flex;align-items:center;gap:6px;background:rgba(124,106,247,.08);
  border:1px solid rgba(124,106,247,.2);border-radius:99px;
  padding:6px 14px;font-size:12.5px;color:var(--mu);font-weight:500;
  width:fit-content;margin:0 auto 4px;position:relative;z-index:1
}

/* Section label */
.pmo-section-label { font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--mu) }

/* Footer */
.pmo-footer {
  display:flex;gap:8px;justify-content:flex-end;margin-top:18px;
  padding-top:14px;border-top:1px solid rgba(255,255,255,.06);
  position:relative;z-index:1
}
.pmo-btn-cancel {
  padding:9px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.04);color:var(--mu);font-family:'DM Sans',sans-serif;
  font-size:13px;font-weight:600;cursor:pointer;transition:all .18s;
  -webkit-tap-highlight-color:transparent
}
.pmo-btn-cancel:hover { background:rgba(255,255,255,.08);color:var(--tx);border-color:rgba(255,255,255,.18) }
.pmo-btn-save {
  padding:9px 20px;border-radius:10px;border:none;
  background:linear-gradient(135deg,#7c6af7,#a695ff);
  color:#fff;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;
  cursor:pointer;display:flex;align-items:center;gap:7px;
  box-shadow:0 4px 18px rgba(124,106,247,.4);transition:all .18s;letter-spacing:.01em;
  -webkit-tap-highlight-color:transparent
}
.pmo-btn-save:hover { transform:translateY(-1px);box-shadow:0 6px 24px rgba(124,106,247,.55) }
.pmo-btn-save:active { transform:translateY(0) scale(.97) }

/* Mobile sheet style */
@media(max-width:768px){
  .mo { align-items:flex-end!important;padding:0 }
  .pmo {
    border-radius:22px 22px 0 0;max-height:88vh;max-width:100%;width:100%;
    padding:1.2rem 1.2rem 2rem;animation:pmoSheetUp .3s cubic-bezier(.4,0,.2,1)
  }
  .pmo-glow { display:none }
  .pmo-hours-grid { grid-template-columns:1fr 1fr 1fr }
  .pmo-grid3 { grid-template-columns:1fr 1fr 1fr }
  .pmo-grid2 { grid-template-columns:1fr 1fr }
}
@media(max-width:380px){
  .pmo-subj-pills { flex-direction:column }
  .pmo-hours-grid { grid-template-columns:1fr }
  .pmo-grid2 { grid-template-columns:1fr }
  .pmo-grid3 { grid-template-columns:1fr 1fr }
}
@keyframes pmoSlideUp { from{opacity:0;transform:translateY(24px) scale(.97)} to{opacity:1;transform:none} }
@keyframes pmoSheetUp { from{transform:translateY(100%)} to{transform:none} }
