/* IncomeRPG v4.0 design layer — loaded ONLY by index-v4.0.html (after app.css), so v3.9 is untouched.
   Holds the design TOKENS (the 4.0 foundation) + the redesigned collectible Hero Card (.hcv4-*).
   Future 4.0 screen refreshes go here as overrides — never edit the shared app.css. */

:root{
  /* palette */
  --v4-navy:#06060e; --v4-text:#eef0f5; --v4-text-2:#b6bbc8; --v4-text-dim:#8a8fa0;
  --v4-lime:#bdff00; --v4-lime-deep:#7aa800; --v4-gold:#ffce4d;
  /* tier / rarity (chapter colors) */
  --v4-tier-1:#9aa0aa; --v4-tier-2:#3ad98a; --v4-tier-3:#5db4ff; --v4-tier-4:#ffce4d; --v4-tier-5:#b98bff;
  /* spacing */ --v4-s1:4px; --v4-s2:8px; --v4-s3:12px; --v4-s4:16px; --v4-s5:24px;
  /* radius */ --v4-r-card:20px; --v4-r-panel:14px; --v4-r-ctl:10px; --v4-r-pill:100px;
  /* elevation */ --v4-e1:0 8px 24px rgba(0,0,0,.45); --v4-e2:0 18px 50px rgba(0,0,0,.55);
  /* type */ --v4-font:'Inter',system-ui,sans-serif; --v4-display:'Orbitron',sans-serif; --v4-mono:'Press Start 2P',monospace;
  /* motion */ --v4-dur:.28s; --v4-ease:cubic-bezier(.2,.9,.3,1); --v4-ease-pop:cubic-bezier(.34,1.4,.6,1);
}

