/* =============================================================
 * Veros — Product Visual (looping motion piece)
 * Tokens lifted verbatim from apps/landing tokens.css v3.
 * Navy + gold on cream · Cormorant Garamond / DM Sans / JetBrains Mono
 * Max weight 500 everywhere.
 * ============================================================= */

:root {
  --navy:#0C1F3F; --navy-mid:#152D58; --navy-deep:#0A0E18;
  --gold:#B8935A; --gold-light:#CCA876; --gold-soft:rgba(184,147,90,0.12);
  --cream:#FAF8F4; --cream-mid:#EDE8DF; --paper-3:#EAE3D3; --white:#FFFFFF;
  --ink:#1A1510; --stone:#6E6458; --ink-soft:#736A5C;
  --green:#166F3D;
  --line:rgba(26,21,16,0.09); --line-soft:rgba(26,21,16,0.05); --line-firm:rgba(26,21,16,0.18);
  --border-card:rgba(184,147,90,0.18); --border-pill:rgba(184,147,90,0.25);
  --shadow-card:0 8px 40px rgba(12,31,63,0.07);
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"DM Sans",system-ui,-apple-system,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,Menlo,monospace;
  --ease:cubic-bezier(0.25,0.46,0.45,0.94);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;}
body{
  background:#0c0d10;            /* letterbox backdrop */
  font-family:var(--sans);
  color:var(--ink);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}

/* ---- Stage / scaling ------------------------------------------------- */
#stage{
  position:fixed; inset:0;
  background:var(--cream);
}
#canvas{
  position:absolute; inset:0;
}

/* ---- Browser chrome (matches landing .media-frame) ------------------- */
.frame{
  position:absolute; inset:0;
  display:flex; flex-direction:column;
  overflow:hidden;
  background:var(--white);
}
.frame__bar{
  flex:0 0 auto;
  display:flex; align-items:center; gap:.85rem;
  padding:.85rem 1.2rem;
  background:var(--cream);
  border-bottom:1px solid var(--line);
}
.frame__dots{display:inline-flex; gap:.45rem;}
.frame__dots i{width:11px;height:11px;border-radius:50%;background:var(--paper-3);display:block;}
.frame__url{
  font-family:var(--mono); font-size:12px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink-soft);
  white-space:nowrap;
}
.frame__body{
  position:relative; flex:1 1 auto; overflow:hidden;
  background:var(--cream);
}
/* scaled scene area: fixed 1600-wide design, fills body width, centered */
.scenes{
  position:absolute; top:50%; left:50%;
  width:1600px; height:856px;
  transform:translate(-50%,-50%) scale(var(--s,1));
  transform-origin:center center;
}
/* chrome can be disabled for in-frame embedding */
#canvas[data-chrome="off"] .frame__bar{display:none;}

/* brand accent hairline at very top of body */
.frame__accent{
  position:absolute; top:0; left:0; right:0; height:3px; z-index:30;
  background:linear-gradient(90deg,var(--navy) 0%,var(--navy-mid) 38%,var(--gold) 100%);
}

/* ---- Scene layers ---------------------------------------------------- */
.scene{
  position:absolute; inset:0;
  opacity:0; visibility:hidden;
  transition:opacity 820ms var(--ease), visibility 0ms linear 820ms;
  display:flex; flex-direction:column;
  padding:54px 70px 76px;
}
.scene.is-active{
  opacity:1; visibility:visible;
  transition:opacity 820ms var(--ease), visibility 0ms;
}

