/* ============================================================
   Darktide — survivors-like arcade game.
   Full-bleed 3D stage with an HTML HUD + screen overlays on top.
   Palette rides on the site's dark blue-black with ember/teal/gold.
   ============================================================ */

.survive-page {
  overflow: hidden;            /* the game owns the viewport */
  overscroll-behavior: none;
  touch-action: none;
}
.survive-page .site-nav { position: relative; z-index: 40; }

.survive-main { position: static; }

/* ---- element-tint accents reused by the HUD ---- */
.survive-page {
  --sv-fire:   #ff6a2c;
  --sv-ice:    #66d8ff;
  --sv-poison: #7be88a;
  --sv-thunder:#b46bff;
  --sv-gold:   #ffd166;
  --sv-blood:  #e8455e;
  --sv-ink:    #0a1326;
}

/* ===== anon gate ===== */
.survive-gate {
  min-height: 70vh; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 14px; text-align: center;
  padding: 40px 20px;
}
.survive-gate h1 { font-family: "Cinzel Decorative", serif; font-size: clamp(2.4rem,7vw,4rem); margin: 0; color: #f2ead6; }
.survive-gate p { color: #b9c2d6; max-width: 32ch; margin: 0 0 8px; }

/* ===== full-bleed stage ===== */
.survive-game { position: static; }
.sv-stage {
  position: fixed; inset: 0; z-index: 1;
  background: radial-gradient(120% 90% at 50% 0%, #16213f 0%, #0a1226 55%, #050a16 100%);
  overflow: hidden;
}
.sv-stage > canvas { display: block; width: 100% !important; height: 100% !important; }

/* ============================================================
   HUD (overlaid; layer ignores pointer except on controls)
   ============================================================ */
.sv-hud {
  position: fixed; inset: 0; z-index: 20; pointer-events: none;
  font-family: "Manrope", system-ui, sans-serif;
  -webkit-user-select: none; user-select: none;
}
.sv-hud > * { pointer-events: auto; }

/* shared glass panel — matches the site's gold-edged dark-glass cards */
.sv-panel {
  background: linear-gradient(180deg, rgba(18,22,40,.62), rgba(8,12,24,.58));
  border: 1px solid rgba(255,209,102,.18); border-radius: 12px;
  backdrop-filter: blur(7px); box-shadow: 0 4px 16px rgba(0,0,0,.42);
}

/* ===== TOP BAR: hero chip · timer/boss · system buttons ===== */
.sv-top {
  position: absolute; top: calc(var(--sv-navh, 60px) + 8px); left: 0; right: 0;
  display: flex; align-items: flex-start; justify-content: space-between; gap: 10px;
  padding: 0 14px; pointer-events: none;
}
.sv-top > * { pointer-events: auto; }

.sv-topleft { display: flex; flex-direction: column; align-items: flex-start; gap: 8px; pointer-events: none; }
.sv-build { display: flex; flex-wrap: wrap; gap: 6px; padding: 7px; max-width: min(252px, 64vw); }
.sv-build:empty { display: none; }
.sv-build-sep { flex: 0 0 100%; height: 1px; background: rgba(255,209,102,.22); margin: 1px 0; }
.sv-ab.pass { box-shadow: 0 0 0 1px rgba(255,209,102,.5) inset, 0 2px 8px rgba(0,0,0,.5); }
.sv-hero-chip { display: flex; align-items: center; gap: 9px; padding: 5px 14px 5px 5px; }
.sv-portrait { width: 42px; height: 42px; border-radius: 50%; object-fit: cover; border: 2px solid rgba(255,209,102,.42); background: #0c1430; flex: 0 0 auto; }
.sv-hero-meta { display: flex; flex-direction: column; gap: 1px; line-height: 1.18; }
.sv-meta-lvl { font-family: "Cinzel", serif; font-weight: 700; font-size: .88rem; color: #f3ead4; }
.sv-meta-lvl b { color: var(--sv-gold); }
.sv-meta-kills { font-size: .76rem; font-weight: 700; color: #cdd3e2; display: inline-flex; align-items: center; gap: 4px; }
.sv-meta-kills i { opacity: .8; font-style: normal; }
.sv-meta-kills b { color: #fff; }

.sv-top-center { display: flex; flex-direction: column; align-items: center; gap: 3px; pointer-events: none; flex: 1; min-width: 0; }
.sv-timer {
  font-family: "Cinzel", serif; font-weight: 900; font-size: clamp(1.7rem, 3.6vw, 2.5rem);
  color: #f4ecd6; letter-spacing: .04em; text-shadow: 0 2px 14px rgba(0,0,0,.7); font-variant-numeric: tabular-nums;
}
.sv-wave { font-size: .78rem; color: var(--sv-blood); font-weight: 800; letter-spacing: .16em; text-transform: uppercase; min-height: 1em; text-shadow: 0 1px 6px #000; }

.sv-sys { display: flex; gap: 5px; padding: 5px; }
.sv-iconbtn {
  width: 34px; height: 34px; border-radius: 9px; border: 1px solid rgba(255,255,255,.12);
  background: rgba(10,16,30,.4); color: #e7ddc4; cursor: pointer; line-height: 1;
  display: grid; place-items: center; font-size: .92rem; transition: border-color .15s, color .15s;
}
.sv-iconbtn:hover { border-color: var(--sv-gold); color: var(--sv-gold); }
#sv-guide-btn { font-family: "Cinzel", serif; font-weight: 800; font-size: 1rem; }
.sv-iconbtn.off { opacity: .5; }

/* ===== ability chips ===== */
.sv-ab {
  width: 42px; height: 42px; border-radius: 10px; position: relative; overflow: hidden;
  background: #0c1430 center/cover no-repeat; border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 2px 8px rgba(0,0,0,.5); display: grid; place-items: center;
  font-weight: 900; color: #e8dcbf;
}
.sv-ab[data-elem="fire"]   { box-shadow: 0 0 0 1px var(--sv-fire) inset, 0 2px 8px rgba(0,0,0,.5); }
.sv-ab[data-elem="ice"]    { box-shadow: 0 0 0 1px var(--sv-ice) inset, 0 2px 8px rgba(0,0,0,.5); }
.sv-ab[data-elem="poison"] { box-shadow: 0 0 0 1px var(--sv-poison) inset, 0 2px 8px rgba(0,0,0,.5); }
.sv-ab[data-elem="thunder"]{ box-shadow: 0 0 0 1px var(--sv-thunder) inset, 0 2px 8px rgba(0,0,0,.5); }
.sv-ab-lvl { position: absolute; bottom: 1px; right: 3px; font-size: .62rem; font-weight: 900; color: var(--sv-gold); text-shadow: 0 1px 2px #000; }
.sv-ab-cd { position: absolute; inset: 0; background: conic-gradient(rgba(0,0,0,.62) var(--cd,0%), transparent 0); pointer-events: none; }

/* ===== BOTTOM: one centered cluster — abilities over bars+ult ===== */
.sv-bottom {
  position: absolute; left: 50%; transform: translateX(-50%); bottom: calc(env(safe-area-inset-bottom, 0px) + 12px);
  width: min(640px, 94vw); display: flex; flex-direction: column; align-items: center; gap: 8px; pointer-events: none;
}
.sv-abilities { display: flex; gap: 7px; justify-content: center; flex-wrap: wrap; pointer-events: auto; }
.sv-barwrap { display: flex; align-items: flex-end; gap: 14px; width: 100%; }
.sv-bars { flex: 1; display: flex; flex-direction: column; gap: 5px; pointer-events: none; }
.sv-bar {
  position: relative; height: 15px; border-radius: 8px; overflow: hidden;
  background: rgba(6,10,20,.72); border: 1px solid rgba(255,255,255,.1);
  box-shadow: inset 0 1px 3px rgba(0,0,0,.6);
}
.sv-bar i { position: absolute; inset: 0; transform-origin: left; transition: width .12s linear; display: block; }
.sv-bar-xp  { height: 11px; }
.sv-bar-xp  i { background: linear-gradient(90deg, #6fd1ff, #b98bff); width: 0%; }
.sv-bar-hp  i { background: linear-gradient(90deg, #e8455e, #ff8a5c); width: 100%; }
.sv-bar-rage i { background: linear-gradient(90deg, #ffb52e, #ffe27a); width: 0%; }
.sv-bar-rage.ready i { animation: sv-rage-pulse .8s ease-in-out infinite; }
@keyframes sv-rage-pulse { 0%,100%{ filter: brightness(1); } 50%{ filter: brightness(1.5); } }
.sv-bar-txt { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); font-size: .62rem; font-weight: 800; color: #fff; text-shadow: 0 1px 2px #000; letter-spacing: .08em; }

.sv-ult {
  pointer-events: auto; width: 62px; height: 62px; flex: 0 0 auto; border-radius: 50%;
  border: 2px solid rgba(255,209,102,.5); background: radial-gradient(circle at 50% 35%, #2a2140, #120c22);
  color: var(--sv-gold); display: grid; place-items: center; cursor: pointer; position: relative; overflow: visible;
  transition: transform .1s, filter .2s; opacity: .5;
}
.sv-ult:not(:disabled) { opacity: 1; box-shadow: 0 0 18px rgba(255,209,102,.55); animation: sv-rage-pulse 1s ease-in-out infinite; }
.sv-ult:not(:disabled):active { transform: scale(.92); }
.sv-ult-ic { font-size: 1.6rem; line-height: 1; display: grid; place-items: center; }
.sv-ult-key { position: absolute; bottom: -15px; left: 50%; transform: translateX(-50%); font-size: .55rem; letter-spacing: .1em; color: #9aa4bd; }

/* mobile joystick */
.sv-stick {
  position: fixed; z-index: 22; width: 120px; height: 120px; border-radius: 50%;
  background: rgba(8,14,28,.35); border: 1px solid rgba(255,255,255,.14);
  pointer-events: none; transform: translate(-50%,-50%);
}
.sv-stick i { position: absolute; left: 50%; top: 50%; width: 52px; height: 52px; margin: -26px 0 0 -26px; border-radius: 50%; background: radial-gradient(circle at 40% 35%, #e9ddc0, #b9a87e); box-shadow: 0 3px 10px rgba(0,0,0,.5); }

/* damage numbers */
.sv-dmg { position: fixed; inset: 0; z-index: 18; pointer-events: none; overflow: hidden; }
.sv-num {
  position: absolute; font-family: "Cinzel", serif; font-weight: 900; font-size: .95rem;
  color: #fff; text-shadow: 0 1px 3px #000, 0 0 6px rgba(0,0,0,.6); will-change: transform, opacity;
  white-space: nowrap; transform: translate(-50%,-50%);
}
.sv-num.crit { font-size: 1.5rem; color: var(--sv-gold); }
.sv-num.heal { color: var(--sv-poison); }
.sv-num.fire { color: var(--sv-fire); }
.sv-num.ice  { color: var(--sv-ice); }
.sv-num.poison { color: var(--sv-poison); }
.sv-num.thunder { color: var(--sv-thunder); }

/* hurt flash / vignette */
.sv-flash { position: fixed; inset: 0; z-index: 17; pointer-events: none; opacity: 0; box-shadow: inset 0 0 140px 30px var(--sv-blood); transition: opacity .08s; }
.sv-flash.on { opacity: .8; transition: opacity .35s; }

/* ---- real-icon swap (glyph is the fallback) ---- */
.sv-ico-gl { display: inline-flex; align-items: center; justify-content: center; line-height: 1; }
.has-img .sv-ico-gl { display: none; }
.sv-ab.has-img, .sv-card-ic.has-img { background-size: cover; background-position: center; }
.sv-ult-ic.has-img { width: 42px; height: 42px; border-radius: 9px; background-size: cover; background-position: center; }

/* ---- boss health bar ---- */
.sv-boss { margin-top: 1px; width: min(58vw, 440px); pointer-events: none; text-align: center; }
.sv-boss-name { font-family: "Cinzel", serif; font-weight: 700; font-size: .78rem; letter-spacing: .14em; text-transform: uppercase; color: #ffb9c2; text-shadow: 0 1px 4px #000; margin-bottom: 3px; }
.sv-boss-bar { height: 13px; border-radius: 7px; overflow: hidden; background: rgba(6,10,20,.7); border: 1px solid rgba(255,90,110,.55); box-shadow: 0 0 16px rgba(232,69,94,.45); }
.sv-boss-bar i { display: block; height: 100%; width: 100%; background: linear-gradient(90deg, #ff3050, #ff8a5c); transition: width .12s linear; }

/* ---- radar ---- */
.sv-radar { position: absolute; right: 14px; top: calc(var(--sv-navh, 60px) + 56px); width: 86px; height: 86px; pointer-events: none; opacity: .9; filter: drop-shadow(0 3px 8px rgba(0,0,0,.5)); }

/* ---- persistent low-HP red vignette ---- */
.sv-lowhp { position: fixed; inset: 0; z-index: 16; pointer-events: none; opacity: 0; box-shadow: inset 0 0 120px 26px rgba(232,69,94,.55); transition: opacity .3s; }
.sv-lowhp.on { opacity: .6; animation: sv-lowpulse 1.1s ease-in-out infinite; }
@keyframes sv-lowpulse { 0%, 100% { opacity: .32; } 50% { opacity: .68; } }

/* ===== guide / field manual ===== */
.sv-guide .sv-screen-inner { text-align: left; }
.sv-guide-title { font-family: "Cinzel Decorative", serif; text-align: center; color: var(--sv-gold); font-size: clamp(1.5rem, 5vw, 2.1rem); margin: 0 0 4px; }
.sv-guide-intro { text-align: center; color: #c2cadc; font-size: .86rem; margin: 0 0 6px; }
.sv-g-h { font-family: "Cinzel", serif; color: #f3ead4; font-size: 1.05rem; letter-spacing: .04em; margin: 18px 0 8px; padding-bottom: 5px; border-bottom: 1px solid rgba(255,209,102,.18); }
.sv-g-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.sv-g-row { display: flex; gap: 10px; align-items: flex-start; background: rgba(8,12,24,.5); border: 1px solid rgba(255,255,255,.08); border-radius: 10px; padding: 9px 11px; }
.sv-g-ic { width: 40px; height: 40px; flex: 0 0 auto; border-radius: 9px; background: #0c1430 center/cover no-repeat; border: 1px solid rgba(255,255,255,.14); display: grid; place-items: center; font-size: 1.2rem; color: #e8dcbf; }
.sv-g-ic.has-img { background-size: cover; background-position: center; }
.sv-g-txt { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.sv-g-txt b { font-family: "Cinzel", serif; color: #f3ead4; font-size: .98rem; }
.sv-g-sub { font-size: .8rem; color: #aeb6cb; line-height: 1.35; }
.sv-g-tagel { font-size: .62rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.sv-g-evo { font-size: .8rem; color: var(--sv-gold); margin-top: 3px; font-weight: 700; }
.sv-g-need { color: #c9b98a; font-weight: 500; }
.sv-el-fire { color: var(--sv-fire); } .sv-el-ice { color: var(--sv-ice); } .sv-el-poison { color: var(--sv-poison); } .sv-el-thunder { color: var(--sv-thunder); } .sv-el-physical { color: #e8c878; }
#sv-guide-close { margin-top: 18px; }

/* ===== chest reward ===== */
.sv-chest-ic { font-size: 3.2rem; line-height: 1; animation: sv-rage-pulse 1.2s ease-in-out infinite; }
.sv-chest-title { font-family: "Cinzel Decorative", serif; color: var(--sv-gold); font-size: clamp(1.7rem, 5vw, 2.5rem); margin: 6px 0 4px; }
.sv-chest-rewards { display: flex; flex-direction: column; gap: 10px; margin: 16px auto; max-width: 420px; }
.sv-chest-row { display: flex; align-items: center; gap: 12px; text-align: left; background: rgba(8,12,24,.55); border: 1px solid rgba(255,209,102,.25); border-radius: 12px; padding: 10px 14px; opacity: 0; transform: translateY(10px); animation: sv-chest-in .42s ease forwards; }
@keyframes sv-chest-in { to { opacity: 1; transform: none; } }
.sv-chest-rico { width: 50px; height: 50px; flex: 0 0 auto; border-radius: 11px; background: #0c1430 center/cover no-repeat; border: 1px solid rgba(255,255,255,.16); display: grid; place-items: center; font-size: 1.5rem; color: #e8dcbf; }
.sv-chest-rico.has-img { background-size: cover; background-position: center; }
.sv-chest-rtx { display: flex; flex-direction: column; }
.sv-chest-rtx b { font-family: "Cinzel", serif; color: #f3ead4; font-size: 1.1rem; }
.sv-chest-rtx span { font-size: .82rem; color: var(--sv-gold); }
.sv-chest-row.evolve { border-color: var(--sv-blood); box-shadow: 0 0 16px rgba(232,69,94,.3); }
.sv-chest-row.evolve .sv-chest-rtx span { color: var(--sv-blood); }

/* ===== leaderboard ===== */
.sv-lb-title { font-family: "Cinzel Decorative", serif; text-align: center; color: var(--sv-gold); font-size: clamp(1.6rem, 5vw, 2.2rem); margin: 0 0 12px; }
.sv-lb-tabs { display: flex; justify-content: center; gap: 8px; margin-bottom: 12px; }
.sv-lb-tab { background: rgba(8,12,24,.5); border: 1px solid rgba(255,255,255,.14); color: #cdd3e2; padding: 7px 16px; border-radius: 999px; cursor: pointer; font-weight: 700; font-size: .85rem; }
.sv-lb-tab.is-active { border-color: var(--sv-gold); color: var(--sv-gold); }
.sv-lb-headrow { display: grid; grid-template-columns: 46px 1fr auto; gap: 10px; padding: 0 12px 6px; font-size: .66rem; text-transform: uppercase; letter-spacing: .08em; color: #99a2ba; border-bottom: 1px solid rgba(255,255,255,.1); }
.sv-lb-h-score { text-align: right; }
.sv-lb-body { display: flex; flex-direction: column; gap: 5px; margin: 8px 0 4px; max-height: 52vh; overflow-y: auto; }
.sv-lb-empty { text-align: center; color: #99a2ba; padding: 22px 0; }
.sv-lb-row { display: grid; grid-template-columns: 46px 1fr auto; gap: 10px; align-items: center; padding: 8px 12px; border-radius: 10px; background: rgba(8,12,24,.5); border: 1px solid rgba(255,255,255,.07); }
.sv-lb-row.you { border-color: var(--sv-gold); background: rgba(40,32,20,.6); }
.sv-lb-row.foot { margin-top: 4px; }
.sv-lb-rank { font-family: "Cinzel", serif; font-weight: 900; color: #f4ecd6; text-align: center; }
.sv-lb-row:first-child .sv-lb-rank { color: var(--sv-gold); }
.sv-lb-player { display: flex; align-items: center; gap: 9px; min-width: 0; }
.sv-lb-av { width: 30px; height: 30px; border-radius: 50%; object-fit: cover; flex: 0 0 auto; border: 1px solid rgba(255,255,255,.18); background: #0c1430; }
.sv-lb-av-fb { display: grid; place-items: center; background: #2a2440; color: #e8dcbf; font-weight: 800; font-size: .8rem; }
.sv-lb-name { font-weight: 700; color: #ece3cd; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sv-lb-score { text-align: right; display: flex; flex-direction: column; line-height: 1.12; }
.sv-lb-score b { font-family: "Cinzel", serif; color: var(--sv-gold); font-size: 1.05rem; }
.sv-lb-score i { font-style: normal; font-size: .66rem; color: #99a2ba; }
#sv-lb-close { margin-top: 8px; }

/* ============================================================
   Screens (start / level-up / pause / results / loading)
   ============================================================ */
/* [hidden] must win over the display rules below (class selectors out-specify the UA [hidden] rule) */
.sv-screen[hidden], .survive-gate[hidden], .sv-hud[hidden], .sv-stick[hidden], .survive-game[hidden] { display: none !important; }

.sv-screen {
  position: fixed; inset: 0; z-index: 30; display: grid; place-items: center; padding: 24px;
  background: radial-gradient(120% 100% at 50% 0%, rgba(12,18,36,.78), rgba(5,9,18,.92));
  backdrop-filter: blur(6px);
  animation: sv-fade .25s ease both;
}
@keyframes sv-fade { from { opacity: 0; } to { opacity: 1; } }
.sv-screen-inner {
  width: min(880px, 96vw); max-height: calc(100vh - 80px); overflow: auto;
  text-align: center; color: #ece3cd;
  border: 1px solid rgba(255,209,102,.18); border-radius: 18px; padding: clamp(20px, 4vw, 40px);
  background: linear-gradient(180deg, rgba(20,16,30,.86), rgba(10,12,24,.92));
  box-shadow: 0 30px 80px rgba(0,0,0,.6);
}

.sv-title { font-family: "Cinzel Decorative", serif; font-weight: 900; font-size: clamp(2.6rem, 8vw, 5rem); margin: .1em 0 .15em; color: #f4ecd6; }
.sv-title em { font-style: normal; color: var(--sv-blood); }
.sv-lead { color: #c2cadc; max-width: 52ch; margin: 0 auto 22px; line-height: 1.55; }

/* hero select */
.sv-heroes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin: 8px 0 22px; }
.sv-hero {
  cursor: pointer; border-radius: 14px; padding: 14px 12px; text-align: center; position: relative;
  border: 1.5px solid rgba(255,255,255,.12); background: rgba(8,12,24,.6); transition: transform .12s, border-color .12s, box-shadow .12s;
}
.sv-hero:hover { transform: translateY(-3px); }
.sv-hero.sel { border-color: var(--sv-gold); box-shadow: 0 0 0 1px var(--sv-gold) inset, 0 12px 30px rgba(0,0,0,.5); background: rgba(28,22,38,.7); }
.sv-hero-port { width: 84px; height: 84px; border-radius: 50%; margin: 0 auto 10px; background: #11183300 center/cover no-repeat; border: 2px solid rgba(255,255,255,.14); }
.sv-hero-name { font-family: "Cinzel", serif; font-weight: 700; font-size: 1.15rem; color: #f3ead4; }
.sv-hero-class { font-size: .76rem; text-transform: uppercase; letter-spacing: .1em; color: #9aa4bd; margin-top: 2px; }
.sv-hero-elem { display: inline-block; margin-top: 8px; font-size: .72rem; font-weight: 800; padding: 2px 9px; border-radius: 999px; }
.sv-hero-elem[data-elem="fire"]   { color: var(--sv-fire);   background: rgba(255,106,44,.14); }
.sv-hero-elem[data-elem="ice"]    { color: var(--sv-ice);    background: rgba(102,216,255,.14); }
.sv-hero-elem[data-elem="poison"] { color: var(--sv-poison); background: rgba(123,232,138,.14); }
.sv-hero-desc { font-size: .8rem; color: #aab3c8; margin-top: 9px; line-height: 1.4; min-height: 2.6em; }

.sv-start-actions { display: flex; flex-direction: column; align-items: center; gap: 10px; }
.sv-play { font-family: "Cinzel", serif; font-size: 1.15rem; padding: 14px 38px; }
.sv-best { color: #c9b98a; font-weight: 700; }
.sv-best b { color: var(--sv-gold); }
.sv-controls { margin-top: 16px; font-size: .78rem; color: #8b94ab; }

/* level-up cards */
.sv-lvl-title { font-family: "Cinzel", serif; font-size: clamp(1.6rem,5vw,2.4rem); color: var(--sv-gold); margin: 0 0 18px; text-shadow: 0 0 22px rgba(255,209,102,.4); }
.sv-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.sv-card {
  cursor: pointer; border-radius: 14px; padding: 18px 14px; text-align: center; position: relative; overflow: hidden;
  border: 1.5px solid rgba(255,255,255,.14); background: linear-gradient(180deg, rgba(18,22,40,.9), rgba(10,12,24,.95));
  transition: transform .12s, border-color .12s, box-shadow .12s; min-height: 200px;
  display: flex; flex-direction: column; align-items: center; justify-content: flex-start; gap: 9px;
}
.sv-card:hover { transform: translateY(-4px); border-color: var(--sv-gold); box-shadow: 0 14px 36px rgba(0,0,0,.55); }
.sv-card::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 4px; background: var(--accent, #888); }
.sv-card-ic { width: 60px; height: 60px; border-radius: 12px; background: #0c1430 center/cover no-repeat; border: 1px solid rgba(255,255,255,.16); display: grid; place-items: center; font-size: 1.8rem; }
.sv-card-tag { font-size: .66rem; letter-spacing: .14em; text-transform: uppercase; color: #9aa4bd; font-weight: 800; }
.sv-card-name { font-family: "Cinzel", serif; font-weight: 700; font-size: 1.08rem; color: #f3ead4; }
.sv-card-lvl { font-size: .72rem; color: var(--sv-gold); font-weight: 800; }
.sv-card-desc { font-size: .82rem; color: #aeb6cb; line-height: 1.4; }
.sv-card.evolve { border-color: var(--sv-blood); }
.sv-card.evolve::before { background: linear-gradient(90deg, var(--sv-gold), var(--sv-blood)); }
.sv-card.evolve .sv-card-tag { color: var(--sv-blood); }
.sv-reroll {
  margin-top: 16px; background: transparent; border: 1px solid rgba(255,255,255,.2); color: #cdd3e2;
  padding: 8px 18px; border-radius: 999px; cursor: pointer; font-weight: 700; font-size: .85rem;
}
.sv-reroll:disabled { opacity: .4; cursor: default; }
.sv-reroll b { color: var(--sv-gold); }

/* pause + results */
.sv-pause-actions, .sv-res-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin: 18px 0 6px; }
.sv-pause-build { display: flex; gap: 6px; flex-wrap: wrap; justify-content: center; margin-top: 10px; }

.sv-res-title { font-family: "Cinzel Decorative", serif; font-size: clamp(2rem,6vw,3.2rem); margin: 0 0 6px; color: var(--sv-blood); }
.sv-res-title.win { color: var(--sv-gold); }
.sv-res-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin: 18px 0; }
.sv-res-stat { background: rgba(8,12,24,.6); border: 1px solid rgba(255,255,255,.1); border-radius: 12px; padding: 14px 8px; }
.sv-res-stat b { display: block; font-family: "Cinzel", serif; font-size: 1.6rem; color: #f4ecd6; font-variant-numeric: tabular-nums; }
.sv-res-stat span { font-size: .68rem; text-transform: uppercase; letter-spacing: .1em; color: #99a2ba; }
.sv-res-score b { color: var(--sv-gold); }
.sv-res-new { color: var(--sv-gold); font-weight: 800; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 6px; animation: sv-rage-pulse 1s infinite; }

/* loading */
.sv-loading .sv-screen-inner { border-color: transparent; background: transparent; box-shadow: none; }
.sv-spinner { width: 46px; height: 46px; border-radius: 50%; border: 3px solid rgba(255,255,255,.15); border-top-color: var(--sv-gold); margin: 0 auto 14px; animation: sv-spin 1s linear infinite; }
@keyframes sv-spin { to { transform: rotate(360deg); } }

/* ===== responsive ===== */
@media (max-width: 640px) {
  .sv-heroes, .sv-cards { grid-template-columns: 1fr; }
  .sv-card { min-height: 0; flex-direction: row; text-align: left; justify-content: flex-start; }
  .sv-card-desc, .sv-card-name { text-align: left; }
  .sv-res-grid { grid-template-columns: repeat(2, 1fr); }
  .sv-portrait { width: 34px; height: 34px; }
  .sv-radar { width: 66px; height: 66px; top: calc(var(--sv-navh, 60px) + 50px); }
  .sv-ab { width: 38px; height: 38px; }
  .sv-bottom { width: 96vw; }
  .sv-g-grid { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  .sv-screen, .sv-bar i, .sv-ult, .sv-res-new, .sv-bar-rage.ready i, .sv-lowhp.on { animation: none !important; transition: none !important; }
}