/* ══ Hero Card v4.0 — scene showcase up top, solid info plate below ══ */
.hcv4{position:relative;width:360px;max-width:94vw;border-radius:var(--v4-r-card);overflow:hidden;
  border:2px solid var(--tier,var(--v4-lime));background:#0a0a16;color:var(--v4-text);font-family:var(--v4-font);
  box-shadow:0 0 36px color-mix(in srgb,var(--tier,#bdff00) 24%,transparent),var(--v4-e2);
  animation:hcv4In .4s var(--v4-ease-pop)}
@keyframes hcv4In{from{opacity:0;transform:translateY(14px) scale(.96)}to{opacity:1;transform:none}}

/* SCENE — the selected background, featured; character stands in it */
.hcv4-scene{position:relative;height:222px;overflow:hidden}
.hcv4-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.hcv4-scene-fade{position:absolute;left:0;right:0;bottom:0;height:48%;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent,rgba(10,10,22,.55) 55%,rgba(10,10,22,.95))}
.hcv4-scene::after{content:'';position:absolute;bottom:8px;left:50%;transform:translateX(-50%);
  width:118px;height:18px;border-radius:50%;background:radial-gradient(closest-side,rgba(0,0,0,.55),transparent);z-index:1}
.hcv4-top{position:absolute;top:10px;left:10px;right:10px;z-index:3;display:flex;justify-content:space-between;align-items:center}
.hcv4-chip{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;padding:6px 12px;
  border-radius:var(--v4-r-pill);background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(4px)}
.hcv4-hero{position:absolute;bottom:6px;left:50%;transform:translateX(-50%);z-index:2;height:150px;width:auto;
  object-fit:contain;image-rendering:pixelated;filter:drop-shadow(0 8px 9px rgba(0,0,0,.55))}

/* PLATE — a blurred, darkened echo of the SAME background sits behind the info (scene stays crisp) */
.hcv4-plate{position:relative;z-index:3;overflow:hidden;background:#0c0d1c;border-top:1px solid color-mix(in srgb,var(--tier,#bdff00) 32%,transparent)}
.hcv4-plate-bg{position:absolute;inset:-16px;z-index:0;background-size:cover;background-position:center;filter:blur(13px) brightness(.62) saturate(1.18);transform:scale(1.08)}
.hcv4-plate-inner{position:relative;z-index:1;padding:11px 14px 14px;background:linear-gradient(180deg,rgba(10,10,22,.28),rgba(10,10,22,.62))}
.hcv4-ribbon{font-family:var(--v4-mono);font-size:8px;letter-spacing:.5px;text-align:center;color:var(--tier,var(--v4-lime));margin:0 0 10px}
.hcv4-name{font-family:var(--v4-display);font-weight:900;font-size:20px;letter-spacing:.5px;line-height:1.1}
.hcv4-title{font-size:10px;letter-spacing:1.5px;color:var(--v4-text-dim);margin-bottom:12px}
.hcv4-stats{display:flex;align-items:stretch;gap:14px;margin-bottom:12px}
.hcv4-stat{flex:1;min-width:0}
.hcv4-vdiv{width:1px;background:rgba(255,255,255,.1)}
.hcv4-slbl{font-size:9px;letter-spacing:1px;color:var(--v4-text-dim)}
.hcv4-snum{font-family:var(--v4-mono);font-size:17px;margin:6px 0 4px;color:var(--v4-text);font-variant-numeric:tabular-nums}
.hcv4-ssub{font-size:10px;color:var(--v4-text-dim)}
.hcv4-xp{position:relative;height:9px;border-radius:var(--v4-r-pill);background:rgba(255,255,255,.09);overflow:hidden;margin-bottom:6px}
.hcv4-xpfill{height:100%;border-radius:var(--v4-r-pill);background:var(--v4-lime);transition:width .6s var(--v4-ease)}
.hcv4-xptext{font-size:10px;color:var(--v4-text-dim);margin-bottom:12px}
.hcv4-sockets{display:flex;gap:8px;align-items:center}
.hcv4-hold{flex:1;min-width:0;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--v4-r-ctl);padding:8px 10px}
.hcv4-hold.empty{opacity:.7}
.hcv4-htag{display:block;font-size:8px;letter-spacing:1px;color:var(--v4-text-dim);margin-bottom:2px}
.hcv4-hsym{font-size:14px;font-weight:700}
.hcv4-hlv{font-size:9px;color:var(--v4-text-dim)}
.hcv4-hmeta{display:block;font-size:9px;color:var(--v4-text-dim);font-variant-numeric:tabular-nums;margin-top:2px}
.hcv4-hempty{font-size:11px;color:var(--v4-text-dim)}
.hcv4-badge,.hcv4-pet{width:40px;height:40px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;
  border:1px solid color-mix(in srgb,var(--v4-lime) 35%,transparent);background:color-mix(in srgb,var(--v4-lime) 7%,transparent);
  color:var(--v4-lime);border-radius:var(--v4-r-ctl);font-size:17px}
.hcv4-pet{border-radius:50%;border-color:color-mix(in srgb,var(--v4-gold) 40%,transparent);background:color-mix(in srgb,var(--v4-gold) 9%,transparent);color:var(--v4-gold)}
.hcv4-badge.filled,.hcv4-pet.filled{background:rgba(0,0,0,.35)}
.hcv4-badge:active,.hcv4-pet:active{transform:scale(.94)}
.hcv4-badge .hcb-img{width:100%;height:100%;object-fit:contain}
.hcv4-pet img{width:28px;height:28px;object-fit:contain}
.hcv4-ver{position:absolute;bottom:9px;right:13px;z-index:4;font-size:8px;font-weight:700;letter-spacing:1px;color:color-mix(in srgb,var(--v4-lime) 55%,transparent)}
@media (prefers-reduced-motion: reduce){ .hcv4{animation:none} .hcv4-xpfill{transition:none} }

  /* v4.0: Royal Advisor on EVERY page — lift it above the walkable scenes (kx-room / kx-map = z2100).
     A visibility observer in advisor-v4.js hides it again while a focus dialog/menu is open. */
  .adv-root{z-index:2120}

/* ══ Pet Racing — "The Beast Derby" (v4.0) ══ */
.race-ov{position:fixed;inset:0;z-index:2600;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  background:radial-gradient(circle at 50% 28%,#0d1430,#05060d 78%);font-family:var(--v4-font);color:var(--v4-text);
  opacity:0;transition:opacity var(--v4-dur) var(--v4-ease)}
.race-ov.open{opacity:1}
.race-hud{display:flex;gap:10px}
.race-chip{font-family:var(--v4-mono);font-size:8px;letter-spacing:.5px;color:var(--v4-lime);background:rgba(0,0,0,.45);
  border:1px solid color-mix(in srgb,var(--v4-lime) 30%,transparent);border-radius:var(--v4-r-pill);padding:8px 14px}

/* the side-view track */
.race-track{position:relative;width:min(900px,94vw);height:clamp(220px,42vh,320px);overflow:hidden;border-radius:var(--v4-r-panel);
  border:2px solid #2a3550;box-shadow:var(--v4-e2);touch-action:none;cursor:pointer;
  background:linear-gradient(180deg,#12224e 0%,#274a86 34%,#356a2f 34%,#2b5227 60%,#6b5535 60%,#4a3a24 100%)}
.race-track::before{content:'';position:absolute;left:0;right:0;top:0;height:34%;pointer-events:none;
  background:radial-gradient(120% 90% at 78% 0,rgba(255,255,255,.20),transparent 62%)}   /* sky sheen */
/* parallax layers — scrolled via background-position-x in JS for a sense of speed */
.race-far,.race-mid,.race-near,.race-speed{position:absolute;left:0;right:0;pointer-events:none;background-repeat:repeat-x;will-change:background-position}
.race-far{bottom:52%;height:16%;z-index:1;background-image:radial-gradient(70px 34px at 42px bottom,#2b3f70 0 98%,transparent 100%);background-size:120px 100%;opacity:.9}
.race-mid{bottom:40%;height:14%;z-index:1;background-image:radial-gradient(9px 9px at 22px bottom,#2f5a35 0 95%,transparent 100%);background-size:56px 100%}
.race-near{bottom:0;height:40%;z-index:1;background-image:repeating-linear-gradient(90deg,rgba(0,0,0,.20) 0 3px,transparent 3px 30px);background-size:30px 100%}
.race-speed{top:8%;height:66%;opacity:0;z-index:4;transition:opacity .2s;animation:raceSpeedScroll .45s linear infinite;
  background-image:repeating-linear-gradient(90deg,transparent 0 84px,rgba(255,255,255,.5) 84px 86px,rgba(189,255,0,.35) 86px 88px,transparent 88px 96px);background-size:96px 100%}
@keyframes raceSpeedScroll{from{background-position-x:0}to{background-position-x:-96px}}
.race-flash{position:absolute;inset:0;z-index:6;pointer-events:none;opacity:0;transition:opacity .12s;
  background:radial-gradient(circle at 50% 50%,rgba(255,60,60,0) 42%,rgba(255,40,40,.45))}
.race-flash.on{opacity:1;transition:none}

.race-finish{position:absolute;top:0;bottom:0;left:82%;width:12px;z-index:3;
  background-image:repeating-conic-gradient(#fff 0 25%,#111 0 50%);background-size:12px 12px;opacity:.95;box-shadow:0 0 14px rgba(189,255,0,.5)}
.race-finish.broke{animation:raceTape .5s var(--v4-ease-pop)}
@keyframes raceTape{0%{transform:scaleX(1)}40%{transform:scaleX(2.4);opacity:.4}100%{transform:scaleX(1);opacity:.95}}
.race-lane{position:absolute;left:0;right:0;height:50%;z-index:2}
.race-lane-top{top:0}
.race-lane-bot{bottom:0}
.race-hurdles{position:absolute;inset:0;pointer-events:none}

.race-runner{position:absolute;left:0;bottom:8px;width:clamp(44px,8vw,62px);text-align:center;z-index:5;transform-origin:50% 100%;will-change:transform}
.race-runner img{width:100%;height:auto;object-fit:contain;image-rendering:pixelated;transform-origin:50% 100%;
  filter:drop-shadow(0 5px 5px rgba(0,0,0,.5));animation:raceBob .28s steps(2) infinite}
.race-runner .race-name{position:absolute;bottom:100%;left:50%;transform:translateX(-50%);white-space:nowrap;margin-bottom:3px;
  font-family:var(--v4-mono);font-size:7px;letter-spacing:.5px;color:#fff;text-shadow:1px 1px 0 #000;background:rgba(0,0,0,.45);padding:3px 6px;border-radius:6px}
.race-rival img{animation-delay:.14s}
.race-stumble{filter:drop-shadow(0 5px 5px rgba(0,0,0,.5)) brightness(1.5) sepia(1) hue-rotate(-35deg) saturate(4)}
@keyframes raceBob{0%{transform:translateY(0)}100%{transform:translateY(-3px)}}
.race-track.race-shaking{animation:raceShakeT .3s}
@keyframes raceShakeT{0%,100%{transform:translate(0,0)}20%{transform:translate(-5px,2px)}40%{transform:translate(5px,-2px)}60%{transform:translate(-4px,-2px)}80%{transform:translate(4px,2px)}}

.race-hurdle{position:absolute;left:0;bottom:8px;width:12px;height:30px;border-radius:2px;z-index:4;
  background:linear-gradient(180deg,#caa45a,#6e4a1f);border:1px solid #43300f;box-shadow:0 3px 6px rgba(0,0,0,.45)}
.race-hurdle.hopped{opacity:.25;transition:opacity .2s}
.race-hurdle.hit{box-shadow:0 0 0 6px rgba(255,70,70,.5)}

/* particles */
.race-particles{position:absolute;inset:0;z-index:5;pointer-events:none}
.race-dust{position:absolute;bottom:10px;width:7px;height:7px;border-radius:50%;background:rgba(220,210,180,.85);animation:raceDust .5s ease-out forwards}
@keyframes raceDust{from{transform:translate(0,0) scale(1);opacity:.85}to{transform:translate(var(--dx),-14px) scale(.2);opacity:0}}
.race-clearspark{position:absolute;bottom:46px;width:14px;height:14px;border-radius:50%;background:radial-gradient(circle,var(--v4-lime),transparent 70%);animation:raceSpark .4s ease-out forwards}
@keyframes raceSpark{from{transform:scale(.3);opacity:1}to{transform:scale(1.9);opacity:0}}

/* 3-2-1-GO countdown */
.race-count{position:absolute;inset:0;z-index:8;display:flex;align-items:center;justify-content:center;pointer-events:none;
  font-family:var(--v4-display);font-weight:900;font-size:clamp(44px,9vw,64px);color:var(--v4-lime);text-shadow:0 0 24px rgba(189,255,0,.6),0 4px 0 #06060e}
.race-count.beat{animation:raceCount .6s var(--v4-ease-pop)}
.race-count.go{color:#fff;text-shadow:0 0 30px rgba(189,255,0,.9)}
@keyframes raceCount{0%{transform:scale(.3);opacity:0}30%{transform:scale(1.15);opacity:1}100%{transform:scale(1);opacity:.9}}

/* progress bars */
.race-bars{display:flex;flex-direction:column;gap:8px;width:min(900px,94vw)}
.race-brow{display:flex;align-items:center;gap:9px}
.race-barlbl{flex:0 0 44px;font-family:var(--v4-mono);font-size:8px;letter-spacing:.5px;color:var(--v4-lime)}
.race-barlbl-rv{color:#ff7a59}
.race-bar{position:relative;flex:1;height:13px;border-radius:var(--v4-r-pill);background:rgba(255,255,255,.08);overflow:hidden}
.race-bar i{position:absolute;left:0;top:0;bottom:0;width:100%;transform-origin:left;transform:scaleX(0);background:var(--v4-lime);border-radius:var(--v4-r-pill)}
.race-bar-rival i{background:#ff7a59}
.race-tip{font-size:12px;color:var(--v4-text-2);letter-spacing:.5px}

/* result card */
.race-result{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%) scale(.9);z-index:2610;
  width:min(360px,90vw);text-align:center;padding:24px 22px;border-radius:var(--v4-r-card);
  background:linear-gradient(180deg,#10122a,#0a0a16);border:2px solid var(--v4-lime);box-shadow:var(--v4-e2),0 0 40px rgba(189,255,0,.25);
  opacity:0;pointer-events:none;transition:opacity var(--v4-dur),transform var(--v4-dur) var(--v4-ease-pop)}
.race-result.show{opacity:1;transform:translate(-50%,-50%) scale(1);pointer-events:auto}
.race-win{font-family:var(--v4-display);font-weight:900;font-size:26px;color:var(--v4-lime);text-shadow:0 0 18px rgba(189,255,0,.5)}
.race-lose{font-family:var(--v4-display);font-weight:900;font-size:24px;color:#ff7a59}
.race-sub{font-size:13px;color:var(--v4-text-2);margin-top:6px}
.race-pop{display:inline-block;animation:racePop .5s var(--v4-ease-pop)}
@keyframes racePop{0%{transform:scale(.4);opacity:0}55%{transform:scale(1.25)}100%{transform:scale(1);opacity:1}}
.race-mile{margin-top:14px;padding:12px;border-radius:var(--v4-r-panel);background:color-mix(in srgb,var(--v4-gold) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--v4-gold) 45%,transparent);font-family:var(--v4-mono);font-size:9px;line-height:1.7;color:var(--v4-gold)}
.race-mile span{color:var(--v4-text)}
.race-next{margin-top:12px;font-size:11px;color:var(--v4-text-dim)}
.race-again{display:flex;gap:10px;margin-top:18px}
.race-btn{flex:1;padding:12px;border:none;border-radius:var(--v4-r-ctl);cursor:pointer;font-weight:800;font-size:13px;
  background:var(--v4-lime);color:#06060e;transition:transform .12s,filter .12s}
.race-btn:hover{filter:brightness(1.08)}.race-btn:active{transform:scale(.96)}
.race-btn-2{background:rgba(255,255,255,.1);color:var(--v4-text)}
@media (prefers-reduced-motion: reduce){
  .race-runner img{animation:none} .race-result{transition:opacity .2s}
  .race-speed{animation:none;opacity:0!important} .race-track.race-shaking{animation:none}
  .race-count.beat{animation:none} .race-dust,.race-clearspark{display:none}
  .race-pop{animation:none} .race-finish.broke{animation:none}
}

/* ══ Athleticism boon track (Pet Shop BOONS tab) ══ */
.race-ath-card{border-left:3px solid var(--v4-lime);background:color-mix(in srgb,var(--v4-lime) 6%,transparent)}
.race-ath-ico{display:flex;align-items:center;justify-content:center;font-size:20px}
.race-ath-card .ath-sub{font-weight:400;font-size:.82em;color:var(--v4-text-dim);margin-left:2px}
.race-ath-btn{border:1px solid color-mix(in srgb,var(--v4-lime) 55%,transparent)}

/* ══ Derby Marshal flair — orbiting mini-pets + sparkle particles around the Town NPC ══ */
/* his raised flag adds height, so show taller than the 100px default → body matches other NPCs, flag rises.
   MUST be > img (direct child) so it does NOT also stretch the nested mini-pet <img>s. */
.pz-npc[data-npc="racer"] > img{height:150px}
.race-npc-fx{position:absolute;inset:0;z-index:6;pointer-events:none;overflow:visible}
/* tiny orbiters. Selector (0,2,0) outranks the shared .pz-npc img{height:100px} (0,1,1) so height:auto
   sticks — otherwise they inherit a 100/150px height and stretch into tall skinny blobs. */
.race-npc-fx .race-mini-pet{position:absolute;left:50%;top:16%;width:16px!important;height:auto!important;
  margin:-8px 0 0 -8px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5));animation:rmpOrbit 6s linear infinite}
.race-npc-fx .race-mini-pet.rmp0{width:17px!important}
.race-npc-fx .race-mini-pet.rmp1{width:14px!important;animation-duration:8s;animation-delay:-2.6s}
.race-npc-fx .race-mini-pet.rmp2{width:12px!important;animation-duration:7s;animation-delay:-4.2s;top:26%}
@keyframes rmpOrbit{from{transform:rotate(0deg) translateX(30px) rotate(0deg)}to{transform:rotate(360deg) translateX(30px) rotate(-360deg)}}
.race-fx-spark{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--v4-lime);
  box-shadow:0 0 7px 1px var(--v4-lime);opacity:0;animation:rcSpark 2.4s ease-in-out infinite}
.race-fx-spark.sp0{left:18%;top:6%;animation-delay:0s}
.race-fx-spark.sp1{left:78%;top:12%;animation-delay:.5s;background:var(--v4-gold);box-shadow:0 0 7px 1px var(--v4-gold)}
.race-fx-spark.sp2{left:50%;top:-4%;animation-delay:1s}
.race-fx-spark.sp3{left:30%;top:34%;animation-delay:1.4s;background:var(--v4-gold);box-shadow:0 0 7px 1px var(--v4-gold)}
.race-fx-spark.sp4{left:84%;top:40%;animation-delay:.9s}
.race-fx-spark.sp5{left:8%;top:22%;animation-delay:1.8s}
.race-fx-spark.sp6{left:64%;top:48%;animation-delay:.3s;background:var(--v4-gold);box-shadow:0 0 7px 1px var(--v4-gold)}
@keyframes rcSpark{0%,100%{opacity:0;transform:scale(.4)}45%{opacity:1;transform:scale(1.2)}}
@media (prefers-reduced-motion: reduce){ .race-mini-pet{animation:none} .race-fx-spark{animation:none;opacity:.6} }

/* ══════════════ Mini-game v4 shell (Duel + Sky Courier) ══════════════ */
.mgv-ov .mgv-panel{position:relative;width:min(560px,94vw);max-height:92vh;overflow:auto;padding:22px 22px 20px;border-radius:var(--v4-r-card);
  background:linear-gradient(180deg,#10122a,#0a0a16);border:2px solid color-mix(in srgb,var(--v4-lime) 40%,transparent);
  box-shadow:var(--v4-e2),0 0 42px color-mix(in srgb,var(--v4-lime) 18%,transparent);color:var(--v4-text);font-family:var(--v4-font);
  animation:hcv4In .34s var(--v4-ease-pop)}
.mgv-title{font-family:var(--v4-display);font-weight:900;font-size:22px;text-align:center;color:var(--v4-lime);text-shadow:0 0 16px rgba(189,255,0,.4)}
.mgv-sub{text-align:center;font-size:12px;color:var(--v4-text-2);margin:4px 0 14px}
.mgv-sub b{color:var(--v4-gold)}
.mgv-stat{text-align:center;font-size:12px;color:var(--v4-text-dim);margin:12px 0}
.mgv-btns{display:flex;gap:10px;justify-content:center;margin-top:12px}
.mgv-btn{flex:1;max-width:340px;padding:13px;border:none;border-radius:var(--v4-r-ctl);cursor:pointer;font-weight:800;font-size:14px;
  background:var(--v4-lime);color:#06060e;transition:transform .12s,filter .12s}
.mgv-btn.big{font-size:16px;padding:15px}
.mgv-btn:hover{filter:brightness(1.08)}.mgv-btn:active{transform:scale(.96)}
.mgv-btn.ghost{background:rgba(255,255,255,.08);color:var(--v4-text);border:1px solid rgba(255,255,255,.14)}
/* upgrade tree rows */
.mgv-list{display:flex;flex-direction:column;gap:9px;margin:6px 0}
.mgv-row{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:var(--v4-r-panel);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09)}
.mgv-ico{font-size:22px;flex:0 0 auto;width:30px;text-align:center}
.mgv-mid{flex:1;min-width:0}
.mgv-name{font-weight:700;font-size:14px}
.mgv-lvl{font-family:var(--v4-mono);font-size:8px;color:var(--v4-text-dim);margin-left:6px}
.mgv-desc{font-size:11px;color:var(--v4-text-2);margin-top:3px}
.mgv-desc b{color:var(--v4-lime)}
.mgv-rt{flex:0 0 auto}
.mgv-up{padding:9px 12px;border:1px solid color-mix(in srgb,var(--v4-lime) 45%,transparent);border-radius:var(--v4-r-ctl);cursor:pointer;
  background:color-mix(in srgb,var(--v4-lime) 12%,transparent);color:var(--v4-lime);font-weight:800;font-size:12px;white-space:nowrap}
.mgv-up:active{transform:scale(.95)}
.mgv-max{font-family:var(--v4-mono);font-size:9px;color:var(--v4-gold)}
.mgv-lock{font-size:11px;color:var(--v4-text-dim)}
/* result overlay */
.mgv-over{position:absolute;inset:0;z-index:5;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  background:rgba(6,6,14,.82);backdrop-filter:blur(3px);border-radius:var(--v4-r-panel);opacity:0;transition:opacity .25s}
.mgv-over.show{opacity:1}
.mgv-over[hidden]{display:none}
.mgv-big{font-family:var(--v4-display);font-weight:900;font-size:34px;letter-spacing:1px}
.mgv-big.win{color:var(--v4-lime);text-shadow:0 0 22px rgba(189,255,0,.6)}
.mgv-big.lose{color:#ff7a59}
.mgv-rew{font-size:14px;color:var(--v4-text)}
.mgv-pop{display:inline-block;color:var(--v4-gold);animation:racePop .5s var(--v4-ease-pop)}
.mgv-left{font-size:11px;color:var(--v4-text-dim);margin-top:2px}
.mgv-cap{font-size:11px;color:var(--v4-text-dim);text-align:center;margin-top:10px;line-height:1.5}

/* ── Dueling Pit ── */
.dl-vs{display:flex;align-items:center;justify-content:center;gap:14px;margin:8px 0}
.dl-fighter{flex:1;text-align:center}
.dl-ava{width:66px;height:66px;display:inline-flex;align-items:center;justify-content:center;font-size:44px;line-height:1;filter:drop-shadow(0 6px 6px rgba(0,0,0,.5))}
.dl-ava img{width:100%;height:100%;object-fit:contain;image-rendering:pixelated}
.dl-fname{font-weight:800;font-size:13px;margin-top:4px}
.dl-fmeta{font-family:var(--v4-mono);font-size:8px;color:var(--v4-text-dim);margin-top:3px}
.dl-vs-x{font-family:var(--v4-display);font-weight:900;color:var(--v4-text-dim);font-size:16px}
.duel-arena{position:relative;overflow:visible}
.dl-atop{display:flex;align-items:flex-end;gap:12px;margin-bottom:14px}
.dl-side{flex:1;text-align:center}
.dl-hlbl{font-family:var(--v4-mono);font-size:8px;color:var(--v4-text-dim);margin-bottom:5px}
.dl-hp{height:12px;border-radius:var(--v4-r-pill);background:rgba(255,255,255,.08);overflow:hidden}
.dl-hp i{display:block;height:100%;width:100%;background:var(--v4-lime);border-radius:var(--v4-r-pill);transition:width .25s}
.dl-hp.foe i{background:#ff7a59}
.dl-side .dl-ava{width:56px;height:56px;font-size:38px;margin-top:8px}
.dl-mid{flex:0 0 64px;display:flex;align-items:center;justify-content:center}
.dl-combo{font-family:var(--v4-mono);font-size:9px;color:var(--v4-gold);text-align:center;min-height:14px}
.dl-combo.crit{color:var(--v4-lime)}
.dl-combo.pulse{animation:racePop .25s}
.dl-bar{position:relative;height:30px;border-radius:8px;background:#0b0e1e;border:1px solid rgba(255,255,255,.12);overflow:hidden;margin:4px 0 2px;cursor:pointer}
.dl-zone{position:absolute;top:0;bottom:0;background:color-mix(in srgb,var(--v4-lime) 55%,transparent);border-left:2px solid var(--v4-lime);border-right:2px solid var(--v4-lime);transition:filter .06s}
.dl-zone.live{filter:brightness(1.6)}
.dl-crit{position:absolute;top:0;bottom:0;background:var(--v4-gold);opacity:.85}
.dl-bar.blocking .dl-zone{background:color-mix(in srgb,#ff5a4a 55%,transparent);border-color:#ff5a4a}
.dl-bar.blocking .dl-crit{display:none}
.dl-marker{position:absolute;top:-3px;bottom:-3px;width:4px;left:0;transform:translateX(-50%);background:#fff;box-shadow:0 0 8px #fff;border-radius:2px}
.dl-hint{font-size:11px;color:var(--v4-text-2);text-align:center;margin:6px 0 10px;min-height:15px}
.dl-fx{position:absolute;left:0;right:0;top:40%;height:0;pointer-events:none}
.dl-pop{position:absolute;font-family:var(--v4-display);font-weight:900;font-size:20px;animation:dlPop .7s ease-out forwards;text-shadow:0 2px 4px #000}
.dl-pop.hit{color:var(--v4-lime)} .dl-pop.crit{color:var(--v4-gold);font-size:26px} .dl-pop.dmg{color:#ff7a59} .dl-pop.miss{color:var(--v4-text-dim);font-size:15px} .dl-pop.block{color:#5db4ff}
@keyframes dlPop{0%{opacity:0;transform:translate(-50%,0) scale(.6)}30%{opacity:1;transform:translate(-50%,-14px) scale(1.1)}100%{opacity:0;transform:translate(-50%,-44px) scale(1)}}
.dl-ava.hurt{animation:dlHurt .26s} .dl-ava.whiff{animation:dlWhiff .2s}
.dl-ava.you.atk{animation:dlAtk .24s}
@keyframes dlAtk{0%,100%{transform:translateX(0) scale(1)}45%{transform:translateX(16px) scale(1.1)}}
@keyframes dlHurt{0%,100%{transform:translateX(0);filter:none}30%{transform:translateX(-4px);filter:brightness(1.7) sepia(1) hue-rotate(-30deg) saturate(4)}70%{transform:translateX(4px)}}
@keyframes dlWhiff{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.duel-arena.dl-shake{animation:raceShakeT .26s}

/* ── Sky Courier ── */
.fl-routes{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin:6px 0 4px}
.fl-route{font-size:10px;padding:5px 9px;border-radius:var(--v4-r-pill);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:var(--v4-text-dim)}
.fl-route.on{color:var(--v4-lime);border-color:color-mix(in srgb,var(--v4-lime) 45%,transparent);background:color-mix(in srgb,var(--v4-lime) 8%,transparent)}
.flight-run{width:min(720px,96vw)}
.fl-hud{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;font-family:var(--v4-mono);font-size:10px;color:var(--v4-lime)}
.fl-hud span{background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.1);border-radius:var(--v4-r-pill);padding:6px 10px}
.fl-hud #fl-dist{font-size:13px;color:var(--v4-lime)}
.fl-hud span.pop{animation:racePop .3s}
.fl-cvwrap{position:relative;border-radius:var(--v4-r-panel);overflow:hidden;border:2px solid #2a3550;box-shadow:var(--v4-e2)}
.fl-cvwrap canvas{display:block;width:100%;height:auto;image-rendering:auto;touch-action:none;cursor:pointer}
.fl-cvwrap.fl-shake{animation:raceShakeT .3s}
@media (prefers-reduced-motion: reduce){ .mgv-ov .mgv-panel{animation:none} .dl-pop{animation-duration:.3s} .dl-ava.hurt,.dl-ava.whiff,.duel-arena.dl-shake{animation:none} .dl-combo.pulse,.fl-hud span.pop,.fl-cvwrap.fl-shake{animation:none} .dl-zone.live{filter:none} }

/* ══ Feed-the-King: digestible help pointers + feed/keep split (v4.0) ══ */
.ksc-help{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.ksc-tip{flex:1;min-width:200px;display:flex;gap:9px;align-items:flex-start;padding:11px 12px;border-radius:var(--v4-r-panel);
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09)}
.ksc-tip-ico{font-size:20px;line-height:1.1;flex:0 0 auto}
.ksc-tip b{display:block;font-size:12px;color:var(--v4-text);margin-bottom:2px}
.ksc-tip span{font-size:11px;color:var(--v4-text-2);line-height:1.45}
.ksc-oneliner{margin-top:12px;font-size:12.5px;color:var(--v4-text-2);line-height:1.5;
  padding:11px 13px;border-radius:var(--v4-r-panel);background:color-mix(in srgb,var(--v4-lime) 6%,transparent);border:1px solid color-mix(in srgb,var(--v4-lime) 22%,transparent)}
.ksc-oneliner b{color:var(--v4-text)}

.feedkeep{margin:0 0 16px;padding:14px 16px;border-radius:var(--v4-r-card);background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.09)}
.feedkeep-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px;font-size:12px;color:var(--v4-text-2)}
.feedkeep-head span:last-child{font-family:var(--v4-mono);font-size:11px;color:var(--v4-lime)}
.feedkeep-bar{display:flex;height:26px;border-radius:var(--v4-r-pill);overflow:hidden;background:rgba(255,255,255,.06)}
.feedkeep-bar i{display:block;height:100%;transition:width .35s var(--v4-ease);min-width:0}
#fk-fed{background:linear-gradient(90deg,#7c5cff,#a855f7)}   /* King = purple growth */
#fk-kept{background:linear-gradient(90deg,#ffce4d,#f0a830)}  /* kept = gold cash */
.feedkeep-lbls{display:flex;justify-content:space-between;margin-top:8px;font-size:11.5px;font-weight:700}
.fk-fed-lbl{color:#b98bff}
.fk-kept-lbl{color:var(--v4-gold)}
.summary-sub{display:block;font-size:10px;color:var(--v4-text-dim);margin-top:5px;line-height:1.35}
@media(max-width:560px){ .ksc-tip{min-width:0;flex-basis:100%} }

/* ══ Calculator redesign — hub + sections + forecast + goals (v4.0) ══ */
.calc-hub{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:18px 0 22px}
.calc-hub-card{display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:16px 16px 14px;cursor:pointer;text-align:left;
  border-radius:var(--v4-r-card);background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.10);color:var(--v4-text);
  transition:transform .16s var(--v4-ease),border-color .16s,box-shadow .16s,background .16s}
.calc-hub-card:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--v4-lime) 55%,transparent);
  box-shadow:0 12px 30px rgba(0,0,0,.4),0 0 22px color-mix(in srgb,var(--v4-lime) 16%,transparent);background:rgba(255,255,255,.06)}
.calc-hub-card:active{transform:translateY(0) scale(.985)}
.calc-hub-card.on{border-color:var(--v4-lime);background:color-mix(in srgb,var(--v4-lime) 9%,transparent);
  box-shadow:0 0 24px color-mix(in srgb,var(--v4-lime) 22%,transparent)}
.chc-ico{font-size:26px;line-height:1}
.chc-t{font-family:var(--v4-display);font-weight:900;font-size:15px}
.chc-s{font-size:11px;color:var(--v4-text-dim);line-height:1.35}
.calc-sec{animation:calcSecIn .32s var(--v4-ease)}
@keyframes calcSecIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.fc-head h3{font-family:var(--v4-display);font-weight:900;font-size:18px;margin:0}
.fc-head p{font-size:12.5px;color:var(--v4-text-2);margin:4px 0 14px}

/* cadence forecast */
.fc-card{padding:20px;border-radius:var(--v4-r-card);background:linear-gradient(180deg,#10122a,#0a0a16);border:1.5px solid rgba(255,255,255,.10);margin-bottom:16px;text-align:center}
.fc-card .fc-head{text-align:left}
.fc-tabs{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;margin-bottom:16px}
.fc-tab{padding:8px 13px;border-radius:var(--v4-r-pill);cursor:pointer;font-size:12px;font-weight:700;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);color:var(--v4-text-2);transition:all .14s}
.fc-tab:hover{color:var(--v4-text);border-color:rgba(255,255,255,.25)}
.fc-tab.on{background:var(--v4-lime);color:#06060e;border-color:var(--v4-lime)}
.fc-big{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 0 4px}
.fc-amt{font-family:var(--v4-display);font-weight:900;font-size:clamp(38px,8vw,60px);color:var(--v4-lime);letter-spacing:1px;
  text-shadow:0 0 26px color-mix(in srgb,var(--v4-lime) 45%,transparent);line-height:1;animation:fcPop .28s var(--v4-ease-pop)}
@keyframes fcPop{from{transform:scale(.9);opacity:.4}to{transform:scale(1);opacity:1}}
.fc-cad{font-family:var(--v4-mono);font-size:9px;letter-spacing:1px;color:var(--v4-text-dim);text-transform:uppercase}
.fc-note{font-size:11.5px;color:var(--v4-text-dim);margin-top:10px}

/* goal cards */
.goal-card{padding:18px;border-radius:var(--v4-r-card);background:rgba(255,255,255,.03);border:1.5px solid rgba(255,255,255,.10);margin-top:16px}
.goal-head h3{font-family:var(--v4-display);font-weight:900;font-size:16px;margin:0}
.goal-head p{font-size:12px;color:var(--v4-text-2);margin:3px 0 14px}
.goal-inputs{display:flex;gap:12px;flex-wrap:wrap}
.goal-inputs label{flex:1;min-width:150px;display:flex;flex-direction:column;gap:6px;font-size:11px;color:var(--v4-text-dim)}
.goal-in{display:flex;align-items:center;gap:6px;padding:0 12px;border-radius:var(--v4-r-ctl);background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.14)}
.goal-in b{color:var(--v4-text-dim);font-weight:700}
.goal-in input{flex:1;background:none;border:none;color:var(--v4-text);font-size:16px;font-weight:700;padding:11px 0;outline:none;font-family:var(--v4-font)}
.goal-in:focus-within{border-color:color-mix(in srgb,var(--v4-lime) 55%,transparent)}
.goal-result{margin-top:14px;padding:14px;border-radius:var(--v4-r-panel);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);
  font-size:13px;color:var(--v4-text-2);text-align:center}
.goal-result.on{border-color:color-mix(in srgb,var(--v4-lime) 40%,transparent);background:color-mix(in srgb,var(--v4-lime) 7%,transparent);color:var(--v4-text)}
.goal-result.reached{border-color:var(--v4-lime);background:color-mix(in srgb,var(--v4-lime) 14%,transparent);color:var(--v4-lime);animation:racePop .4s var(--v4-ease-pop)}
.goal-big{font-family:var(--v4-display);font-weight:900;font-size:20px;color:var(--v4-lime)}
.goal-when{display:block;font-size:11px;color:var(--v4-text-dim);margin-top:3px}
.goal-fine{font-size:10.5px;color:var(--v4-text-dim);margin-top:11px;line-height:1.45;text-align:center}
@media(max-width:620px){ .calc-hub{grid-template-columns:1fr} }
@media (prefers-reduced-motion: reduce){ .calc-sec,.fc-amt,.goal-result.reached{animation:none} .calc-hub-card:hover{transform:none} }

/* ══ Portfolio Stats live dashboard (pstats, v4.0) — sec-portfolio only ══ */
.ps-orbbar{display:flex;align-items:center;justify-content:center;gap:22px;margin:6px 0 2px}
.ps-arrow{width:44px;height:44px;border-radius:50%;border:1px solid rgba(189,255,0,.35);cursor:pointer;
  background:rgba(189,255,0,.06);color:var(--v4-lime);font-size:24px;line-height:1;font-family:var(--v4-display);
  display:flex;align-items:center;justify-content:center;transition:transform .15s var(--v4-ease),background .15s,box-shadow .15s;
  backdrop-filter:blur(6px)}
.ps-arrow:hover{background:rgba(189,255,0,.14);box-shadow:0 0 18px rgba(189,255,0,.18)}
.ps-arrow:active{transform:translateY(2px) scale(.94)}
.ps-orbwrap{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:170px}
.ps-orb{width:86px;height:86px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;
  background:radial-gradient(circle at 32% 28%,#1b1d36,#0a0a16 72%);
  border:2px solid rgba(189,255,0,.5);box-shadow:0 0 26px rgba(189,255,0,.18),inset 0 0 18px rgba(189,255,0,.07);
  animation:psOrbBob 5.5s ease-in-out infinite}
@keyframes psOrbBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.ps-orb-ico{font-size:36px;line-height:1}
.ps-orb-ico img{width:52px;height:52px;object-fit:contain;image-rendering:pixelated}
.ps-orb-name{font-family:var(--v4-display);font-size:17px;font-weight:800;letter-spacing:.4px;color:var(--v4-text)}
.ps-orb-sub{font-size:11.5px;color:var(--v4-text-dim)}
.ps-dots{display:flex;justify-content:center;gap:6px;margin:8px 0 14px}
.ps-dots i{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.16);transition:background .2s,transform .2s}
.ps-dots i.on{background:var(--v4-lime);transform:scale(1.3);box-shadow:0 0 8px rgba(189,255,0,.5)}

.ps-stage{position:relative;background:linear-gradient(180deg,#0b0c1a,#090911);border:1px solid rgba(255,255,255,.07);
  border-radius:var(--v4-r-card);padding:20px 20px 16px;box-shadow:var(--v4-e1)}
.ps-in-r{animation:psInR .26s var(--v4-ease)}
.ps-in-l{animation:psInL .26s var(--v4-ease)}
@keyframes psInR{from{opacity:0;transform:translateX(26px)}to{opacity:1;transform:none}}
@keyframes psInL{from{opacity:0;transform:translateX(-26px)}to{opacity:1;transform:none}}

.ps-live{position:absolute;top:14px;right:16px;font-size:10.5px;letter-spacing:.6px;font-weight:700;text-transform:uppercase;
  padding:4px 10px;border-radius:var(--v4-r-pill);border:1px solid rgba(255,255,255,.1);color:var(--v4-text-dim)}
.ps-live.on{color:var(--v4-lime);border-color:rgba(189,255,0,.35);background:rgba(189,255,0,.07)}
.ps-live.loading{color:var(--v4-gold);border-color:rgba(255,206,77,.3)}
.ps-live.offline{color:#ff8f6b;border-color:rgba(255,143,107,.3)}
.ps-bigval{font-family:var(--v4-mono);font-size:clamp(26px,5vw,44px);color:var(--v4-lime);
  text-shadow:0 0 24px rgba(189,255,0,.35);margin:14px 0 6px;text-align:center}
.ps-today{text-align:center;font-size:13.5px;font-weight:700;color:var(--v4-text-dim);margin-bottom:14px}
.ps-today.up{color:#3ad98a}.ps-today.down{color:#ff6b6b}

.ps-ranges{display:flex;justify-content:center;gap:8px;margin-bottom:10px}
.ps-rchip{padding:6px 16px;border-radius:var(--v4-r-pill);border:1px solid rgba(255,255,255,.12);cursor:pointer;
  background:transparent;color:var(--v4-text-2);font-weight:800;font-size:12px;letter-spacing:.5px;
  transition:all .15s var(--v4-ease)}
.ps-rchip:hover{border-color:rgba(189,255,0,.4);color:var(--v4-text)}
.ps-rchip:active{transform:translateY(1px) scale(.97)}
.ps-rchip.on{background:var(--v4-lime);border-color:var(--v4-lime);color:#0a0a10;box-shadow:0 0 16px rgba(189,255,0,.35)}
.ps-chartwrap{position:relative;margin-bottom:16px}
.ps-chartwrap canvas{display:block;width:100%;border-radius:var(--v4-r-panel);background:rgba(255,255,255,.02)}
.ps-rdelta{text-align:center;margin-top:8px;font-size:13px;font-weight:800;color:var(--v4-text-dim)}
.ps-rdelta.up{color:#3ad98a}.ps-rdelta.down{color:#ff6b6b}

.ps-glcard{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:var(--v4-r-panel);
  padding:14px 16px;margin-bottom:14px}
.ps-glrow{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.ps-gllbl{font-size:12.5px;color:var(--v4-text-dim)}
.ps-gllbl b{color:var(--v4-text);font-size:14px;margin-left:4px}
.ps-glbadge{font-weight:900;font-size:13px;padding:4px 12px;border-radius:var(--v4-r-pill)}
.ps-glbadge.up{color:#3ad98a;background:rgba(58,217,138,.1);border:1px solid rgba(58,217,138,.3)}
.ps-glbadge.down{color:#ff6b6b;background:rgba(255,107,107,.1);border:1px solid rgba(255,107,107,.3)}
.ps-glbar{height:10px;border-radius:var(--v4-r-pill);background:rgba(255,255,255,.06);overflow:hidden;display:flex}
.ps-glbar i{display:block;height:100%;transition:width .5s var(--v4-ease)}
.ps-glbar #ps-glbar-base{background:rgba(255,255,255,.22)}
.ps-glbar #ps-glbar-gain.up{background:linear-gradient(90deg,#3ad98a,var(--v4-lime))}
.ps-glbar #ps-glbar-gain.down{background:linear-gradient(90deg,#ff6b6b,#ff8f6b)}
.ps-glnote{font-size:11px;color:var(--v4-text-dim);margin:8px 0 0;line-height:1.5}

.ps-chips{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-bottom:14px}
.ps-chip{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:var(--v4-r-panel);
  padding:10px 12px;display:flex;flex-direction:column;gap:3px}
.ps-chip span{font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--v4-text-dim)}
.ps-chip b{font-size:15px;color:var(--v4-text)}

.ps-goalcard{margin-top:2px}
.ps-goalbar{height:14px;border-radius:var(--v4-r-pill);background:rgba(255,255,255,.06);overflow:hidden;margin:10px 0 8px}
.ps-goalbar i{display:block;height:100%;width:0;border-radius:var(--v4-r-pill);
  background:linear-gradient(90deg,var(--v4-lime-deep),var(--v4-lime));box-shadow:0 0 14px rgba(189,255,0,.4);
  transition:width .6s var(--v4-ease)}
.ps-goalmeta{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;font-size:13px;font-weight:700;
  color:var(--v4-text-2);margin-bottom:12px}
.ps-goalmeta b{color:var(--v4-lime)}

@media (max-width:520px){
  .ps-orbbar{gap:12px}.ps-orb{width:72px;height:72px}.ps-orb-ico{font-size:30px}
  .ps-stage{padding:16px 12px 12px}.ps-live{position:static;display:inline-block;margin-bottom:6px}
}
@media (prefers-reduced-motion:reduce){
  .ps-orb{animation:none}
  .ps-in-r,.ps-in-l{animation:none}
  .ps-glbar i,.ps-goalbar i{transition:none}
}

/* ══ pstats round 2 — price box, smoother swap, invested hint, 7 range chips ══ */
.ps-pricebox{position:absolute;top:14px;left:16px;display:flex;flex-direction:column;gap:2px;
  padding:8px 14px;border-radius:var(--v4-r-panel);background:rgba(189,255,0,.05);
  border:1px solid rgba(189,255,0,.28);box-shadow:0 0 16px rgba(189,255,0,.08);backdrop-filter:blur(6px)}
.ps-pb-lbl{font-size:9.5px;text-transform:uppercase;letter-spacing:.8px;color:var(--v4-text-dim);font-weight:800}
.ps-pb-px{font-family:var(--v4-display);font-size:19px;font-weight:900;color:var(--v4-text);line-height:1.1}
.ps-pb-mv{font-size:11px;font-weight:800}
.ps-pb-mv.up{color:#3ad98a}.ps-pb-mv.down{color:#ff6b6b}

/* two-phase swap: glide out, swap data, glide in — continuous, not a hard cut */
.ps-out-l{animation:psOutL .15s var(--v4-ease) forwards}
.ps-out-r{animation:psOutR .15s var(--v4-ease) forwards}
@keyframes psOutL{to{opacity:0;transform:translateX(-22px)}}
@keyframes psOutR{to{opacity:0;transform:translateX(22px)}}
.ps-in-r{animation:psInR .28s var(--v4-ease)}
.ps-in-l{animation:psInL .28s var(--v4-ease)}

.ps-glhint{display:block;font-size:9.5px;font-style:normal;color:var(--v4-text-dim);letter-spacing:.3px;margin-top:1px}
.ps-glright{text-align:right}
.ps-ranges{flex-wrap:wrap}
@media (max-width:560px){
  .ps-pricebox{position:static;display:inline-flex;margin-bottom:8px}
  .ps-rchip{padding:6px 11px;font-size:11px}
}
@media (prefers-reduced-motion:reduce){ .ps-out-l,.ps-out-r{animation:none} }
