/* ============================================================
   LIFE OS — design system
   dark + cyan glow, inspired by WHOOP + FitApp aesthetic
   ============================================================ */
:root{
  --bg:#05070d;
  --bg2:#0a0e18;
  --panel:rgba(17,23,38,.62);
  --panel-solid:#0e1320;
  --stroke:rgba(120,160,220,.12);
  --stroke-2:rgba(120,160,220,.22);
  --txt:#eaf2ff;
  --muted:#8a98b5;
  --faint:#5b6783;
  --cyan:#00e5ff;
  --cyan-d:#00a6c4;
  --blue:#3b82f6;
  --violet:#8b5cf6;
  --green:#22e6a4;
  --amber:#ffb020;
  --red:#ff5c7a;
  --pink:#ff4fa3;
  --glow:0 0 22px rgba(0,229,255,.45);
  --r:20px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);
  color:var(--txt);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  position:relative;
}
::selection{background:rgba(0,229,255,.3);color:#fff}
a{color:inherit;text-decoration:none}

/* ---- background ---- */
#aurora{position:fixed;inset:0;width:100%;height:100%;z-index:-2;opacity:.9}
body:after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(1200px 600px at 80% -10%,rgba(0,229,255,.10),transparent 60%),
             radial-gradient(900px 500px at -10% 110%,rgba(139,92,246,.10),transparent 55%);}
.grain{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.035;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ---- boot ---- */
#boot{position:fixed;inset:0;z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;
  background:radial-gradient(circle at 50% 40%,#0a1020,#05070d 70%);transition:opacity .6s var(--ease),visibility .6s}
#boot.gone{opacity:0;visibility:hidden}
.boot-ring{position:relative;width:96px;height:96px}
.boot-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.boot-ring .bt{fill:none;stroke:rgba(255,255,255,.08);stroke-width:5}
.boot-ring .bf{fill:none;stroke:var(--cyan);stroke-width:5;stroke-linecap:round;stroke-dasharray:276;stroke-dashoffset:276;
  filter:drop-shadow(0 0 8px var(--cyan));animation:bootspin 1.4s var(--ease) forwards}
@keyframes bootspin{to{stroke-dashoffset:40}}
.boot-ring span{position:absolute;inset:0;display:grid;place-items:center;font-weight:800;color:var(--cyan);letter-spacing:1px}
.boot-name{font-weight:900;font-size:30px;letter-spacing:8px;background:linear-gradient(90deg,#fff,var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.boot-bar{width:180px;height:3px;border-radius:3px;background:rgba(255,255,255,.08);overflow:hidden}
.boot-bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--cyan),var(--violet));animation:bootbar 1.5s var(--ease) forwards;box-shadow:var(--glow)}
@keyframes bootbar{to{width:100%}}
.boot-status{font:600 12px 'JetBrains Mono',monospace;color:var(--faint);letter-spacing:1px}

/* ---- shell layout ---- */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh;opacity:0;transition:opacity .6s var(--ease)}
.shell.ready{opacity:1}

/* ---- sidebar ---- */
.sidebar{position:sticky;top:0;height:100vh;padding:22px 16px;display:flex;flex-direction:column;gap:8px;
  background:linear-gradient(180deg,rgba(10,14,24,.6),rgba(7,9,15,.3));backdrop-filter:blur(18px);
  border-right:1px solid var(--stroke)}