/* ---- Caption (bottom mono eyebrow) ----------------------------------- */
.caption{
  position:absolute; left:0; right:0; bottom:26px; z-index:40;
  display:flex; align-items:center; justify-content:center; gap:.85rem;
  pointer-events:none;
}
.caption .rule{width:clamp(14px,5vw,30px);height:1px;background:var(--gold);opacity:.6;}
.caption .txt{
  font-family:var(--mono); font-size:clamp(7.5px,2.4vw,12.5px); font-weight:500;
  letter-spacing:.22em; text-transform:uppercase; color:var(--gold);
  white-space:nowrap;
  opacity:0; transition:opacity 520ms var(--ease);
}
.caption.show .txt{opacity:1;}
/* The embed scales the whole scene down to ~20% on a phone, but the caption
   lives outside that scaled area — so on narrow embeds we shrink it (above) and
   pull it tighter to the edge so it never crowds the scaled-down dashboard. */
@media (max-width:560px){
  .caption{bottom:12px;gap:.5rem;}
  .caption .txt{letter-spacing:.14em;}
}

/* =====================================================================
 * Shared UI chrome inside scenes
 * ===================================================================== */
.wordmark{font-family:var(--serif);font-weight:500;font-size:30px;color:var(--navy);letter-spacing:.01em;line-height:1;}

/* onboarding stepper header */
.ob-head{display:flex;align-items:center;gap:34px;margin-bottom:8px;}
.ob-steps{display:flex;align-items:center;gap:26px;flex:1;}
.ob-step{display:flex;align-items:center;gap:9px;font-family:var(--sans);font-size:15px;color:var(--stone);font-weight:400;white-space:nowrap;}
.ob-step .dot{width:8px;height:8px;border-radius:50%;background:var(--line-firm);}
.ob-step.done{color:var(--navy);} .ob-step.done .dot{background:var(--navy);}
.ob-step.cur{color:var(--navy);font-weight:500;} .ob-step.cur .dot{background:var(--gold);box-shadow:0 0 0 4px var(--gold-soft);}
.ob-step .line{width:34px;height:1px;background:var(--line);}
.save-exit{font-family:var(--sans);font-size:14px;color:var(--navy);border:1px solid var(--border-navy,rgba(12,31,63,0.35));padding:9px 16px;border-radius:3px;}

/* app top-nav */
.appnav{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px;}
.appnav__links{display:flex;align-items:center;gap:30px;}
.appnav__links a{font-family:var(--sans);font-size:15px;color:var(--stone);text-decoration:none;font-weight:400;position:relative;padding-bottom:6px;}
.appnav__links a.active{color:var(--navy);font-weight:500;}
.appnav__links a.active::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--gold);}
.appnav__right{display:flex;align-items:center;gap:18px;}
.gear{width:20px;height:20px;color:var(--stone);}
.avatar{width:34px;height:34px;border-radius:50%;border:1px solid var(--border-card);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:16px;color:var(--navy);font-style:italic;}

.eyebrow{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:.7rem;}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);}

.serif-h{font-family:var(--serif);font-weight:400;color:var(--navy);letter-spacing:-0.01em;line-height:1.05;}
.serif-h em{font-style:italic;color:var(--gold);}
.sub{font-family:var(--sans);font-weight:300;color:var(--stone);line-height:1.6;}

/* generic anim helper — children fade-up when scene runs.
   Base state is VISIBLE; we only hide-then-reveal when motion is allowed,
   so reduced-motion + any non-painting context still shows content. */
.scene .au{opacity:1;}
@media (prefers-reduced-motion:no-preference){
  .scene .au{opacity:0;}
  .scene.run.is-active .au{animation:fadeUp .7s var(--ease) both;}
}

