/* ============================================================
   T90 Portal — Reference-exact stylesheet
   Source of truth: /t90-design-reference.html
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

:root{
  --bg:#060606;
  --bg2:#101010;
  --card:#151515;
  --card2:#1b1b1b;
  --border:#232323;
  --silver:#7a7a7a;
  --bone:#f0ede6;
  --bonedim:#a8a5a0;
  --gold:#c9a84c;
  --green:#86efac;
  --blue:#60a5fa;
  --red:#f87171;
  --purple:#c084fc;
  --amber:#fbbf24;
}

*{margin:0;padding:0;box-sizing:border-box}

html,body{background:var(--bg);color:var(--bone);font-family:'Rajdhani',sans-serif;font-size:14px}
body{max-width:420px;margin:0 auto;min-height:100vh;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;color:inherit;cursor:pointer}
input,select,textarea{font-family:'Rajdhani',sans-serif}
iframe{border:0}

/* SCREEN SHELL */
.app-root{position:relative;padding-top:env(safe-area-inset-top,0);padding-bottom:env(safe-area-inset-bottom,0)}
.screen{display:none;padding:20px 20px 76px;min-height:100vh}
.screen.active{display:block}
.screen.has-tabs{padding-bottom:calc(76px + env(safe-area-inset-bottom,0))}

.screen-head{display:flex;align-items:center;gap:12px;padding:max(4px,env(safe-area-inset-top,0)) 0 14px}
.app-head{padding-top:max(0px,env(safe-area-inset-top,0))}
.btn-back{background:transparent;border:1px solid var(--border);color:var(--bone);width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:16px;border-radius:0}
.head-title{font-family:'Rajdhani',sans-serif;font-size:18px;letter-spacing:4px;color:var(--bone);font-weight:700;text-transform:uppercase;flex:1}
.head-sub{font-size:9px;letter-spacing:3px;color:var(--silver);font-family:'Space Mono',monospace;text-transform:uppercase}

.app-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:14px;gap:12px}
.head-hello{font-size:10px;letter-spacing:3px;color:var(--silver);font-family:'Space Mono',monospace;text-transform:uppercase}
.head-name{font-family:'Rajdhani',sans-serif;font-size:26px;letter-spacing:4px;color:var(--bone);font-weight:700;text-transform:uppercase;line-height:1.1}
.head-avatar{width:40px;height:40px;border-radius:50%;background:var(--card);border:1px solid var(--border);color:var(--bone);font-family:'Space Mono',monospace;font-size:12px;letter-spacing:2px;display:flex;align-items:center;justify-content:center}

/* TYPOGRAPHY */
.sh{font-family:'Rajdhani',sans-serif;font-size:26px;letter-spacing:4px;color:var(--bone);font-weight:700;text-transform:uppercase}
.ss{font-size:10px;color:var(--silver);letter-spacing:3px;font-family:'Space Mono',monospace;margin-top:1px;margin-bottom:14px;text-transform:uppercase}
.ct{font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:3px;color:var(--bonedim);margin:14px 0 9px;font-weight:700;text-transform:uppercase}
label{display:block;font-size:9px;letter-spacing:4px;color:var(--silver);margin-bottom:5px;font-family:'Space Mono',monospace;text-transform:uppercase}

