:root{
  --bg:#06080f; --txt:#f2f6ff; --mut:#8b95ad;
  --acc:#ff8a3d; --acc2:#ff4d8d; --grn:#3ee594; --blu:#46a0ff; --pur:#b47bff; --gold:#ffd24d; --ice:#7fd8ff;
  --glass:rgba(20,27,44,.55); --line:rgba(255,255,255,.10);
  --auroraSpeed:18s;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Space Grotesk','Segoe UI Variable','Segoe UI',system-ui,sans-serif;
  font-variant-numeric:tabular-nums;
  background:var(--bg);color:var(--txt);min-height:100vh;overflow-x:hidden;
  padding:18px 18px calc(86px + env(safe-area-inset-bottom));max-width:780px;margin:0 auto;position:relative;z-index:1}
/* display face for the numbers & titles that carry the game */
.title,.lvlName,.streak .n,.tile .v,.bossNow .bv,.todayPts,.actName,.readyZone,
.hdn,.sv,.celebTitle,.gTitle,.chatTitle,.strLast,.repMeta b,.xpMeta,.daylabel{
  font-family:'Chakra Petch','Space Grotesk',sans-serif}

/* ── DESKTOP: dashboard grid instead of a phone column in a void ── */
@media(min-width:1080px){
  body{max-width:1240px;padding:26px 34px calc(96px + env(safe-area-inset-bottom))}
  #view-today.on{display:grid;grid-template-columns:1.2fr .9fr;gap:0 18px;align-items:stretch;grid-auto-flow:row dense} /* row partners same height (Andy 2026-07-04) */
  #view-today.on>*{min-width:0}
  #view-today #wknd:empty{display:none}
  #view-today .hero{grid-column:1/-1}
  #view-today .gQuest{grid-column:1;grid-row:span 6}
  #view-today .gReady,#view-today #wknd,#view-today #todayIntelCard,#view-today .gPlateM,#view-today .gWx,#view-today .gStress{grid-column:2}
  #view-character.on,#view-battles.on,#view-body.on,#view-lab.on,#view-train.on{display:block;column-count:2;column-gap:18px}
  #view-character.on>.card,#view-battles.on>.card,#view-body.on>.card,#view-lab.on>.card,#view-train.on>.card{
    break-inside:avoid;margin-bottom:18px}
  .tabbar{gap:14px}
}
.view.on{animation:viewIn .32s cubic-bezier(.16,1,.3,1)}
@keyframes viewIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ---- animated aurora + grain (BODY-REACTIVE: mood retunes color + speed) ---- */
.bg{position:fixed;inset:0;z-index:-2;overflow:hidden;background:var(--bg);transition:background 1.2s}
.blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;mix-blend-mode:screen;
  animation:drift var(--auroraSpeed) ease-in-out infinite;transition:background 1.5s,opacity 1.5s}