.brand{display:flex;align-items:center;gap:12px;padding:6px 8px 18px}
.brand-mark{width:38px;height:38px;color:var(--cyan);filter:drop-shadow(var(--glow));animation:spin 18s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.brand-text b{display:block;font-weight:900;letter-spacing:3px;font-size:15px}
.brand-text span{font:600 10px 'JetBrains Mono',monospace;color:var(--green);letter-spacing:1px}
.nav{display:flex;flex-direction:column;gap:4px;flex:1}
.nav button{display:flex;align-items:center;gap:13px;padding:12px 14px;border:0;border-radius:14px;background:transparent;color:var(--muted);
  font:600 14px 'Inter';cursor:pointer;text-align:left;position:relative;transition:.25s var(--ease)}
.nav button .ico{width:20px;height:20px;flex:none;display:grid;place-items:center;transition:.25s}
.nav button .ico svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.9}
.nav button:hover{background:rgba(255,255,255,.04);color:var(--txt)}
.nav button.on{background:linear-gradient(90deg,rgba(0,229,255,.16),rgba(0,229,255,.02));color:#fff}
.nav button.on .ico{color:var(--cyan);filter:drop-shadow(0 0 6px rgba(0,229,255,.6))}
.nav button.on:before{content:"";position:absolute;left:0;top:9px;bottom:9px;width:3px;border-radius:3px;background:var(--cyan);box-shadow:var(--glow)}
.nav .badge{margin-left:auto;font:700 10px 'JetBrains Mono';padding:2px 7px;border-radius:20px;background:rgba(0,229,255,.14);color:var(--cyan)}
.sidebar-foot{padding-top:12px;border-top:1px solid var(--stroke)}
.streak-chip{display:flex;align-items:center;gap:7px;padding:11px 13px;border-radius:14px;background:rgba(255,176,32,.08);color:var(--amber);font:600 13px 'Inter';border:1px solid rgba(255,176,32,.18)}
.streak-chip b{font-weight:900;font-size:15px}
.flame{animation:flicker 1.6s ease-in-out infinite}
@keyframes flicker{0%,100%{transform:scale(1) rotate(-2deg);opacity:1}50%{transform:scale(1.15) rotate(3deg);opacity:.85}}

/* ---- main ---- */
.main{padding:26px 32px 60px;max-width:1280px;width:100%}
.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:26px}
.hello h1{font-size:30px;font-weight:800;letter-spacing:-.5px}
.hello #subline{color:var(--muted);font-size:14px;margin-top:5px;max-width:46ch}
.topbar-right{display:flex;align-items:center;gap:14px}
.clock{font:700 18px 'JetBrains Mono';color:var(--txt);letter-spacing:1px}
.live{display:flex;align-items:center;gap:7px;font:600 11px 'JetBrains Mono';color:var(--green);letter-spacing:.5px}
.live i{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.8)}}
.end-day{padding:10px 18px;border-radius:12px;border:1px solid var(--stroke-2);background:rgba(255,255,255,.03);color:var(--txt);
  font:700 13px 'Inter';cursor:pointer;transition:.25s}