/* BUTTONS */
.btn-bone{padding:12px 20px;background:var(--bone);color:#060606;border:none;font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:5px;cursor:pointer;font-weight:700;text-transform:uppercase;border-radius:0}
.btn-sm{padding:8px 16px;background:var(--bone);color:#060606;border:none;font-family:'Rajdhani',sans-serif;font-size:13px;letter-spacing:4px;cursor:pointer;font-weight:700;text-transform:uppercase;border-radius:0}
.btn-outline{padding:7px 13px;background:transparent;border:1px solid var(--silver);color:var(--bone);font-family:'Rajdhani',sans-serif;font-size:12px;letter-spacing:3px;cursor:pointer;font-weight:600;text-transform:uppercase;border-radius:0}
.btn-bone.full,.btn-sm.full,.btn-outline.full{width:100%;display:block}
.btn-bone[disabled],.btn-sm[disabled]{opacity:0.4;cursor:not-allowed}

/* CARDS */
.card{background:var(--card);border:1px solid var(--border);padding:14px;margin-bottom:8px;border-radius:0}
.badge{display:inline-block;font-size:8px;letter-spacing:4px;background:var(--bone);color:#060606;padding:2px 8px;font-family:'Space Mono',monospace;margin-bottom:6px;text-transform:uppercase}

/* HOME */
.greet-name{font-family:'Rajdhani',sans-serif;font-size:30px;letter-spacing:3px;line-height:1.05;color:var(--bone);font-weight:700;text-transform:uppercase}
.greet-d{font-size:10px;color:var(--silver);letter-spacing:3px;margin-top:3px;margin-bottom:16px;font-family:'Space Mono',monospace;text-transform:uppercase}

.sg{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:8px}
.sg.three{grid-template-columns:1fr 1fr 1fr}
.sc{background:var(--card);border:1px solid var(--border);padding:12px;border-radius:0}
.sl{font-size:8px;letter-spacing:4px;color:var(--silver);font-family:'Space Mono',monospace;text-transform:uppercase}
.sv{font-family:'Rajdhani',sans-serif;font-size:26px;line-height:1.1;color:var(--bone);font-weight:700}
.su{font-size:11px;color:var(--silver)}
.sc-note{font-size:10px;margin-top:1px;font-family:'Space Mono',monospace;letter-spacing:1px}

.tw-card{background:var(--card);border:1px solid var(--border);padding:14px;margin-bottom:8px;border-radius:0}
.tw-title{font-family:'Rajdhani',sans-serif;font-size:20px;letter-spacing:3px;margin-bottom:2px;color:var(--bone);font-weight:700;text-transform:uppercase}
.tw-meta{font-size:11px;color:var(--silver);letter-spacing:1px;font-family:'Space Mono',monospace}

/* DAY TABS */
.dtabs{display:flex;gap:4px;overflow-x:auto;margin-bottom:12px;padding-bottom:2px}
.dtabs::-webkit-scrollbar{display:none}
.dtab{flex-shrink:0;padding:5px 10px;background:var(--card);border:1px solid var(--border);font-size:9px;letter-spacing:2px;cursor:pointer;font-family:'Space Mono',monospace;color:var(--silver);text-align:center;text-transform:uppercase;border-radius:0;min-width:54px}
.dtab.on{background:var(--bone);color:#060606;border-color:var(--bone)}
.dtab small{display:block;font-size:7px;margin-top:1px;letter-spacing:1px}

/* EXERCISE */
.ex-card{background:var(--card);border:1px solid var(--border);margin-bottom:7px;overflow:hidden;border-radius:0}
.ex-card.open{border-color:var(--silver)}
.ex-hd{padding:12px 14px;display:flex;align-items:center;gap:10px;cursor:pointer}
.ex-num{width:24px;height:24px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Space Mono',monospace;font-size:9px;color:var(--silver);flex-shrink:0}
.ex-name{font-family:'Rajdhani',sans-serif;font-size:16px;letter-spacing:2px;color:var(--bone);font-weight:700;text-transform:uppercase}
.ex-meta{font-size:10px;color:var(--silver);letter-spacing:1px;font-family:'Space Mono',monospace;text-transform:uppercase;margin-top:1px}
.ex-chev{color:var(--silver);font-size:9px;margin-left:4px;font-family:'Space Mono',monospace}
.chk{width:20px;height:20px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:9px;cursor:pointer;background:transparent;color:var(--silver)}
.chk.done{background:rgba(134,239,172,0.12);border-color:rgba(134,239,172,0.5);color:var(--green)}

.ex-body{padding:0 14px 13px;border-top:1px solid var(--border);display:none}
.ex-card.open .ex-body{display:block}
.ex-video{width:100%;background:#000;border:1px solid var(--border);margin:10px 0;padding-bottom:56.25%;position:relative;overflow:hidden}
.ex-video iframe{position:absolute;inset:0;width:100%;height:100%}
.ex-video-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--silver);font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;text-transform:uppercase}

.srow{display:flex;gap:5px;align-items:center;padding:7px 0;border-bottom:1px solid rgba(255,255,255,0.04)}
.slb{font-size:8px;letter-spacing:2px;color:var(--silver);width:34px;font-family:'Space Mono',monospace;text-transform:uppercase}
.sinp{flex:1;background:var(--bg2);border:1px solid var(--border);padding:6px 7px;color:var(--bone);font-family:'Space Mono',monospace;font-size:12px;text-align:center;outline:none;max-width:62px;border-radius:0}
.sinp:focus{border-color:var(--silver)}
.srow-x{color:var(--border)}
.srow-check{padding:6px 9px;background:transparent;border:1px solid var(--border);color:var(--silver);font-size:9px;cursor:pointer;font-family:'Space Mono',monospace;border-radius:0}
.srow-check.on{background:rgba(134,239,172,0.08);border-color:rgba(134,239,172,0.4);color:var(--green)}
.srow-del{padding:6px 8px;background:transparent;border:1px solid var(--border);color:var(--silver);font-size:9px;cursor:pointer;font-family:'Space Mono',monospace;border-radius:0}
.srow-del:hover{border-color:var(--red);color:var(--red)}
.ex-notes{width:100%;margin-top:8px;background:var(--bg2);border:1px solid var(--border);color:var(--bone);padding:8px;font-family:'Space Mono',monospace;font-size:11px;min-height:50px;border-radius:0;outline:none;resize:vertical}
.ex-add-set{margin-top:8px;padding:6px 10px;background:transparent;border:1px solid var(--border);color:var(--silver);font-family:'Space Mono',monospace;font-size:9px;letter-spacing:2px;text-transform:uppercase;border-radius:0}

/* PROFILE HERO */
.phero{margin:-20px -20px 0;padding:0 20px;height:165px;background:linear-gradient(180deg,#0a0a0a,var(--bg));position:relative;overflow:hidden;display:flex;align-items:flex-end}
.phero-bg{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 29px,rgba(255,255,255,0.013) 30px),repeating-linear-gradient(90deg,transparent,transparent 29px,rgba(255,255,255,0.013) 30px)}
.phero-c{position:relative;z-index:2;padding-bottom:13px;display:flex;align-items:flex-end;gap:13px}
.rank-out{width:64px;height:64px;border-radius:50%;border:2px solid var(--gold);background:var(--card);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;box-shadow:0 0 18px rgba(201,168,76,0.12)}
.rank-in{font-family:'Rajdhani',sans-serif;font-size:28px;color:var(--gold);line-height:1;font-weight:700}
.rlbl{position:absolute;bottom:-5px;left:50%;transform:translateX(-50%);background:var(--gold);color:#060606;font-size:7px;font-family:'Space Mono',monospace;padding:1px 5px;white-space:nowrap;letter-spacing:1px}
.pname{font-family:'Rajdhani',sans-serif;font-size:22px;letter-spacing:3px;line-height:1;color:var(--bone);font-weight:700;text-transform:uppercase}
.phandle{font-size:9px;color:var(--silver);letter-spacing:3px;font-family:'Space Mono',monospace;margin-top:2px;text-transform:uppercase}
.pclass{display:inline-block;margin-top:5px;font-size:8px;letter-spacing:3px;border:1px solid rgba(168,85,247,0.5);color:var(--purple);padding:2px 7px;font-family:'Space Mono',monospace;text-transform:uppercase}

.xp-sec{padding:12px 0;border-bottom:1px solid var(--border);margin-bottom:12px}
.xp-lbl{display:flex;justify-content:space-between;font-size:9px;font-family:'Space Mono',monospace;color:var(--silver);margin-bottom:6px;letter-spacing:2px;text-transform:uppercase}
.xp-out{height:5px;background:var(--card2)}
.xp-in{height:100%;background:linear-gradient(90deg,var(--silver),var(--bone))}
.xp-sub{font-size:9px;color:var(--silver);font-family:'Space Mono',monospace;margin-top:4px;letter-spacing:2px;text-transform:uppercase}

.attr-row{display:flex;flex-direction:column;gap:7px;margin-bottom:12px}
.attr-i{display:flex;align-items:center;gap:9px}
.attr-n{font-size:9px;letter-spacing:2px;width:80px;color:var(--silver);font-family:'Space Mono',monospace;text-transform:uppercase}
.attr-bo{flex:1;height:3px;background:var(--card2)}
.attr-bi{height:100%}
.attr-v{font-family:'Rajdhani',sans-serif;font-size:14px;width:26px;text-align:right;color:var(--bone);font-weight:700}

/* SIDE QUESTS */
.sq-card{background:var(--card);border:1px solid var(--border);margin-bottom:7px;padding:12px 13px;border-radius:0}
.sq-card.done-q{border-color:rgba(134,239,172,0.3);background:rgba(134,239,172,0.02)}
.sq-card.pending{border-color:rgba(201,168,76,0.3);background:rgba(201,168,76,0.02)}
.sq-top{display:flex;align-items:flex-start;gap:10px}
.sq-icon{font-size:19px;flex-shrink:0;margin-top:1px}
.sq-name{font-family:'Rajdhani',sans-serif;font-size:15px;letter-spacing:2px;color:var(--bone);font-weight:700;text-transform:uppercase}
.sq-desc{font-size:12px;color:var(--silver);margin-top:1px;line-height:1.4;font-family:'Space Mono',monospace}
.sq-xp{font-family:'Rajdhani',sans-serif;font-size:13px;color:var(--gold);letter-spacing:2px;font-weight:700}
.sq-xp-tag{font-size:9px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:2px;text-transform:uppercase}
.sq-bottom{margin-top:5px;display:flex;align-items:center;gap:8px}
.sq-status{font-size:9px;font-family:'Space Mono',monospace;padding:3px 8px;border:1px solid;flex-shrink:0;letter-spacing:2px;text-transform:uppercase}
.sq-status.open{color:var(--bone);border-color:var(--border)}
.sq-status.pending{color:var(--amber);border-color:rgba(251,191,36,0.4)}
.sq-status.approved{color:var(--green);border-color:rgba(134,239,172,0.4)}
.sq-actions{display:flex;gap:6px;margin-top:10px}

/* NUTRITION RING */
.mring-sec{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--border);padding:14px;margin-bottom:8px;border-radius:0}
.mring{position:relative;width:86px;height:86px;flex-shrink:0}
.mring svg{transform:rotate(-90deg)}
.mrc{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.mrc-cal{font-family:'Rajdhani',sans-serif;font-size:20px;line-height:1;color:var(--bone);font-weight:700}
.mrc-sub{font-size:9px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:1px}
.macro-row{display:flex;align-items:center;gap:7px;margin-bottom:7px}
.macro-row:last-child{margin-bottom:0}
.macro-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.macro-lb{font-size:9px;color:var(--silver);font-family:'Space Mono',monospace;width:50px;letter-spacing:2px;text-transform:uppercase}
.macro-bo{flex:1;height:3px;background:var(--card2)}
.macro-bi{height:100%}
.macro-v{font-size:10px;font-family:'Space Mono',monospace;width:40px;text-align:right}

/* MEAL SLOTS */
.meal-slot{background:var(--card);border:1px solid var(--border);margin-bottom:7px}
.meal-slot .ms-head{padding:12px 14px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;gap:10px}
.ms-title{font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:3px;color:var(--bone);font-weight:700;text-transform:uppercase}
.ms-kcal{font-size:10px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:2px;margin-top:2px;text-transform:uppercase}
.ms-chev{color:var(--silver);font-size:10px}
.ms-body{display:none;padding:0 14px 13px;border-top:1px solid var(--border)}
.meal-slot.open .ms-body{display:block}
.food-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.04);gap:10px}
.food-name{font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:1px;color:var(--bone);font-weight:600}
.food-macros{font-size:9px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:1px;margin-top:1px;text-transform:uppercase}
.food-kcal{font-family:'Space Mono',monospace;font-size:11px;color:var(--bone);letter-spacing:1px}
.water-cups{display:grid;grid-template-columns:repeat(8,1fr);gap:5px;margin-top:8px}
.cup{aspect-ratio:1;background:transparent;border:1px solid var(--border);cursor:pointer;border-radius:0;color:var(--silver);display:flex;align-items:center;justify-content:center;padding:0}
.cup svg{width:60%;height:60%;display:block}
.cup.active{color:var(--blue);background:rgba(96,165,250,0.08);border-color:var(--blue)}
.cup.active svg path{fill:var(--blue);stroke:var(--blue)}

/* BOTTOM NAV */
.bnav{position:fixed;bottom:0;left:0;right:0;height:calc(56px + env(safe-area-inset-bottom,0));padding-bottom:env(safe-area-inset-bottom,0);background:rgba(6,6,6,0.98);border-top:1px solid var(--border);display:flex;max-width:420px;margin:0 auto;z-index:50}
.ni{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;border-top:2px solid transparent;background:transparent;border-left:none;border-right:none;border-bottom:none;padding:0}
.ni.on{border-top-color:var(--bone)}
.ni-ic{font-size:16px;line-height:1}
.ni-lb{font-size:8px;letter-spacing:2px;color:var(--silver);font-family:'Space Mono',monospace;text-transform:uppercase}
.ni.on .ni-lb{color:var(--bone)}

/* TOGGLES */
.toggle{width:36px;height:18px;border-radius:9px;background:var(--card2);border:1px solid var(--border);position:relative;cursor:pointer;flex-shrink:0}
.toggle.on{background:rgba(134,239,172,0.25);border-color:rgba(134,239,172,0.5)}
.toggle::after{content:'';position:absolute;width:12px;height:12px;border-radius:50%;background:var(--silver);top:2px;left:2px;transition:all 0.2s}
.toggle.on::after{left:18px;background:var(--green)}

/* FORMS */
.app-form{display:flex;flex-direction:column;gap:12px}
.f-group{display:flex;flex-direction:column}
.f-row{display:flex;gap:10px}
.f-row .f-group{flex:1}
input[type=text],input[type=email],input[type=password],input[type=tel],input[type=number],select,textarea{background:var(--bg2);border:1px solid var(--border);padding:10px 12px;color:var(--bone);border-radius:0;font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:1px;outline:none;width:100%}
input:focus,select:focus,textarea:focus{border-color:var(--silver)}
textarea{resize:vertical;min-height:72px;font-family:'Space Mono',monospace;font-size:12px}

.foot-link{margin-top:18px;text-align:center;font-size:10px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:2px;text-transform:uppercase}
.foot-link a{color:var(--bone);border-bottom:1px solid var(--border)}

/* PRICING */
.brand{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.brand-txt{font-family:'Rajdhani',sans-serif;font-size:20px;letter-spacing:3px;color:var(--bone);font-weight:700;text-transform:uppercase}
.brand-txt em{font-style:normal;color:var(--gold)}
.heartbeat-logo{flex-shrink:0;display:block;overflow:visible}
.heartbeat-logo .hb-bg{opacity:0.55}
.heartbeat-logo .hb-pulse{stroke-dasharray:20 110;stroke-dashoffset:0;filter:drop-shadow(0 0 3px rgba(201,168,76,0.7));animation:ecgTrace 2s linear infinite}
@keyframes ecgTrace{0%{stroke-dashoffset:40}100%{stroke-dashoffset:-90}}
@media (prefers-reduced-motion: reduce){.heartbeat-logo .hb-pulse{animation:none}}
.eyebrow-mini{font-size:9px;letter-spacing:4px;color:var(--silver);font-family:'Space Mono',monospace;text-transform:uppercase;margin-bottom:10px}
.big-title{font-family:'Rajdhani',sans-serif;font-size:32px;letter-spacing:3px;line-height:1.05;color:var(--bone);font-weight:700;text-transform:uppercase;margin-bottom:10px}
.big-title .accent{color:var(--gold)}
.lede{font-size:13px;color:var(--bonedim);line-height:1.5;margin-bottom:18px;font-family:'Space Mono',monospace;letter-spacing:0.5px}

.plan-stack{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.plan-card{background:var(--card);border:1px solid var(--border);border-radius:0;padding:16px;text-align:left;position:relative;color:var(--bone);cursor:pointer;width:100%}
.plan-card.featured{border-color:var(--gold)}
.plan-badge{position:absolute;top:-1px;right:14px;background:var(--gold);color:#060606;font-family:'Space Mono',monospace;font-size:8px;letter-spacing:2px;padding:3px 8px;text-transform:uppercase}
.plan-name{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:4px;color:var(--silver);text-transform:uppercase;margin-bottom:8px}
.plan-price{font-family:'Rajdhani',sans-serif;font-size:32px;color:var(--bone);font-weight:700;letter-spacing:2px}
.plan-price span{font-size:12px;color:var(--silver);letter-spacing:2px;margin-left:4px;font-family:'Space Mono',monospace}
.plan-bullets{list-style:none;margin:12px 0;padding:0;display:flex;flex-direction:column;gap:6px}
.plan-bullets li{font-size:12px;color:var(--bonedim);font-family:'Space Mono',monospace;letter-spacing:0.5px;padding-left:16px;position:relative}
.plan-bullets li::before{content:'◆';position:absolute;left:0;top:0;color:var(--gold);font-size:8px}
.plan-cta{margin-top:6px;font-family:'Rajdhani',sans-serif;font-size:12px;letter-spacing:4px;color:var(--bone);font-weight:700;text-transform:uppercase;padding-top:10px;border-top:1px solid var(--border);display:flex;justify-content:space-between}

/* ---- PRICING: fixed-position, full viewport, never scrolls ---- */
#screen-pricing.active{
  position:fixed;
  top:0;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:420px;
  height:100vh;
  height:100dvh;
  display:flex;
  flex-direction:column;
  padding:max(14px,env(safe-area-inset-top,0)) 20px max(14px,env(safe-area-inset-bottom,0));
  overflow:hidden;
  background:var(--bg);
  z-index:2;
}
#screen-pricing .brand{margin-bottom:2px}
#screen-pricing .head-sub{margin-bottom:8px}
#screen-pricing .eyebrow-mini{margin-bottom:4px}
#screen-pricing .big-title{font-size:24px;margin-bottom:4px}
#screen-pricing .lede{font-size:11px;line-height:1.35;margin-bottom:8px}

/* Plan stack takes the remaining space and centers the two cards */
#screen-pricing .plan-stack{
  flex:1;min-height:0;
  display:flex;flex-direction:column;justify-content:center;
  gap:8px;margin-bottom:6px;
}
#screen-pricing .plan-card{padding:10px 14px}
#screen-pricing .plan-name{margin-bottom:4px;font-size:9px;letter-spacing:3px}
#screen-pricing .plan-price{font-size:22px}
#screen-pricing .plan-price span{font-size:11px}
#screen-pricing .plan-bullets{margin:6px 0;gap:3px}
#screen-pricing .plan-bullets li{font-size:10px;padding-left:12px}
#screen-pricing .plan-bullets li::before{font-size:7px}
#screen-pricing .plan-cta{margin-top:4px;padding-top:6px;font-size:10px}
#screen-pricing .plan-badge{font-size:7px;padding:2px 7px}
#screen-pricing .foot-link{margin-top:6px;margin-bottom:0;font-size:9px}

/* Short-screen squeeze */
@media (max-height: 720px){
  #screen-pricing .lede{display:none}
  #screen-pricing .big-title{font-size:20px}
  #screen-pricing .plan-bullets li:nth-child(n+4){display:none}
}
@media (max-height: 620px){
  #screen-pricing .eyebrow-mini{display:none}
  #screen-pricing .plan-bullets li:nth-child(n+3){display:none}
  #screen-pricing .big-title{font-size:18px;margin-bottom:2px}
  #screen-pricing .head-sub{display:none}
}
@media (max-height: 560px){
  #screen-pricing .plan-bullets{display:none}
  #screen-pricing .plan-card{padding:8px 12px}
}

/* ---- SIGNUP + LOGIN: fixed-position, full viewport, never scroll ---- */
#screen-signup.active,
#screen-login.active{
  position:fixed;
  top:0;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:420px;
  height:100vh;
  height:100dvh;
  display:flex;
  flex-direction:column;
  padding:max(14px,env(safe-area-inset-top,0)) 20px max(14px,env(safe-area-inset-bottom,0));
  overflow:hidden;
  background:var(--bg);
  z-index:2;
}
#screen-signup .app-form,
#screen-login .app-form{
  flex:1;min-height:0;
  display:flex;flex-direction:column;justify-content:center;
  gap:10px;
}
#screen-signup .app-form .btn-bone,
#screen-login .app-form .btn-bone{margin-top:6px}
#screen-signup .f-group,
#screen-login .f-group{margin:0}
#screen-signup .selected-plan-chip{margin-bottom:8px}
#screen-signup .foot-link,
#screen-login .foot-link{margin-top:10px;margin-bottom:0}
#screen-login .demo-creds{margin-top:10px}

@media (max-height: 680px){
  #screen-signup .app-form,
  #screen-login .app-form{gap:7px}
  #screen-signup .f-group input,
  #screen-login .f-group input{padding:9px 10px}
  #screen-login .demo-creds{font-size:9px;padding:8px 10px;margin-top:6px}
}
@media (max-height: 580px){
  #screen-signup .selected-plan-chip{display:none}
  #screen-login .demo-creds{display:none}
}

/* ---- ONBOARDING: fixed viewport, no scroll — except the coach step ---- */
#screen-onboard.active:not([data-step-kind="coach"]){
  position:fixed;
  top:0;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:420px;
  height:100vh;
  height:100dvh;
  display:flex;
  flex-direction:column;
  padding:max(14px,env(safe-area-inset-top,0)) 20px max(14px,env(safe-area-inset-bottom,0));
  overflow:hidden;
  background:var(--bg);
  z-index:2;
}
#screen-onboard:not([data-step-kind="coach"]) #obBody{
  flex:1;min-height:0;
  display:flex;flex-direction:column;
}
#screen-onboard:not([data-step-kind="coach"]) .ob-step{
  flex:1;min-height:0;
  display:flex;flex-direction:column;
}
#screen-onboard:not([data-step-kind="coach"]) .ob-body{
  flex:1;min-height:0;
  display:flex;flex-direction:column;justify-content:center;
  overflow:hidden;
}
#screen-onboard .ob-title{font-size:20px;margin-bottom:4px}
#screen-onboard .ob-sub{font-size:11px;margin-bottom:12px}