.b1{width:520px;height:520px;background:radial-gradient(circle,#ff7a2d,transparent 60%);top:-160px;right:-120px}
.b2{width:480px;height:480px;background:radial-gradient(circle,#ff4d8d,transparent 60%);top:30%;left:-160px;animation-delay:-6s}
.b3{width:520px;height:520px;background:radial-gradient(circle,#46a0ff,transparent 60%);bottom:-180px;right:-80px;animation-delay:-11s}
@keyframes drift{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(40px,30px) scale(1.12)}66%{transform:translate(-30px,20px) scale(.95)}}
.grain{position:fixed;inset:0;z-index:-1;opacity:.05;pointer-events:none;
  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")}

/* mood themes — set by readiness (the app feels how his body feels) */
body[data-mood="recovery"]{--auroraSpeed:34s}
body[data-mood="recovery"] .b1{background:radial-gradient(circle,#2b5f9e,transparent 60%)}
body[data-mood="recovery"] .b2{background:radial-gradient(circle,#3b4bb0,transparent 60%);opacity:.4}
body[data-mood="recovery"] .b3{background:radial-gradient(circle,#1f8a8a,transparent 60%)}
body[data-mood="push"]{--auroraSpeed:11s}
body[data-mood="push"] .b1{background:radial-gradient(circle,#ff9a2d,transparent 60%);opacity:.62}
body[data-mood="push"] .b2{background:radial-gradient(circle,#ff4d3d,transparent 60%);opacity:.55}
body[data-mood="push"] .b3{background:radial-gradient(circle,#ffd24d,transparent 60%)}
@media(prefers-reduced-motion:reduce){
  .blob,.flame,.fill,.fill::after,.glint,.avatar,.badge.got .bi{animation:none!important}
  .card{animation-duration:.01s!important}
}

.label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--mut);font-weight:800}
.card{background:var(--glass);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);
  border:1px solid var(--line);border-radius:22px;padding:18px;margin-bottom:15px;
  box-shadow:0 12px 40px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.06);
  opacity:0;transform:translateY(18px);animation:rise .7s cubic-bezier(.16,1,.3,1) forwards}
@keyframes rise{to{opacity:1;transform:none}}
.view .card:nth-child(2){animation-delay:.07s}.view .card:nth-child(3){animation-delay:.14s}
.view .card:nth-child(4){animation-delay:.21s}.view .card:nth-child(5){animation-delay:.28s}

/* VIEWS + TABBAR */
.view{display:none}.view.on{display:block}
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;justify-content:center;gap:4px;
  padding:8px max(10px, env(safe-area-inset-left)) calc(8px + env(safe-area-inset-bottom));
  background:rgba(8,11,20,.82);backdrop-filter:blur(20px) saturate(150%);-webkit-backdrop-filter:blur(20px) saturate(150%);
  border-top:1px solid var(--line)}
.tab{flex:1;max-width:130px;display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 4px;
  background:none;border:none;border-radius:14px;color:var(--mut);cursor:pointer;transition:.25s;position:relative}
.tab .ti{font-size:20px;filter:grayscale(.35);opacity:.75;transition:.25s}
.tab.on .ti{opacity:1}
.tab .tl{font-size:9px;font-weight:800;letter-spacing:.8px;text-transform:uppercase}
.tab.on{color:var(--txt);background:rgba(255,138,61,.10)}
.tab.on .ti{filter:none;transform:translateY(-1px) scale(1.12)}
.tab.on::after{content:"";position:absolute;top:-5px;left:50%;transform:translateX(-50%);width:26px;height:3px;border-radius:99px;
  background:linear-gradient(90deg,var(--acc),var(--acc2));box-shadow:0 0 10px var(--acc)}

/* HERO */
.hero{position:relative;overflow:hidden}
.glint{position:absolute;top:-40%;left:-30%;width:60%;height:180%;transform:rotate(20deg);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.07),transparent);animation:glint 6s ease-in-out infinite}
@keyframes glint{0%,100%{left:-40%}50%{left:120%}}
.heroTop{display:flex;align-items:center;gap:13px;position:relative}
.avatar{width:56px;height:56px;border-radius:16px;flex:0 0 auto;display:grid;place-items:center;font-size:28px;
  background:linear-gradient(135deg,var(--acc),var(--acc2));box-shadow:0 0 28px rgba(255,138,61,.55);animation:bob 4s ease-in-out infinite}
@keyframes bob{50%{transform:translateY(-4px)}}
.title{font-size:23px;font-weight:900;letter-spacing:.5px;background:linear-gradient(90deg,#fff,#ffd9bf);
  -webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.subtitle{font-size:12px;color:var(--mut);margin-top:4px;letter-spacing:.3px}
.streak{margin-left:auto;text-align:center;padding:9px 13px;border-radius:16px;flex:0 0 auto;position:relative;
  background:rgba(255,138,61,.12);border:1px solid rgba(255,138,61,.4);box-shadow:0 0 22px rgba(255,138,61,.25)}
.streak .flame{font-size:18px;animation:flicker 1.6s ease-in-out infinite;filter:drop-shadow(0 0 6px var(--acc))}
@keyframes flicker{0%,100%{transform:scale(1) rotate(-2deg);opacity:1}50%{transform:scale(1.18) rotate(2deg);opacity:.85}}
.streak .n{font-size:23px;font-weight:900;color:var(--acc);line-height:1}
.streak .t{font-size:8.5px;letter-spacing:1px;color:var(--acc);text-transform:uppercase;opacity:.85}
.streak .fz{font-size:10px;font-weight:800;color:var(--ice);margin-top:3px;text-shadow:0 0 8px rgba(127,216,255,.6)}
.lvlRow{display:flex;align-items:flex-end;justify-content:space-between;margin:18px 0 9px}
.lvlNum{font-size:11px;color:var(--gold);letter-spacing:2px;font-weight:800;text-shadow:0 0 10px rgba(255,210,77,.4)}
.lvlName{font-size:19px;font-weight:900}
.xpMeta{font-size:11px;color:var(--mut);text-align:right;line-height:1.5}
.bar{height:15px;border-radius:99px;background:rgba(255,255,255,.06);overflow:hidden;border:1px solid var(--line);position:relative}
.fill{height:100%;width:0;border-radius:99px;position:relative;
  background:linear-gradient(90deg,var(--acc),var(--acc2),var(--gold));background-size:200% 100%;
  box-shadow:0 0 18px rgba(255,138,61,.7);transition:width 1.4s cubic-bezier(.16,1,.3,1);animation:flow 3s linear infinite}
@keyframes flow{to{background-position:200% 0}}
.fill::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);animation:shine 2.2s ease-in-out infinite}
@keyframes shine{0%{transform:translateX(-100%)}60%,100%{transform:translateX(260%)}}
.identity{margin-top:10px;font-size:11.5px;color:var(--gold);font-style:italic;opacity:.85;letter-spacing:.3px;transition:opacity .6s}
.identity.fade{opacity:0}

/* READINESS */
.readyWrap{display:flex;align-items:center;gap:16px}
.readyRing{flex:0 0 auto}
.readyMeta{flex:1;min-width:0}
.readyZone{font-size:17px;font-weight:900;letter-spacing:.5px}
.readyTip{font-size:11.5px;color:var(--mut);margin-top:4px;line-height:1.45}
.readyParts{display:flex;gap:7px;margin-top:10px;flex-wrap:wrap}
.rpart{font-size:10px;font-weight:800;padding:5px 9px;border-radius:9px;border:1px solid var(--line);background:rgba(255,255,255,.04)}
.rpart.good{color:var(--grn);border-color:rgba(62,229,148,.4)}
.rpart.bad{color:var(--acc2);border-color:rgba(255,77,141,.4)}
.rpart.na{color:var(--mut)}

/* QUEST */
.questHead{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.todayPts{font-size:13px;font-weight:900;color:var(--gold);text-shadow:0 0 10px rgba(255,210,77,.4)}
.daynav{display:flex;align-items:center;gap:10px;margin-bottom:13px}
.navbtn{width:34px;height:34px;border-radius:11px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--txt);font-size:13px;font-weight:900;cursor:pointer;flex:0 0 auto;transition:transform .15s,opacity .2s}
.navbtn:active{transform:scale(.88)}.navbtn:disabled{opacity:.22;cursor:default}
.daylabel{flex:1;text-align:center;font-size:13.5px;font-weight:800;letter-spacing:.3px;line-height:1.15}
.daylabel small{display:block;font-size:9.5px;color:var(--mut);font-weight:700;text-transform:uppercase;letter-spacing:1.2px;margin-top:2px}
.todaybtn{padding:7px 11px;border-radius:10px;border:1px solid rgba(70,160,255,.4);background:rgba(70,160,255,.12);color:var(--blu);font-size:10.5px;font-weight:800;cursor:pointer;flex:0 0 auto}
.quest{display:flex;flex-direction:column;gap:9px}
.q{display:flex;align-items:center;gap:13px;background:rgba(255,255,255,.035);border:1px solid var(--line);
  border-radius:16px;padding:13px;cursor:pointer;transition:transform .12s,background .25s,border-color .25s;position:relative;overflow:hidden}
.q:active{transform:scale(.97)}
.q .ic{font-size:21px;width:28px;text-align:center;flex:0 0 auto}
.q .nm{font-weight:800;font-size:14.5px}.q .wh{font-size:11px;color:var(--mut)}
.q .meta{flex:1;min-width:0}
.q .val{font-size:11px;font-weight:800;color:var(--blu)}
.check{width:28px;height:28px;border-radius:9px;border:2px solid var(--line);flex:0 0 auto;display:grid;place-items:center;
  font-size:16px;color:transparent;transition:.25s cubic-bezier(.2,1.6,.4,1)}
.q.done{background:linear-gradient(90deg,rgba(62,229,148,.09),rgba(62,229,148,.02));border-color:rgba(62,229,148,.3);
  padding:9px 13px;opacity:.85}
.q.done .ic{font-size:17px}
.q.done .nm{color:var(--grn);font-size:13px}
.q.done .wh{font-size:10px;opacity:.8}
.q.done .check{width:24px;height:24px;background:var(--grn);border-color:var(--grn);color:#04210f;transform:scale(1) rotate(8deg);box-shadow:0 0 10px rgba(62,229,148,.45)}
.q.coreu{border-left:3px solid var(--acc);background:rgba(255,138,61,.05)}
.qprog{height:8px;border-radius:99px;background:rgba(255,255,255,.06);border:1px solid var(--line);position:relative;margin-bottom:12px;overflow:visible}
.qpfill{height:100%;width:0;border-radius:99px;background:linear-gradient(90deg,var(--acc),var(--gold));
  box-shadow:0 0 10px rgba(255,210,77,.4);transition:width .6s cubic-bezier(.16,1,.3,1)}
.qpwin{position:absolute;top:-4px;bottom:-4px;width:2px;background:var(--grn);border-radius:2px;box-shadow:0 0 8px var(--grn)}
.qpwin::after{content:"WIN";position:absolute;top:-13px;left:-11px;font-size:7.5px;font-weight:900;letter-spacing:1px;color:var(--grn)}
.q.lift{border-color:rgba(180,123,255,.45);background:linear-gradient(90deg,rgba(180,123,255,.12),transparent)}
.pop{position:absolute;right:46px;font-weight:900;color:var(--gold);font-size:13px;pointer-events:none;opacity:0}
.pop.go{animation:floatup .9s ease-out}
@keyframes floatup{0%{opacity:0;transform:translateY(6px)}25%{opacity:1}100%{opacity:0;transform:translateY(-22px)}}
.dmgfly{position:fixed;z-index:70;font-weight:900;color:var(--gold);font-size:15px;pointer-events:none;
  text-shadow:0 0 10px rgba(255,210,77,.8);transition:transform .8s cubic-bezier(.3,.7,.2,1),opacity .8s}
.perfect{margin-top:12px;text-align:center;font-weight:900;font-size:13.5px;color:var(--gold);letter-spacing:.5px;
  background:linear-gradient(90deg,rgba(255,210,77,.15),rgba(255,138,61,.12));border:1px dashed rgba(255,210,77,.6);
  border-radius:14px;padding:11px;display:none}
.perfect.on{display:block;animation:pop2 .5s cubic-bezier(.2,1.6,.4,1)}
@keyframes pop2{0%{transform:scale(.8);opacity:0}100%{transform:scale(1);opacity:1}}
.bonusRow{margin-top:10px;font-size:11px;color:var(--gold);text-align:left;opacity:.85;line-height:1.55;
  max-height:3.4em;overflow:hidden;cursor:pointer;position:relative;transition:max-height .3s}
.bonusRow.open{max-height:30em}
.bonusRow.clampable:not(.open)::after{content:"… more";position:absolute;right:0;bottom:0;background:linear-gradient(90deg,transparent,var(--bg) 30%);padding-left:26px;color:var(--blu);font-weight:800}

/* TILES */
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:11px}
.tile{background:rgba(255,255,255,.035);border:1px solid var(--line);border-radius:16px;padding:14px 8px;text-align:center;position:relative;overflow:hidden}
.tile .v{font-size:20px;font-weight:900;line-height:1.05}
.tile .k{font-size:9px;letter-spacing:.5px;color:var(--mut);text-transform:uppercase;margin-top:5px}
.tile .d{font-size:10px;margin-top:4px}.up{color:var(--grn)}.down{color:var(--acc2)}.flat{color:var(--mut)}

/* FUEL */
.rings{display:flex;gap:14px;justify-content:space-around;align-items:center;flex-wrap:wrap}
.ring{display:flex;flex-direction:column;align-items:center;gap:7px}
.ring svg{transform:rotate(-90deg)}
.ring .rl{font-size:10.5px;color:var(--mut);text-transform:uppercase;letter-spacing:.5px;font-weight:800}
.ring .rv{font-size:12px;font-weight:800}
.tdee{margin-top:13px;text-align:center;font-size:11px;color:var(--mut);border-top:1px dashed var(--line);padding-top:11px}
.tdee b{color:var(--blu)}

/* TRENDS */
.trendMain{margin-bottom:12px}
.trendGrid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.tr{background:rgba(255,255,255,.035);border:1px solid var(--line);border-radius:16px;padding:11px}
.tr .th{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.tr .tk{font-size:9.5px;letter-spacing:.5px;color:var(--mut);text-transform:uppercase;font-weight:800}
.tr .tv{font-size:13px;font-weight:900}
.tr .td{font-size:9.5px;font-weight:700}
.tr svg{display:block;width:100%}
.trEmpty{font-size:10px;color:var(--mut);text-align:center;padding:12px 0}

/* HISTORY */
.hist{display:flex;gap:6px;overflow-x:auto;padding:2px 0 6px}
.hd{flex:0 0 auto;width:42px;border-radius:13px;border:1px solid var(--line);background:rgba(255,255,255,.03);padding:8px 3px;text-align:center;cursor:pointer;transition:transform .15s,border-color .25s;position:relative}
.hd:active{transform:scale(.92)}
.hd.sel{border-color:rgba(255,138,61,.7);box-shadow:0 0 12px rgba(255,138,61,.3);background:rgba(255,138,61,.08)}
.hd.win{border-color:rgba(62,229,148,.35)}
.hd.perfectday{border-color:rgba(255,210,77,.5)}
.hd .hdd{font-size:8.5px;color:var(--mut);text-transform:uppercase;letter-spacing:.5px;font-weight:800}
.hd .hdn{font-size:15px;font-weight:900;margin-top:2px;line-height:1}
.hd .hdp{font-size:9px;font-weight:800;margin-top:4px;color:var(--acc)}
.hd.win .hdp{color:var(--grn)}
.hd.empty{opacity:.45}.hd.empty .hdp{color:var(--mut)}
.hd .hdstar{position:absolute;top:-7px;right:-3px;font-size:12px;filter:drop-shadow(0 0 4px var(--gold))}
.hd .hdice{position:absolute;top:-7px;left:-3px;font-size:11px;filter:drop-shadow(0 0 4px var(--ice))}
.freezeNote{margin-top:10px;font-size:10px;color:var(--mut);text-align:center}

/* BOSS */
.bossCard{border-color:rgba(255,77,141,.35)}
.bossTop{display:flex;align-items:center;gap:12px;margin-bottom:11px}
.bossIcon{font-size:30px;filter:drop-shadow(0 0 10px rgba(255,77,141,.7));animation:bob 4s ease-in-out infinite}
.bossTitle{font-size:15px;font-weight:900;letter-spacing:.5px}
.bossSub{font-size:10.5px;color:var(--mut);margin-top:3px;line-height:1.4}
.bossNow{margin-left:auto;text-align:center;flex:0 0 auto}
.bossNow .bv{font-size:24px;font-weight:900;color:var(--acc2);text-shadow:0 0 12px rgba(255,77,141,.5);line-height:1}
.bossNow .bu{font-size:9px;color:var(--mut);text-transform:uppercase;letter-spacing:1px}
.phaseChip{display:inline-block;margin:0 0 10px;padding:5px 11px;border-radius:99px;font-size:10.5px;font-weight:900;letter-spacing:1px;
  background:rgba(255,77,141,.14);border:1px solid rgba(255,77,141,.5);color:var(--acc2)}
.hpbar{height:13px;border-radius:99px;background:rgba(255,255,255,.06);border:1px solid var(--line);overflow:hidden;position:relative}
.hpfill{height:100%;width:0;border-radius:99px;background:linear-gradient(90deg,#7a1230,var(--acc2));
  box-shadow:0 0 14px rgba(255,77,141,.45);transition:width 1.5s cubic-bezier(.16,1,.3,1)}
.bossMeta{display:flex;justify-content:space-between;font-size:10px;color:var(--mut);margin-top:6px}
.bossDelta{margin-top:10px;font-size:11.5px;font-weight:800;text-align:center}

/* MINI-BOSSES */
.mb2{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.035);border:1px solid var(--line);
  border-radius:16px;padding:12px;margin-bottom:9px}
.mb2 .mic{font-size:24px;flex:0 0 auto}
.mb2 .mnm{font-size:13px;font-weight:900}
.mb2 .mdesc{font-size:10.5px;color:var(--mut);margin-top:2px;line-height:1.4}
.mb2 .mstate{margin-left:auto;flex:0 0 auto;font-size:10px;font-weight:900;letter-spacing:1px;padding:6px 10px;border-radius:99px;border:1px solid var(--line)}
.mb2.won{border-color:rgba(62,229,148,.45)}.mb2.won .mstate{color:var(--grn);border-color:rgba(62,229,148,.5)}
.mb2.lost{opacity:.6}.mb2.lost .mstate{color:var(--acc2);border-color:rgba(255,77,141,.5)}
.mb2.today{border-color:rgba(255,210,77,.55);box-shadow:0 0 16px rgba(255,210,77,.15)}
.mb2.today .mstate{color:var(--gold);border-color:rgba(255,210,77,.6);animation:flicker 1.6s infinite}
.mb2.ahead .mstate{color:var(--mut)}

/* CHARACTER */
.actCard{border-color:rgba(255,210,77,.3)}
.actHead{display:flex;align-items:baseline;gap:10px}
.actNum{font-size:11px;color:var(--gold);letter-spacing:2px;font-weight:800}
.actName{font-size:19px;font-weight:900}
.actKg{margin-left:auto;font-size:11px;color:var(--mut)}
.actDots{display:flex;gap:6px;margin:12px 0 4px}
.adot{flex:1;height:6px;border-radius:99px;background:rgba(255,255,255,.08);position:relative;overflow:hidden}
.adot .af{position:absolute;inset:0;border-radius:99px;background:linear-gradient(90deg,var(--gold),var(--acc));width:0;transition:width 1.2s cubic-bezier(.16,1,.3,1)}
.actLabels{display:flex;justify-content:space-between;font-size:9px;color:var(--mut)}
.charWrap{display:flex;gap:10px;align-items:center;justify-content:space-between;margin-bottom:8px}
.avatarBox{flex:0 0 38%;display:grid;place-items:center}
.avatarBox svg{width:100%;max-width:150px;filter:drop-shadow(0 0 18px rgba(255,138,61,.35))}
.hexBox{flex:1;display:grid;place-items:center}
.hexBox svg{width:100%;max-width:230px}
.statRow{display:flex;align-items:center;gap:11px;padding:8px 2px;border-bottom:1px solid rgba(255,255,255,.05)}
.statRow:last-child{border-bottom:none}
.statRow .sic{font-size:17px;width:24px;text-align:center;flex:0 0 auto}
.statRow .snm{font-size:11.5px;font-weight:800;width:86px;flex:0 0 auto}
.statRow .slv{font-size:10px;font-weight:900;color:var(--gold);width:38px;flex:0 0 auto}
.statRow .strk{flex:1;height:8px;border-radius:99px;background:rgba(255,255,255,.06);overflow:hidden}
.statRow .sf{height:100%;width:0;border-radius:99px;background:linear-gradient(90deg,var(--blu),var(--pur));transition:width 1.1s cubic-bezier(.16,1,.3,1)}
.statRow .sproof{font-size:9px;color:var(--mut);width:32%;flex:0 0 auto;text-align:right;line-height:1.3}

/* REPLICA */
.repWrap{display:flex;gap:10px;justify-content:space-around;align-items:flex-end;margin-bottom:8px}
.repFig{flex:0 0 44%;max-width:170px}
.repFig svg{width:100%;filter:drop-shadow(0 0 16px rgba(255,138,61,.3))}
.repFig .rfl{text-align:center;font-size:9px;letter-spacing:1.5px;color:var(--mut);text-transform:uppercase;font-weight:800;margin-top:4px}
#repSlider{width:100%;margin:10px 0 4px;accent-color:var(--acc);height:22px;cursor:pointer}
.repMeta{display:flex;justify-content:space-between;align-items:baseline;font-size:11px;color:var(--mut)}
.repMeta b{color:var(--gold);font-size:14px}
.repMeta .rd{font-size:12px;font-weight:800;color:var(--txt)}
.repNote{margin-top:10px;font-size:10.5px;color:var(--blu);line-height:1.5;border-top:1px dashed var(--line);padding-top:9px}
#rep3d{height:340px;border-radius:16px;overflow:hidden;background:radial-gradient(ellipse at 50% 80%,rgba(255,138,61,.08),transparent 70%);cursor:grab;touch-action:none}
#rep3d:active{cursor:grabbing}
#rep3d canvas{display:block;width:100%!important;height:100%!important}

/* EXPANDERS + MOOD */
.statDetail,.mbDetail,.bossLegend{display:none;font-size:10px;color:var(--mut);line-height:1.5;padding:6px 4px 8px}
.statDetail.on,.mbDetail.on,.bossLegend.on{display:block}
.mbDetail{padding:5px 0 0}
.bossLegend{margin-top:8px;border-top:1px dashed var(--line);padding-top:8px}
.bossLegend span{display:inline-block;margin-right:10px;padding:3px 8px;border-radius:8px;border:1px solid var(--line);font-weight:700}
.bossLegend span.cur{color:var(--acc2);border-color:rgba(255,77,141,.5);background:rgba(255,77,141,.1)}
.moodRow{display:flex;align-items:center;gap:5px;margin-top:7px;flex-wrap:wrap}
.moodRow .tk{margin-right:4px}
.moodCell{display:inline-flex;flex-direction:column;align-items:center;font-size:15px;line-height:1}
.moodCell i{font-style:normal;font-size:7.5px;color:var(--mut);margin-bottom:2px}

/* STRENGTH */
.strTabs{display:flex;gap:8px;margin-bottom:12px}
.strTab{flex:1;padding:8px;border-radius:11px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--mut);font-weight:800;font-size:12px;cursor:pointer;text-align:center}
.strTab.on{color:var(--txt);border-color:rgba(180,123,255,.55);background:rgba(180,123,255,.12);box-shadow:0 0 12px rgba(180,123,255,.2)}
.strRow{display:flex;align-items:center;gap:10px;padding:9px 4px;border-bottom:1px solid rgba(255,255,255,.05)}
.strRow:last-child{border-bottom:none}
.strNm{font-size:12.5px;font-weight:800;flex:1;min-width:0}
.strNext{font-size:9.5px;color:var(--mut);margin-top:2px}
.strLast{font-size:13px;font-weight:900;color:var(--pur);flex:0 0 auto}
.strBeat{width:34px;text-align:center;font-size:12px;font-weight:900;flex:0 0 auto}
.strBeat.up{color:var(--grn)}.strBeat.dn{color:var(--acc2)}.strBeat.base{color:var(--gold);font-size:9px;letter-spacing:.5px}

/* LAB */
.exp{background:rgba(255,255,255,.035);border:1px solid rgba(70,160,255,.35);border-radius:16px;padding:13px;margin-bottom:10px}
.expTop{display:flex;align-items:center;gap:10px}
.exp .eic{font-size:22px}.exp .enm{font-size:13px;font-weight:900}
.exp .estat{margin-left:auto;font-size:9.5px;font-weight:900;letter-spacing:1px;color:var(--blu)}
.exp .ehyp{font-size:11px;color:var(--mut);margin-top:6px;line-height:1.5}
.expBar{height:9px;border-radius:99px;background:rgba(255,255,255,.06);overflow:hidden;margin-top:10px}
.expFill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blu),var(--ice));width:0;transition:width 1.2s cubic-bezier(.16,1,.3,1)}
.expMeta{display:flex;justify-content:space-between;font-size:9.5px;color:var(--mut);margin-top:5px}
.loot{display:flex;gap:12px;background:rgba(255,255,255,.035);border:1px solid var(--line);border-radius:16px;padding:13px;margin-bottom:10px;position:relative;overflow:hidden}
.loot .lic{font-size:24px;flex:0 0 auto}
.loot .lnm{font-size:12.5px;font-weight:900}
.loot .lv2{font-size:11px;color:var(--mut);margin-top:4px;line-height:1.5}
.loot .lrar{position:absolute;top:9px;right:11px;font-size:8.5px;font-weight:900;letter-spacing:1.5px;text-transform:uppercase}
.loot.common{border-color:rgba(139,149,173,.4)}.loot.common .lrar{color:var(--mut)}
.loot.rare{border-color:rgba(70,160,255,.5)}.loot.rare .lrar{color:var(--blu)}
.loot.epic{border-color:rgba(180,123,255,.55)}.loot.epic .lrar{color:var(--pur)}
.loot.legendary{border-color:rgba(255,210,77,.6);box-shadow:0 0 18px rgba(255,210,77,.15)}.loot.legendary .lrar{color:var(--gold)}
.story{font-size:12px;line-height:1.65;color:var(--txt)}
.story h3{font-size:14px;margin-bottom:6px}
.story .shl{color:var(--gold);font-weight:800}
.story ul{margin:8px 0 0 18px}

/* PLATE */
.pmeal{display:flex;align-items:baseline;gap:10px;padding:8px 2px;border-bottom:1px solid rgba(255,255,255,.05)}
.pmeal:last-child{border-bottom:none}
.pmeal .pn{font-size:12.5px;font-weight:800;flex:1;min-width:0}
.pmeal .pm{font-size:11px;color:var(--mut);flex:0 0 auto}
.pmeal .pm b{color:var(--grn)}
.prec{display:flex;align-items:baseline;gap:10px;padding:8px 10px;border:1px solid rgba(62,229,148,.22);background:rgba(62,229,148,.05);border-radius:12px;margin-bottom:7px}
.prec .pn{font-size:12px;font-weight:800;flex:1}
.prec .pw{font-size:10px;color:var(--mut);margin-top:2px}
.prec .pm{font-size:10.5px;color:var(--grn);font-weight:800;flex:0 0 auto}
.recMore{width:100%;margin-top:4px;padding:9px;border-radius:12px;border:1px dashed var(--line);background:none;
  color:var(--mut);font-size:10.5px;font-weight:800;cursor:pointer}
.ateBtn{flex:0 0 auto;margin-left:8px;padding:7px 10px;border-radius:11px;border:1px solid rgba(62,229,148,.35);
  background:none;color:var(--grn);font-size:10px;font-weight:800;cursor:pointer;transition:.15s}
.ateBtn:active{transform:scale(.92)}
.ateBtn:disabled{opacity:.7;cursor:default}

/* CHAT */
#chatFab{position:fixed;right:16px;bottom:calc(118px + env(safe-area-inset-bottom));z-index:65;
  display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:99px;color:#fff;cursor:pointer;
  border:1px solid rgba(255,138,61,.55);background:linear-gradient(135deg,rgba(255,138,61,.92),rgba(255,77,141,.92));
  backdrop-filter:blur(10px);box-shadow:0 10px 30px rgba(255,77,141,.4), inset 0 1px 0 rgba(255,255,255,.25);
  transition:transform .2s,box-shadow .2s}
#chatFab svg{display:block;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}
#chatFab .cfl{font-family:'Chakra Petch','Space Grotesk',sans-serif;font-size:12.5px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase}
#chatFab:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(255,77,141,.5), inset 0 1px 0 rgba(255,255,255,.25)}
#chatFab:active{transform:scale(.93)}
@media(max-width:520px){#chatFab{padding:13px;border-radius:50%}#chatFab .cfl{display:none}}
#chat{position:fixed;inset:0;z-index:88;display:none;place-items:end center;background:rgba(6,8,15,.9);backdrop-filter:blur(10px)}
#chat.on{display:grid}
.chatCard{width:100%;max-width:640px;height:88vh;display:flex;flex-direction:column;background:#0a0e1a;
  border:1px solid var(--line);border-radius:24px 24px 0 0;box-shadow:0 -16px 60px rgba(0,0,0,.7)}
.chatHead{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid var(--line)}
.chatTitle{font-size:15px;font-weight:900}
.chatSub{font-size:10px;color:var(--mut);margin-top:3px}
.chatMsgs{flex:1;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column;gap:10px}
.cm{max-width:86%;padding:11px 14px;border-radius:16px;font-size:12.5px;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}
.cm.user{align-self:flex-end;background:linear-gradient(135deg,rgba(255,138,61,.25),rgba(255,77,141,.2));border:1px solid rgba(255,138,61,.35)}
.cm.model{align-self:flex-start;background:rgba(255,255,255,.045);border:1px solid var(--line)}
.cm.model b{color:var(--gold)}
.cm .ctools{display:block;margin-top:7px;font-size:9px;color:var(--blu);opacity:.8}
.cm.typing{align-self:flex-start;color:var(--mut);font-size:11px;animation:flicker 1.4s infinite}
.cm img{max-width:160px;border-radius:10px;display:block;margin-top:6px}
.chatAttach{padding:0 16px;font-size:10px;color:var(--blu)}
.chatBar{display:flex;align-items:flex-end;gap:8px;padding:10px 12px calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--line)}
.chatBtn{width:38px;height:38px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.05);
  display:grid;place-items:center;font-size:16px;cursor:pointer;flex:0 0 auto}
#chatInput{flex:1;resize:none;max-height:110px;padding:10px 12px;border-radius:13px;border:1px solid var(--line);
  background:rgba(255,255,255,.05);color:var(--txt);font-family:inherit;font-size:13px;outline:none}
#chatInput:focus{border-color:rgba(255,138,61,.5)}
.chatSend{width:42px;height:38px;border-radius:12px;border:1px solid rgba(255,138,61,.5);background:linear-gradient(135deg,var(--acc),var(--acc2));
  color:#06080f;font-size:15px;font-weight:900;cursor:pointer;flex:0 0 auto}
.chatSend:disabled{opacity:.4}
.chatChips{display:flex;flex-direction:column;gap:7px;margin-top:6px}
.chip{align-self:flex-start;padding:9px 13px;border-radius:14px;border:1px solid rgba(70,160,255,.35);background:rgba(70,160,255,.08);
  color:var(--txt);font-size:11.5px;font-weight:700;cursor:pointer;text-align:left;transition:.2s}
.chip:active{transform:scale(.96)}

/* FORM GUIDE */
.strRow.hasGuide{cursor:pointer}
.strRow.hasGuide:active{transform:scale(.98)}
.strRow .chev{color:var(--mut);font-size:14px;flex:0 0 auto;margin-left:2px}
.strHint{margin-top:10px;font-size:10px;color:var(--mut);text-align:center}
#guide{position:fixed;inset:0;z-index:91;display:none;place-items:center;padding:16px;background:rgba(6,8,15,.9);backdrop-filter:blur(10px)}
#guide.on{display:grid}
.gCard{width:100%;max-width:480px;max-height:88vh;overflow-y:auto;background:var(--glass);border:1px solid rgba(180,123,255,.4);
  border-radius:24px;padding:22px;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.7);animation:pop2 .35s cubic-bezier(.2,1.6,.4,1)}
.gClose{position:sticky;top:0;float:right;width:32px;height:32px;border-radius:10px;border:1px solid var(--line);
  background:rgba(255,255,255,.06);color:var(--txt);font-size:14px;cursor:pointer;z-index:2}
.gTitle{font-size:18px;font-weight:900;margin:2px 0 10px;padding-right:40px}
.gChips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.gChip{font-size:9.5px;font-weight:800;letter-spacing:.5px;padding:5px 10px;border-radius:99px;text-transform:uppercase}
.gChip.p{background:rgba(255,138,61,.18);border:1px solid rgba(255,138,61,.55);color:var(--acc)}
.gChip.s{background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--mut)}
.gFigs{display:flex;gap:14px;justify-content:center;margin-bottom:6px}
.gFigs>div{flex:0 0 40%;max-width:150px;text-align:center}
.gFigs svg{width:100%}
#gVideo{margin:8px 0 4px}
.gVidBtn{display:flex;align-items:center;gap:10px;width:100%;padding:12px;border-radius:14px;border:1px solid rgba(70,160,255,.4);
  background:rgba(70,160,255,.1);color:var(--txt);cursor:pointer;text-align:left}
.gVidBtn .gp{font-size:20px}
.gVidBtn .gt{font-size:12px;font-weight:800}
.gVidBtn .gc{font-size:10px;color:var(--mut)}
#gVideo iframe{width:100%;aspect-ratio:16/9;border:none;border-radius:14px}
.gSec{margin-top:13px}
.gH{font-size:10px;letter-spacing:1.5px;color:var(--mut);font-weight:800;margin-bottom:7px}
.gSetup{font-size:11.5px;color:var(--blu);line-height:1.5;background:rgba(70,160,255,.07);border:1px dashed rgba(70,160,255,.3);border-radius:12px;padding:10px}
.gSteps{margin-left:18px;display:flex;flex-direction:column;gap:6px}
.gSteps li{font-size:12px;line-height:1.55}
.gList{margin-left:16px;display:flex;flex-direction:column;gap:6px;list-style:none}
.gList li{font-size:11.5px;line-height:1.5;color:var(--txt);position:relative;padding-left:4px}
.gList li::before{content:"·";color:var(--gold);font-weight:900;margin-right:6px}
.gList.gBad li::before{color:var(--acc2)}
.gList.gBad li{color:var(--mut)}

/* INTEL */
.intel{display:flex;flex-direction:column;gap:10px}
.icard{display:flex;gap:12px;background:rgba(255,255,255,.035);border:1px solid var(--line);border-radius:16px;padding:13px;position:relative;overflow:hidden}
.icard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px}
.icard.win::before{background:var(--grn)}.icard.pattern::before{background:var(--blu)}
.icard.research::before{background:var(--pur)}.icard.nudge::before{background:var(--gold)}
.icard .ic{font-size:20px;flex:0 0 auto}
.icard .it{font-size:12.5px;font-weight:900}
.icard .ib{font-size:11.5px;color:var(--mut);margin-top:4px;line-height:1.5}

/* ACHIEVEMENTS */
.ach{display:grid;grid-template-columns:repeat(4,1fr);gap:11px}
.badge{text-align:center;background:rgba(255,255,255,.035);border:1px solid var(--line);border-radius:16px;padding:13px 6px;transition:.3s}
.badge.locked{opacity:.3;filter:grayscale(1)}
.badge.got{border-color:rgba(255,210,77,.5);box-shadow:0 0 16px rgba(255,210,77,.14)}
.badge .bi{font-size:25px;display:block}.badge.got .bi{animation:bob 4s ease-in-out infinite}
.badge .bn{font-size:9px;font-weight:800;margin-top:6px;line-height:1.15}

/* INPUT SHEET — mouse/tap-only logging */
#isheet{position:fixed;inset:0;z-index:92;display:none;place-items:end center;background:rgba(6,8,15,.9);backdrop-filter:blur(10px)}
#isheet.on{display:grid}
.isCard{width:100%;max-width:520px;max-height:88vh;overflow-y:auto;background:#0a0e1a;border:1px solid rgba(255,138,61,.35);
  border-radius:24px 24px 0 0;padding:20px 18px calc(16px + env(safe-area-inset-bottom));box-shadow:0 -16px 60px rgba(0,0,0,.7);
  animation:pop2 .3s cubic-bezier(.2,1.6,.4,1)}
.isTitle{font-size:16px;font-weight:900;margin-bottom:14px}
.isGroup{margin-bottom:16px}
.isLabel{font-size:10px;letter-spacing:1.5px;color:var(--mut);font-weight:800;text-transform:uppercase;margin-bottom:8px;display:flex;justify-content:space-between}
.isLabel b{color:var(--gold);font-size:13px;letter-spacing:0}
.isChips{display:flex;flex-wrap:wrap;gap:7px}
.isChip{padding:9px 12px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--txt);
  font-size:12.5px;font-weight:800;cursor:pointer;transition:.15s}
.isChip:active{transform:scale(.93)}
.isChip.on{border-color:rgba(255,138,61,.7);background:rgba(255,138,61,.16);color:var(--acc);box-shadow:0 0 10px rgba(255,138,61,.25)}
.isFine{display:flex;gap:8px;margin-top:9px;align-items:center;justify-content:center}
.isFine button{width:64px;height:36px;border-radius:11px;border:1px solid var(--line);background:rgba(255,255,255,.05);
  color:var(--txt);font-size:12px;font-weight:900;cursor:pointer}
.isStep{display:flex;align-items:center;justify-content:center;gap:16px;margin:4px 0 10px}
.isStep .sv{font-size:30px;font-weight:900;min-width:110px;text-align:center;color:var(--gold)}
.isStep .su{font-size:12px;color:var(--mut);font-weight:700}
.isStep button{width:52px;height:52px;border-radius:16px;border:1px solid rgba(255,138,61,.4);background:rgba(255,138,61,.1);
  color:var(--acc);font-size:24px;font-weight:900;cursor:pointer;transition:.12s}
.isStep button:active{transform:scale(.9)}
.isRange{width:100%;accent-color:var(--acc);height:24px;cursor:pointer}
.isMoods{display:flex;gap:8px;justify-content:space-between}
.isMood{flex:1;padding:10px 4px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.04);
  font-size:24px;cursor:pointer;transition:.15s;text-align:center;filter:grayscale(.6);opacity:.75}
.isMood:active{transform:scale(.9)}
.isMood.on{border-color:rgba(255,210,77,.7);background:rgba(255,210,77,.12);filter:none;opacity:1;box-shadow:0 0 12px rgba(255,210,77,.3);transform:scale(1.06)}
.isTags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:9px}
.isTa{width:100%;min-height:64px;padding:10px 12px;border-radius:13px;border:1px solid var(--line);background:rgba(255,255,255,.05);
  color:var(--txt);font-family:inherit;font-size:13px;outline:none;resize:vertical}