@keyframes fadeUp{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes scaleIn{from{opacity:0;transform:scale(.9);}to{opacity:1;transform:scale(1);}}

/* =====================================================================
 * SCENE 1 — Talk to Vera (voice intake)
 * ===================================================================== */
.s-vera{align-items:center;}
.s-vera__intro{text-align:center;max-width:760px;margin:18px auto 26px;}
.s-vera__intro h2{font-size:46px;}
.s-vera__intro p{font-size:18px;margin-top:14px;}
.vera-card{
  width:430px;background:var(--white);border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--shadow-card);
  padding:38px 34px 26px;display:flex;flex-direction:column;align-items:center;
}
.vera-orb-wrap{position:relative;width:200px;height:200px;display:flex;align-items:center;justify-content:center;}
.vera-orb-wrap .ring{position:absolute;inset:0;border-radius:50%;border:1px solid var(--border-card);}
.vera-orb{
  width:160px;height:160px;border-radius:50%;
  background:conic-gradient(from 0deg,#fdfbf7,#cda76e,#8a6a3c,#f4ecdf,#b8935a,#fdfbf7);
  filter:saturate(1.05);
  box-shadow:inset 0 0 30px rgba(255,255,255,.55), 0 6px 24px rgba(184,147,90,.28);
}
.scene.run.is-active .vera-orb{animation:orbSpin 14s linear infinite, orbBreath 4s var(--ease) infinite;}
@keyframes orbSpin{to{transform:rotate(360deg);}}
@keyframes orbBreath{0%,100%{filter:saturate(1.05) brightness(1);}50%{filter:saturate(1.15) brightness(1.06);}}
.scene.run.is-active .vera-orb-wrap .ring{animation:veraRing 3.4s ease-out infinite;}
@keyframes veraRing{0%{opacity:.5;transform:scale(.97);}100%{opacity:0;transform:scale(1.12);}}
.vera-pill{margin-top:18px;font-family:var(--sans);font-size:14px;color:var(--stone);background:var(--cream);border-radius:999px;padding:8px 18px;}
.vera-input{
  margin-top:16px;width:100%;border:1px solid var(--line);border-radius:14px;
  padding:14px 16px;display:flex;align-items:center;justify-content:space-between;
}
.vera-input span{font-family:var(--sans);font-size:14px;color:var(--stone);white-space:nowrap;}
.vera-input .btns{display:flex;gap:8px;}
.vera-input .btns i{width:30px;height:30px;border-radius:50%;border:1px solid var(--line);display:block;}
.vera-input .btns i.send{background:var(--navy);border-color:var(--navy);}
.vera-powered{margin-top:16px;font-family:var(--sans);font-size:12px;color:var(--ink-soft);}

/* =====================================================================
 * SCENE 2 — Review (captured intake autofilled)
 * ===================================================================== */
.s-review .head{margin-bottom:18px;}
.s-review h2{font-size:40px;margin-top:8px;}
.s-review .sub{font-size:16px;margin-top:10px;max-width:640px;}
.intake{
  margin-top:6px;background:var(--white);border:1px solid var(--line);
  border-radius:8px;box-shadow:var(--shadow-card);overflow:hidden;
  border-top:3px solid transparent;
}
.intake__top{position:absolute;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy),var(--gold));}
.intake__hd{display:flex;align-items:center;justify-content:space-between;padding:26px 34px 20px;border-bottom:1px solid var(--line-soft);position:relative;}
.intake__hd h3{font-family:var(--serif);font-size:24px;color:var(--navy);font-weight:500;}
.intake__hd .meta{font-family:var(--mono);font-size:12px;color:var(--stone);margin-top:4px;letter-spacing:.04em;}
.badge{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);border:1px solid var(--border-pill);border-radius:999px;padding:6px 14px;}
.intake__rows{padding:6px 34px 10px;}
.irow{padding:18px 0;border-bottom:1px solid var(--line-soft);display:flex;justify-content:space-between;gap:24px;}
.irow:last-child{border-bottom:0;}
.irow .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:8px;}
.irow .val{font-family:var(--sans);font-size:17px;color:var(--ink);line-height:1.45;}
.irow .edit{font-family:var(--sans);font-size:14px;color:var(--stone);white-space:nowrap;display:flex;align-items:center;gap:6px;}
.irow ul{list-style:none;}
.irow li{font-family:var(--sans);font-size:17px;color:var(--ink);padding:4px 0 4px 18px;position:relative;}
.irow li::before{content:"";position:absolute;left:0;top:.85em;width:5px;height:5px;border-radius:50%;background:var(--gold);opacity:.7;}