/* Coach step keeps its native scroll */
#screen-onboard[data-step-kind="coach"] .ob-body{
  max-height:none;
  overflow:visible;
}

@media (max-height: 680px){
  #screen-onboard .ob-title{font-size:18px}
  #screen-onboard .ob-sub{font-size:10px;margin-bottom:8px}
}

/* ---- PAYMENT + SUCCESS: fixed viewport, no scroll ---- */
#screen-payment.active,
#screen-success.active{
  position:fixed;
  top:0;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:420px;
  height:100vh;
  height:100dvh;
  display:flex;
  flex-direction:column;
  padding:max(14px,env(safe-area-inset-top,0)) 20px max(14px,env(safe-area-inset-bottom,0));
  overflow:hidden;
  background:var(--bg);
  z-index:2;
}
#screen-payment .app-form{
  flex:1;min-height:0;
  display:flex;flex-direction:column;justify-content:center;
  gap:10px;
}
#screen-payment .app-form .btn-bone{margin-top:6px}
#screen-payment .f-group{margin:0}
#screen-payment .pay-summary{margin-bottom:10px}

#screen-success .success-wrap{
  flex:1;min-height:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:16px;
}

@media (max-height: 680px){
  #screen-payment .app-form{gap:7px}
  #screen-payment .f-group input{padding:9px 10px}
  #screen-payment .pay-summary{padding:10px;margin-bottom:6px}
  #screen-payment .pay-summary .pay-row{padding:3px 0}
  #screen-success .success-ring{width:80px;height:80px}
  #screen-success .success-h{font-size:22px}
  #screen-success .success-p{font-size:11px}
}
@media (max-height: 580px){
  #screen-payment .pay-note{display:none}
  #screen-payment .pay-summary .pay-row:not(.total):not(:first-child){display:none}
}