.isBtns{display:flex;gap:10px;margin-top:6px}
.isCancel{flex:1;padding:13px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.05);color:var(--mut);
  font-weight:800;font-size:13px;cursor:pointer}
.isSave{flex:2;margin-top:0}

/* CELEBRATION */
#celebrate{position:fixed;inset:0;z-index:90;display:none;place-items:center;padding:24px;background:rgba(6,8,15,.92);backdrop-filter:blur(12px)}
#celebrate.on{display:grid}
.celebCard{max-width:360px;text-align:center;background:var(--glass);border:1px solid rgba(255,210,77,.5);border-radius:26px;padding:34px 28px;
  box-shadow:0 0 60px rgba(255,210,77,.25);animation:pop2 .5s cubic-bezier(.2,1.6,.4,1)}
.celebIc{font-size:56px;filter:drop-shadow(0 0 18px rgba(255,210,77,.7));animation:bob 3s ease-in-out infinite}
.celebTitle{font-size:20px;font-weight:900;margin:14px 0 8px;background:linear-gradient(90deg,#fff,var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.celebSub{font-size:12.5px;color:var(--mut);line-height:1.6;margin-bottom:20px}

.foot{text-align:center;color:var(--mut);font-size:11px;margin:8px 0 10px}
.syncbtn{margin-top:9px;font-size:11px;color:var(--blu);text-decoration:underline;cursor:pointer;background:none;border:none}
.dot{display:inline-block;width:7px;height:7px;border-radius:99px;background:var(--mut);margin-right:5px;vertical-align:middle}
.dot.ok{background:var(--grn);box-shadow:0 0 8px var(--grn)}.dot.local{background:var(--gold)}
canvas#cf{position:fixed;inset:0;z-index:95;pointer-events:none}
#lock{position:fixed;inset:0;z-index:100;display:none;place-items:center;padding:24px;background:rgba(6,8,15,.9);backdrop-filter:blur(10px)}
.lockcard{max-width:340px;text-align:center;background:var(--glass);border:1px solid var(--line);border-radius:24px;padding:32px 26px;box-shadow:0 16px 50px rgba(0,0,0,.6)}
.connectBig{margin-top:8px;padding:13px 24px;border-radius:14px;border:1px solid rgba(255,138,61,.5);background:linear-gradient(135deg,var(--acc),var(--acc2));color:#06080f;font-weight:900;font-size:14px;cursor:pointer;box-shadow:0 0 24px rgba(255,138,61,.5)}
@media(max-width:420px){
  .grid4{grid-template-columns:repeat(2,1fr)}
  .charWrap{flex-direction:column}.avatarBox{flex:0 0 auto}
  .statRow .sproof{display:none}
}

/* ── v8: TRAIN tab + editable plate + centered sheet on desktop ── */
.sessTitle{font-family:'Chakra Petch','Space Grotesk',sans-serif;font-size:17px;letter-spacing:.02em;margin-bottom:4px}
.sessSub{font-size:12.5px;color:var(--mut);line-height:1.5;margin-bottom:8px}
.sessNext{display:inline-block;margin-top:6px;padding:8px 12px;border-radius:12px;border:1px solid rgba(255,210,77,.35);background:rgba(255,210,77,.07);color:var(--gold);font-weight:700;font-size:12.5px}
.sessEx{display:flex;align-items:center;gap:10px;padding:11px 4px;border-bottom:1px dashed rgba(255,255,255,.08);cursor:pointer;font-size:14px;border-radius:8px}
.sessEx:last-child{border-bottom:0}
.sessEx>span:first-child{flex:1;min-width:0}
.sessEx b{font-family:'Chakra Petch','Space Grotesk',sans-serif;font-size:13px;color:var(--gold);font-weight:700;white-space:nowrap}
.sessEx .chev{color:var(--mut)}
.sessEx:hover{background:rgba(255,255,255,.03)}
.motivCard{border-color:rgba(255,138,61,.3);background:linear-gradient(160deg,rgba(255,138,61,.09),rgba(255,77,141,.05) 60%,var(--glass))}
.motiv{font-family:'Chakra Petch','Space Grotesk',sans-serif;font-size:18px;line-height:1.55;letter-spacing:.01em}

/* tap-to-edit affordances (plate meals + coach recs) */
.pmeal.canEdit{cursor:pointer;align-items:center;border-radius:8px}
.pmeal.canEdit:hover{background:rgba(255,255,255,.03)}
.pmeal .chev,.prec .chev{color:var(--mut);font-size:13px;flex:0 0 auto}
.prec{cursor:pointer}
.isDel{width:100%;margin-top:2px;margin-bottom:6px;padding:12px;border-radius:13px;border:1px solid rgba(255,77,141,.4);background:rgba(255,77,141,.1);color:var(--acc2);font-weight:800;font-size:13px;cursor:pointer;font-family:inherit}
.isDel:hover{background:rgba(255,77,141,.18)}

/* input sheet: bottom-anchored on phones (thumb reach), CENTERED on desktop */
@media(min-width:760px){
  #isheet{place-items:center}
  .isCard{border-radius:24px;max-width:480px;box-shadow:0 24px 80px rgba(0,0,0,.75)}
}

/* ── v9: day-at-a-glance + ticker + train logging + battles grid + mood cells ── */
.dstats{display:flex;flex-wrap:wrap;gap:8px}
.dchip{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:14px;border:1px solid var(--line);
  background:rgba(255,255,255,.04);min-width:0}
.dchip .di{font-size:16px}
.dchip b{font-family:'Chakra Petch','Space Grotesk',sans-serif;font-size:15px;display:block;line-height:1.05}
.dchip b i{font-style:normal;font-size:10.5px;color:var(--mut);font-weight:600}
.dchip .dl{font-size:9px;letter-spacing:.8px;text-transform:uppercase;color:var(--mut);font-weight:800;display:block;margin-top:2px}
.dchip .dd{font-family:'Chakra Petch',sans-serif;font-size:11.5px;font-weight:700;margin-left:2px;padding:3px 7px;border-radius:8px}
.dchip .dd.gain{color:var(--grn);background:rgba(62,229,148,.12)}
.dchip .dd.loss{color:var(--acc2);background:rgba(255,77,141,.12)}
.dchip.winc{border-color:rgba(62,229,148,.45);background:rgba(62,229,148,.07)}
.dchip.winc b,.dchip.winc .dl{color:var(--grn)}

/* the corner — persistent motivation ticker above the tabbar */
#ticker{position:fixed;left:0;right:0;bottom:74px;z-index:59; /* JS re-measures the real tabbar height on boot/resize */
  display:flex;align-items:center;gap:9px;justify-content:center;padding:8px 16px;cursor:pointer;
  background:rgba(8,11,20,.78);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);
  border-top:1px solid rgba(255,138,61,.16)}
#ticker .tkIc{font-size:13px;flex:0 0 auto;opacity:.8}
#tickTxt{font-family:'Chakra Petch','Space Grotesk',sans-serif;font-size:12.5px;letter-spacing:.02em;color:#e8d9c8;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:860px;transition:opacity .26s,transform .26s}
#tickTxt.out{opacity:0;transform:translateY(6px)}

/* train: session rows get a log button + rest clock */
.sessTmr{font-family:'Chakra Petch',sans-serif;font-size:11px;font-weight:700;color:var(--gold);
  border:1px solid rgba(255,210,77,.4);background:rgba(255,210,77,.08);border-radius:9px;padding:3px 8px;vertical-align:2px}
.logBtn{flex:0 0 auto;padding:7px 11px;border-radius:10px;border:1px solid rgba(62,229,148,.4);background:rgba(62,229,148,.08);
  color:var(--grn);font-weight:800;font-size:11.5px;cursor:pointer;font-family:inherit;transition:.2s}
.logBtn:hover{background:rgba(62,229,148,.16)}
.hypeBtn{width:100%;margin-top:12px;padding:12px;border-radius:13px;cursor:pointer;font-family:'Chakra Petch',sans-serif;
  font-size:13px;font-weight:700;letter-spacing:.6px;color:#fff;border:1px solid rgba(255,138,61,.45);
  background:linear-gradient(135deg,rgba(255,138,61,.25),rgba(255,77,141,.18));transition:.2s}
.hypeBtn:hover{background:linear-gradient(135deg,rgba(255,138,61,.4),rgba(255,77,141,.3))}

/* battles: proper desktop grid instead of lopsided masonry */
@media(min-width:1080px){
  #view-battles.on{display:grid;grid-template-columns:1.05fr .95fr;gap:0 18px;align-items:start;column-count:unset}
  #view-battles.on>.card{margin-bottom:18px}
  #view-battles .gHist{grid-column:1/-1}
  #view-today .gStats{grid-column:1/-1}
}

/* mood cells: emoji first, date under — readable, not cryptic */
.moodRow{display:flex;align-items:center;gap:10px;margin-top:9px}
.moodRow .tk{flex:0 0 44px}
.moodCells{display:flex;gap:7px;overflow-x:auto;padding-bottom:2px}
.moodCell{display:inline-flex;flex-direction:column;align-items:center;font-size:17px;line-height:1.15;flex:0 0 auto}
.moodCell i{font-style:normal;font-size:8.5px;color:var(--mut);font-weight:700}

/* room for the ticker above the tabbar */
body{padding-bottom:calc(122px + env(safe-area-inset-bottom))}
@media(min-width:1080px){body{padding-bottom:calc(132px + env(safe-area-inset-bottom))}}

/* v9.1 sweep: hero identity line was whisper-quiet; the coach should be heard */
.hero .identity{color:#f0cfa4;opacity:.92;text-shadow:0 1px 6px rgba(0,0,0,.4)}

/* coach alerts card */
.alSt{display:inline-block;font-family:'Chakra Petch',sans-serif;font-size:12px;font-weight:700;letter-spacing:.6px;
  padding:7px 12px;border-radius:11px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--mut);margin-bottom:12px}
.alSt.on{color:var(--grn);border-color:rgba(62,229,148,.45);background:rgba(62,229,148,.08)}
.alRow{display:flex;align-items:center;gap:10px;padding:8px 2px;border-bottom:1px dashed rgba(255,255,255,.07);font-size:13px}
.alRow:last-child{border-bottom:0}
.alRow .ai{font-size:15px;flex:0 0 22px}
.alRow b{font-family:'Chakra Petch',sans-serif;font-size:13px;color:var(--gold);flex:0 0 44px}
.alRow .at{flex:1;min-width:0}
.alRow .ad{font-size:9.5px;letter-spacing:.8px;text-transform:uppercase;color:var(--mut);font-weight:800;flex:0 0 auto}
.alNote{font-size:11.5px;color:var(--mut);line-height:1.5;margin:10px 0 12px}
.alBtns{display:flex;gap:10px}

/* quick-add food row + pending state */
.paddRow{width:100%;margin-top:9px;padding:11px;border-radius:12px;border:1px dashed rgba(62,229,148,.35);
  background:rgba(62,229,148,.04);color:var(--grn);font-weight:700;font-size:12.5px;cursor:pointer;font-family:inherit;text-align:center;transition:.2s}
.paddRow:hover{background:rgba(62,229,148,.1)}
.pmeal.pend{opacity:.5}
.pmeal.pend .pn::after{content:"";display:inline-block;width:10px;height:10px;margin-left:8px;border-radius:50%;
  border:2px solid var(--grn);border-top-color:transparent;animation:spin .8s linear infinite;vertical-align:-1px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── v10: freshness banner, week strip, progress badges, misc audit sweep ── */
#fresh{display:flex;align-items:center;gap:11px;margin-bottom:15px;padding:12px 15px;border-radius:16px;
  border:1px solid rgba(255,210,77,.4);background:rgba(255,210,77,.08);font-size:12.5px;line-height:1.5;color:#f0dcb0}
#fresh span{font-size:18px}
.recMenu{margin:4px 0 10px}
.rmI{padding:7px 2px;border-bottom:1px dashed rgba(255,255,255,.07);font-size:12.5px;color:var(--txt);line-height:1.45}
.rmI:last-child{border-bottom:0}
.wkRow{display:flex;gap:8px;margin-bottom:10px}
.wkS{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:9px 4px;border-radius:13px;border:1px solid var(--line);background:rgba(255,255,255,.03)}
.wkS b{font-family:'Chakra Petch',sans-serif;font-size:10px;letter-spacing:1px;color:var(--mut)}
.wkS span{font-size:14px}
.wkS i{font-style:normal;font-size:12px;font-weight:800}
.wkS.done{border-color:rgba(62,229,148,.45);background:rgba(62,229,148,.07)} .wkS.done i{color:var(--grn)}
.wkS.today{border-color:rgba(255,210,77,.5);background:rgba(255,210,77,.07)} .wkS.today i{color:var(--gold)}
.wkS.miss i{color:var(--acc2)}
.wkMeta{font-size:11.5px;color:var(--mut);line-height:1.5}
.logBtn.sm{padding:6px 9px;font-size:12px;margin-left:6px}
.avatarBox{position:relative}
.lvB{position:absolute;top:4px;right:6px;font-family:'Chakra Petch',sans-serif;font-size:10.5px;font-weight:700;letter-spacing:.8px;
  color:var(--gold);border:1px solid rgba(255,210,77,.45);background:rgba(255,210,77,.1);border-radius:9px;padding:3px 7px}
.dchip.addc{cursor:pointer;border-style:dashed;border-color:rgba(62,229,148,.4);background:rgba(62,229,148,.05);font-family:inherit;transition:.2s}
.dchip.addc b,.dchip.addc .dl{color:var(--grn)}
.dchip.addc:hover{background:rgba(62,229,148,.12)}
.actLabels i{font-style:normal;font-size:8px;color:var(--mut);margin-left:1px}
.badge .bp{font-size:8.5px;font-weight:800;color:var(--gold);margin-top:3px;opacity:.85}
.badge.locked .bp{color:#b9a06a}

/* ── v11: crafted tab icons, quest time bands, plate mini ── */
.tab .ti svg{width:21px;height:21px;display:block;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;opacity:.75;transition:.25s}
.tab.on .ti svg{opacity:1;filter:drop-shadow(0 0 6px rgba(255,138,61,.6))}
.tab .ti{filter:none}
.tab.on .ti{transform:translateY(-1px) scale(1.1)}
.qgrp{font-size:9px;letter-spacing:2px;font-weight:900;color:var(--mut);text-transform:uppercase;
  margin:13px 2px 7px;padding-top:2px;display:flex;align-items:center;gap:8px}
.qgrp::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,rgba(255,255,255,.09),transparent)}
.quest .qgrp:first-child{margin-top:2px}
.pmRow{display:flex;align-items:baseline;gap:10px;padding:6.5px 2px;border-bottom:1px solid rgba(255,255,255,.05);font-size:12.5px}
.pmRow span{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pmRow b{font-family:'Chakra Petch',sans-serif;font-size:12px;color:var(--mut)}
.pmFoot{display:flex;align-items:center;gap:8px;margin-top:10px;font-size:12px;color:var(--mut)}
.pmFoot b{color:var(--grn)}
.pmBtn{padding:7px 11px;border-radius:10px;border:1px solid var(--line);background:rgba(255,255,255,.04);
  color:var(--txt);font-weight:700;font-size:11.5px;cursor:pointer;font-family:inherit;transition:.2s}
.pmBtn.add{border-color:rgba(62,229,148,.4);color:var(--grn);background:rgba(62,229,148,.06)}
.pmBtn:hover{background:rgba(255,255,255,.09)}
.pmBtn.add:hover{background:rgba(62,229,148,.13)}

/* ── v12: app header (logo · wordmark · account), bigger chat input ── */
#appbar{position:sticky;top:0;z-index:70;display:flex;align-items:center;justify-content:space-between;
  margin:-18px -18px 14px;padding:10px 16px calc(10px);
  background:rgba(8,11,20,.72);backdrop-filter:blur(20px) saturate(150%);-webkit-backdrop-filter:blur(20px) saturate(150%);
  border-bottom:1px solid var(--line)}
@media(min-width:1080px){#appbar{margin:-26px -34px 18px;padding:11px 22px}}
.abL{display:flex;align-items:center;gap:10px}
.abLogo{width:27px;height:27px;filter:drop-shadow(0 2px 8px rgba(255,77,141,.45))}
.abTitle{font-family:'Chakra Petch','Space Grotesk',sans-serif;font-size:13.5px;font-weight:700;letter-spacing:2.5px;
  background:linear-gradient(90deg,#fff 20%,#ffd9bf 40%,#ff8a3d 50%,#ffd9bf 60%,#fff 80%);background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;animation:wordmark 6s linear infinite}
@keyframes wordmark{to{background-position:-200% 0}}
.abR{display:flex;align-items:center;gap:12px}
#acctBtn{width:36px;height:36px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.05);
  color:var(--txt);cursor:pointer;display:grid;place-items:center;transition:.2s}
#acctBtn:hover{background:rgba(255,255,255,.1)}
#acctMenu{position:absolute;top:calc(100% + 8px);right:12px;min-width:230px;display:none;
  background:#0b101d;border:1px solid var(--line);border-radius:16px;padding:8px;
  box-shadow:0 18px 50px rgba(0,0,0,.6)}
#acctMenu.on{display:block;animation:pop2 .22s cubic-bezier(.2,1.4,.4,1)}
.amHead{padding:9px 11px;border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:6px}
.amHead b{font-family:'Chakra Petch',sans-serif;font-size:14px}
.amSub{display:block;font-size:10.5px;color:var(--mut);margin-top:2px}
.amRow{display:block;width:100%;text-align:left;padding:10px 11px;border:none;border-radius:11px;background:none;
  color:var(--txt);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}
.amRow:hover{background:rgba(255,255,255,.06)}
.amNote{padding:9px 11px 6px;font-size:10.5px;color:var(--mut);border-top:1px solid rgba(255,255,255,.07);margin-top:6px;line-height:1.45}
.foot{padding-bottom:6px}

/* chat input: comfortable on thumbs, 16px kills iOS zoom-on-focus */
.chatBar{display:flex;align-items:flex-end;gap:10px;padding:12px 14px calc(14px + env(safe-area-inset-bottom));border-top:1px solid var(--line)}
.chatBtn{width:44px;height:46px;border-radius:13px;flex:0 0 auto}
#chatInput{flex:1;resize:none;max-height:140px;min-height:46px;padding:12px 14px;border-radius:14px;font-size:16px;line-height:1.35}
.chatSend{width:52px;height:46px;border-radius:13px;font-size:17px;flex:0 0 auto}
/* v12.1: textarea min-width:auto blocked flex shrink — send button was clipped off-screen on mobile */
#chatInput{min-width:0}
.chatCard{min-width:0}

/* ── v13: Outside card, install guide ── */
.wxTop{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.wxIco{font-size:30px;filter:drop-shadow(0 2px 8px rgba(255,210,77,.3))}
.wxT{font-family:'Chakra Petch',sans-serif;font-size:24px;display:block;line-height:1}
.wxFeels{font-size:11px;color:var(--mut);display:block;margin-top:3px}
.wxChips{display:flex;flex-wrap:wrap;gap:6px;margin-left:auto}
.wxC{font-family:'Chakra Petch',sans-serif;font-size:11px;font-weight:700;padding:5px 9px;border-radius:9px;
  border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--txt)}
.wxC.bad{color:var(--acc2);border-color:rgba(255,77,141,.4)}
.wxTips{margin-top:10px}
.wxTip{padding:7px 2px;border-top:1px dashed rgba(255,255,255,.07);font-size:12.5px;line-height:1.45;color:#e8d9c8}
.wxSrc{margin-top:8px;font-size:9.5px;color:var(--mut);opacity:.7}
.igStep{display:flex;align-items:center;gap:12px;padding:11px 4px;border-bottom:1px dashed rgba(255,255,255,.08);font-size:14px}
.igStep b{flex:0 0 26px;height:26px;display:grid;place-items:center;border-radius:9px;
  background:linear-gradient(135deg,var(--acc),var(--acc2));color:#fff;font-family:'Chakra Petch',sans-serif}
.igShare{display:inline-grid;place-items:center;width:24px;height:24px;border:1px solid var(--line);border-radius:7px;font-size:13px}
.haeBox code{display:inline-block;background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:6px;
  padding:2px 6px;font-size:10px;margin:2px 0;word-break:break-all;user-select:all}

/* ── v14: dark scrollbars everywhere (the white bars were Windows defaults), chat controls, groceries ── */
*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.16) transparent}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.13);border-radius:99px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.24);background-clip:padding-box}
::-webkit-scrollbar-corner{background:transparent}