/* =====================================================================
 * SCENE 3 — Trust deed + attorney review
 * ===================================================================== */
.s-deed{flex-direction:row;gap:30px;padding-top:42px;padding-bottom:84px;}
.deed{
  flex:1.55;background:linear-gradient(180deg,#fff,#fafaf8);
  border:1px solid var(--border-card);border-radius:4px;
  box-shadow:var(--shadow-card);padding:44px 54px;overflow:hidden;
  font-family:var(--serif);color:hsl(222 25% 18%);
}
.deed h1{
  text-align:center;font-family:var(--mono);letter-spacing:.24em;text-transform:uppercase;
  font-size:13px;font-weight:500;color:var(--navy);margin-bottom:30px;padding-bottom:16px;
  border-bottom:1px solid rgba(12,31,63,.18);
}
.deed p{font-size:17px;line-height:1.75;margin-bottom:30px;}
.deed h2{font-family:var(--serif);font-weight:500;font-size:22px;color:var(--navy);margin:24px 0 12px;}
.deed .term{border-bottom:1px dotted rgba(184,147,90,.6);}
.deed .uc{background:linear-gradient(to bottom,rgba(184,147,90,.08),rgba(184,147,90,.16));color:#7a5e30;border-radius:4px;padding:0 6px;border-bottom:1px solid rgba(184,147,90,.35);}
/* attorney rail */
.atty{flex:.85;display:flex;flex-direction:column;gap:16px;padding-top:4px;}
.atty__card{background:var(--white);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-card);padding:26px 26px;}
.atty__live{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:8px;margin-bottom:14px;}
.atty__live .d{width:7px;height:7px;border-radius:50%;background:var(--green);}
.scene.run.is-active .atty__live .d{animation:pulseDot 2s ease-in-out infinite;}
@keyframes pulseDot{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(1.4);}}
.atty__card h4{font-family:var(--serif);font-size:23px;color:var(--navy);font-weight:500;line-height:1.2;}
.atty__card p{font-family:var(--sans);font-size:14.5px;color:var(--stone);line-height:1.6;margin-top:10px;}
.atty__who{display:flex;align-items:center;gap:12px;margin-top:20px;padding-top:18px;border-top:1px solid var(--line-soft);}
.atty__who .pf{width:42px;height:42px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:18px;}
.atty__who b{font-family:var(--sans);font-weight:500;font-size:15px;color:var(--ink);display:block;}
.atty__who span{font-family:var(--sans);font-size:13px;color:var(--stone);}
.atty__prog{margin-top:20px;}
.atty__prog .row{display:flex;justify-content:space-between;gap:12px;font-family:var(--sans);font-size:12.5px;color:var(--ink);margin-bottom:9px;}
.atty__prog .row span{white-space:nowrap;}
.atty__prog .row .r{color:var(--stone);}
.atty__bar{height:5px;border-radius:999px;background:var(--cream-mid);overflow:hidden;}
.atty__bar i{display:block;height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--gold),var(--gold-light));}
.scene.run.is-active .atty__bar i{animation:attyFill 3.2s var(--ease) .4s forwards;}
@keyframes attyFill{from{width:8%;}to{width:96%;}}
.atty__chip{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:14px;color:var(--navy);background:rgba(22,111,61,.08);border:1px solid rgba(22,111,61,.25);border-radius:999px;padding:9px 16px;opacity:0;}
.atty__chip .ck{width:18px;height:18px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;}
.scene.run.is-active .atty__chip{animation:fadeUp .7s var(--ease) 2.9s both;}

/* =====================================================================
 * SCENE 4 — Wealth at a glance
 * ===================================================================== */
