:root{
  --teal:#028090; --teal2:#02C39A; --ink:#10202c; --muted:#5d7385; --line:#e6edf2;
  --bg:#f3f7f9; --card:#fff; --good:#02C39A; --watch:#F0A024; --alert:#E5484D;
  --low:#F2C14E; --med:#F08A24; --high:#E5484D;
  --shadow-soft:0 1px 2px rgba(16,32,44,.05),0 8px 24px rgba(16,32,44,.08);
  --shadow-lift:0 1px 2px rgba(16,32,44,.06),0 14px 34px rgba(16,32,44,.12);
  --motion-ease:ease-out;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
body{font-family:-apple-system,'Inter',system-ui,sans-serif;background:var(--bg);color:var(--ink);overflow-x:hidden}
.hidden{display:none!important}
.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
.sheet-bank{display:none!important}
.muted{color:var(--muted)} .tiny{font-size:11px}
a{cursor:pointer;color:var(--teal)}

/* ---- auth ---- */
.auth{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(800px 500px at 70% -10%,#15263a,#0b1018 60%)}
.auth-card{background:#fff;border-radius:22px;padding:26px 24px;width:360px;max-width:94vw;
  box-shadow:0 20px 60px rgba(0,0,0,.3);text-align:center}
.auth-avatar{height:210px;border-radius:16px;overflow:hidden;background:linear-gradient(180deg,#f4f9fb,#e7f0f4);margin-bottom:12px}
.auth-avatar model-viewer{width:100%;height:100%;min-height:210px}
.auth h1{font-size:26px;font-weight:800;color:var(--teal);letter-spacing:-.5px}
.auth-sub{color:var(--muted);font-size:14px;margin:4px 0 16px}
.auth input{width:100%;border:1px solid var(--line);border-radius:10px;padding:12px;font:inherit;font-size:15px;margin-bottom:10px}
.auth-toggle{font-size:13px;color:var(--muted);margin-top:10px}
.auth-err{color:var(--high);font-size:13px;min-height:18px;margin-top:6px}
.auth-consent{display:flex;gap:8px;align-items:flex-start;text-align:left;font-size:11px;color:var(--muted);margin-top:12px}

/* ---- shell ---- */
.app{min-height:100vh;display:flex;flex-direction:column}
.demo-mode .app{padding-top:34px}
.demo-badge{position:fixed;top:0;left:0;right:0;z-index:30;background:#10202c;color:#fff;text-align:center;
  font-size:12px;font-weight:800;line-height:1.25;padding:9px 12px;box-shadow:0 1px 6px rgba(16,32,44,.18)}
.sidenav{display:none}
.content{flex:1;max-width:760px;width:100%;margin:0 auto;padding-bottom:calc(82px + env(safe-area-inset-bottom));position:relative}
.tabs{position:fixed;bottom:0;left:0;right:0;display:flex;border-top:1px solid var(--line);background:#fff;z-index:10;
  padding-bottom:env(safe-area-inset-bottom)}
.tabs button{flex:1;border:none;background:none;font:inherit;padding:8px 0 12px;min-height:56px;color:var(--muted);
  font-size:10px;font-weight:600;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px}
.tabs button .i{font-size:18px}
.tabs button.on{color:var(--teal)}
@media(min-width:700px){
  .app{flex-direction:row}
  .sidenav{display:flex;flex-direction:column;gap:4px;width:210px;padding:20px 12px;border-right:1px solid var(--line);
    background:#fff;height:100vh;position:sticky;top:0}
  .sidenav .brand{font-weight:800;color:var(--teal);font-size:18px;padding:6px 12px 16px}
  .sidenav a{display:flex;gap:10px;padding:11px 14px;border-radius:10px;color:var(--muted);font-size:14px;font-weight:600}
  .sidenav a.on{background:#e8f6f3;color:var(--teal)}
  .content{max-width:1040px;padding:10px 24px 30px}
  .tabs{display:none}
  .avatar-wrap{min-height:520px!important}
  .avatar-wrap model-viewer{min-height:520px!important}
}

/* ---- screens ---- */
.scr{display:flex;flex-direction:column;position:absolute;inset:0 0 auto;width:100%;opacity:0;transform:translateY(6px);
  visibility:hidden;pointer-events:none;transition:opacity .18s var(--motion-ease),transform .18s var(--motion-ease),visibility 0s linear .18s}
.scr.on{position:relative;opacity:1;transform:none;visibility:visible;pointer-events:auto;transition-delay:0s}
.scr.entering>.head,.scr.entering>.twin-stage,.scr.entering>.action-row,.scr.entering>.focus-chip,.scr.entering>.insight-rail .insight-card{
  animation:screen-enter .24s var(--motion-ease) both}
.scr.entering>.twin-stage{animation-delay:.06s}.scr.entering>.action-row{animation-delay:.12s}
.scr.entering>.focus-chip{animation-delay:.18s}.scr.entering>.insight-rail .insight-card:nth-child(1){animation-delay:.24s}
.scr.entering>.insight-rail .insight-card:nth-child(2){animation-delay:.30s}.scr.entering>.insight-rail .insight-card:nth-child(3){animation-delay:.36s}
.scr.entering>.insight-rail .insight-card:nth-child(4){animation-delay:.42s}
@keyframes screen-enter{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.head{padding:18px 18px 6px;display:flex;justify-content:space-between;align-items:flex-end}
.head h2{font-size:22px;font-weight:800;letter-spacing:-.4px}
.head .day{font-size:12px;color:var(--muted)}
.sync-btn{border:1px solid var(--line);background:#fff;border-radius:20px;padding:7px 13px;min-height:44px;font:inherit;
  font-size:12px;font-weight:700;color:var(--teal);cursor:pointer}
.sec-head{display:flex;justify-content:space-between;align-items:baseline;padding:16px 18px 4px}
.sec-head h3{font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}

/* ---- twin stage dashboard ---- */
.dash-head{align-items:center}
.twin-stage{--score-color:var(--teal);position:relative;margin:8px 16px 12px;min-height:46vh;border:1px solid var(--line);
  border-radius:24px;overflow:hidden;background:linear-gradient(180deg,#fbfdfe,#eaf3f6);box-shadow:var(--shadow-soft)}
.twin-stage:before{content:"";position:absolute;inset:8% 4% 18%;border-radius:50%;
  background:radial-gradient(circle at 50% 44%,color-mix(in srgb,var(--score-color) 30%,transparent),transparent 54%);
  opacity:.9;transform:scale(1);animation:stage-breathe 7s ease-in-out infinite;pointer-events:none}
@keyframes stage-breathe{0%,100%{opacity:.82;transform:scale(1)}50%{opacity:.98;transform:scale(1.06)}}
.stage-avatar{position:absolute;inset:8px 0 42px;display:flex;align-items:center;justify-content:center}
.stage-avatar model-viewer{width:100%;height:100%;min-height:360px;pointer-events:none}
.score-ring{position:absolute;top:14px;right:14px;width:76px;height:88px;border:0;background:#fff;border-radius:18px;
  box-shadow:var(--shadow-soft);cursor:pointer;color:var(--ink);transition:transform .18s var(--motion-ease),box-shadow .18s var(--motion-ease),filter .18s var(--motion-ease)}
.score-ring svg{position:absolute;inset:0;width:76px;height:76px;transform:rotate(-90deg)}
.score-ring circle{fill:none;stroke-width:7;stroke-linecap:round}
.score-track{stroke:#e7eef2}.score-arc{stroke:var(--teal);stroke-dasharray:194.8;stroke-dashoffset:194.8;
  transition:stroke-dashoffset .8s var(--motion-ease),stroke .25s var(--motion-ease)}
.score-ring-num{position:absolute;top:23px;left:0;right:0;text-align:center;font-weight:900;font-size:21px;line-height:1;color:var(--ink)}
.score-ring-delta{position:absolute;top:61px;left:0;right:0;text-align:center;font-size:11px;font-weight:800}
.level-badge{position:absolute;top:14px;left:14px;z-index:2;border:0;background:#fff;border-radius:18px;padding:9px 10px;
  box-shadow:var(--shadow-soft);cursor:pointer;color:var(--teal);font:inherit;font-size:12px;font-weight:800;
  transition:transform .18s var(--motion-ease),box-shadow .18s var(--motion-ease)}
.level-segs{display:flex;gap:3px;margin-bottom:5px}.level-segs i{display:block;width:14px;height:5px;border-radius:999px;background:#dce8ed}.level-segs i.on{background:var(--teal)}
.stage-chips{position:absolute;left:12px;right:12px;bottom:12px;display:flex;gap:8px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:2px}
.stage-chip{flex:0 0 auto;scroll-snap-align:start;border:1px solid rgba(255,255,255,.75);background:rgba(255,255,255,.92);
  border-radius:999px;padding:8px 10px;display:flex;align-items:center;gap:6px;font:inherit;font-size:12px;font-weight:800;color:var(--ink);
  box-shadow:var(--shadow-soft);cursor:pointer;transition:transform .18s var(--motion-ease),box-shadow .18s var(--motion-ease),filter .18s var(--motion-ease)}
.stage-chip i{width:8px;height:8px;border-radius:50%;display:block}.stage-chip.ok{color:var(--teal)}
.stage-chip.alert i{animation:alert-dot 2s ease-in-out infinite}
@keyframes alert-dot{0%,100%{opacity:1}50%{opacity:.5}}
.action-row{display:grid;grid-template-columns:1fr auto;gap:10px;margin:0 16px 10px}
.action-row .btn{margin-top:0}.primary-action{min-height:48px;background:linear-gradient(135deg,var(--teal),color-mix(in srgb,var(--teal2) 82%,#fff 18%));
  box-shadow:0 1px 2px rgba(16,32,44,.06),0 10px 24px rgba(2,128,144,.18)}
.secondary-action{width:auto;white-space:nowrap;padding-left:14px;padding-right:14px}
.focus-chip{margin:2px 16px 10px;width:calc(100% - 32px);border:1px solid var(--line);background:#fff;border-radius:16px;
  padding:13px 14px;display:flex;align-items:center;gap:9px;font:inherit;cursor:pointer;box-shadow:var(--shadow-soft);text-align:left}
.focus-chip b{flex:1;font-size:14px}.focus-chip span:last-child{color:#b3c2cb;font-size:20px}
.insight-rail{display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x mandatory;padding:2px 16px 18px;
  mask-image:linear-gradient(90deg,transparent 0,#000 16px,#000 calc(100% - 16px),transparent 100%)}
.insight-card{flex:0 0 148px;scroll-snap-align:start;border:1px solid var(--line);border-radius:16px;background:#fff;padding:13px;
  min-height:86px;text-align:left;font:inherit;cursor:pointer;box-shadow:var(--shadow-soft);
  transition:transform .18s var(--motion-ease),box-shadow .18s var(--motion-ease)}
.insight-card span{display:block;color:var(--muted);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.insight-card b{display:block;margin-top:12px;font-size:17px;line-height:1.15}

/* ---- mini avatar hero (legacy avatar state) ---- */
.mini-hero{display:flex;align-items:center;gap:14px;margin:8px 16px;padding:12px;background:#fff;
  border:1px solid var(--line);border-radius:18px;cursor:pointer;text-align:left;width:calc(100% - 32px);
  box-shadow:0 6px 20px rgba(20,40,60,.05)}
.mini-av{width:96px;height:120px;flex:none;border-radius:14px;overflow:hidden;
  background:linear-gradient(180deg,#f4f9fb,#e7f0f4)}
.mini-av model-viewer{width:100%;height:100%;min-height:120px;pointer-events:none}
.mini-meta{flex:1}
.mini-score{display:flex;align-items:baseline;gap:2px;margin-bottom:6px}
.mini-score .ms-num{font-size:34px;font-weight:800;line-height:1}
.ms-max{font-size:13px;color:var(--muted);margin-left:3px}
.mini-state{font-size:18px;font-weight:800;display:flex;align-items:center;gap:8px}
.mini-level{font-size:13px;color:var(--teal);font-weight:700;margin-top:2px}
.mini-cta{font-size:12px;color:var(--muted);margin-top:8px}
.dash-next{cursor:pointer;padding:12px 14px;margin-bottom:12px}
.dash-next:hover{opacity:.85}
.dash-next.priority{border-color:#bfe4df;box-shadow:0 8px 22px rgba(16,56,74,.08)}
.dns-head{font-size:10px;font-weight:700;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;margin-bottom:6px}
.dns-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.dns-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dns-label{font-weight:700;font-size:14px;flex:1}
.dns-badge{background:var(--teal);color:#000;font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;white-space:nowrap}
.dns-focus{background:#e8f6f3;color:var(--teal)}
.dns-rec{font-size:13px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.dns-status{font-size:11px;color:var(--muted);font-weight:700;margin-top:7px}
.llm-priority{padding:12px 14px;margin-bottom:12px}
.llm-toggle{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer}
.llm-toggle span{display:flex;flex-direction:column;gap:2px;min-width:0}
.llm-toggle b{font-size:13px;color:var(--ink)}
.llm-toggle small{font-size:11px;color:var(--muted);line-height:1.25}
.llm-toggle input{position:absolute;opacity:0;pointer-events:none}
.llm-toggle i{width:42px;height:24px;border-radius:999px;background:#d9e4ea;position:relative;flex:0 0 auto;transition:background .15s}
.llm-toggle i:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.22);transition:transform .15s}
.llm-toggle input:checked + i{background:var(--teal)}
.llm-toggle input:checked + i:before{transform:translateX(18px)}
.llm-toggle input:disabled + i{opacity:.6}

/* ---- score history ---- */
.score-history-head{padding-top:10px}
.score-history-head span{font-size:12px;font-weight:800}
.score-history-card{padding:12px 14px}
.score-history-summary{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:8px}
.score-history-summary b{font-size:20px;letter-spacing:0}
.score-history-summary span{font-size:13px;font-weight:800}
.score-history-chart{display:grid;grid-template-columns:28px 1fr 18px;align-items:center;gap:8px}
.score-history-chart span{font-size:10px;color:var(--muted);font-weight:700}
.score-history-chart svg{width:100%;height:58px;display:block;overflow:visible}
.score-history-chart line{stroke:var(--line);stroke-width:1}
.score-history-chart path{fill:none;stroke:var(--teal);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.score-history-chart circle{fill:#fff;stroke:var(--teal);stroke-width:1.5}
.score-history-dates{display:flex;justify-content:space-between;color:var(--muted);font-size:11px;font-weight:700;margin:2px 26px 0 36px}
.score-history-empty{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:13px}
.score-history-single{display:flex;align-items:baseline;gap:8px;color:var(--ink)}
.score-history-single span{font-size:11px;color:var(--muted);font-weight:700}

/* ---- vital signs ---- */
.vitals-card{padding:10px}
.vitals-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
@media(min-width:560px){.vitals-grid{grid-template-columns:repeat(4,1fr)}}
.vital-tile{border:1px solid var(--line);border-radius:12px;padding:10px 11px;min-height:96px;
  display:flex;flex-direction:column;justify-content:space-between;background:#fbfdfe}
.vital-tile.clickable{cursor:pointer;transition:box-shadow .18s var(--motion-ease),border-color .18s var(--motion-ease),transform .18s var(--motion-ease)}
.vital-tile.clickable:hover{border-color:#bfe4df;box-shadow:var(--shadow-lift);transform:translateY(-2px)}
.vital-top{display:flex;align-items:center;justify-content:space-between;gap:6px}
.vital-icon{font-size:18px;line-height:1}
.vital-meta{display:flex;align-items:center;gap:5px;min-width:0}
.vital-status{width:7px;height:7px;border-radius:50%;flex:0 0 auto;background:#c8d3db}
.vital-good{background:var(--good)} .vital-watch{background:var(--watch)} .vital-alert{background:var(--alert)}
.vital-neutral{background:#c8d3db}
.vital-period{font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em;text-align:right}
.vital-value{font-size:24px;font-weight:800;letter-spacing:-.3px;line-height:1.1;margin-top:8px}
.vital-unit{font-size:11px;font-weight:700;color:var(--muted);margin-left:4px;letter-spacing:0}
.vital-label{font-size:12px;color:var(--muted);font-weight:700;margin-top:6px}

/* ---- metric cards ---- */
.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:4px 16px}
@media(min-width:560px){.metric-grid{grid-template-columns:1fr 1fr 1fr}}
@media(min-width:700px){.metric-grid{grid-template-columns:1fr 1fr 1fr 1fr}}
.metric{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 13px;cursor:pointer;
  position:relative;min-height:96px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--shadow-soft);
  transition:transform .18s var(--motion-ease),box-shadow .18s var(--motion-ease),border-color .18s var(--motion-ease)}
.metric .m-top{display:flex;justify-content:space-between;align-items:flex-start}
.metric .m-ic{font-size:18px}
.metric .m-dot{width:9px;height:9px;border-radius:50%;margin-top:4px}
.m-good{background:var(--good)} .m-watch{background:var(--watch)} .m-alert{background:var(--alert)}
.metric .m-val{font-size:24px;font-weight:800;letter-spacing:-.5px;margin-top:6px}
.metric .m-val .u{font-size:12px;font-weight:600;color:var(--muted);margin-left:3px}
.metric .m-lbl{font-size:12px;color:var(--muted);font-weight:600}
.metric.alert{border-color:#f3c9c9}.metric.watch{border-color:#f3e3c0}

/* ---- findings ---- */
.findings{list-style:none;padding:4px 16px 0}
.frow{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:13px 14px;margin-bottom:8px;cursor:pointer;box-shadow:var(--shadow-soft);
  transition:transform .18s var(--motion-ease),box-shadow .18s var(--motion-ease),border-color .18s var(--motion-ease)}
.frow.priority{border-color:#8edbd1;box-shadow:var(--shadow-soft)}
.frow .dot{width:9px;height:9px;border-radius:50%;flex:none}
.frow .lbl{font-weight:600;font-size:14px;flex:1}
.f-focus{font-size:11px;font-weight:800;color:var(--teal);background:#e8f6f3;border-radius:999px;padding:3px 7px;white-space:nowrap}
.frow .st{font-size:12px;font-weight:700} .frow .chev{color:#c0ccd4}
.empty{color:var(--muted);font-size:13px;padding:8px 18px}
.findings-block{padding:6px 0 12px}.findings-block h3{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:10px 18px 2px}

/* ---- avatar ---- */
.avatar-wrap{position:relative;margin:8px 16px;border-radius:20px;overflow:hidden;
  background:linear-gradient(180deg,#f4f9fb,#e7f0f4);min-height:420px}
model-viewer{width:100%;height:100%;min-height:420px}
#state-pill{background:#fff;border-radius:20px;padding:5px 11px;font-weight:700;display:inline-flex;gap:7px;align-items:center;font-size:13px}
.dot{display:inline-block}
.hot{position:absolute;width:20px;height:20px;border-radius:50%;border:2px solid #fff;cursor:pointer;
  transform:translate(-50%,-50%);animation:organ-pulse 1.2s ease-in-out infinite}
@keyframes organ-pulse{
  0%,100%{box-shadow:0 0 0 3px color-mix(in srgb,var(--organ) 70%,transparent)}
  50%{box-shadow:0 0 10px 4px color-mix(in srgb,var(--organ) 25%,transparent)}
}
.hot.high{animation-duration:.8s}
.hot.healthy{animation:none;box-shadow:none;background:#2ECC71!important}
#mv.projected{opacity:.82;filter:drop-shadow(0 0 8px rgba(100,180,255,.45))}
#mv.healthy{filter:hue-rotate(90deg) saturate(.6);opacity:.92}
.avatar-mode{display:flex;align-items:center;gap:8px;margin:2px 16px 8px}
.avatar-mode .seg{display:flex;flex-wrap:wrap;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
.avatar-mode button{border:none;background:#fff;color:var(--muted);font:inherit;font-size:12px;font-weight:700;padding:8px 12px;cursor:pointer;min-width:78px;
  transition:transform .18s var(--motion-ease),filter .18s var(--motion-ease),background .18s var(--motion-ease)}
.avatar-mode button.on{background:#e8f6f3;color:var(--teal)}
.avatar-note{margin:0 16px 8px}
.next-step{cursor:pointer;border-left:3px solid var(--teal);transition:transform .18s var(--motion-ease),box-shadow .18s var(--motion-ease)}
.next-step:hover{box-shadow:var(--shadow-lift);transform:translateY(-2px)}
.next-step-goal-link{color:var(--teal);font-size:.85rem;text-decoration:none;display:inline-block;margin-top:6px}
.next-step-goal-link:hover{text-decoration:underline}
.next-step-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle}
.next-step-impact { color: var(--teal); font-size: 12px; font-weight: 600; margin: 4px 0; }
.ask-card-inner{margin-top:8px}
.ask-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.ask-title{font-weight:600;font-size:1rem}
.ask-trash{background:transparent;border:none;cursor:pointer;opacity:.6;font-size:1.1rem;padding:2px 4px}
.ask-thread{display:flex;flex-direction:column;gap:6px;max-height:280px;overflow-y:auto;margin-bottom:8px}
.ask-bubble{border-radius:12px;padding:8px 12px;font-size:.875rem;line-height:1.4;max-width:85%;word-break:break-word}
.ask-bubble.user{align-self:flex-end;background:var(--teal,#0a9396);color:#fff}
.ask-bubble.bot{align-self:flex-start;background:var(--field,#1e2530);color:var(--text,#e2e8f0)}
.ask-loading{opacity:.6;font-style:italic}
.ask-disclaimer{font-size:.7rem;color:var(--muted,#64748b);text-align:center;margin:4px 0 0}
.ask-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.ask-chip{border:1px solid var(--teal,#0a9396);border-radius:16px;padding:4px 10px;background:transparent;color:var(--teal,#0a9396);font-size:.8rem;cursor:pointer}
.ask-chip:hover{opacity:.8}
.ask-inputrow{display:flex;gap:6px;align-items:center}
#ask-input{flex:1;padding:6px 10px;border-radius:8px;border:1px solid var(--line,#334155);background:var(--field,#1e2530);color:var(--text,#e2e8f0);font-size:.875rem}
.ask-send{padding:6px 12px;border-radius:8px;min-width:36px;width:auto;margin-top:0}

/* ---- cards / fields ---- */
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;margin:8px 16px;box-shadow:var(--shadow-soft)}
.card h3{font-size:15px;margin-bottom:10px}
.field{display:flex;align-items:center;gap:8px;margin:9px 0}
.field label{width:120px;font-size:13px;color:var(--muted)}
.field input{flex:1;border:1px solid var(--line);border-radius:9px;padding:10px 11px;font:inherit;font-size:14px}
.lab-field{align-items:flex-start}
.lab-field label{padding-top:2px;line-height:1.25}
.lab-group-title{margin:14px 0 6px;font-size:12px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.card h3 + .lab-group-title{margin-top:4px}
.lab-ref{display:block;font-size:11px;color:#8aa0b4;font-weight:600;margin-top:3px}
.lab-input{flex:1;min-width:0}
.lab-input input{width:100%}
.lab-status{display:flex;align-items:center;gap:6px;min-height:18px;margin-top:5px;font-size:12px;font-weight:700;color:var(--muted)}
.lab-status:not(.on){display:none}
.lab-dot{width:8px;height:8px;border-radius:50%;background:currentColor;flex:0 0 auto}
.lab-status.level-none{color:var(--good)}
.lab-status.level-low{color:var(--low)}
.lab-status.level-medium{color:var(--med)}
.lab-status.level-high{color:var(--high)}
.lab-reaction-card{border-left:3px solid var(--teal)}
.lab-reaction-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:10px}
.lab-reaction-head h3{margin-bottom:0}
.lab-reaction-head a{font-size:12px;font-weight:700;white-space:nowrap}
.lab-reaction-score{display:flex;align-items:center;gap:10px;margin:6px 0 10px}
.lab-reaction-score span{display:flex;flex-direction:column;gap:1px}
.lab-reaction-score b{font-size:24px;line-height:1}
.lab-reaction-score small{font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.lab-reaction-arrow{color:var(--muted);font-weight:800}
.lab-reaction-score strong{margin-left:auto;font-size:14px}
.lab-reaction-list{list-style:none;display:flex;flex-direction:column;gap:7px;margin:8px 0 10px}
.lab-reaction-list li{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700}
.lab-reaction-list span{width:20px;height:20px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex:none;background:#eef3f6;font-size:12px}
.lab-reaction-list .up span{background:#fdecec;color:var(--alert)}
.lab-reaction-list .down span{background:#e8f6f3;color:var(--good)}
.lab-reaction-list .flat span{background:#eef3f6;color:var(--muted)}
.co-links-card{border-left:3px solid var(--teal)}
.co-links-list{display:flex;flex-direction:column;gap:8px}
.co-link{border:0;border-left:3px solid var(--line);padding:8px 10px;background:var(--bg);border-radius:8px;font:inherit;font-size:13px;line-height:1.35;color:var(--ink);text-align:left;cursor:pointer;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;width:100%}
.co-link:hover{background:#eef6f8}
.co-link.bad{border-left-color:var(--watch)}
.co-link.good{border-left-color:var(--good)}
.co-link-arrow{font-size:18px;line-height:1;color:var(--muted);font-weight:800;flex:0 0 auto}
.marker-goal{border-left:3px solid var(--teal)}
.marker-goal.clickable{cursor:pointer;transition:box-shadow .18s var(--motion-ease),border-color .18s var(--motion-ease),transform .18s var(--motion-ease)}
.marker-goal.clickable:hover{border-left-color:#129783;box-shadow:var(--shadow-lift);transform:translateY(-2px)}
.marker-goal.reached{border-left-color:var(--good)}
.marker-goal.reached.clickable:hover{border-left-color:var(--good)}
.marker-goal .sec-head{padding:0 0 4px}
.marker-goal-title{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:2px 0 6px}
.marker-goal-title b{font-size:17px;line-height:1.2}
.marker-goal-title span{font-size:13px;font-weight:800;color:var(--teal)}
.marker-goal.reached .marker-goal-title span{color:var(--good)}
.marker-goal-text{font-size:13px;line-height:1.4;color:var(--ink);margin-bottom:10px}
.marker-goal-bar{height:12px;border-radius:999px;background:var(--bg);border:1px solid var(--line);overflow:hidden}
.marker-goal-bar span{display:block;height:100%;border-radius:999px;background:var(--teal);transition:width .2s ease}
.marker-goal.reached .marker-goal-bar span{background:var(--good)}
.marker-goal-scale{display:flex;justify-content:space-between;gap:10px;margin-top:6px;color:var(--muted);font-size:11px;font-weight:700}
.marker-goal-current{margin-top:8px;font-size:12px;color:var(--muted)}
.marker-goal-current b{color:var(--ink);font-size:14px}
.marker-goal-link{margin-top:10px;font-size:12px;font-weight:800;color:var(--teal)}
.priority-card{border-left:5px solid var(--priority-color);box-shadow:0 10px 28px rgba(16,32,44,.08);padding:18px 18px 16px}
.priority-kicker{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:8px}
.priority-source{display:inline-flex;margin-left:6px;padding:2px 7px;border-radius:999px;background:#e8f6f3;color:var(--teal);letter-spacing:0;text-transform:none}
.priority-title{display:flex;align-items:center;gap:9px;font-size:19px;line-height:1.2;margin-bottom:8px}
.priority-dot{width:11px;height:11px;border-radius:50%;background:var(--priority-color);box-shadow:0 0 0 4px color-mix(in srgb,var(--priority-color) 18%,transparent);flex:0 0 auto}
.priority-reason{font-size:14px;line-height:1.45;color:var(--ink);margin-bottom:10px}
.priority-action{border-top:1px solid var(--line);padding-top:10px;color:var(--muted);font-size:13px;line-height:1.4;font-weight:700}
.connect{margin:8px 16px;background:#0c1620;color:#fff;border:none;border-radius:12px;padding:14px;
  width:calc(100% - 32px);font:inherit;font-size:14px;font-weight:600;cursor:pointer;text-align:left}
.btn{display:block;width:100%;margin-top:10px;padding:13px;border:none;border-radius:12px;
  background:var(--teal);color:#fff;font:inherit;font-weight:700;font-size:15px;cursor:pointer;
  transition:transform .18s var(--motion-ease),box-shadow .18s var(--motion-ease),filter .18s var(--motion-ease),background .18s var(--motion-ease)}
.btn.ghost{background:#fff;border:1px solid var(--line);color:var(--teal)}
.btn.danger{background:#fff;border:1px solid #f3c4c4;color:var(--high)}
.data-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:8px 16px 12px}
.action-card,.organ-card,.section-card{border:1px solid var(--line);background:#fff;border-radius:16px;padding:14px;text-align:left;
  font:inherit;cursor:pointer;box-shadow:var(--shadow-soft);transition:transform .18s var(--motion-ease),box-shadow .18s var(--motion-ease)}
.action-card{min-height:96px;display:grid;grid-template-rows:auto 1fr auto;gap:6px}.action-card span{font-size:24px}.action-card b{font-size:15px}.action-card i{font-style:normal;color:var(--muted);font-size:12px;font-weight:700}
.organ-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0 16px 12px}
.organ-card{position:relative;min-height:112px;display:flex;flex-direction:column;gap:8px}
.organ-card .organ-ic{font-size:24px}.organ-card b{font-size:15px}.organ-card i{position:absolute;top:14px;right:14px;width:10px;height:10px;border-radius:50%}.organ-card em{margin-top:auto;font-style:normal;color:var(--muted);font-size:12px;font-weight:800}
.view-toggle{display:flex;gap:6px;margin:0 16px 12px;background:#e9f0f4;border:1px solid var(--line);border-radius:14px;padding:4px}
.view-toggle button{flex:1;border:0;background:transparent;border-radius:10px;padding:9px 10px;font:inherit;font-size:13px;font-weight:800;color:var(--muted);cursor:pointer}
.view-toggle button.on{background:#fff;color:var(--teal);box-shadow:var(--shadow-soft)}
.view-toggle button:disabled{opacity:.45;cursor:not-allowed}
.service-grid,.exam-grid{display:grid;grid-template-columns:1fr;gap:12px;margin:0 16px 12px}
.service-card,.exam-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;box-shadow:var(--shadow-soft)}
.service-card-head{display:flex;justify-content:space-between;gap:12px;margin-bottom:12px}
.service-card h3,.exam-card h3{font-size:15px;line-height:1.2;margin-bottom:6px}
.service-card p{font-size:12px;line-height:1.35;color:var(--muted)}
.service-card-head b,.exam-price{font-size:13px;font-weight:900;color:var(--teal);white-space:nowrap}
.service-markers{display:grid;grid-template-columns:1fr;gap:8px}
.catalog-marker{display:grid;grid-template-columns:minmax(0,1fr) 86px auto;align-items:center;gap:8px;border:1px solid var(--line);border-radius:10px;padding:8px;background:#fbfdfe}
.catalog-marker span{font-size:12px;font-weight:800;min-width:0}
.catalog-marker i{display:block;font-style:normal;color:var(--muted);font-size:10px;font-weight:800;margin-top:1px}
.catalog-marker input{width:86px;border:1px solid var(--line);border-radius:8px;padding:8px 9px;font:inherit;font-size:13px;background:#fff}
.catalog-marker small{font-size:11px;color:var(--muted);font-weight:800;white-space:nowrap}
.shop-link{margin-top:12px;text-align:center;text-decoration:none}
.exam-card{display:flex;flex-direction:column;gap:10px;min-height:142px}
.organ-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.organ-tags span{background:#e8f6f3;color:var(--teal);border-radius:999px;padding:4px 8px;font-size:11px;font-weight:800}
.shop-mini{font-size:13px;font-weight:900;color:var(--teal);text-decoration:none}
.catalog-footnote{padding:0 18px 12px}
.app-teaser{display:flex;align-items:center;justify-content:space-between;gap:12px}
.app-teaser b{font-size:14px}
.app-teaser p{font-size:12px;color:var(--muted);margin-top:3px;line-height:1.35}
.app-teaser span{border:1px solid #bfe4df;background:#e8f6f3;color:var(--teal);border-radius:999px;padding:5px 8px;font-size:11px;font-weight:900;white-space:nowrap}
.bottom-primary{width:calc(100% - 32px);margin:4px 16px 10px}
.sheet-content>.vitals-grid{padding:0 16px 12px}
.sheet-content>#ah-grid{padding-top:4px}.sheet-content>#score-history .card,.sheet-content>#dash-next-step .card,.sheet-content>#llm-priority-control .card{margin-left:16px;margin-right:16px}
.sheet-content>#today{position:static!important;width:auto!important;height:auto!important;margin:0 18px 10px!important;clip:auto!important;display:block;color:var(--muted);font-size:13px;white-space:normal!important}
.lab-sheet-card{box-shadow:none}

.trend{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--line);font-size:14px}
.trend:last-child{border:none}
.down{color:var(--good);font-weight:700}.up{color:var(--high);font-weight:700}.flat{color:var(--muted);font-weight:600}

/* profile */
.profile-overview{padding:14px 16px}
.profile-overview-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:12px}
.profile-stat-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.profile-score-ring{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto}
.profile-score-ring span{width:48px;height:48px;border-radius:50%;background:#fff;display:grid;place-items:center;font-size:20px;font-weight:900}
.profile-stat-head b{display:block;font-size:17px;margin-bottom:7px}
.profile-stat-head .level-segs{margin-bottom:5px}
.profile-stat-head small{display:block;color:var(--muted);font-size:12px;font-weight:800}
.profile-overview-head h3{margin-bottom:0}
.profile-overview-score{font-size:13px;font-weight:800;color:var(--teal);white-space:nowrap}
.profile-overview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;text-align:center}
.profile-overview-grid>div{border:1px solid var(--line);border-radius:12px;padding:10px 8px;background:#fbfdfe;min-width:0}
.profile-overview-val{display:block;font-size:20px;font-weight:800;letter-spacing:0;line-height:1.1}
.profile-overview-lbl{display:block;font-size:11px;color:var(--muted);font-weight:700;margin-top:3px;line-height:1.25}
.profile-overview-focus{margin-top:12px;border-top:1px solid var(--line);padding-top:12px;display:flex;justify-content:space-between;gap:12px;align-items:baseline}
.profile-overview-focus span{font-size:11px;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.06em}
.profile-overview-focus b{font-size:14px;text-align:right}
.profile-sections{display:flex;flex-direction:column;gap:10px;margin:8px 16px 18px}
.section-card{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;min-height:58px}
.section-card b{font-size:15px}.section-card span{font-size:13px;color:var(--muted);font-weight:800;text-align:right}
@media(max-width:420px){
  .profile-overview-head{display:block}
  .profile-overview-score{display:block;margin-top:2px;white-space:normal}
  .profile-overview-grid{grid-template-columns:1fr 1fr}
}

/* mission */
.level{display:flex;align-items:center;gap:10px;margin:6px 16px;font-weight:700}
.pips{letter-spacing:3px;color:var(--teal);font-size:18px}
.chal{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin:8px 16px}
.chal .ring{width:34px;height:34px;border-radius:50%;border:4px solid #e3ebf0;border-top-color:var(--teal);transform:rotate(45deg);flex:none}
.next-badge{display:flex;align-items:center;gap:12px}
.next-badge-icon{font-size:30px;color:var(--teal);line-height:1;flex:none}
.badges{display:flex;flex-wrap:wrap;gap:12px;margin:8px 16px}
.badge{width:70px;text-align:center;font-size:10px;color:var(--muted)}
.badge .ic{width:50px;height:50px;border-radius:50%;background:#e8f6f3;display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 4px}
.badge.lock .ic{background:#eef3f6;filter:grayscale(1);opacity:.45}
.badge-hint{display:block;font-size:9px;color:var(--muted);line-height:1.2;margin-top:2px}

/* overlay */
.ov{position:fixed;inset:0;background:rgba(16,32,44,.4);display:flex;align-items:flex-end;justify-content:center;z-index:30;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .15s var(--motion-ease),visibility 0s linear .15s}
.ov.on,.ov.closing{visibility:visible}
.ov.on{opacity:1;pointer-events:auto;transition-delay:0s}
.sheet{background:#fff;width:100%;max-width:520px;max-height:84%;overflow-y:auto;border-radius:22px 22px 0 0;padding-bottom:20px;
  opacity:0;transform:translateY(24px);transition:opacity .22s var(--motion-ease),transform .22s var(--motion-ease);box-shadow:0 1px 2px rgba(16,32,44,.08),0 18px 50px rgba(16,32,44,.18)}
.ov.on .sheet{opacity:1;transform:none}
@media(min-width:700px){.ov{align-items:center}.sheet{border-radius:18px}}
.sheet .sh-head{display:flex;justify-content:space-between;align-items:center;padding:16px 18px 6px}
.sheet .sh-head h3{font-size:18px}
.x{border:none;background:#f1f6f9;width:44px;height:44px;border-radius:50%;font-size:16px;cursor:pointer}
.quote{font-size:15px;line-height:1.5;padding:0 18px;margin:6px 0 12px}
.drivers{display:flex;flex-wrap:wrap;gap:6px;padding:0 18px}
.tag{font-size:12px;background:#f1f6f9;border:1px solid var(--line);border-radius:20px;padding:4px 10px}
.organ-function{padding:0 18px;margin:14px 0 0}
.organ-function .tiny{text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.organ-function p{font-size:14px;line-height:1.45;margin:0;color:#20313f}
.rec{background:#e8f6f3;border-radius:10px;padding:10px 12px;font-size:13px;color:#0a5;margin:12px 18px 0}
.warn{font-size:11px;color:var(--muted);padding:8px 18px 0}

.toast{position:fixed;bottom:calc(92px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);background:#10202c;color:#fff;
  padding:11px 18px;border-radius:30px;font-size:13px;z-index:99;opacity:0;transition:opacity .2s;pointer-events:none;max-width:90vw;text-align:center}
.toast.on{opacity:1}
.foot{text-align:center;color:#8aa0b4;font-size:11px;padding:14px 20px calc(92px + env(safe-area-inset-bottom))}
.foot a{font-weight:800;text-decoration:none}
@media(min-width:700px){.foot{padding-bottom:14px}}
.next-step-challenge { display:block; width:100%; background:var(--teal); color:#fff; border:none; border-radius:6px; padding:10px 14px; font-size:0.95rem; font-weight:600; cursor:pointer; margin-top:12px; text-align:center; }
.next-step-challenge:hover { opacity:0.88; }
.next-step-challenge-active { color:var(--teal); font-size:0.88rem; margin-top:10px; }
.befund-challenge { width:auto; margin:12px 18px 0; }
.mission-stats { display:flex; gap:12px; justify-content:space-around; text-align:center; }
.mission-stat-val { display:block; font-size:1.5rem; font-weight:700; }
.mission-stat-lbl { display:block; font-size:0.75rem; color:var(--muted); margin-top:2px; }
.mission-rec { border:1px solid rgba(2,128,144,.45); border-radius:10px; padding:8px; margin:6px 0; }
.mission-rec-label { color:var(--teal); font-size:0.75rem; font-weight:700; margin-bottom:4px; }

/* ---- motion & interaction polish ---- */
button,a,input{touch-action:manipulation}
button:focus-visible,a:focus-visible,input:focus-visible{
  outline:2px solid color-mix(in srgb,var(--teal) 78%,#fff 22%);
  outline-offset:3px;
  box-shadow:0 0 0 4px color-mix(in srgb,var(--teal) 16%,transparent);
}
.score-ring-num,.score-ring-delta,.insight-card b,.metric .m-val,.vital-value,.profile-overview-val,.profile-score-ring span,
.mission-stat-val,.lab-reaction-score b,.score-history-summary b,.score-history-single b{font-variant-numeric:tabular-nums}
.card,.dash-next,.llm-priority,.score-history-card,.vital-tile.clickable,.metric,.frow,.action-card,.organ-card,.section-card,
.focus-chip,.insight-card,.mini-hero,.next-step,.marker-goal.clickable,.chal{
  transition:transform .18s var(--motion-ease),box-shadow .18s var(--motion-ease),border-color .18s var(--motion-ease),filter .18s var(--motion-ease);
}
@media(hover:hover){
  .card:hover,.dash-next:hover,.llm-priority:hover,.vital-tile.clickable:hover,.metric:hover,.frow:hover,.action-card:hover,.organ-card:hover,
  .section-card:hover,.focus-chip:hover,.insight-card:hover,.mini-hero:hover,.next-step:hover,.marker-goal.clickable:hover,.chal:hover{
    transform:translateY(-2px);box-shadow:var(--shadow-lift);
  }
  .stage-chip:hover,.avatar-mode button:hover,.ask-chip:hover{transform:translateY(-2px);filter:saturate(1.08);box-shadow:var(--shadow-lift)}
  .score-ring:hover,.level-badge:hover{transform:translateY(-2px);box-shadow:var(--shadow-lift)}
  .btn:hover,.connect:hover,.next-step-challenge:hover{filter:brightness(1.06);box-shadow:var(--shadow-lift)}
  .primary-action:hover{filter:brightness(1.08) saturate(1.04)}
  .tabs button:hover,.sidenav a:hover,.sync-btn:hover,.x:hover{filter:brightness(1.04)}
}
.card:active,.dash-next:active,.llm-priority:active,.vital-tile.clickable:active,.metric:active,.frow:active,.action-card:active,
.organ-card:active,.section-card:active,.focus-chip:active,.insight-card:active,.mini-hero:active,.next-step:active,.marker-goal.clickable:active,
.chal:active,.score-ring:active,.level-badge:active{transform:scale(.985)}
.stage-chip:active,.avatar-mode button:active,.ask-chip:active{transform:scale(.96)}
.btn:active,.connect:active,.next-step-challenge:active,.sync-btn:active,.x:active{transform:scale(.985)}

/* ---- responsive desktop enhancements ---- */
@media(min-width:700px){
  .demo-mode .app{padding-top:32px}
  .data-actions,.organ-grid,.service-grid,.exam-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .profile-sections{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media(min-width:1100px){
  .content{max-width:1560px;padding:14px 32px 36px}
  .head{padding-left:0;padding-right:0}
  .card{margin-left:0;margin-right:0}

  #s-dashboard.scr.on{
    display:grid;
    grid-template-columns:minmax(0,1.38fr) minmax(360px,.92fr);
    grid-template-rows:auto auto auto 1fr;
    column-gap:24px;
    align-items:start;
  }
  #s-dashboard>.dash-head{grid-column:1/-1}
  #s-dashboard>.twin-stage{
    grid-column:1;
    grid-row:2/5;
    margin:8px 0 0;
    min-height:calc(100vh - 126px);
  }
  #s-dashboard>.action-row{grid-column:2;grid-row:2;margin:8px 0 12px}
  #s-dashboard>.focus-chip{grid-column:2;grid-row:3;margin:0 0 12px;width:100%;min-height:62px}
  #s-dashboard>.insight-rail{
    grid-column:2;
    grid-row:4;
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
    overflow:visible;
    scroll-snap-type:none;
    padding:0;
    mask-image:none;
  }
  #s-dashboard .insight-card{flex:initial;min-height:118px}
  #s-dashboard .insight-card b{font-size:20px}
  #s-dashboard .stage-avatar{inset:24px 0 58px}
  #s-dashboard .stage-avatar model-viewer{min-height:620px}
  #s-dashboard .score-ring{top:22px;right:22px;width:96px;height:110px;border-radius:22px}
  #s-dashboard .score-ring svg{width:96px;height:96px}
  #s-dashboard .score-ring circle{stroke-width:6}
  #s-dashboard .score-ring-num{top:31px;font-size:27px}
  #s-dashboard .score-ring-delta{top:78px;font-size:12px}
  #s-dashboard .level-badge{top:22px;left:22px;padding:12px 14px;font-size:13px;border-radius:22px}
  #s-dashboard .level-segs{gap:4px;margin-bottom:7px}
  #s-dashboard .level-segs i{width:19px;height:6px}
  #s-dashboard .stage-chips{left:22px;right:22px;bottom:20px;flex-wrap:wrap;overflow:visible;scroll-snap-type:none}
  #s-dashboard .stage-chip{scroll-snap-align:none}

  .view-toggle,.service-grid,.exam-grid,.catalog-footnote{margin-left:0;margin-right:0;padding-left:0;padding-right:0}
  .data-actions,.organ-grid,.service-grid,.exam-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-left:0;margin-right:0;gap:14px}
  .action-card,.organ-card{min-height:126px}
  .bottom-primary{max-width:480px;margin:14px auto 18px}

  .profile-overview{padding:14px 0}
  .profile-overview .card{width:100%}
  .profile-sections{grid-template-columns:repeat(2,minmax(0,1fr));margin:8px 0 20px;gap:14px}
  .section-card{min-height:86px}

  #s-avatar.scr.on{
    display:grid;
    grid-template-columns:minmax(0,1.25fr) minmax(360px,.82fr);
    grid-auto-rows:min-content;
    column-gap:24px;
    align-items:start;
  }
  #s-avatar>.head{grid-column:1/-1}
  #s-avatar>.avatar-wrap{
    grid-column:1;
    grid-row:2/10;
    margin:8px 0 0;
    min-height:calc(100vh - 126px)!important;
  }
  #s-avatar>.avatar-wrap model-viewer{min-height:calc(100vh - 126px)!important}
  #s-avatar>#ask-card,
  #s-avatar>#priority-card,
  #s-avatar>#explain-card,
  #s-avatar>#links-card,
  #s-avatar>#goal-card,
  #s-avatar>#next-step-card,
  #s-avatar>#avatar-projection-controls,
  #s-avatar>#avatar-projection-note,
  #s-avatar>.findings-block{grid-column:2}
  #s-avatar .avatar-mode,#s-avatar .avatar-note{margin-left:0;margin-right:0}
  #s-avatar .findings{padding-left:0;padding-right:0}
  #s-avatar .findings-block h3{padding-left:0;padding-right:0}

  .sheet{max-width:560px;border-radius:18px;max-height:min(84vh,760px)}
}

@media(min-width:1500px){
  .content{padding-left:44px;padding-right:44px}
  #s-dashboard.scr.on{grid-template-columns:minmax(0,1.48fr) minmax(390px,.88fr);column-gap:32px}
  #s-dashboard>.twin-stage,#s-avatar>.avatar-wrap{min-height:calc(100vh - 132px)!important}
  #s-dashboard .stage-avatar model-viewer,#s-avatar>.avatar-wrap model-viewer{min-height:calc(100vh - 132px)!important}
  #s-avatar.scr.on{grid-template-columns:minmax(0,1.34fr) minmax(390px,.86fr);column-gap:32px}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;
    animation-iteration-count:1!important;
    transition-duration:.001ms!important;
    scroll-behavior:auto!important;
  }
  .scr,.scr.on{transform:none!important}
  .twin-stage:before,.stage-chip.alert i,.hot{animation:none!important}
  .ov,.sheet{transition:none!important}
}