#chatModel{background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:9px;color:var(--txt);
  font-family:inherit;font-size:11px;font-weight:600;padding:4px 6px;max-width:230px}
#chatModel:focus{outline:none;border-color:rgba(255,138,61,.5)}
.chIcon{width:36px;height:36px;border-radius:11px;border:1px solid var(--line);background:rgba(255,255,255,.05);
  color:var(--txt);font-size:15px;cursor:pointer;flex:0 0 auto;margin-right:8px;transition:.2s}
.chIcon:hover{background:rgba(255,255,255,.1)}
.cm.chHist{opacity:.72}
.cm.histDiv{align-self:center;background:none;border:none;color:var(--mut);font-size:10.5px;letter-spacing:1px;text-transform:uppercase;padding:6px 0}

.grocHead{font-family:'Chakra Petch',sans-serif;font-size:13.5px;color:var(--gold);margin-bottom:8px}
.grocGrp{font-size:10px;letter-spacing:1.6px;font-weight:900;color:var(--mut);text-transform:uppercase;margin:13px 2px 6px}
.grocRow{display:flex;align-items:center;gap:10px;padding:8px 2px;border-bottom:1px solid rgba(255,255,255,.05)}
.grocRow .gq{font-family:'Chakra Petch',sans-serif;font-size:11.5px;color:var(--gold);margin-left:4px}
.grocRow.skip{opacity:.6}
.grocRow.skip .pn{text-decoration:line-through;text-decoration-color:rgba(255,77,141,.6);text-decoration-thickness:1.5px}
.grocGo{flex:0 0 auto;padding:7px 11px;border-radius:10px;border:1px solid rgba(62,229,148,.4);background:rgba(62,229,148,.07);
  color:var(--grn);font-weight:700;font-size:11px;text-decoration:none;transition:.2s}