.end-day:hover{background:var(--cyan);color:#04121a;border-color:var(--cyan);box-shadow:var(--glow)}

/* ---- views ---- */
.view{display:none}
.view.on{display:block;animation:viewin .5s var(--ease)}
@keyframes viewin{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.section-title{display:flex;align-items:center;gap:10px;margin:26px 2px 14px;font-size:13px;font-weight:800;letter-spacing:2px;color:var(--faint);text-transform:uppercase}
.section-title:first-child{margin-top:0}
.section-title .ln{flex:1;height:1px;background:linear-gradient(90deg,var(--stroke),transparent)}

/* grid */
.grid{display:grid;gap:16px}
.g-12{grid-template-columns:repeat(12,1fr)}
.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-5{grid-column:span 5}
.col-6{grid-column:span 6}.col-7{grid-column:span 7}.col-8{grid-column:span 8}.col-12{grid-column:span 12}

/* ---- card ---- */
.card{background:var(--panel);border:1px solid var(--stroke);border-radius:var(--r);padding:18px;backdrop-filter:blur(16px);
  position:relative;overflow:hidden;transition:transform .3s var(--ease),border-color .3s,box-shadow .3s}
.card:before{content:"";position:absolute;inset:0;border-radius:var(--r);padding:1px;pointer-events:none;
  background:linear-gradient(140deg,rgba(255,255,255,.10),transparent 40%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.7}
.card:hover{transform:translateY(-4px);border-color:var(--stroke-2);box-shadow:0 18px 50px rgba(0,0,0,.45)}
.card.glow:hover{box-shadow:0 18px 50px rgba(0,0,0,.45),0 0 30px rgba(0,229,255,.12)}
.reveal{opacity:0;transform:translateY(18px);animation:reveal .6s var(--ease) forwards}
@keyframes reveal{to{opacity:1;transform:none}}

.card-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card-h h3{font-size:13px;font-weight:700;color:var(--muted);letter-spacing:.4px;display:flex;align-items:center;gap:8px}
.card-h .ic{width:16px;height:16px;opacity:.8}
.tag{font:700 10px 'JetBrains Mono';padding:3px 8px;border-radius:8px;letter-spacing:.5px}
.tag.up{background:rgba(34,230,164,.14);color:var(--green)}
.tag.down{background:rgba(255,92,122,.14);color:var(--red)}
.tag.neutral{background:rgba(138,152,181,.14);color:var(--muted)}

/* big metric */
.metric .num{font-size:40px;font-weight:800;letter-spacing:-1.5px;line-height:1}
.metric .unit{font-size:15px;color:var(--muted);font-weight:600;margin-left:4px}
.metric .lbl{color:var(--faint);font-size:12px;margin-top:6px;font-weight:600;text-transform:uppercase;letter-spacing:1px}

/* ---- hero gauge ---- */
.hero{display:flex;gap:26px;align-items:center}
.gauge{position:relative;width:230px;height:230px;flex:none}
.gauge svg{width:100%;height:100%;transform:rotate(-90deg)}
.gauge .track{fill:none;stroke:rgba(255,255,255,.06);stroke-width:14}
.gauge .fill{fill:none;stroke:url(#gaugeGrad);stroke-width:14;stroke-linecap:round;filter:drop-shadow(0 0 10px rgba(0,229,255,.5));transition:stroke-dashoffset 1.4s var(--ease)}
.gauge .center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.gauge .score{font-size:62px;font-weight:900;letter-spacing:-3px;line-height:1;background:linear-gradient(180deg,#fff,#bfe9ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.gauge .score small{font-size:22px;font-weight:700;color:var(--cyan);-webkit-text-fill-color:var(--cyan)}
.gauge .cap{font:700 11px 'JetBrains Mono';color:var(--faint);letter-spacing:2px;margin-top:4px}
.hero-side{flex:1;display:flex;flex-direction:column;gap:12px}
.hero-side .state{font-size:22px;font-weight:800}
.hero-side .desc{color:var(--muted);font-size:13.5px;line-height:1.5}
.mini-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:6px}
.mini-stats .ms{background:rgba(255,255,255,.03);border:1px solid var(--stroke);border-radius:14px;padding:12px}
.mini-stats .ms b{font-size:22px;font-weight:800;display:block}
.mini-stats .ms span{font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:1px;font-weight:600}

/* ---- ring mini ---- */
.ring{position:relative;width:84px;height:84px;flex:none}
.ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.ring .t{fill:none;stroke:rgba(255,255,255,.07);stroke-width:9}
.ring .f{fill:none;stroke-width:9;stroke-linecap:round;transition:stroke-dashoffset 1.3s var(--ease)}
.ring .v{position:absolute;inset:0;display:grid;place-items:center;font-weight:800;font-size:19px}
.ringcard{display:flex;align-items:center;gap:16px}
.ringcard .meta b{font-size:15px;font-weight:700;display:block}
.ringcard .meta span{font-size:12px;color:var(--muted)}
.ringcard .meta .d{margin-top:4px;font:700 11px 'JetBrains Mono'}

/* ---- metric bar rows (WHOOP style) ---- */
.bars{display:flex;flex-direction:column;gap:2px}
.barrow{display:grid;grid-template-columns:26px 1fr 64px;align-items:center;gap:14px;padding:13px 4px;border-top:1px solid var(--stroke)}
.barrow:first-child{border-top:0}
.barrow .bi{width:26px;height:26px;display:grid;place-items:center;color:var(--muted)}
.barrow .bi svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8}
.barrow .bl{font-size:13.5px;font-weight:600}
.barrow .bl small{display:block;color:var(--faint);font-size:11px;font-weight:500}
.barrow .track2{height:7px;border-radius:6px;background:rgba(255,255,255,.06);overflow:hidden;margin-top:7px}
.barrow .track2 i{display:block;height:100%;width:0;border-radius:6px;transition:width 1.3s var(--ease)}
.barrow .bv{text-align:right;font:800 16px 'Inter'}
.legend{display:flex;gap:18px;margin-top:14px;padding-top:14px;border-top:1px solid var(--stroke)}
.legend span{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--muted);font-weight:600}
.legend i{width:18px;height:5px;border-radius:3px}

/* ---- overseer ---- */
.overseer{background:linear-gradient(150deg,rgba(139,92,246,.14),rgba(0,229,255,.06));border-color:rgba(139,92,246,.25)}
.ov-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.ov-orb{width:46px;height:46px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#c4b5fd,#7c3aed 60%,#4c1d95);position:relative;flex:none;
  box-shadow:0 0 24px rgba(139,92,246,.6);animation:breathe 3.2s ease-in-out infinite}
.ov-orb:after{content:"";position:absolute;inset:-5px;border-radius:50%;border:1.5px solid rgba(196,181,253,.4);animation:ovring 3.2s ease-in-out infinite}
@keyframes breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
@keyframes ovring{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.25);opacity:0}}
.ov-head b{font-size:15px;font-weight:800;display:block}
.ov-head span{font:600 11px 'JetBrains Mono';color:var(--green)}
.ov-msg{font-size:14px;line-height:1.6;color:#dfe6f5;min-height:66px}
.ov-msg .cursor{display:inline-block;width:8px;height:16px;background:var(--cyan);vertical-align:-2px;margin-left:2px;animation:blink 1s steps(2) infinite}
@keyframes blink{50%{opacity:0}}
.ov-actions{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.chip{padding:8px 13px;border-radius:11px;background:rgba(255,255,255,.05);border:1px solid var(--stroke-2);font:600 12px 'Inter';color:var(--txt);cursor:pointer;transition:.2s}
.chip:hover{background:var(--violet);border-color:var(--violet);color:#fff}

/* ---- timeline ---- */
.tl{display:flex;flex-direction:column}
.tl .ev{display:grid;grid-template-columns:54px 22px 1fr auto;align-items:center;gap:10px;padding:11px 0;position:relative}
.tl .ev .ti{font:700 12px 'JetBrains Mono';color:var(--faint)}
.tl .ev .dot{width:13px;height:13px;border-radius:50%;border:2.5px solid var(--cyan);background:var(--bg);z-index:1;justify-self:center}
.tl .ev.done .dot{background:var(--cyan);box-shadow:var(--glow)}
.tl .ev.now .dot{border-color:var(--green);box-shadow:0 0 10px var(--green);animation:pulse 1.6s infinite}
.tl .ev:not(:last-child):after{content:"";position:absolute;left:64px;top:24px;bottom:-2px;width:2px;background:var(--stroke-2)}
.tl .ev .ttl{font-size:14px;font-weight:600}
.tl .ev.done .ttl{color:var(--muted)}
.tl .ev .ck{font-size:12px;color:var(--faint)}

/* ---- habit pills ---- */
.habits{display:flex;flex-direction:column;gap:10px}
.habit{display:flex;align-items:center;gap:13px;cursor:pointer;padding:4px 2px}
.habit .box{width:26px;height:26px;border-radius:9px;border:2px solid var(--stroke-2);flex:none;display:grid;place-items:center;transition:.25s}
.habit .box svg{width:14px;height:14px;stroke:#04121a;fill:none;stroke-width:3;opacity:0;transition:.2s}
.habit.done .box{background:var(--cyan);border-color:var(--cyan);box-shadow:var(--glow)}
.habit.done .box svg{opacity:1}
.habit .hn{font-size:14px;font-weight:600;transition:.2s}
.habit.done .hn{color:var(--muted);text-decoration:line-through}
.habit .hstreak{margin-left:auto;font:600 11px 'JetBrains Mono';color:var(--amber)}

/* ---- sparkline / chart ---- */
.spark{width:100%;height:60px;display:block}
.spark path.line{fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:1000;stroke-dashoffset:1000;animation:draw 1.6s var(--ease) forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.bars-chart{display:flex;align-items:flex-end;gap:8px;height:120px;padding-top:10px}
.bars-chart .bar{flex:1;border-radius:7px 7px 3px 3px;background:linear-gradient(180deg,var(--cyan),var(--cyan-d));position:relative;min-height:4px;
  height:0;transition:height 1s var(--ease);opacity:.85}
.bars-chart .bar:hover{opacity:1;filter:brightness(1.2)}
.bars-chart .bar span{position:absolute;bottom:-22px;left:0;right:0;text-align:center;font:600 10px 'JetBrains Mono';color:var(--faint)}
.bars-chart .bar b{position:absolute;top:-20px;left:0;right:0;text-align:center;font:700 11px 'Inter';opacity:0;transition:.2s}
.bars-chart .bar:hover b{opacity:1}

/* finance bars */
.donut{position:relative;width:160px;height:160px;flex:none}
.donut svg{width:100%;height:100%;transform:rotate(-90deg)}
.donut .seg{fill:none;stroke-width:20;transition:stroke-dashoffset 1.2s var(--ease)}
.donut .mid{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.donut .mid b{font-size:26px;font-weight:800}
.donut .mid span{font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:1px}
.flegend{display:flex;flex-direction:column;gap:11px;flex:1}
.flegend .fl{display:flex;align-items:center;gap:11px}
.flegend .fl i{width:11px;height:11px;border-radius:4px;flex:none}
.flegend .fl .fn{font-size:13.5px;font-weight:600;flex:1}
.flegend .fl .fa{font:800 14px 'Inter'}
.flegend .fl .fp{font:600 11px 'JetBrains Mono';color:var(--faint);width:38px;text-align:right}

/* PR list */
.prlist{display:flex;flex-direction:column}
.prrow{display:flex;align-items:center;gap:12px;padding:12px 2px;border-top:1px solid var(--stroke)}
.prrow:first-child{border-top:0}
.prrow .pname{font-size:14px;font-weight:600;flex:1}
.prrow .pval{font:800 15px 'Inter';color:var(--cyan)}
.prrow .pd{font:700 11px 'JetBrains Mono';color:var(--green);width:46px;text-align:right}
.prrow .pmedal{font-size:16px}

/* muscle / body */
.bodywrap{display:flex;align-items:center;justify-content:center;padding:6px}
.bodywrap svg{height:260px;width:auto;filter:drop-shadow(0 0 20px rgba(0,229,255,.15))}
.muscle{transition:fill 1.2s var(--ease)}

/* badges */
.badges{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:14px}
.badge-it{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;border-radius:16px;background:rgba(255,255,255,.03);border:1px solid var(--stroke);text-align:center;transition:.3s var(--ease)}
.badge-it:hover{transform:translateY(-4px) scale(1.03);border-color:var(--stroke-2)}
.badge-it .em{font-size:34px;filter:drop-shadow(0 4px 10px rgba(0,0,0,.4))}
.badge-it.locked{opacity:.4;filter:grayscale(.8)}
.badge-it .bn{font-size:11px;font-weight:700}
.badge-it .bd{font-size:10px;color:var(--faint)}
.badge-it.unlocked .em{animation:pop .5s var(--ease)}
@keyframes pop{0%{transform:scale(0)}70%{transform:scale(1.25)}100%{transform:scale(1)}}

/* mood */
.moodrow{display:flex;gap:10px;justify-content:space-between}
.moodrow .mo{flex:1;aspect-ratio:1;border-radius:14px;border:1px solid var(--stroke);background:rgba(255,255,255,.03);display:grid;place-items:center;font-size:26px;cursor:pointer;transition:.25s}
.moodrow .mo:hover{transform:scale(1.1)}
.moodrow .mo.sel{border-color:var(--cyan);background:rgba(0,229,255,.12);box-shadow:var(--glow);transform:scale(1.05)}

/* progress big */
.pbig{margin-top:4px}
.pbig .ptop{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px}
.pbig .ptop b{font-size:15px;font-weight:700}
.pbig .ptop span{font:800 15px 'Inter';color:var(--cyan)}
.pbig .ptrack{height:11px;border-radius:8px;background:rgba(255,255,255,.06);overflow:hidden}
.pbig .pfill{height:100%;width:0;border-radius:8px;background:linear-gradient(90deg,var(--cyan),var(--violet));transition:width 1.3s var(--ease);box-shadow:0 0 12px rgba(0,229,255,.4)}
.pbig small{display:block;color:var(--faint);font-size:11.5px;margin-top:7px}

/* dock (mobile bottom nav) */
.dock{display:none}

/* toasts */
.toasts{position:fixed;right:22px;bottom:22px;z-index:90;display:flex;flex-direction:column;gap:10px;max-width:340px}
.toast{background:rgba(14,19,32,.92);border:1px solid var(--stroke-2);border-radius:14px;padding:13px 15px;display:flex;gap:12px;align-items:flex-start;
  backdrop-filter:blur(16px);box-shadow:0 16px 40px rgba(0,0,0,.5);animation:toastin .45s var(--ease);border-left:3px solid var(--cyan)}
.toast.out{animation:toastout .4s var(--ease) forwards}
@keyframes toastin{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:none}}
@keyframes toastout{to{opacity:0;transform:translateX(40px);height:0;padding:0 15px;margin:0}}
.toast .te{font-size:20px;flex:none}
.toast b{font-size:13px;display:block;margin-bottom:2px}
.toast p{font-size:12.5px;color:var(--muted);line-height:1.4}

/* count flash */
.flash{animation:flash .6s var(--ease)}
@keyframes flash{0%{color:var(--cyan);text-shadow:0 0 14px rgba(0,229,255,.7)}100%{}}

/* responsive */
@media(max-width:980px){
  .shell{grid-template-columns:1fr}
  .sidebar{display:none}
  .main{padding:18px 16px 110px}
  .col-3,.col-4,.col-5,.col-6,.col-7,.col-8{grid-column:span 12}
  .col-4.keep,.col-3.keep{grid-column:span 6}
  .hero{flex-direction:column;text-align:center}
  .mini-stats{width:100%}
  .topbar{flex-direction:column;gap:14px}
  .topbar-right{width:100%;justify-content:space-between}
  .hero-side{align-items:center}
  .dock{display:flex;position:fixed;left:50%;transform:translateX(-50%);bottom:14px;z-index:80;
    background:rgba(10,14,24,.86);backdrop-filter:blur(20px);border:1px solid var(--stroke-2);border-radius:22px;
    padding:8px;gap:2px;box-shadow:0 14px 40px rgba(0,0,0,.5)}
  .dock button{border:0;background:transparent;color:var(--faint);padding:9px 14px;border-radius:16px;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;transition:.25s}
  .dock button svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.9}
  .dock button span{font-size:9px;font-weight:700;letter-spacing:.3px}
  .dock button.on{color:var(--cyan)}
  .dock button.on{background:rgba(0,229,255,.12)}
}
@media(max-width:560px){
  .gauge{width:190px;height:190px}.gauge .score{font-size:52px}
  .hello h1{font-size:24px}
  .mini-stats{grid-template-columns:repeat(3,1fr)}
}
@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}