.s-wealth .panel{background:var(--white);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-card);padding:34px 40px;flex:1;position:relative;overflow:hidden;}
.s-wealth .panel__top{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy),var(--gold));}
.wealth-total{font-family:var(--serif);font-weight:400;font-size:52px;color:var(--navy);line-height:1;margin-top:10px;}
.wealth-sub{font-family:var(--sans);font-weight:300;font-size:15px;color:var(--stone);margin-top:12px;max-width:560px;line-height:1.55;}
.wealth-sub .hl{color:var(--gold);}
.split{display:flex;gap:18px;margin-top:26px;}
.split .tile{flex:1;border:1px solid var(--line);border-radius:8px;padding:18px 22px;}
.split .tile.on{border-color:var(--gold);box-shadow:inset 0 0 0 1px var(--gold-soft);}
.split .tile .k{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--stone);}
.split .tile.on .k{color:var(--gold);}
.split .tile .v{font-family:var(--serif);font-size:30px;color:var(--navy);margin-top:6px;}
.breakdown{display:flex;gap:50px;align-items:center;margin-top:36px;}
.donut{width:188px;height:188px;flex:0 0 auto;position:relative;}
.donut svg{width:100%;height:100%;transform:rotate(0deg);}
.donut__c{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;}
.donut__c .a{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone);}
.donut__c .b{font-family:var(--serif);font-size:26px;color:var(--navy);margin-top:2px;}
.bars{flex:1;display:flex;flex-direction:column;gap:19px;}
.bar .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px;}
.bar .top .nm{font-family:var(--sans);font-size:15px;color:var(--ink);display:flex;align-items:center;gap:9px;}
.bar .top .nm .sw{width:11px;height:11px;border-radius:2px;}
.bar .top .amt{font-family:var(--sans);font-size:15px;color:var(--ink);}
.bar .track{height:6px;border-radius:999px;background:var(--cream-mid);overflow:hidden;}
.bar .track i{display:block;height:100%;width:0;border-radius:999px;}
.bar .pct{font-family:var(--mono);font-size:11px;color:var(--stone);margin-top:6px;}
.scene.run.is-active .bar .track i{animation:barGrow 1.2s var(--ease) forwards;}
.bar:nth-child(1) .track i{animation-delay:.5s;}
.bar:nth-child(2) .track i{animation-delay:.66s;}
.bar:nth-child(3) .track i{animation-delay:.82s;}
.bar:nth-child(4) .track i{animation-delay:.98s;}
@keyframes barGrow{to{width:var(--w);}}

/* donut draw */
.donut circle.seg{fill:none;stroke-width:13;stroke-linecap:butt;}
.scene.run.is-active .donut circle.seg{animation:donutDraw 1.3s var(--ease) forwards;}
.donut circle.s1{animation-delay:.4s;} .donut circle.s2{animation-delay:.62s;}
.donut circle.s3{animation-delay:.82s;} .donut circle.s4{animation-delay:1s;}
@keyframes donutDraw{to{stroke-dashoffset:var(--off);}}

/* =====================================================================
 * SCENE 5 — Family tree
 * ===================================================================== */