.grocGo:hover{background:rgba(62,229,148,.15)}

/* ── v15: header v2 — status pill, gradient-ring avatar, accent underline ── */
#appbar{border-bottom:none}
#appbar::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;
  background:linear-gradient(90deg,var(--acc),var(--acc2) 35%,rgba(255,77,141,.12) 70%,transparent);opacity:.6;pointer-events:none}
.abTitle{font-size:14px;letter-spacing:3px}
.abStatus{display:flex;align-items:center;gap:7px;padding:8px 13px;border-radius:99px;cursor:pointer;
  border:1px solid rgba(255,138,61,.35);background:linear-gradient(135deg,rgba(255,138,61,.12),rgba(255,77,141,.07));
  color:var(--txt);font-family:'Chakra Petch','Space Grotesk',sans-serif;font-size:11.5px;font-weight:700;letter-spacing:.5px;transition:.2s}
.abStatus i{font-style:normal;color:var(--mut);opacity:.55}
.abStatus:hover{border-color:rgba(255,138,61,.6);transform:translateY(-1px)}
.abStatus:empty{display:none}
#acctBtn{width:38px;height:38px;border-radius:50%;position:relative;
  border:1.5px solid transparent;
  background:linear-gradient(#0d1220,#0d1220) padding-box,linear-gradient(135deg,var(--acc),var(--acc2)) border-box}
#acctBtn .dot{position:absolute;right:-2px;bottom:-2px;width:12px;height:12px;border:2.5px solid #0a0e19;margin:0}
.amGrp{font-size:8.5px;letter-spacing:2px;font-weight:900;color:var(--mut);padding:9px 11px 3px;text-transform:uppercase;opacity:.75}
#acctMenu{min-width:252px}
.pmPct{font-family:'Chakra Petch','Space Grotesk',sans-serif;font-size:10px;font-weight:700;color:var(--blu);
  border:1px solid rgba(70,160,255,.35);background:rgba(70,160,255,.08);border-radius:7px;padding:2px 6px;margin-left:7px;flex:0 0 auto}
.pmRow b i{font-style:normal;font-size:9px;color:var(--mut);margin-left:3px;font-weight:600}
@media(max-width:430px){
  .abTitle{font-size:11px;letter-spacing:2px}
  .abStatus{padding:7px 9px;font-size:10.5px;gap:5px}
}
/* v15.1: .pmRow span{flex:1} was stretching the % pills into bars */
.pmRow .pmPct{flex:0 0 auto;text-align:center}
.pmRow b{flex:0 0 auto}

/* ── v16: stress card, breathe overlay, future projection ── */
.stRow{display:flex;gap:9px}
.stSlot{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 6px;border-radius:14px;
  border:1px dashed var(--line);background:rgba(255,255,255,.03);cursor:pointer;transition:.2s;font-family:inherit}
.stSlot .stEmo{font-size:21px;line-height:1;color:var(--mut)}
.stSlot .stLab{font-size:9px;letter-spacing:1.2px;text-transform:uppercase;font-weight:800;color:var(--mut)}
.stSlot:hover{background:rgba(255,255,255,.07)}
.stSlot.set{border-style:solid;border-color:rgba(180,123,255,.45);background:rgba(180,123,255,.08)}
.stFoot{display:flex;align-items:center;gap:10px;margin-top:11px}
.stHint{font-size:10.5px;color:var(--mut);line-height:1.4;flex:1}

#breathe{position:fixed;inset:0;z-index:96;display:none;place-items:center;background:rgba(4,7,14,.96);backdrop-filter:blur(14px)}
#breathe.on{display:grid;animation:brIn .5s ease}
@keyframes brIn{from{opacity:0}}
.brInner{text-align:center}
.brRing{width:230px;height:230px;margin:0 auto 26px;border-radius:50%;display:grid;place-items:center;
  border:1px solid rgba(127,216,255,.25);box-shadow:0 0 60px rgba(70,160,255,.12) inset}
.brCore{width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle at 38% 32%, rgba(127,216,255,.85), rgba(70,160,255,.5) 55%, rgba(30,70,140,.35));
  box-shadow:0 0 70px rgba(70,160,255,.4);transform:scale(.42)}
.brPhase{font-family:'Chakra Petch','Space Grotesk',sans-serif;font-size:22px;font-weight:700;letter-spacing:1px;margin-bottom:6px}
.brCount{font-size:12px;color:var(--mut);letter-spacing:1px}
.brClose{margin-top:26px;padding:10px 22px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.05);
  color:var(--txt);font-weight:700;cursor:pointer;font-family:inherit}

.repEta{margin-top:10px;font-size:12px;color:var(--txt);line-height:1.6;border-top:1px dashed rgba(255,255,255,.08);padding-top:10px}
.repEta b{color:var(--gold);font-family:'Chakra Petch',sans-serif}
.etaGoal{margin-top:6px;color:#e8d9c8;font-size:12px}
.etaHint{color:var(--mut);font-size:11.5px}
.repWrap.proj .repFig{opacity:.78;filter:saturate(.65) brightness(1.05)}
.repWrap.proj .repFig svg{outline:1.5px dashed rgba(255,210,77,.35);outline-offset:6px;border-radius:14px}

/* ── v17: MITO lives ── */
.hero .avatar.mitoBox{background:transparent;box-shadow:none;animation:none;overflow:visible;cursor:pointer}
.mitoBox svg{width:100%;height:100%;display:block;animation:mitoBreathe 3.4s ease-in-out infinite;transform-origin:center bottom}
.mitoBox[data-state=tired] svg,.mitoBox[data-state=depleted] svg{animation-duration:5.6s}
.mitoBox[data-state=spore] svg{animation-duration:8s}
.mitoBox[data-state=radiant]{filter:drop-shadow(0 0 16px rgba(255,210,77,.6))}
.mitoBox[data-state=healthy]{filter:drop-shadow(0 0 11px rgba(255,138,61,.5))}
.mitoBox[data-state=tired]{filter:drop-shadow(0 0 6px rgba(255,138,61,.25))}
.mitoBox[data-state=depleted]{filter:saturate(.75) drop-shadow(0 0 5px rgba(70,160,255,.25))}
.mitoBox[data-state=spore]{filter:grayscale(.65) brightness(.85)}
@keyframes mitoBreathe{50%{transform:scale(1.055) translateY(-1px)}}
.mitoBox.hop svg{animation:mitoHop .6s cubic-bezier(.3,1.7,.4,1)}
@keyframes mitoHop{30%{transform:translateY(-10px) scale(1.1) rotate(-5deg)}62%{transform:translateY(0) scale(.95)}82%{transform:scale(1.03)}}
.mitoBox.munch svg{animation:mitoMunch .85s ease}
@keyframes mitoMunch{20%,70%{transform:scale(1.12,.9)}45%{transform:scale(.92,1.1)}}
.mitoEye{transform-box:fill-box;transform-origin:center;animation:mitoBlink 4.6s infinite}
@keyframes mitoBlink{0%,91%,100%{transform:scaleY(1)}94%{transform:scaleY(.12)}}

/* ── v19: MOBILE LITE MODE — backdrop-filter was cooking phones AND dropping
   first paints (WebKit); big blurred animated blobs were the other burner ── */
@media (pointer:coarse), (max-width:820px){
  .card,#appbar,.tabbar,#ticker,#acctMenu,.chatCard,.isCard,.gCard,.celebCard{
    backdrop-filter:none!important;-webkit-backdrop-filter:none!important}
  .card{background:rgba(15,20,36,.94)}
  #appbar,.tabbar{background:rgba(8,11,20,.97)}
  #ticker{background:rgba(8,11,20,.95)}
  #acctMenu{background:#0b101d}
  #chat,#isheet,#guide,#breathe,#celebrate{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(5,7,13,.97)}
  .blob{animation:none;filter:blur(44px);opacity:.32}
  .b2{display:none}
  .glint{display:none}
  .fill::after{animation:none}
  .card{animation-duration:.35s}
}

/* ── body animation polish pass 1: the 2D figures BREATHE ── */
.repFig svg{animation:repBreathe 4.6s ease-in-out infinite;transform-origin:50% 92%}
@keyframes repBreathe{50%{transform:scaleY(1.014) scaleX(1.005)}}
.repFig{transition:opacity .22s ease}

/* pass 2: timeline scrubbing gets a soft crossfade instead of hard pops */
.repWrap.morphing .repFig{opacity:.5}

/* pass 3: the projected future shimmers — a goal, not a fact */
.repWrap.proj .repFig svg{animation:repBreathe 6.4s ease-in-out infinite, projGlow 2.6s ease-in-out infinite}
@keyframes projGlow{50%{outline-color:rgba(255,210,77,.7);filter:brightness(1.12)}}
@media (prefers-reduced-motion:reduce){.repFig svg{animation:none!important}}

/* ── v20: MITO the star — speech bubble, You-tab stage; mobile typography pass ── */
.hero .avatar.mitoBox{position:relative}
.mitoSay{position:absolute;left:62px;top:-6px;z-index:6;min-width:150px;max-width:210px;padding:9px 12px;
  border-radius:14px;border-bottom-left-radius:3px;background:#131a2e;border:1px solid rgba(255,210,77,.4);
  font-size:11.5px;line-height:1.45;color:#f2e8d4;text-align:left;font-weight:600;
  opacity:0;transform:translateY(5px) scale(.94);transform-origin:left bottom;pointer-events:none;
  transition:opacity .25s,transform .25s;box-shadow:0 8px 24px rgba(0,0,0,.5)}