.selected-plan-chip{display:inline-block;margin-bottom:14px;font-size:9px;letter-spacing:3px;color:var(--silver);border:1px solid var(--border);padding:4px 10px;font-family:'Space Mono',monospace;text-transform:uppercase}

.demo-creds{margin-top:18px;padding:12px;border:1px solid var(--border);background:var(--card);font-family:'Space Mono',monospace;font-size:11px;color:var(--bonedim);letter-spacing:1px;line-height:1.6}
.demo-creds-h{font-size:9px;letter-spacing:3px;color:var(--silver);margin-bottom:6px;text-transform:uppercase}
.demo-creds strong{color:var(--bone)}

/* ONBOARDING */
.ob-counter{font-size:9px;letter-spacing:3px;color:var(--silver);font-family:'Space Mono',monospace;text-transform:uppercase}
.ob-progress{height:2px;background:var(--card2);margin:0 -20px 18px}
.ob-progress-fill{height:100%;background:var(--bone);transition:width 0.3s}
.ob-title{font-family:'Rajdhani',sans-serif;font-size:22px;letter-spacing:3px;color:var(--bone);font-weight:700;text-transform:uppercase;margin-bottom:4px;line-height:1.15}
.ob-sub{font-size:11px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:1px;margin-bottom:16px;line-height:1.5}
.ob-choices{display:flex;flex-direction:column;gap:7px}
.ob-choice{background:var(--card);border:1px solid var(--border);color:var(--bone);padding:14px;text-align:left;display:flex;justify-content:space-between;align-items:center;font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:2px;text-transform:uppercase;font-weight:600;border-radius:0;width:100%}
.ob-choice.selected{border-color:var(--bone)}
.ob-choice-dot{width:14px;height:14px;border-radius:50%;border:1px solid var(--border)}
.ob-choice.selected .ob-choice-dot{background:var(--bone);border-color:var(--bone)}
.ob-metrics{display:flex;flex-direction:column;gap:12px}
.ob-text-actions{display:flex;gap:8px;margin-top:10px}
.ob-text-actions .btn-outline{flex:1}
.ob-text-actions .btn-bone{flex:2}
.ob-coaches{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.ob-coach-tile{background:var(--card);border:1px solid var(--border);padding:13px;text-align:left;color:var(--bone);display:flex;gap:12px;align-items:flex-start;border-radius:0;width:100%;flex-wrap:wrap}
.ob-coach-tile.selected{border-color:var(--gold)}
.ob-coach-tile.full{opacity:0.5;cursor:not-allowed}
.ct-av{width:44px;height:44px;border-radius:50%;background:var(--card2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:'Space Mono',monospace;font-size:12px;color:var(--bone);letter-spacing:2px;flex-shrink:0}
.ct-body{flex:1;min-width:0}
.ct-name{font-family:'Rajdhani',sans-serif;font-size:15px;letter-spacing:2px;color:var(--bone);font-weight:700;text-transform:uppercase}
.ct-spec{font-size:9px;color:var(--gold);font-family:'Space Mono',monospace;letter-spacing:2px;margin-top:2px;text-transform:uppercase}
.ct-bio{font-size:11px;color:var(--bonedim);margin-top:5px;line-height:1.4;font-family:'Space Mono',monospace}
.ct-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.ct-tags span{font-size:8px;letter-spacing:2px;border:1px solid var(--border);color:var(--silver);padding:2px 6px;font-family:'Space Mono',monospace;text-transform:uppercase}
.ct-slots{font-size:9px;letter-spacing:2px;color:var(--green);font-family:'Space Mono',monospace;margin-top:7px;text-transform:uppercase;width:100%}
.ct-slots.full{color:var(--red)}

/* PAYMENT */
.pay-summary{background:var(--card);border:1px solid var(--border);padding:14px;margin-bottom:14px}
.pay-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--border);font-size:11px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:2px;text-transform:uppercase}
.pay-row:last-child{border-bottom:none}
.pay-row strong{color:var(--bone);font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:2px;font-weight:700}
.pay-row.total strong{color:var(--gold);font-size:18px}
.pay-note{font-size:10px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:1px;line-height:1.5;padding:10px;border:1px solid var(--border);background:var(--card2);margin-top:8px}
.pay-note strong{color:var(--bone)}