.s-family{align-items:stretch;}
.fam-panel{flex:1;background:var(--white);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-card);padding:40px 50px;position:relative;overflow:hidden;display:flex;flex-direction:column;}
.fam-panel__top{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy),var(--gold));}
.fam-head{display:flex;align-items:flex-start;justify-content:space-between;}
.fam-head h2{font-family:var(--serif);font-size:30px;color:var(--navy);font-weight:400;margin-top:10px;}
.fam-head h2 em{font-style:italic;color:var(--gold);}
.fam-edit{font-family:var(--sans);font-size:14px;color:var(--navy);border:1px solid rgba(12,31,63,.3);border-radius:3px;padding:9px 16px;}
.tree{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.node{display:flex;flex-direction:column;align-items:center;width:182px;}
.node .circ{width:96px;height:96px;border-radius:50%;border:1px solid var(--border-card);background:var(--cream);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:36px;color:var(--navy);}
.node .role{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-top:14px;}
.node .nm{font-family:var(--serif);font-size:21px;color:var(--navy);margin-top:8px;white-space:nowrap;}
.node .det{font-family:var(--sans);font-size:13px;color:var(--stone);margin-top:3px;white-space:nowrap;}
.connector{width:1px;height:46px;background:var(--gold);opacity:.45;transform-origin:top;}
.children{display:flex;gap:84px;position:relative;}
.children::before{content:"";position:absolute;top:-46px;left:48px;right:48px;height:1px;background:var(--gold);opacity:.45;}
.children .stem{position:absolute;top:-46px;width:1px;height:46px;background:var(--gold);opacity:.45;}
.scene.run.is-active .tree .node{animation:fadeUp .7s var(--ease) both;}
.scene.run.is-active .tree .node.settlor{animation-delay:.2s;}
.scene.run.is-active .tree .node.b1{animation-delay:.7s;}
.scene.run.is-active .tree .node.b2{animation-delay:.86s;}
.scene.run.is-active .tree .node.b3{animation-delay:1.02s;}
.scene.run.is-active .connector,
.scene.run.is-active .children::before{animation:fadeIn .6s var(--ease) .55s both;}

/* =====================================================================
 * SCENE 6 — Ongoing: check-ins + milestones
 * ===================================================================== */
.s-admin .head{margin-bottom:22px;}
.s-admin .head h2{font-family:var(--serif);font-size:32px;color:var(--navy);font-weight:400;margin-top:10px;}
.s-admin .head h2 em{font-style:italic;color:var(--gold);}
.s-admin .head p{font-family:var(--sans);font-weight:300;font-size:15px;color:var(--stone);margin-top:8px;max-width:560px;line-height:1.55;}
.checkins{flex:1;}
.ci{display:flex;align-items:flex-start;gap:30px;padding:20px 0;border-bottom:1px solid var(--line-soft);}
.ci .date{flex:0 0 110px;}
.ci .date .d{font-family:var(--serif);font-size:24px;color:var(--navy);}
.ci .date .w{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-top:3px;}
.ci .body{flex:1;}
.ci .body h5{font-family:var(--serif);font-size:20px;color:var(--navy);font-weight:500;}
.ci .body p{font-family:var(--sans);font-size:14px;color:var(--stone);margin-top:5px;line-height:1.5;}
.ci .act{display:flex;flex-direction:column;align-items:flex-end;gap:10px;}
.ci .act .btn{font-family:var(--sans);font-size:14px;color:var(--navy);border:1px solid rgba(12,31,63,.3);border-radius:3px;padding:9px 16px;white-space:nowrap;}
.ci .act .later{font-family:var(--sans);font-size:13px;color:var(--stone);}

/* milestone timeline strip */
.milestones{margin-top:16px;background:var(--white);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-card);padding:28px 40px 32px;position:relative;overflow:hidden;}
.milestones__top{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy),var(--gold));}
.ms-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;}
.ms-head .t{font-family:var(--serif);font-size:22px;color:var(--navy);}
.ms-head .t em{font-style:italic;color:var(--gold);}
.ms-track{position:relative;display:flex;justify-content:space-between;padding:0 20px;}
.ms-track::before{content:"";position:absolute;left:100px;right:100px;top:33px;height:1px;background:var(--line-firm);}
.ms{display:flex;flex-direction:column;align-items:center;width:160px;position:relative;z-index:1;}
.ms .cap{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);margin-bottom:13px;white-space:nowrap;}
.ms .pt{width:14px;height:14px;border-radius:50%;background:var(--cream);border:2px solid var(--gold);}
.ms.fill .pt{background:var(--gold);}
.ms.future .pt{border-color:var(--line-firm);background:var(--white);}
.ms .lbl{font-family:var(--sans);font-size:14px;color:var(--navy);margin-top:14px;white-space:nowrap;text-align:center;}
.ms.here .cap{color:var(--gold);font-family:var(--serif);font-style:italic;font-size:15px;text-transform:none;letter-spacing:0;margin-bottom:11px;}
.ms.here .lbl{color:var(--gold);}