.mitoSay.on{opacity:1;transform:none}
.mcWrap{display:flex;align-items:center;gap:16px}
.mcFig{width:110px;height:110px;flex:0 0 auto;cursor:pointer}
.mcFig svg{width:100%;height:100%;display:block;animation:mitoBreathe 3.4s ease-in-out infinite;transform-origin:center bottom}
.mcFig.hop svg{animation:mitoHop .6s cubic-bezier(.3,1.7,.4,1)}
.mcFig[data-state=radiant]{filter:drop-shadow(0 0 20px rgba(255,210,77,.55))}
.mcFig[data-state=healthy]{filter:drop-shadow(0 0 14px rgba(255,138,61,.45))}
.mcFig[data-state=spore]{filter:grayscale(.65)}
.mcMeta{flex:1;min-width:0}
.mcState{font-family:'Chakra Petch','Space Grotesk',sans-serif;font-size:15px;font-weight:700;letter-spacing:2px;margin-bottom:9px}
.mcState[data-state=radiant]{color:var(--gold)}.mcState[data-state=healthy]{color:var(--acc)}
.mcState[data-state=tired]{color:var(--mut)}.mcState[data-state=depleted]{color:var(--blu)}.mcState[data-state=spore]{color:var(--mut)}
.mcBarRow{display:flex;align-items:center;gap:9px;margin-bottom:7px}
.mcBarRow span{font-size:9px;letter-spacing:1.4px;font-weight:800;color:var(--mut);flex:0 0 58px}
.mcBarRow b{font-family:'Chakra Petch',sans-serif;font-size:12px;flex:0 0 26px;text-align:right}
.mcBar{flex:1;height:7px;border-radius:99px;background:rgba(255,255,255,.06);overflow:hidden}
.mcFill{height:100%;border-radius:99px;transition:width 1s cubic-bezier(.16,1,.3,1)}
.mcEra{display:flex;align-items:center;gap:5px;margin-top:9px;font-size:10.5px;color:var(--mut)}
.mcEra span:last-child{margin-left:4px}
.mcDot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid var(--line)}
.mcDot.on{background:var(--gold);border-color:var(--gold);box-shadow:0 0 6px rgba(255,210,77,.5)}
.mcBio{margin-top:12px;font-size:11.5px;color:var(--mut);line-height:1.55;border-top:1px dashed rgba(255,255,255,.08);padding-top:10px}
.mcBio b{color:#e8d9c8}

/* mobile typography pass: hero + acts stop wrapping awkwardly */
@media(max-width:430px){
  .title{font-size:18px;letter-spacing:.3px}
  .subtitle{font-size:10.5px}
  .hero .avatar{width:62px;height:62px}
  .lvlNum{font-size:13px}
  .xpMeta{font-size:9.5px;max-width:46%;text-align:right;line-height:1.5}
  .actHead{flex-wrap:wrap;row-gap:3px}
  .actKg{width:100%;font-size:10.5px}
  .mitoSay{left:56px;max-width:170px;font-size:11px}
  .mcFig{width:88px;height:88px}
}

/* ── v21: iOS blank-view KILL SHOT — cards must never depend on an animation
   to become visible (dropped animation start = invisible forever) ── */
@media (pointer:coarse), (max-width:820px){
  .card{opacity:1!important;transform:none!important;animation:none!important}
  .view.on{animation:none}
}
/* interactivity affordances */
.wkS{cursor:pointer;transition:border-color .2s,transform .2s}
.wkS:hover{border-color:rgba(255,138,61,.55);transform:translateY(-1px)}
.dchip.tap{cursor:pointer;transition:background .2s,transform .2s}
.dchip.tap:hover{background:rgba(255,255,255,.09);transform:translateY(-1px)}
.tile{cursor:pointer;transition:background .2s}
.tile:hover{background:rgba(255,255,255,.07)}
.pmRow{cursor:pointer}

/* ── v23: dark native form controls (the white dropdown), history bubbles wrap, weather prep, day-note cleanup ── */
:root{color-scheme:dark}
#chatModel option{background:#0d1220;color:#f2f6ff}
/* history bubbles style-match LIVE chat exactly (pre-wrap) — sanitizer in JS
   handles the markdown-table junk; extra overrides here caused paint bugs */
.wxPrepH{font-size:9px;letter-spacing:1.8px;font-weight:900;color:var(--mut);margin-top:11px;text-transform:uppercase}
#dayNote.bonusRow{color:#9fc4ef;background:rgba(70,160,255,.06);border:1px solid rgba(70,160,255,.18);
  border-radius:12px;padding:9px 12px;max-height:3.6em}
#dayNote.bonusRow.open{max-height:30em}
#dayNote.bonusRow.clampable:not(.open)::after{background:linear-gradient(90deg,transparent,#0d1524 40%)}

/* ============ v25 — reset CTA, CTA alignment, MITO v2, bloat picker ============ */
/* THE 60-SECOND RESET — a button that wants to be pressed */
.brCta{display:flex;align-items:center;gap:12px;width:100%;margin-top:12px;padding:12px 14px;text-align:left;cursor:pointer;
  border-radius:16px;border:1px solid rgba(62,229,148,.35);color:var(--tx);
  background:linear-gradient(135deg,rgba(62,229,148,.10),rgba(70,160,255,.07) 55%,rgba(180,123,255,.08));
  box-shadow:0 0 18px rgba(62,229,148,.10);animation:brGlow 3.6s ease-in-out infinite;transition:transform .15s ease,box-shadow .2s}
.brCta:hover{transform:translateY(-1px);box-shadow:0 0 26px rgba(62,229,148,.22)}
.brCta:active{transform:scale(.985)}
@keyframes brGlow{50%{box-shadow:0 0 26px rgba(62,229,148,.20);border-color:rgba(62,229,148,.55)}}
.brCtaIc{font-size:24px;line-height:1;animation:brLung 4s ease-in-out infinite}
@keyframes brLung{45%{transform:scale(1.16)}}
.brCtaTxt{flex:1;min-width:0}
.brCtaTxt b{display:block;font-size:12.5px;letter-spacing:1.6px;color:var(--grn);font-weight:900}
.brCtaTxt i{display:block;font-style:normal;font-size:11px;color:var(--mut);line-height:1.45;margin-top:3px}
.brCtaGo{font-size:20px;color:var(--grn);opacity:.7}
.stHint{margin-top:8px;font-size:10.5px;color:var(--mut)}
/* aligned CTA rows — one height, one radius, no ransom-note buttons */
.alBtns{display:flex;gap:10px;align-items:stretch;flex-wrap:wrap;margin-top:12px}
.alBtns .todaybtn,.alBtns .connectBig{flex:1 1 200px;display:inline-flex;align-items:center;justify-content:center;
  padding:13px 18px !important;border-radius:14px;font-size:13px;line-height:1.2;min-height:48px}
/* bloat picker — smaller moods with a label under the emoji */
.isMood.sm{padding:8px 2px;font-size:17px;display:flex;flex-direction:column;align-items:center;gap:3px}
.isMoodLab{font-size:8.5px;letter-spacing:.6px;color:var(--mut);text-transform:uppercase;font-weight:800}
.isMood.sm.on .isMoodLab{color:var(--gold)}
/* MITO v2 — queasy (junk day), pet-buff aura + burst, care chips, gym companion */
.mitoBox.queasy svg{animation:mitoQueasy 1.4s ease}
@keyframes mitoQueasy{15%{transform:rotate(-6deg) scale(1.05,.94)}35%{transform:rotate(5deg) scale(.96,1.05)}
  55%{transform:rotate(-4deg) scale(1.06,.93)}75%{transform:rotate(2deg)}}
.mitoBox[data-state=queasy] svg{animation-duration:5.2s} /* slower breathing — he's sluggish */
.mitoBox.aura{filter:drop-shadow(0 0 14px rgba(255,210,77,.55))}
.mitoBox.aura svg{animation-duration:2.6s} /* petted = perkier */
.mitoBox.burst::after{content:"✨";position:absolute;inset:0;display:grid;place-items:center;font-size:30px;
  animation:mitoBurst 1.1s ease forwards;pointer-events:none}
@keyframes mitoBurst{0%{transform:scale(.4);opacity:0}35%{transform:scale(1.5);opacity:1}100%{transform:scale(2.4);opacity:0}}
.mcCare{display:flex;gap:7px;flex-wrap:wrap;align-items:center;margin:10px 0 2px}
.mcChip{padding:7px 11px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.04);
  color:var(--mut);font-size:11px;font-weight:800;cursor:pointer;transition:all .15s}