/* SUCCESS */
.success-wrap{padding:40px 0;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.success-ring{width:90px;height:90px;border-radius:50%;border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;box-shadow:0 0 24px rgba(201,168,76,0.2)}
.success-tick{font-size:38px;color:var(--gold);line-height:1}
.success-h{font-family:'Rajdhani',sans-serif;font-size:28px;letter-spacing:4px;color:var(--bone);font-weight:700;text-transform:uppercase}
.success-p{font-size:12px;color:var(--bonedim);font-family:'Space Mono',monospace;letter-spacing:1px;line-height:1.5;max-width:320px}

/* HABIT ROW */
.habit-row{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:8px}
.habit-chip{background:var(--card);border:1px solid var(--border);padding:10px 12px;display:flex;align-items:center;gap:9px;cursor:pointer;border-radius:0;color:var(--bone);text-align:left}
.habit-chip.on{border-color:var(--green)}
.habit-icon{font-size:16px}
.habit-l{flex:1;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;color:var(--silver);text-transform:uppercase}
.habit-chip.on .habit-l{color:var(--bone)}
.habit-tick{color:var(--green);font-family:'Space Mono',monospace;font-size:11px}

.quests-summary{display:flex;align-items:center;justify-content:space-between;cursor:pointer}
.qs-n{font-family:'Rajdhani',sans-serif;font-size:18px;letter-spacing:2px;color:var(--bone);font-weight:700;text-transform:uppercase}
.qs-n strong{color:var(--gold)}
.qs-l{font-size:10px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:2px;margin-top:2px;text-transform:uppercase}
.qs-arrow{color:var(--silver);font-family:'Space Mono',monospace}

/* LEADERBOARD */
.lb-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--card);border:1px solid var(--border);margin-bottom:6px}
.lb-row.me{border-color:var(--gold)}
.lb-rank{width:22px;height:22px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:'Space Mono',monospace;font-size:10px;color:var(--silver);flex-shrink:0}
.lb-rank.r1{border-color:var(--gold);color:var(--gold)}
.lb-name{flex:1;font-family:'Rajdhani',sans-serif;font-size:13px;letter-spacing:2px;color:var(--bone);font-weight:600;text-transform:uppercase}
.lb-xp{font-family:'Space Mono',monospace;font-size:10px;color:var(--gold);letter-spacing:1px}