/* =====================================================================
 * SCENE 7 — Calm home (resolve)
 * ===================================================================== */
.s-home .welcome{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:.7rem;}
.s-home .welcome::before{content:"";width:26px;height:1px;background:var(--gold);}
.s-home h1{font-family:var(--serif);font-weight:400;font-size:60px;color:var(--navy);margin-top:18px;letter-spacing:-0.01em;line-height:1;}
.s-home .lede{font-family:var(--sans);font-weight:300;font-size:18px;color:var(--stone);margin-top:18px;max-width:560px;line-height:1.55;}
.home-meta{display:flex;align-items:center;gap:0;margin-top:46px;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);padding:26px 0;}
.home-seal{width:74px;height:74px;border-radius:50%;border:1px solid var(--gold);display:flex;align-items:center;justify-content:center;margin-right:34px;position:relative;}
.home-seal::after{content:"";position:absolute;inset:6px;border-radius:50%;border:1px solid var(--border-card);}
.home-seal span{font-family:var(--serif);font-style:italic;font-size:28px;color:var(--navy);}
.home-meta .col{padding:0 30px;border-left:1px solid var(--line-soft);}
.home-meta .col:first-of-type{border-left:0;padding-left:0;}
.home-meta .col .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);}
.home-meta .col .v{font-family:var(--sans);font-size:16px;color:var(--ink);margin-top:7px;}
.home-actions{display:flex;gap:20px;margin-top:40px;}
.ha{flex:1;background:var(--white);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow-card);padding:26px 28px;}
.ha .ic{width:42px;height:42px;border-radius:50%;background:var(--cream);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:18px;}
.ha h4{font-family:var(--serif);font-size:21px;color:var(--navy);font-weight:500;}
.ha p{font-family:var(--sans);font-size:13.5px;color:var(--stone);line-height:1.5;margin-top:8px;}
.ha .go{font-family:var(--sans);font-size:14px;color:var(--gold);margin-top:16px;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;}

/* FAB */
.fab{position:absolute;right:34px;bottom:30px;width:58px;height:58px;border-radius:50%;background:var(--gold);box-shadow:0 12px 32px rgba(184,147,90,.35);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-style:italic;font-size:24px;color:#fff;z-index:25;}

/* =====================================================================
 * Reduced motion — the scene tour still plays (it's the product), but with a
 * gentle opacity-only crossfade and every transform/scale/spin disabled. The
 * scene loop is driven by the master clock for all users (see index.html); we
 * deliberately keep the base `.scene` opacity transition so changes are a soft
 * fade rather than a jarring hard cut.
 * ===================================================================== */
@media (prefers-reduced-motion:reduce){
  .scene .au{opacity:1 !important;transform:none !important;animation:none !important;}
  .vera-orb,.atty__bar i,.bar .track i,.donut circle.seg,
  .vera-orb-wrap .ring,.atty__live .d{animation:none !important;}
  .bar .track i{width:var(--w) !important;}
  .donut circle.seg{stroke-dashoffset:var(--off) !important;}
  .atty__chip{opacity:1 !important;}
  .connector,.children::before,.tree .node{opacity:1 !important;transform:none !important;animation:none !important;}
}

/* JS safety net: if CSS animations are frozen (offscreen/embedded contexts),
   .force commits each active scene's final visible state ~1s after it shows,
   so content is never stuck invisible. Harmless once the fade has played. */
.scene.force .au{opacity:1 !important;transform:none !important;}
.scene.force .bar .track i{width:var(--w) !important;}
.scene.force .donut circle.seg{stroke-dashoffset:var(--off) !important;}
.scene.force .atty__chip{opacity:1 !important;}
.scene.force .atty__bar i{width:96% !important;}
.scene.force .tree .node,
.scene.force .connector,
.scene.force .children::before{opacity:1 !important;transform:none !important;}