.mcChip.on{border-color:rgba(62,229,148,.45);color:var(--grn);background:rgba(62,229,148,.08)}
.mcChip:active{transform:scale(.93)}
.mcJunk{font-size:10.5px;color:#c9d47a;font-weight:800}
.mcFig{position:relative}
.mcFig .mitoSay{position:absolute;left:50%;top:-8px;transform:translateX(-50%);background:rgba(13,21,36,.96);
  border:1px solid var(--line);border-radius:12px;padding:7px 10px;font-size:11px;line-height:1.35;width:max-content;
  max-width:220px;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:5}
.mcFig .mitoSay.on{opacity:1;transform:translateX(-50%) translateY(-6px)}
.mitoTrain{display:flex;align-items:center;gap:10px;margin-top:12px;padding:9px 12px;border-radius:14px;
  border:1px dashed rgba(255,210,77,.25);background:rgba(255,210,77,.04);cursor:pointer}
.mtFig{width:44px;height:44px;flex:none;position:relative}
.mtFig svg{width:100%;height:100%;display:block;animation:mitoBreathe 3.4s ease-in-out infinite;transform-origin:center bottom}
.mtFig.hop svg{animation:mitoHop .6s cubic-bezier(.3,1.7,.4,1)}
.mtLine{font-size:12px;color:var(--tx);line-height:1.4;font-style:italic}
.mitoBox{position:relative} /* anchors the burst ✨ + card speech bubble to the figure, not the row */
.mitoBox[data-state=queasy]{filter:saturate(.9) drop-shadow(0 0 9px rgba(143,208,106,.4))}
/* v26 — 3D control rail */
#rep3d{position:relative}
.r3Ctl{position:absolute;top:10px;right:10px;display:flex;flex-direction:column;gap:8px;z-index:6}
.r3Btn{width:40px;height:40px;border-radius:13px;border:1px solid var(--line);background:rgba(13,21,36,.82);
  font-size:17px;display:grid;place-items:center;cursor:pointer;transition:all .15s;color:var(--tx)}
.r3Btn:hover{border-color:rgba(255,210,77,.5);transform:translateY(-1px)}
.r3Btn:active{transform:scale(.92)}
.r3Btn.on{border-color:rgba(255,210,77,.65);background:rgba(255,210,77,.13);box-shadow:0 0 10px rgba(255,210,77,.25)}
/* v27 — tick pop, typing dots, breathe cycle dots, ticker edge fade */
.q.ping .check{animation:tickPop .6s cubic-bezier(.3,1.9,.4,1)}
@keyframes tickPop{0%{transform:scale(.2) rotate(-30deg)}45%{transform:scale(1.5) rotate(8deg)}72%{transform:scale(.9)}100%{transform:scale(1)}}
.q.ping{animation:rowFlash .75s ease}
@keyframes rowFlash{22%{background:rgba(62,229,148,.15);box-shadow:0 0 18px rgba(62,229,148,.18)}}
.cm.typing{display:flex;align-items:center;gap:5px;padding:12px 14px}
.tdot{width:7px;height:7px;border-radius:50%;background:var(--acc);opacity:.5;animation:tdot 1.2s ease-in-out infinite}
.tdot:nth-child(2){animation-delay:.18s}.tdot:nth-child(3){animation-delay:.36s}
@keyframes tdot{35%{transform:translateY(-5px);opacity:1}}
.tlab{font-size:10.5px;color:var(--mut);margin-left:5px}
.brDots{display:flex;gap:9px;justify-content:center;margin-top:14px}
.brDot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.14);transition:all .4s}
.brDot.live{background:var(--grn);box-shadow:0 0 10px rgba(62,229,148,.6);transform:scale(1.25)}
.brDot.done{background:rgba(62,229,148,.55)}
#ticker{-webkit-mask-image:linear-gradient(90deg,transparent,#000 26px,#000 calc(100% - 26px),transparent);
  mask-image:linear-gradient(90deg,transparent,#000 26px,#000 calc(100% - 26px),transparent)}
/* v28 — EU label card + compact groceries */
.euHead{font-size:9.5px;letter-spacing:1.6px;text-transform:uppercase;color:var(--mut);font-weight:900;
  padding-bottom:7px;border-bottom:2px solid rgba(255,255,255,.14);margin-bottom:4px}
.euRow{display:flex;align-items:center;gap:9px;padding:6.5px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.euRow.sub{padding-left:12px}
.euRow.sub .euN{color:var(--mut);font-size:11px}
.euN{flex:1;min-width:0;font-size:12px;font-weight:700}
.euV{font-size:12px;color:var(--tx);white-space:nowrap}
.euP{width:64px;height:5px;border-radius:3px;background:rgba(255,255,255,.07);overflow:hidden;flex:0 0 auto}
.euP i{display:block;height:100%;border-radius:3px;background:linear-gradient(90deg,var(--grn),#8be59b)}
.euP i.over{background:linear-gradient(90deg,var(--acc),var(--acc2))}
.euPct{width:38px;text-align:right;font-size:11px;color:var(--mut)}
.euPct.over{color:var(--acc)}
.euFoot{margin-top:9px;font-size:10px;color:var(--mut);line-height:1.5}
.euMiss{color:#c9d47a}
/* groceries — tighter rhythm, calmer rows */
.grocRow{padding:7px 0 !important;gap:9px}
.grocRow .pn{font-size:12.5px;line-height:1.35}
.grocRow .pw{font-size:10.5px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.grocRow .gq{font-size:10px;background:rgba(255,210,77,.12);border:1px solid rgba(255,210,77,.3);color:var(--gold);
  border-radius:999px;padding:1px 7px;margin-left:4px;vertical-align:1px}
.grocGo{padding:6px 11px !important;font-size:11px !important;border-radius:10px !important;flex:0 0 auto;align-self:center}
.grocGrp{margin-top:12px !important;padding-bottom:4px}
/* v29 — HAE key/value setup rows + a breathing-room pass on dense text */
.haeSteps{margin:10px 0 4px;line-height:1.55}
.kvRow{display:flex;flex-direction:column;gap:4px;margin:9px 0}
.kvLab{font-size:9px;letter-spacing:1.6px;text-transform:uppercase;font-weight:900;color:var(--mut)}
.kvCopy{display:block;background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:9px;
  padding:8px 10px;font-size:11px;word-break:break-all;cursor:pointer;position:relative;transition:all .15s;line-height:1.4}
.kvCopy:hover{border-color:rgba(255,210,77,.45)}
.kvCopy:active{transform:scale(.985)}
.kvCopy.copied{border-color:rgba(62,229,148,.6);background:rgba(62,229,148,.08)}
.kvCopy.copied::after{content:"✓ copied";position:absolute;right:8px;top:50%;transform:translateY(-50%);
  font-size:10px;font-weight:800;color:var(--grn)}
.kvSide{font-size:11px;color:var(--mut)}
.kvTx{font-size:11.5px;color:var(--tx);line-height:1.5}
/* breathing room — consistent paragraph rhythm for every prose block */
.alNote{line-height:1.6;margin:12px 0}
.alNote + .alNote{margin-top:12px}
.alNote b{color:var(--tx)}
.tdee{line-height:1.6}
.etaGoal{line-height:1.6;margin-top:9px}
#repEta{line-height:1.7}
.repNote{line-height:1.6;margin-top:12px}
.mcBio{line-height:1.65}
.euFoot{line-height:1.6;margin-top:11px}
.sessSub{line-height:1.55;margin-bottom:10px}
.stHint{line-height:1.5}
.mdesc{line-height:1.5}
.grocHead{line-height:1.55;margin-bottom:8px}
.trEmpty{line-height:1.5}
/* v30 — WORKOUT FLOW: the guided session */
#wflow{position:fixed;inset:0;z-index:88;display:none;place-items:center;padding:20px;
  background:rgba(5,7,13,.96);backdrop-filter:blur(10px)}
#wflow.on{display:grid}
.wfCard{width:100%;max-width:420px;text-align:center;position:relative}
.wfHead{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px}
.wfProg{display:flex;gap:7px}
.wfDot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.14);transition:all .3s}
.wfDot.done{background:rgba(62,229,148,.6)}
.wfDot.live{background:var(--gold);box-shadow:0 0 9px rgba(255,210,77,.6);transform:scale(1.3)}
.wfX{width:38px;height:38px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.05);color:var(--mut);font-size:15px;cursor:pointer}
.wfCount{font-size:11px;letter-spacing:2.5px;color:var(--mut);font-weight:900}
.wfEx{font-family:'Chakra Petch',sans-serif;font-size:26px;font-weight:900;margin:10px 0 6px}
.wfLast{font-size:12.5px;color:var(--mut);margin-bottom:24px;line-height:1.5}
.wfLast b{color:var(--gold)}
.wfRow{display:flex;align-items:center;justify-content:center;gap:14px;margin:14px 0}
.wfLab{width:56px;text-align:right;font-size:9.5px;letter-spacing:1.8px;color:var(--mut);font-weight:900}
.wfStep{width:56px;height:56px;border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.05);
  color:var(--tx);font-size:24px;cursor:pointer;transition:all .12s;touch-action:manipulation}
.wfStep:active{transform:scale(.9);background:rgba(255,210,77,.12)}
.wfVal{min-width:104px;font-family:'Chakra Petch',sans-serif;font-size:34px;font-weight:900;color:var(--gold)}
.wfVal i{font-style:normal;font-size:14px;color:var(--mut);margin-left:3px}
.wfGo{display:block;width:100%;margin:26px 0 0;padding:16px;border-radius:16px;border:none;cursor:pointer;
  background:linear-gradient(90deg,var(--acc),var(--acc2));color:#fff;font-weight:900;font-size:15px;
  font-family:'Chakra Petch',sans-serif;letter-spacing:.5px;box-shadow:0 8px 28px rgba(255,77,141,.35)}
.wfGo:active{transform:scale(.98)}
.wfSub{display:flex;justify-content:space-between;margin-top:16px}
.wfLink{background:none;border:none;color:var(--mut);font-size:12px;cursor:pointer;padding:8px}
.wfLink:hover{color:var(--tx)}
.wfRestRing{position:relative;width:170px;height:170px;margin:6px auto 18px}
.wfRestRing svg{width:100%;height:100%;transform:rotate(-90deg)}
.wfRingBg{fill:none;stroke:rgba(255,255,255,.08);stroke-width:5}
.wfRingFg{fill:none;stroke:var(--grn);stroke-width:5;stroke-linecap:round;transition:stroke-dashoffset 1s linear}
.wfRestT{position:absolute;inset:0;display:grid;place-items:center;font-family:'Chakra Petch',sans-serif;
  font-size:44px;font-weight:900;color:var(--grn)}
.wfRestLab{font-size:10.5px;letter-spacing:2px;color:var(--mut);font-weight:900;margin-bottom:10px}
.wfNext{font-size:13px;color:var(--tx);line-height:1.5}
.wfNext b{color:var(--gold)}
.wfBig{font-size:54px;margin-top:10px}
.wfTitle{font-family:'Chakra Petch',sans-serif;font-size:21px;font-weight:900;margin:12px 0 20px;
  background:linear-gradient(90deg,#fff,var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent}
.wfStats{display:flex;gap:10px;justify-content:center;margin-bottom:16px}
.wfStats>div{flex:1;max-width:120px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:14px;padding:12px 8px}
.wfStats b{display:block;font-family:'Chakra Petch',sans-serif;font-size:22px;color:var(--gold)}
.wfStats span{font-size:9.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--mut);font-weight:800}
.wfHint{font-size:12px;color:var(--mut);line-height:1.55;margin-bottom:6px}
.wfStart{display:block;width:100%;margin:12px 0;padding:14px;border-radius:14px;border:1px solid rgba(255,210,77,.4);
  background:rgba(255,210,77,.08);color:var(--gold);font-weight:900;font-size:13.5px;cursor:pointer;
  font-family:'Chakra Petch',sans-serif;letter-spacing:.5px;transition:all .15s}
.wfStart:hover{background:rgba(255,210,77,.15);transform:translateY(-1px)}
@media (pointer:coarse),(max-width:820px){#wflow{backdrop-filter:none;background:rgba(5,7,13,.98)}}
/* v31 — The Read, equal CTAs, breathing room below */
#guideCard{border-left:3px solid rgba(255,210,77,.5)}
.guideTx{font-size:13.5px;line-height:1.7;color:var(--tx)}
.guideTx b{color:var(--gold)}
.guideAct{display:block;width:100%;margin-top:12px;padding:13px 16px;border-radius:13px;cursor:pointer;
  border:1px solid rgba(255,210,77,.4);background:rgba(255,210,77,.08);color:var(--gold);
  font-weight:900;font-size:13px;font-family:'Chakra Petch',sans-serif;letter-spacing:.4px;transition:all .15s}
.guideAct:hover{background:rgba(255,210,77,.15);transform:translateY(-1px)}
.guideAct:active{transform:scale(.98)}
/* equal-height CTA row — same box, same presence, whatever the label length */
.alBtns .todaybtn,.alBtns .connectBig{min-height:56px;height:auto;flex:1 1 0;font-size:12.5px;line-height:1.3}
/* room to breathe at the bottom of every scroller */
#chatMsgs{padding-bottom:14px}
.chatBar{padding-bottom:calc(18px + env(safe-area-inset-bottom)) !important}
.view{padding-bottom:126px}
.chatChips{margin-bottom:8px}
.guideHint{margin-top:11px;font-size:12px;color:var(--mut);line-height:1.55;border-top:1px dashed rgba(255,255,255,.08);padding-top:10px}
.alBtns .connectBig{margin-top:0} /* its standalone 8px top-margin ate into the stretched flex height */
/* v32 — MITO ROAMS: the street-level companion + cosmetics locker */
.card{position:relative;z-index:2} /* panes sit ABOVE the roamer — he hides under them */
#mitoRoam{position:fixed;left:0;bottom:106px;width:58px;height:58px;z-index:1;cursor:pointer;
  transition:transform 3s ease-in-out;will-change:transform;-webkit-tap-highlight-color:transparent}
#mitoRoam .rIn{display:block;width:100%;height:100%;animation:roamWaddle 1.6s ease-in-out infinite;transform-origin:center bottom}
#mitoRoam .rIn svg{width:100%;height:100%;display:block}
#mitoRoam .rIn.flip{scale:-1 1}
#mitoRoam.egg .rIn{animation:eggBounce 1.15s cubic-bezier(.36,0,.34,1) infinite}
@keyframes roamWaddle{0%,100%{rotate:-4deg;translate:0 0}25%{translate:0 -2px}50%{rotate:4deg;translate:0 0}75%{translate:0 -2px}}
@keyframes eggBounce{0%,100%{translate:0 0;scale:1 1}18%{scale:1.08 .9}42%{translate:0 -13px;scale:.94 1.07}70%{translate:0 0;scale:1 1}84%{scale:1.05 .95}}
#mitoRoam.hop .rIn{animation:mitoHop .6s cubic-bezier(.3,1.7,.4,1)}
#mitoRoam.aura{filter:drop-shadow(0 0 13px rgba(255,210,77,.55))}
#mitoRoam.burst::after{content:"✨";position:absolute;inset:0;display:grid;place-items:center;font-size:26px;
  animation:mitoBurst 1.1s ease forwards;pointer-events:none}
#mitoRoam[data-state=radiant]{filter:drop-shadow(0 0 11px rgba(255,210,77,.5))}
#mitoRoam[data-state=queasy] .rIn{animation-duration:2.6s}
#mitoRoam .mitoSay{position:absolute;left:50%;bottom:calc(100% + 6px);transform:translateX(-50%);
  background:rgba(13,21,36,.96);border:1px solid var(--line);border-radius:12px;padding:7px 10px;
  font-size:11px;line-height:1.35;width:max-content;max-width:210px;opacity:0;pointer-events:none;
  transition:opacity .25s,translate .25s;z-index:3}
#mitoRoam .mitoSay.on{opacity:1;translate:0 -4px}
/* cosmetics locker */
.mitoPv{width:96px;height:96px;margin:2px auto 10px}
.mitoPv svg{width:100%;height:100%;display:block;animation:mitoBreathe 3.4s ease-in-out infinite;transform-origin:center bottom}
.isChip.lock{opacity:.35;cursor:not-allowed;text-decoration:none}
.mcStyle{margin-top:9px;padding:7px 12px;border-radius:999px;border:1px solid rgba(180,123,255,.4);
  background:rgba(180,123,255,.08);color:#c9a8ff;font-size:11px;font-weight:800;cursor:pointer;transition:all .15s}
.mcStyle:hover{background:rgba(180,123,255,.16)}
@media (pointer:coarse),(max-width:820px){#mitoRoam{bottom:112px}}
#mitoRoam{z-index:3} /* the star is VISIBLE by default — he walks the strip above the ticker */
#mitoRoam.under{z-index:1} /* …and physically slips beneath the panes while hiding */
/* v33 — physics Mito + onboarding */
#mitoRoam{transition:transform 3s ease-in-out;touch-action:none;user-select:none}
#mitoRoam.held{cursor:grabbing;z-index:60 !important;transition:none}
#mitoRoam.held .rIn{animation:none;scale:1.12}
#mitoRoam.land .rIn{animation:roamLand .5s cubic-bezier(.3,1.6,.4,1)}
@keyframes roamLand{0%{scale:1 1}35%{scale:1.22 .78}70%{scale:.92 1.08}100%{scale:1 1}}
.obName{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.05);
  color:var(--tx);font-size:14px;font-family:inherit;outline:none}
.obName:focus{border-color:rgba(255,210,77,.5)}
.obSw{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:6px;vertical-align:-1px;border:1px solid rgba(255,255,255,.25)}
/* v34 — roamer full-soul: shared reactions + night sleep */
#mitoRoam.munch .rIn{animation:mitoMunch .85s ease}
#mitoRoam.queasy .rIn{animation:mitoQueasy 1.4s ease}
#mitoRoam.asleep .rIn{animation-duration:6.5s;filter:brightness(.75) saturate(.8)}
/* v35 — street on the quote bar, FAB perch, wants, no sideways scroll */
html,body{overflow-x:hidden;overscroll-behavior-x:none;max-width:100vw}
#mitoRoam{top:0;left:0;bottom:auto}
#mitoRoam.onFab{z-index:66} /* above the chat button while he clowns on it */
.mitoWant{position:absolute;left:50%;top:-6px;translate:-50% 0;font-size:19px;pointer-events:none;
  animation:wantFloat 2.5s ease forwards;filter:drop-shadow(0 2px 6px rgba(0,0,0,.5))}
@keyframes wantFloat{0%{opacity:0;translate:-50% 4px;scale:.5}18%{opacity:1;scale:1.15}
  35%{scale:1}80%{opacity:.95}100%{opacity:0;translate:-50% -34px;scale:.9}}
/* v36 — MITO expansion: hatch, party, held face, evolution road, shiver */
#mitoRoam.hatch .rIn{animation:hatchShake 1.7s ease-in-out}
@keyframes hatchShake{0%,100%{rotate:0deg}10%{rotate:-10deg}20%{rotate:9deg}30%{rotate:-12deg}
  40%{rotate:11deg;scale:1.05 .95}55%{rotate:-13deg;scale:.95 1.06}70%{rotate:12deg;scale:1.1 .9}85%{rotate:-8deg}}
#mitoRoam.party .rIn{animation:mitoParty .5s ease-in-out infinite}
@keyframes mitoParty{0%,100%{translate:0 0;rotate:-8deg}50%{translate:0 -14px;rotate:8deg}}
#mitoRoam[data-state=depleted] .rIn{animation-name:mitoShiver;animation-duration:2.2s}
@keyframes mitoShiver{0%,86%,100%{translate:0 0}88%{translate:-1.5px 0}91%{translate:1.5px 0}94%{translate:-1.5px 0}97%{translate:1px 0}}
.mcRoad{display:flex;align-items:center;justify-content:center;gap:2px;margin:12px 0 2px}
.mcRoadStop{width:46px;text-align:center}
.mcRoadStop svg{width:40px;height:40px;display:block;margin:0 auto}
.mcRoadStop span{font-size:8px;letter-spacing:1px;font-weight:900;color:var(--mut)}
.mcRoadStop.now span{color:var(--gold)}
.mcRoadStop.now{filter:drop-shadow(0 0 8px rgba(255,210,77,.45))}
.mcRoadStop.future{filter:grayscale(.9) brightness(.45)}
.mcRoadStop.past{opacity:.75}
.mcRoadArrow{font-style:normal;color:var(--mut);opacity:.5;font-size:13px}
.mcRoadCap{text-align:center;font-size:10.5px;color:var(--mut);margin-bottom:4px}
.mcRoadCap b{color:var(--gold)}
/* v37 — goals card */
.glRow{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.glRow.done .glTx{text-decoration:line-through;color:var(--mut)}
.glIc{flex:0 0 auto;font-size:15px}
.glTx{flex:1;min-width:0;font-size:12.5px;line-height:1.45}
.glDue{flex:0 0 auto;font-size:10px;font-weight:800;color:var(--gold);background:rgba(255,210,77,.1);
  border:1px solid rgba(255,210,77,.3);border-radius:999px;padding:2px 8px}
.glDue.late{color:var(--acc2);background:rgba(255,77,141,.1);border-color:rgba(255,77,141,.35)}
/* v38 — mystery road, arc hops */
.mcRoadStop.future{filter:none}
.mcRoadStop.future svg{filter:brightness(0);opacity:.5}
.mcRoadStop.future{position:relative}
.mcRoadStop.future::after{content:"?";position:absolute;top:11px;left:0;right:0;text-align:center;
  font-size:15px;font-weight:900;color:rgba(255,255,255,.55);font-family:'Chakra Petch',sans-serif}
.rArc{display:block;width:100%;height:100%}
#mitoRoam.arcing .rArc{animation:arcJump var(--hopD,.8s) 1}
@keyframes arcJump{0%{translate:0 0;animation-timing-function:cubic-bezier(.25,.6,.5,1)}
  46%{translate:0 var(--hopH,-48px);animation-timing-function:cubic-bezier(.5,0,.75,.4)}100%{translate:0 0}}
/* v39 — he stands ON the quote bar (above z59), still under FAB(65)+overlays(85+) */
#mitoRoam{z-index:61}
#mitoRoam.held{z-index:64 !important}
#mitoRoam.under{z-index:1}
/* v40 — rest-screen Mito, urge chip, installed-PWA safe area */
.wfMito{width:64px;margin:4px auto 12px;text-align:center}
.wfMito svg{width:52px;height:52px;display:block;margin:0 auto;animation:mitoParty 1.1s ease-in-out infinite;transform-origin:center bottom}
.wfMito i{display:block;font-style:italic;font-size:10.5px;color:var(--mut);margin-top:4px;line-height:1.4}
.mcChip.urge{border-color:rgba(255,210,77,.55);color:var(--gold);animation:urgePulse 1.6s ease-in-out infinite}
@keyframes urgePulse{50%{box-shadow:0 0 12px rgba(255,210,77,.4);transform:scale(1.04)}}
.tabbar{padding-bottom:env(safe-area-inset-bottom)}
/* v42 — roamer bubble: kill the top/bottom collision with the hero rule + clamp to screen */
#mitoRoam .mitoSay{top:auto;min-width:0;white-space:normal;line-height:1.35}
#mitoRoam .mitoSay.edgeL{left:2px;right:auto;transform:none}
#mitoRoam .mitoSay.edgeR{left:auto;right:2px;transform:none}
/* v43 — grocery paste import */
.grocRm{margin-left:8px;width:20px;height:20px;border-radius:7px;border:1px solid var(--line);background:rgba(255,255,255,.04);
  color:var(--mut);font-size:10px;cursor:pointer;vertical-align:1px}
.grocRm:hover{color:var(--acc2);border-color:rgba(255,77,141,.4)}
/* v44 — set-screen quick targets */
.wfQuick{display:flex;gap:8px;justify-content:center;margin-top:16px}
.wfQ{padding:9px 13px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.04);
  color:var(--mut);font-size:12px;font-weight:800;cursor:pointer;transition:all .12s}
.wfQ.hot{border-color:rgba(255,210,77,.4);color:var(--gold)}
.wfQ.on{border-color:var(--grn);color:var(--grn);background:rgba(62,229,148,.1)}
.wfQ:active{transform:scale(.93)}
/* v45 — audit pass: readiness note on its own line */
.readyNote{display:block;margin-top:4px;font-size:10px;color:var(--mut);opacity:.85}
/* v47 — the chat knows (and shows) everything */
#brainStrip{padding:7px 16px;font-size:10.5px;color:var(--mut);letter-spacing:.3px;
  border-bottom:1px solid rgba(255,255,255,.06);background:rgba(180,123,255,.05);
  white-space:nowrap;overflow-x:auto;scrollbar-width:none}