/* PROGRESS */
.weight-hero{text-align:left}
.weight-label{font-size:9px;color:var(--silver);letter-spacing:3px;font-family:'Space Mono',monospace;text-transform:uppercase}
.weight-big{font-family:'Rajdhani',sans-serif;font-size:40px;letter-spacing:2px;color:var(--bone);font-weight:700;line-height:1.1;margin-top:4px}
.weight-big em{font-style:normal;font-size:16px;color:var(--silver);margin-left:6px;font-family:'Space Mono',monospace;letter-spacing:2px}
.chart-delta{font-size:10px;font-family:'Space Mono',monospace;letter-spacing:2px;text-transform:uppercase}
.chart-delta.down{color:var(--green)}
.chart-delta.up{color:var(--amber)}
.unit-seg{display:inline-flex;border:1px solid var(--border);margin-top:10px}
.unit-seg button{background:transparent;border:none;padding:6px 10px;color:var(--silver);font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;cursor:pointer;text-transform:uppercase;border-radius:0}
.unit-seg button.active{background:var(--bone);color:#060606}
.progress-chart{width:100%;height:180px;display:block;margin-top:10px}
.chart-head{display:flex;justify-content:space-between;align-items:center}
.chart-label{font-size:9px;color:var(--silver);letter-spacing:3px;font-family:'Space Mono',monospace;text-transform:uppercase}
.chart-val{font-family:'Rajdhani',sans-serif;font-size:18px;color:var(--bone);font-weight:700;letter-spacing:2px;margin-top:2px}
.chart-val em{font-size:11px;color:var(--silver);font-style:normal;font-family:'Space Mono',monospace}
.chart-range{font-size:9px;color:var(--silver);letter-spacing:2px;font-family:'Space Mono',monospace;border:1px solid var(--border);padding:2px 8px;text-transform:uppercase}

.mood-row{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:14px}
.mood-chip{background:var(--card);border:1px solid var(--border);padding:10px 0;font-size:20px;cursor:pointer;border-radius:0;color:var(--bone)}
.mood-chip.on{border-color:var(--bone)}

.st-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:var(--card);border:1px solid var(--border);margin-bottom:6px}
.st-name{font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:2px;color:var(--bone);font-weight:700;text-transform:uppercase;flex:1}
.st-val{font-family:'Space Mono',monospace;font-size:12px;color:var(--bone);letter-spacing:1px}
.st-delta{font-family:'Space Mono',monospace;font-size:10px;color:var(--green);letter-spacing:1px}

.photo-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:8px}
.photo-slot{aspect-ratio:3/4;background:var(--card);border:1px solid var(--border);position:relative;cursor:pointer;display:flex;align-items:flex-end;justify-content:center;overflow:hidden}
.photo-slot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.photo-slot-label{position:relative;z-index:2;width:100%;text-align:center;font-size:8px;letter-spacing:3px;color:var(--silver);font-family:'Space Mono',monospace;background:rgba(6,6,6,0.7);padding:4px 0;text-transform:uppercase}
.photo-slot.has .photo-slot-label{color:var(--bone)}

.ach-row{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:8px}
.ach{aspect-ratio:1;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--silver)}
.ach.earned{border-color:var(--gold);color:var(--gold)}

.link-row{display:flex;align-items:center;justify-content:space-between;width:100%;padding:13px 14px;background:var(--card);border:1px solid var(--border);color:var(--bone);font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:3px;font-weight:600;text-transform:uppercase;margin-bottom:6px;border-radius:0;text-align:left}
.lr-arrow{color:var(--silver);font-family:'Space Mono',monospace}
.foot-version{margin-top:16px;text-align:center;font-size:9px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:3px;text-transform:uppercase}

/* SETTINGS */
.setting-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:var(--card);border:1px solid var(--border);margin-bottom:6px}
.sr-label{font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:2px;color:var(--bone);font-weight:600;text-transform:uppercase}
.sr-sub{font-size:9px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:2px;margin-top:2px;text-transform:uppercase}

/* COACH */
.coach-client-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--card);border:1px solid var(--border);margin-bottom:6px;cursor:pointer}
.ccr-av{width:40px;height:40px;border-radius:50%;background:var(--card2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:'Space Mono',monospace;font-size:11px;color:var(--bone);letter-spacing:2px;flex-shrink:0}
.ccr-body{flex:1;min-width:0}
.ccr-name{font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:2px;color:var(--bone);font-weight:700;text-transform:uppercase}
.ccr-meta{font-size:9px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:1px;margin-top:2px;text-transform:uppercase}
.ccr-rank{width:30px;height:30px;border-radius:50%;border:1px solid var(--gold);display:flex;align-items:center;justify-content:center;font-family:'Rajdhani',sans-serif;font-size:14px;color:var(--gold);font-weight:700}

.profile-hero{display:flex;align-items:center;gap:12px}
.profile-av{width:52px;height:52px;border-radius:50%;background:var(--card2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:'Space Mono',monospace;font-size:14px;color:var(--bone);letter-spacing:2px;flex-shrink:0}
.profile-name{font-family:'Rajdhani',sans-serif;font-size:18px;letter-spacing:3px;color:var(--bone);font-weight:700;text-transform:uppercase}
.profile-email{font-size:10px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:1px;margin-top:2px}
.profile-plan{font-size:9px;color:var(--gold);font-family:'Space Mono',monospace;letter-spacing:2px;margin-top:3px;text-transform:uppercase}

.plan-list-item{padding:12px 14px;background:var(--card);border:1px solid var(--border);margin-bottom:6px}
.pli-name{font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:2px;color:var(--bone);font-weight:700;text-transform:uppercase}
.pli-meta{font-size:10px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:1px;margin-top:2px;text-transform:uppercase}

.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:8px}
.stat-chip{background:var(--card);border:1px solid var(--border);padding:10px;text-align:center}
.sc-n{font-family:'Rajdhani',sans-serif;font-size:22px;color:var(--bone);font-weight:700;letter-spacing:1px;line-height:1.1}
.sc-n em{font-style:normal;font-size:11px;color:var(--silver);margin-left:2px;font-family:'Space Mono',monospace}
.sc-l{font-size:8px;letter-spacing:3px;color:var(--silver);font-family:'Space Mono',monospace;margin-top:3px;text-transform:uppercase}

/* MODAL */
.modal-back{position:fixed;inset:0;background:rgba(0,0,0,0.8);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.modal-back.show{display:flex}
.modal{width:100%;max-width:380px;background:var(--card);border:1px solid var(--border);padding:18px;max-height:85vh;overflow-y:auto}
.modal-h{font-family:'Rajdhani',sans-serif;font-size:18px;letter-spacing:3px;color:var(--bone);font-weight:700;text-transform:uppercase;margin-bottom:12px}
.modal-row{display:flex;gap:8px;margin-top:12px}
.xp-suggest{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;background:var(--card2);border:1px solid var(--border);margin:8px 0}
.xp-suggest-l{font-size:9px;color:var(--silver);letter-spacing:2px;font-family:'Space Mono',monospace;text-transform:uppercase}
.xp-suggest-n{font-family:'Rajdhani',sans-serif;font-size:18px;color:var(--gold);font-weight:700;letter-spacing:2px}

/* TOAST */
.toast{position:fixed;bottom:72px;left:50%;transform:translateX(-50%);background:var(--card);border:1px solid var(--border);color:var(--bone);padding:10px 16px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;opacity:0;pointer-events:none;transition:opacity 0.2s;z-index:200;max-width:340px;text-align:center}
.toast.show{opacity:1}

/* COMPAT (legacy button classes used by some render paths — mapped to flat style) */
.btn-primary{padding:12px 20px;background:var(--bone);color:#060606;border:none;font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:5px;cursor:pointer;font-weight:700;text-transform:uppercase;border-radius:0}
.btn-primary.sm{padding:8px 16px;font-size:13px;letter-spacing:4px}
.btn-primary[disabled]{opacity:0.4;cursor:not-allowed}
.btn-ghost{padding:10px 16px;background:transparent;border:1px solid var(--border);color:var(--bone);font-family:'Rajdhani',sans-serif;font-size:13px;letter-spacing:3px;cursor:pointer;font-weight:600;text-transform:uppercase;border-radius:0}
.btn-ghost.sm{padding:6px 12px;font-size:11px}
.full-width{width:100%;display:block}

/* REST DAY */
.rest-day-card{text-align:center;padding:36px 20px}
.rest-day-h{font-family:'Rajdhani',sans-serif;font-size:24px;letter-spacing:5px;color:var(--bone);font-weight:700;text-transform:uppercase}
.rest-day-p{font-size:11px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:1px;margin-top:8px;line-height:1.5}

/* WEEK PROGRESS BAR */
.pw-label{font-size:9px;color:var(--silver);letter-spacing:3px;font-family:'Space Mono',monospace;text-transform:uppercase}
.pw-count{font-family:'Rajdhani',sans-serif;font-size:20px;letter-spacing:2px;color:var(--bone);font-weight:700;margin:4px 0 8px}
.pw-count strong{color:var(--gold)}
.pw-bar{height:4px;background:var(--card2)}
.pw-bar-fill{height:100%;background:linear-gradient(90deg,var(--silver),var(--bone))}

/* BOOT SCREEN */
.boot-screen{position:fixed;inset:0;z-index:9999;background:#060606;display:flex;align-items:center;justify-content:center;padding-top:env(safe-area-inset-top,0);transition:opacity 0.4s ease}
.boot-screen.hide{opacity:0;pointer-events:none}
.boot-inner{display:flex;flex-direction:column;align-items:center;gap:14px;padding:20px;max-width:340px;width:100%}
.boot-logo{flex-shrink:0;display:block;overflow:visible}
.boot-title{font-family:'Rajdhani',sans-serif;font-size:18px;letter-spacing:4px;color:var(--gold);font-weight:700;text-transform:uppercase}
.boot-log{width:100%;margin-top:10px;min-height:130px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:1.5px;color:var(--silver);line-height:1.8;text-align:left}
.boot-line{white-space:pre;overflow:hidden}
.boot-cursor{display:inline-block;width:7px;color:var(--gold);animation:bootBlink 0.9s steps(1) infinite}
@keyframes bootBlink{0%,49%{opacity:1}50%,100%{opacity:0}}

/* MESSAGES */
.msg-wrap{display:flex;flex-direction:column;height:calc(100vh - 56px - 60px - 66px - env(safe-area-inset-top,0) - env(safe-area-inset-bottom,0));position:relative}
#screen-coach-messages.has-tabs,#screen-client-messages.has-tabs{padding-bottom:calc(56px + 66px + env(safe-area-inset-bottom,0))}
.msg-header{display:flex;align-items:center;gap:12px;padding:6px 0 12px;border-bottom:1px solid var(--border);margin-bottom:10px}
.msg-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:4px 0 14px;min-height:0}
.msg-bubble{max-width:78%;padding:8px 11px;border:1px solid var(--border);background:var(--card);border-radius:0}
.msg-bubble .msg-text{font-family:'Rajdhani',sans-serif;font-size:13px;letter-spacing:1px;color:var(--bone);line-height:1.4}
.msg-bubble .msg-ts{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:1px;color:var(--silver);margin-top:4px;text-transform:uppercase}
.msg-bubble.mine{align-self:flex-end;border-color:var(--gold)}
.msg-bubble.theirs{align-self:flex-start;border-color:var(--bone)}
.msg-input-row{display:flex;gap:8px;padding:10px 20px;border-top:1px solid var(--border);background:rgba(6,6,6,0.98);position:fixed;left:0;right:0;bottom:calc(56px + env(safe-area-inset-bottom,0));max-width:420px;margin:0 auto;z-index:49;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.msg-input-row input{flex:1;min-width:0}
.msg-input-row button{flex-shrink:0}
.msg-empty{text-align:center;color:var(--silver);font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;padding:30px 0;text-transform:uppercase}

/* COACH EDIT (workout/diet) */
.edit-day-card{background:var(--card);border:1px solid var(--border);padding:12px;margin-bottom:10px}
.edit-day-h{font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:3px;color:var(--gold);font-weight:700;text-transform:uppercase;margin-bottom:8px}
.edit-ex{border:1px solid var(--border);padding:10px;margin-bottom:6px;background:var(--bg2)}
.edit-ex .eer{display:flex;gap:6px;margin-bottom:6px;flex-wrap:wrap}
.edit-ex .eer input{flex:1;min-width:60px}
.edit-ex .eer input.ei-name{flex:2;min-width:140px}
.edit-ex-actions{display:flex;gap:6px;align-items:center;margin-top:4px;flex-wrap:wrap}
.edit-ex-actions .btn-outline,.edit-ex-actions .btn-ghost{font-size:10px;padding:5px 8px;letter-spacing:2px}
.edit-ex-actions label{margin:0;border:1px solid var(--silver);padding:5px 8px;cursor:pointer;color:var(--bone);font-size:10px;letter-spacing:2px}
.edit-ex-actions input[type=file]{display:none}
.edit-ex .vid-tag{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:1px;color:var(--green);margin-left:4px}

.watch-demo-btn{margin-top:8px;padding:5px 10px;background:transparent;border:1px solid var(--gold);color:var(--gold);font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;border-radius:0}

/* ===================== RANK SYSTEM ===================== */
.level-big{font-family:'Rajdhani',sans-serif;font-size:28px;letter-spacing:4px;font-weight:700;line-height:1;margin-bottom:8px;text-transform:uppercase}
.rank-prog{margin-top:10px;padding-top:10px;border-top:1px dashed var(--border)}
.prestige-row{position:absolute;top:-12px;left:50%;transform:translateX(-50%);display:flex;gap:2px;color:var(--gold);font-size:10px;letter-spacing:2px;text-shadow:0 0 6px rgba(201,168,76,0.8);white-space:nowrap}
.s-rank-banner{margin-top:10px;padding:8px 10px;border:1px solid var(--gold);background:rgba(201,168,76,0.06);color:var(--gold);font-family:'Space Mono',monospace;font-size:9px;letter-spacing:3px;text-align:center;text-transform:uppercase;box-shadow:0 0 12px rgba(201,168,76,0.18) inset}

/* Level-up toast */
.level-toast{position:fixed;top:calc(env(safe-area-inset-top,0) + 56px);left:50%;transform:translateX(-50%) translateY(-8px);background:rgba(6,6,6,0.92);border:1px solid var(--bone);color:var(--bone);font-family:'Rajdhani',sans-serif;font-size:18px;letter-spacing:5px;font-weight:700;padding:10px 22px;z-index:9000;opacity:0;pointer-events:none;transition:opacity .25s ease,transform .25s ease;text-transform:uppercase;backdrop-filter:blur(8px)}
.level-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Rank-up overlay */
.rankup-ov{position:fixed;inset:0;background:rgba(0,0,0,0.82);z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .45s ease;backdrop-filter:blur(6px)}
.rankup-ov.show{opacity:1;pointer-events:auto}
.rankup-ov.sovereign{background:radial-gradient(ellipse at center,rgba(201,168,76,0.15),rgba(0,0,0,0.95) 70%)}
.rankup-inner{text-align:center;padding:30px 40px;border:1px solid var(--rc,var(--gold));background:rgba(6,6,6,0.9);box-shadow:0 0 60px var(--rg,rgba(201,168,76,0.3)),0 0 120px var(--rg,rgba(201,168,76,0.2));animation:rankupPop .55s cubic-bezier(.2,.9,.3,1.3) both;max-width:80%}
.rankup-inner.sovereign{padding:40px 52px;animation:sovereignPop 1s cubic-bezier(.2,.9,.3,1.3) both}
.rankup-sub{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:6px;color:var(--silver);margin-bottom:14px;text-transform:uppercase}
.rankup-badge{width:140px;height:140px;border-radius:50%;border:3px solid var(--rc,var(--gold));margin:0 auto 16px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 40px var(--rg,rgba(201,168,76,0.4)) inset,0 0 30px var(--rg,rgba(201,168,76,0.4))}
.rankup-badge span{font-family:'Rajdhani',sans-serif;font-size:80px;color:var(--rc,var(--gold));font-weight:700;line-height:1;text-shadow:0 0 20px var(--rg,rgba(201,168,76,0.6))}
.sovereign-badge{width:170px;height:170px;border-width:4px;animation:sovereignGlow 2s ease-in-out infinite alternate}
.sovereign-badge span{font-size:100px}
.rankup-label{font-family:'Rajdhani',sans-serif;font-size:22px;letter-spacing:6px;color:var(--rc,var(--gold));font-weight:700;text-transform:uppercase}
.sovereign-label{font-size:28px;letter-spacing:8px;text-shadow:0 0 14px var(--rg,rgba(201,168,76,0.6))}
.rankup-tag{margin-top:10px;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:4px;color:var(--silver);text-transform:uppercase}
.rankup-level{font-family:'Rajdhani',sans-serif;font-size:16px;letter-spacing:8px;color:var(--gold);font-weight:700;text-transform:uppercase;margin-bottom:12px}
.rankup-divider{height:1px;background:linear-gradient(90deg,transparent,var(--rc,var(--gold)),transparent);margin:14px auto;width:80%}
@keyframes rankupPop{0%{opacity:0;transform:scale(.6)}60%{opacity:1;transform:scale(1.05)}100%{opacity:1;transform:scale(1)}}
@keyframes sovereignPop{0%{opacity:0;transform:scale(.3) rotate(-6deg);filter:blur(10px)}45%{opacity:1;transform:scale(1.1) rotate(0);filter:blur(0)}70%{transform:scale(.98)}100%{opacity:1;transform:scale(1)}}
@keyframes sovereignGlow{from{box-shadow:0 0 40px rgba(201,168,76,0.5) inset,0 0 30px rgba(201,168,76,0.5)}to{box-shadow:0 0 60px rgba(201,168,76,0.85) inset,0 0 60px rgba(201,168,76,0.8)}}

/* XP lock icon in quest modals */
.xp-lock{color:var(--silver);font-size:18px;padding:4px 10px;border:1px dashed var(--border);border-radius:0;cursor:default;user-select:none}

/* Coach personal tracker */
.ct-hero{display:flex;justify-content:space-between;align-items:center;background:var(--card);border:1px solid var(--border);padding:14px 16px;margin-bottom:14px;gap:12px}
.ct-hero-tag{display:inline-block;padding:3px 8px;border:1px solid var(--gold);color:var(--gold);font-family:'Space Mono',monospace;font-size:9px;letter-spacing:2px;text-transform:uppercase;margin-bottom:6px}
.ct-hero-n{font-family:'Rajdhani',sans-serif;font-size:22px;color:var(--bone);font-weight:700;letter-spacing:2px}
.ct-hero-r{font-size:9px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:2px;text-transform:uppercase;text-align:right;max-width:40%}
.ct-meals{display:flex;flex-direction:column;gap:7px;padding:12px}
.ct-meal{display:flex;justify-content:space-between;align-items:center;background:var(--bg2);border:1px solid var(--border);color:var(--bone);padding:11px 13px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;border-radius:0;text-align:left;width:100%}
.ct-meal:hover{border-color:var(--silver)}
.ct-meal.done{border-color:var(--gold);background:rgba(201,168,76,0.05);color:var(--gold)}
.ct-meal-l{font-weight:700}
.ct-meal-r{font-size:9px;color:var(--silver)}
.ct-meal.done .ct-meal-r{color:var(--gold)}
.ct-hint{margin-top:8px;font-size:9px;color:var(--silver);font-family:'Space Mono',monospace;letter-spacing:2px;text-transform:uppercase;text-align:center}

/* Debug pill for ?xp= / ?level= overrides */
.debug-pill{position:fixed;top:calc(env(safe-area-inset-top,0) + 8px);right:8px;background:rgba(201,168,76,0.12);border:1px solid var(--gold);color:var(--gold);font-family:'Space Mono',monospace;font-size:9px;letter-spacing:2px;padding:4px 8px;z-index:9500;text-transform:uppercase;pointer-events:none}