#brainStrip::-webkit-scrollbar{display:none}
.ctools{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}
.tchip{font-style:normal;font-size:10px;font-weight:800;color:var(--mut);
  border:1px solid rgba(180,123,255,.3);background:rgba(180,123,255,.08);
  border-radius:999px;padding:3px 9px}
.chatCard{animation:chatUp .32s cubic-bezier(.2,.9,.3,1)}
@keyframes chatUp{from{transform:translateY(26px);opacity:.4}to{transform:translateY(0);opacity:1}}
.cm.model{border-left:2px solid rgba(180,123,255,.35)}
/* v48 — gym-grade workout flow */
.wfRestPick{display:flex;gap:8px;justify-content:center;margin:2px 0 8px}
.wfVs{font-size:12.5px;font-weight:800;color:var(--acc2);margin-bottom:10px}
.wfVs.up{color:var(--grn)}
/* v50 — the entrance */
#mitoRoam.rollin .rIn{animation:rollIn 1.4s cubic-bezier(.3,.6,.4,1)}
@keyframes rollIn{0%{rotate:-360deg}70%{rotate:12deg}100%{rotate:0deg}}
/* v51 — grounded shadow physics */
#mitoRoam .rIn svg > ellipse:first-of-type{opacity:0} /* the baked-in shadow travels with the body — the real one lives below */
.rShadow{position:absolute;left:50%;bottom:1px;translate:-50% 0;width:36px;height:8px;border-radius:50%;
  background:radial-gradient(ellipse at center,rgba(0,0,0,.5),transparent 68%);
  transition:scale .35s ease,opacity .35s ease;pointer-events:none}
#mitoRoam.arcing .rShadow{animation:shadowArc var(--hopD,.8s) ease}
@keyframes shadowArc{0%,100%{scale:1;opacity:1}45%{scale:.5;opacity:.45}}
#mitoRoam.held .rShadow{scale:.4;opacity:.25}
#mitoRoam.under .rShadow{opacity:0}
#mitoRoam.egg .rShadow{width:30px}
/* v52 — desktop readability: the mobile-first px scale is too small at
   monitor distance. Tiered zoom on content containers (NOT body — the
   roamer's fixed-position math stays 1:1 with the viewport). */
@media (min-width:1280px){
  .view,#appbar,#ticker,.tabbar,.chatCard,.isCard,.gCard,.brInner,.celebCard,.wfCard{zoom:1.12}
}
@media (min-width:1700px){
  .view,#appbar,#ticker,.tabbar,.chatCard,.isCard,.gCard,.brInner,.celebCard,.wfCard{zoom:1.22}
}
/* v53 — panel micro-fixes */
.pmT{white-space:nowrap}

/* ── v54: sign-in lock, My Plan sheet, progress photos, goal buttons, wf swap ── */
.lockG{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;background:#fff;color:#1a1c22;border-color:rgba(255,255,255,.85);box-shadow:0 4px 18px rgba(0,0,0,.45)}
.lockG svg{flex:0 0 auto}
.lockOr{margin:14px 0 10px;font-size:10px;letter-spacing:.14em;color:var(--mut);text-transform:uppercase;display:flex;align-items:center;gap:10px}
.lockOr::before,.lockOr::after{content:"";flex:1;height:1px;background:var(--line)}
.lockIn{width:100%;margin:0 0 8px;padding:11px 13px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.05);color:var(--txt);font-size:13px;font-family:inherit}
.lockIn:focus{outline:none;border-color:rgba(255,138,61,.55)}
.lockRow{display:flex;gap:8px;margin-top:2px}
.lockRow .todaybtn{flex:1;min-height:42px;font-size:12px}
.lockLegacy{margin-top:16px;background:none;border:none;color:var(--mut);font-size:11px;cursor:pointer;text-decoration:underline;text-underline-offset:3px;font-family:inherit}
.lockLegacy:hover{color:var(--txt)}
.glBtn{flex:0 0 auto;width:26px;height:26px;border-radius:8px;border:1px solid var(--line);background:rgba(255,255,255,.05);color:var(--mut);font-size:12px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;margin-left:4px}
.glBtn.win{border-color:rgba(80,220,140,.5);color:#5be49b;background:rgba(80,220,140,.1)}
.glBtn:disabled{opacity:.4}
.planRow{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:8px;padding:6px 0}
.planRow .wfLab{flex:1 1 auto;width:auto;text-align:left}
.planRow .wfStep{width:36px;height:36px;min-height:36px;border-radius:12px;font-size:17px;flex:0 0 auto}
.planRow .wfVal{min-width:88px;text-align:center;font-size:19px;flex:0 0 auto}
.planHabits{display:flex;flex-direction:column;gap:4px;margin:6px 0}
.planHab{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 10px;border:1px solid var(--line);border-radius:11px;background:rgba(255,255,255,.03);font-size:12px}
.planHab>span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.planDow{font-style:normal;color:var(--mut);font-size:10px;margin-left:4px}
.planCore{font-style:normal;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--mut);border:1px solid var(--line);border-radius:6px;padding:2px 6px}
.planAdd{display:flex;flex-direction:column;gap:7px;margin-top:9px}
.planAdd .lockIn{margin:0}
.planDows .isChip{min-width:32px;text-align:center;padding:5px 0}
.planAdd .todaybtn{min-height:38px}
.planTape{display:flex;gap:8px}
.planTape .lockIn{margin:0;text-align:center}
.wfSwapList{display:flex;flex-direction:column;gap:6px;margin:12px 0;max-height:44vh;overflow-y:auto}
.wfSwapRow{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.04);color:var(--txt);font-size:13px;font-weight:700;cursor:pointer;text-align:left;font-family:inherit}
.wfSwapRow i{font-style:normal;color:var(--mut);font-size:10.5px;font-weight:600;flex:0 0 auto}
.wfSwapRow:active{background:rgba(255,138,61,.12);border-color:rgba(255,138,61,.4)}
.phGal{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}
.phChip{padding:6px 10px;border-radius:9px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--txt);font-size:10.5px;font-weight:700;cursor:pointer;font-family:inherit}
.phChip.on{border-color:rgba(255,138,61,.6);background:rgba(255,138,61,.14);color:var(--acc)}
.phCmp{display:flex;gap:8px;margin-top:10px}
.phCmp figure{flex:1;min-width:0;margin:0}
.phCmp img{width:100%;border-radius:12px;border:1px solid var(--line);display:block}
.phCmp figcaption{font-size:10px;color:var(--mut);text-align:center;margin-top:4px}

/* ── v58: FitMito wordmark ── */
.wmG{background:linear-gradient(135deg,var(--acc),var(--acc2));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ── v59: guide movement demo ── */
.gAnimWrap{margin:6px 0 2px}
.gAnimWrap .gH{margin-bottom:4px}
.gAnimSvg{width:100%;max-width:230px;height:150px;display:block;margin:0 auto;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:14px}

/* ── v59: benchmark-style 2-col lock, swap sections ── */
.lockWrap{display:grid;grid-template-columns:1fr;gap:36px;align-items:center;max-width:980px;width:100%;justify-items:center}
.lockAside{display:none;position:relative}
.lockAside::before{content:"";position:absolute;inset:-40px;background:radial-gradient(55% 55% at 30% 30%,rgba(255,138,61,.13),transparent 70%);pointer-events:none}
@media (min-width:900px){
  .lockWrap{grid-template-columns:1.05fr .95fr;justify-items:stretch}
  .lockAside{display:block;max-width:430px}
  #lock .lockcard{justify-self:end;width:100%;max-width:360px}
}
.laBrand{display:flex;align-items:center;gap:9px;margin-bottom:24px;font-family:'Chakra Petch',sans-serif;font-size:19px;letter-spacing:.4px}
.laHead{font-family:'Chakra Petch',sans-serif;font-size:27px;line-height:1.28;font-weight:700}
.laSub{color:var(--mut);font-size:13.5px;margin:10px 0 26px;line-height:1.6}
.laProps{list-style:none;display:flex;flex-direction:column;gap:15px;margin:0;padding:0}
.laProps li{display:flex;gap:12px;align-items:flex-start}
.laIc{width:35px;height:35px;flex:0 0 auto;display:grid;place-items:center;background:rgba(255,138,61,.1);border:1px solid rgba(255,138,61,.28);border-radius:11px;font-size:16px}
.laProps b{display:block;font-size:13.5px;font-weight:700}
.laProps i{display:block;font-style:normal;color:var(--mut);font-size:12px;margin-top:2px;line-height:1.5}
.laTrust{margin-top:26px;color:var(--mut);font-size:11.5px}
.laTrust a{color:var(--acc);text-decoration:none}
.lockLinks{display:flex;justify-content:center;gap:18px;margin-top:14px}
.wfSwapH{font-size:9.5px;letter-spacing:.16em;color:var(--mut);font-weight:900;text-transform:uppercase;margin:8px 0 2px;text-align:left}
.wfSwapRow>span{min-width:0;text-align:left}
.wfMus{display:block;font-style:normal;font-size:10px;color:var(--acc);font-weight:600;margin-top:2px}

/* ── v61: onboarding wizard, sign-in loading, scan progress ── */
.obHead{margin-bottom:4px}
.obDots{display:flex;gap:6px;margin-bottom:12px}
.obDots i{height:4px;flex:1;border-radius:2px;background:rgba(255,255,255,.1)}
.obDots i.done{background:rgba(255,138,61,.45)}
.obDots i.on{background:linear-gradient(90deg,var(--acc),var(--acc2))}
.obStepT{font-family:'Chakra Petch',sans-serif;font-size:17px;font-weight:700}
.obStepS{color:var(--mut);font-size:12px;line-height:1.55;margin-top:5px}
.obBack{margin-top:14px;background:none;border:none;color:var(--mut);font-size:12px;cursor:pointer;font-family:inherit;text-decoration:underline;text-underline-offset:3px;padding:0}
#lockLoad{display:none}
#lock.loading #lockForm{display:none}
#lock.loading #lockLoad{display:block}
.llBar{height:5px;border-radius:3px;background:rgba(255,255,255,.08);overflow:hidden;margin:18px 0 12px}
.llBar i{display:block;height:100%;width:40%;border-radius:3px;background:linear-gradient(90deg,var(--acc),var(--acc2));animation:llSweep 1.15s ease-in-out infinite}
@keyframes llSweep{0%{transform:translateX(-110%)}100%{transform:translateX(280%)}}
.llMsg{color:var(--mut);font-size:12.5px;min-height:17px}
.vsBar{height:6px;border-radius:3px;background:rgba(255,255,255,.08);overflow:hidden;margin:4px 0 8px}
.vsBar i{display:block;height:100%;width:0;border-radius:3px;background:linear-gradient(90deg,var(--acc),var(--acc2));transition:width .8s ease}
.vsMsg{color:var(--mut);font-size:12px;min-height:16px}

/* ── v64: guide legibility on mobile — solid card, no bleed-through over the workout ── */
@media (pointer:coarse),(max-width:820px){
  .gCard{background:rgba(11,15,26,.98);backdrop-filter:none}
  #guide{backdrop-filter:none;background:rgba(5,7,13,.94)}
}

/* ── v65: Mito slip-under crouch + Train consolidation ── */
#mitoRoam .crouch .rIn{transform:scaleY(.8);transform-origin:50% 100%;transition:transform .22s ease}

/* ── v67: zoom-tier compensation — the zoom multiplies vh heights and eats the
   header gap; every zoomed card with a vh dimension needs tier-divided values ── */
@media (min-width:1280px){
  .view{padding-top:20px}
  .chatCard{height:78vh}
  .gCard,.isCard{max-height:78vh}
}
@media (min-width:1700px){
  .view{padding-top:22px}
  .chatCard{height:70vh}
  .gCard,.isCard{max-height:70vh}
}
