/* ============================================================
   Codigo Vital - estilos (modo claro)
   ============================================================ */
:root{
  /* paleta del curso */
  --verde:#00B159;  --verde-ink:#067a40;
  --amarillo:#FFCC33; --amarillo-ink:#9a6b00;
  --rojo:#FF1919;   --rojo-ink:#cf1212;
  --azul:#1564A7;   --azul-ink:#114e84;

  /* neutros (modo claro, frio) */
  --bg:#eaf0f7;
  --surface:#ffffff;
  --surface-2:#f5f8fc;
  --line:#dbe5ee;
  --line-strong:#c3d1e0;
  --ink:#14202e;
  --ink-soft:#46586c;
  --ink-dim:#74879b;

  /* acento del escenario (lo setea el juego) */
  --accent:#1564A7;
  --accent-soft:rgba(21,100,167,.14);
  --art-accent:#1564A7;

  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px;
  --maxw:1280px;
  --font-display:"Saira Condensed", system-ui, "Segoe UI", sans-serif;
  --font-ui:"Saira", system-ui, "Segoe UI", sans-serif;
  --ease-out:cubic-bezier(.16,1,.3,1);

  --z-bg:0; --z-base:1; --z-hud:10; --z-overlay:60; --z-flash:80; --z-toast:90;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font-ui);
  background:var(--bg);
  color:var(--ink);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
button{font-family:inherit;color:inherit;border:none;background:none;cursor:pointer}
svg{display:block}
.ic{width:1em;height:1em;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;fill:none;flex:none}

#app{position:fixed;inset:0;display:flex;flex-direction:column;isolation:isolate}

/* ---- fondo ---- */
#bg{position:absolute;inset:0;z-index:var(--z-bg);overflow:hidden;pointer-events:none}
#bg .wash{position:absolute;inset:0;background:
  radial-gradient(80% 60% at 50% -10%, color-mix(in srgb,var(--accent) 12%,transparent), transparent 70%),
  linear-gradient(180deg,#f3f7fc,#e7eef6);transition:background .8s ease}
#bg .dots{position:absolute;inset:0;opacity:.5;
  background-image:radial-gradient(rgba(21,100,167,.10) 1.3px, transparent 1.3px);
  background-size:26px 26px;
  mask-image:radial-gradient(ellipse 90% 80% at 50% 30%,#000 30%,transparent 100%)}
body.state-danger #bg .wash{background:radial-gradient(80% 60% at 50% -10%, rgba(255,25,25,.14), transparent 70%),linear-gradient(180deg,#fdf1f1,#f6e6e6)}
body.state-win #bg .wash{background:radial-gradient(80% 60% at 50% -10%, rgba(0,177,89,.16), transparent 70%),linear-gradient(180deg,#eef9f2,#e4f3ea)}

/* ---- screens ---- */
.screen{position:absolute;inset:0;z-index:var(--z-base);display:none;flex-direction:column;padding:clamp(16px,3vw,38px);overflow:auto}
.screen.active{display:flex}
.screen.enter{animation:screenIn .5s var(--ease-out) both}
@keyframes screenIn{from{opacity:0;transform:translateY(14px) scale(.99)}to{opacity:1;transform:none}}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto}

/* ============================ START ============================ */
#scr-start{text-align:center;justify-content:flex-start}
#scr-start::before, #scr-start::after{content:""; flex:1; min-height:0}
#scr-start .wrap{margin:0 auto; flex:none}
.start-bg{position:absolute;inset:0;display:grid;place-items:center;z-index:0;pointer-events:none;overflow:hidden}
.start-bg img{width:min(82vh,880px);max-width:120%;height:auto;opacity:.11;filter:grayscale(1)}
#scr-start .wrap{position:relative;z-index:1}
.eyebrow{font-weight:600;letter-spacing:.26em;text-transform:uppercase;font-size:clamp(11px,1.2vw,13px);color:var(--azul);margin-top:4px;margin-bottom:12px}
.title{font-family:var(--font-display);font-weight:800;line-height:.92;letter-spacing:-.02em;
  font-size:clamp(50px,10vw,112px);text-transform:uppercase;color:var(--ink)}
.title .v{color:var(--rojo)}
.subtitle{max-width:64ch;margin:16px auto 0;color:var(--ink-soft);font-size:clamp(15px,1.7vw,18px);line-height:1.55}
.subtitle b{color:var(--ink);font-weight:600}

.section-label{display:flex;align-items:center;gap:12px;justify-content:center;margin:clamp(24px,4vw,40px) 0 16px;
  color:var(--ink-dim);font-weight:600;letter-spacing:.14em;text-transform:uppercase;font-size:12.5px}
.section-label::before,.section-label::after{content:"";height:1px;width:min(80px,12vw);background:var(--line-strong)}

.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:16px}
.card{position:relative;text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:20px;overflow:hidden;box-shadow:0 6px 20px -14px rgba(20,40,70,.4);
  transition:transform .35s var(--ease-out),border-color .25s,box-shadow .35s}
.card:hover{transform:translateY(-5px);border-color:var(--line-strong);box-shadow:0 16px 36px -18px rgba(20,40,70,.45)}
.card:focus-visible{outline:3px solid var(--accent);outline-offset:3px}
.card.sel{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent) inset,0 18px 44px -20px var(--accent-soft);transform:translateY(-5px)}
.card .badge{position:absolute;top:15px;right:15px;width:26px;height:26px;border-radius:50%;border:1.5px solid var(--line-strong);
  display:grid;place-items:center;font-size:15px;color:transparent;transition:.25s}
.card.sel .badge{background:var(--accent);border-color:var(--accent);color:#fff}
.card .c-ico{font-size:28px;width:56px;height:56px;border-radius:14px;display:grid;place-items:center;
  background:var(--accent-soft);color:var(--accent);margin-bottom:15px}
.card h3{font-family:var(--font-display);font-weight:700;font-size:23px;letter-spacing:-.01em;line-height:1.05;color:var(--ink)}
.card p{color:var(--ink-soft);font-size:13.5px;line-height:1.5;margin-top:8px;min-height:4em}
.card .meta{display:flex;gap:7px;flex-wrap:wrap;margin-top:14px}
.tag{font-size:11.5px;font-weight:600;letter-spacing:.03em;color:var(--ink-soft);background:var(--surface-2);
  border:1px solid var(--line);border-radius:999px;padding:4px 10px;display:inline-flex;align-items:center;gap:5px}
.tag .ic{font-size:13px;color:var(--accent)}

.start-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:center;margin-top:26px}
.config-menu{position:relative}
.config-toggle{display:inline-flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line-strong);
  color:var(--ink-soft);font-family:var(--font-display);font-weight:700;font-size:clamp(16px,1.9vw,19px);text-transform:uppercase;
  letter-spacing:.02em;padding:16px 22px;border-radius:var(--r-md);transition:.22s var(--ease-out);box-shadow:0 6px 18px -14px rgba(20,40,70,.4)}
.config-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
.config-toggle .ic{font-size:19px}
.config-toggle .chev{font-size:17px;transition:transform .25s var(--ease-out)}
.config-menu.open .config-toggle{border-color:var(--accent);color:var(--accent)}
.config-menu.open .config-toggle .chev{transform:rotate(180deg)}
.config-panel{position:absolute;left:50%;bottom:calc(100% + 12px);transform:translate(-50%,8px);width:min(560px,86vw);
  text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px 22px;
  box-shadow:0 24px 50px -22px rgba(20,40,70,.55);opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .22s var(--ease-out),transform .22s var(--ease-out),visibility .22s;z-index:20}
.config-menu.open .config-panel{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,0)}
.config-panel::after{content:"";position:absolute;left:50%;top:100%;transform:translateX(-50%);border:8px solid transparent;border-top-color:var(--surface)}
.cfg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px 18px}
.field label{display:block;font-size:12.5px;color:var(--ink-soft);margin-bottom:7px;font-weight:500}
.stepper{display:flex;align-items:center;background:var(--surface-2);border:1px solid var(--line-strong);border-radius:10px;overflow:hidden}
.stepper button{width:34px;height:38px;color:var(--ink-soft);font-size:20px;font-weight:700;transition:.2s}
.stepper button:hover{background:var(--accent-soft);color:var(--accent)}
.stepper output{flex:1;text-align:center;font-family:var(--font-display);font-weight:700;font-size:19px;font-variant-numeric:tabular-nums;color:var(--ink)}
.toggle{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none;color:var(--ink-soft);font-size:14px}
.toggle b{color:var(--ink);font-weight:600}
.toggle .sw{width:46px;height:26px;border-radius:999px;background:var(--line-strong);position:relative;transition:.25s;flex:none}
.toggle .sw::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:.25s var(--ease-out);box-shadow:0 1px 3px rgba(0,0,0,.25)}
.toggle.on .sw{background:var(--verde)}
.toggle.on .sw::after{left:23px}
.toggle:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:999px}

.hint{margin-top:14px}
.btn-go{position:relative;background:var(--verde);color:#fff;font-family:var(--font-display);font-weight:800;
  font-size:clamp(19px,2.2vw,24px);letter-spacing:.02em;text-transform:uppercase;padding:18px 24px;border-radius:var(--r-md);
  box-shadow:0 14px 32px -12px rgba(0,177,89,.6);display:flex;align-items:center;justify-content:center;gap:12px;
  transition:transform .25s var(--ease-out),box-shadow .25s,filter .2s}
.btn-go:hover{transform:translateY(-3px);box-shadow:0 20px 44px -12px rgba(0,177,89,.7)}
.btn-go:active{transform:translateY(0) scale(.99)}
.btn-go:disabled{background:var(--line-strong);color:#fff;cursor:not-allowed;box-shadow:none;transform:none}
.btn-go .ic{font-size:1.05em}
.hint{color:var(--ink-dim);font-size:12.5px;text-align:center}
kbd{font-family:var(--font-ui);font-weight:600;background:var(--surface);border:1px solid var(--line-strong);border-bottom-width:2px;border-radius:6px;padding:1px 7px;font-size:12px;color:var(--ink-soft)}

/* ============================ BRIEFING ============================ */
#scr-brief{justify-content:flex-start}
#scr-brief::before, #scr-brief::after{content:""; flex:1; min-height:0}
#scr-brief .wrap{margin:0 auto; flex:none; max-width:1600px; width:100%; padding: 0 24px}
.brief-card{width:95%;max-width:1600px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);
  padding:clamp(22px,3.4vw,40px);position:relative;overflow:hidden;box-shadow:0 20px 50px -28px rgba(20,40,70,.5)}
.brief-card::before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:linear-gradient(90deg,var(--accent),transparent)}
.case-kicker{display:inline-flex;align-items:center;gap:9px;color:var(--accent);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:13px;margin-bottom:16px}
.case-kicker .dot{width:9px;height:9px;border-radius:50%;background:var(--accent);animation:beacon 1.6s infinite}
@keyframes beacon{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 60%,transparent)}70%{box-shadow:0 0 0 13px transparent}100%{box-shadow:0 0 0 0 transparent}}
.brief-head{display:grid;grid-template-columns:minmax(400px,720px) 1fr;gap:36px;align-items:center}
.brief-art{background:linear-gradient(165deg,var(--accent-soft),var(--surface-2));border:1px solid var(--line);border-radius:var(--r-lg);padding:8px;aspect-ratio:3/2;overflow:hidden}
.brief-art .illus-svg{width:100%;height:100%}
.brief-art img{width:100%;height:100%;object-fit:cover;border-radius:calc(var(--r-lg) - 8px);display:block}
.brief-copy h2{font-family:var(--font-display);font-weight:800;font-size:clamp(28px,4.4vw,46px);line-height:1;text-transform:uppercase;letter-spacing:-.01em;color:var(--ink)}
.brief-scene{color:var(--ink-soft);font-size:clamp(15px,1.7vw,18px);line-height:1.55;margin-top:14px;text-wrap:pretty}
.vitals-row{display:flex;flex-wrap:wrap;gap:8px;margin:22px 0 4px}
.vchip{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:10px 12px;flex:1 1 auto;min-width:0;white-space:nowrap}
.vchip .ic{font-size:21px;color:var(--accent)}
.vchip .k{font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-dim)}
.vchip .v{font-family:var(--font-display);font-weight:700;font-size:19px;line-height:1;color:var(--ink)}

/* ============================ GAME / SIM ============================ */
#scr-game{padding:0;overflow:hidden}
.sim{flex:1;display:flex;flex-direction:column;min-height:0;padding:clamp(12px,1.8vw,20px);gap:clamp(12px,1.6vw,16px)}

/* top bar */
.sim-top{display:flex;align-items:center;gap:16px}
.scn-id{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:700;font-size:clamp(15px,1.8vw,21px);text-transform:uppercase;letter-spacing:.01em;color:var(--ink);min-width:0}
.scn-id .ic{font-size:1.35em;color:var(--accent)}
.scn-id .t{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.clockwrap{margin-left:auto;margin-right:auto;display:flex;flex-direction:column;align-items:center;line-height:1;position:relative}
.clockwrap .cap{display:flex;align-items:center;gap:7px;color:var(--ink-dim);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:11px}
.clockwrap .cap .ic{font-size:14px}
.clock{font-family:var(--font-display);font-weight:800;font-variant-numeric:tabular-nums;line-height:.92;
  font-size:clamp(40px,6.4vw,76px);letter-spacing:.01em;color:var(--verde-ink);transition:color .4s}
.clock.warn{color:var(--amarillo-ink)}
.clock.crit{color:var(--rojo-ink);animation:clockCrit .9s steps(2) infinite}
@keyframes clockCrit{50%{opacity:.5}}
.clock.tick{animation:clockTick .4s var(--ease-out)}
@keyframes clockTick{0%{transform:scale(1)}30%{transform:scale(1.04)}100%{transform:scale(1)}}
.delta{position:absolute;left:50%;top:100%;font-family:var(--font-display);font-weight:800;font-size:20px;opacity:0;pointer-events:none;transform:translateX(-50%)}
.delta.plus{color:var(--verde-ink)}.delta.minus{color:var(--rojo-ink)}
.delta.show{animation:deltaFloat 1.2s var(--ease-out)}
@keyframes deltaFloat{0%{opacity:0;transform:translate(-50%,6px)}15%{opacity:1}100%{opacity:0;transform:translate(-50%,-22px)}}
.deltawrap{position:relative;height:0;width:0;align-self:center}
.icon-btn{width:42px;height:42px;border-radius:12px;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink-soft);display:grid;place-items:center;font-size:20px;transition:.2s;flex:none}
.icon-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}

/* body grid */
.sim-body{flex:1;display:grid;grid-template-columns:minmax(320px,38%) 1fr;gap:clamp(12px,1.6vw,16px);min-height:0}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:0 6px 18px -16px rgba(20,40,70,.4)}

/* left: map + vitals */
.sim-left{display:grid;grid-template-rows:1fr auto;gap:clamp(12px,1.6vw,16px);min-height:0}
.map-panel{position:relative;overflow:hidden;display:flex;flex-direction:column;min-height:0}
.map-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 8px;flex:none}
.map-head .ttl{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:14px;color:var(--ink-soft);display:flex;align-items:center;gap:8px}
.map-head .ttl .ic{color:var(--accent);font-size:17px}
.map-head .ph{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--accent);font-variant-numeric:tabular-nums}
.map-stage{position:relative;flex:1;min-height:0}
#map{position:absolute;inset:0;width:100%;height:100%;display:block}
.map-legend{display:flex;gap:14px;justify-content:center;padding:8px 12px 12px;flex:none;flex-wrap:wrap}
.lg{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--ink-soft);font-weight:500}
.lg .d{width:10px;height:10px;border-radius:50%}
.lg.done .d{background:var(--verde)} .lg.now .d{background:#1f7fd6} .lg.todo .d{background:#9aa9bb} .lg.hosp .d{background:var(--rojo)}

.vitals-panel{display:flex;align-items:center;gap:14px;padding:12px 16px}
.vstat{display:flex;flex-direction:column;line-height:1;flex:none}
.vstat .k{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-dim)}
.vstat .v{font-family:var(--font-display);font-weight:800;font-size:24px;color:var(--ink);font-variant-numeric:tabular-nums}
.vstat .v.fc{color:var(--rojo-ink)} .vstat .v.spo{color:var(--azul-ink)}
.ecg-wrap{flex:1;min-width:0;height:54px;position:relative;background:#0c1622;border-radius:10px;overflow:hidden;border:1px solid var(--line)}
#ecg{position:absolute;inset:0;width:100%;height:100%}
.vstate{flex:none;font-weight:600;font-size:13px;color:var(--ink-soft);min-width:84px;text-align:right}
body.state-danger .vstate{color:var(--rojo-ink)}

/* right: scene + question + options */
.sim-right{display:flex;flex-direction:column;gap:clamp(12px,1.5vw,16px);min-height:0}
.case-banner{display:grid;grid-template-columns:minmax(160px,30%) 1fr;gap:18px;align-items:center;padding:14px 18px}
.banner-art{background:linear-gradient(165deg,var(--accent-soft),var(--surface-2));border:1px solid var(--line);border-radius:var(--r-md);padding:6px;aspect-ratio:3/2;overflow:hidden}
.banner-art .illus-svg{width:100%;height:100%}
.phase-tag{display:inline-flex;align-items:center;gap:11px;color:var(--accent);font-weight:700;letter-spacing:.03em;text-transform:uppercase;font-size:clamp(15px,2vw,22px);line-height:1.2}
.phase-tag .pn{font-family:var(--font-display);font-weight:800;background:var(--accent);color:#fff;width:32px;height:32px;border-radius:9px;display:grid;place-items:center;font-size:19px;flex:none}
.question{font-family:var(--font-display);font-weight:700;font-size:clamp(22px,3vw,36px);line-height:1.08;letter-spacing:-.01em;color:var(--ink);text-wrap:balance;padding:0 2px}

.options{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(11px,1.3vw,16px);flex:1;align-content:stretch;min-height:0}
.opt{position:relative;text-align:left;background:var(--surface);border:1.5px solid var(--line-strong);border-radius:var(--r-md);
  padding:16px 20px;display:flex;align-items:center;gap:17px;font-size:clamp(16px,1.95vw,22px);line-height:1.3;color:var(--ink);
  box-shadow:0 4px 14px -12px rgba(20,40,70,.5);transition:transform .18s var(--ease-out),border-color .18s,background .18s,box-shadow .18s}
.opt .key{flex:none;width:46px;height:46px;border-radius:12px;background:var(--surface-2);border:1px solid var(--line-strong);
  font-family:var(--font-display);font-weight:800;font-size:25px;display:grid;place-items:center;color:var(--ink-soft);transition:.18s}
.opt .txt{flex:1;font-weight:500}
.opt .res{flex:none;font-size:27px;width:27px;display:flex;align-items:center;justify-content:center;color:transparent}
.opt:not(:disabled):hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 12px 26px -16px var(--accent-soft)}
.opt:not(:disabled):hover .key{background:var(--accent);color:#fff;border-color:var(--accent)}
.opt:focus-visible{outline:3px solid var(--accent);outline-offset:2px}
.opt.correct{border-color:var(--verde);background:color-mix(in srgb,var(--verde) 12%,var(--surface));box-shadow:0 0 0 1.5px var(--verde),0 14px 30px -18px rgba(0,177,89,.7)}
.opt.correct .key{background:var(--verde);color:#fff;border-color:var(--verde)}
.opt.correct .res{color:var(--verde-ink)}
.opt.wrong{border-color:var(--rojo);background:color-mix(in srgb,var(--rojo) 9%,var(--surface))}
.opt.wrong .key{background:var(--rojo);color:#fff;border-color:var(--rojo)}
.opt.wrong .res{color:var(--rojo-ink)}
.opt.wrong .txt{text-decoration:line-through;text-decoration-color:color-mix(in srgb,var(--rojo) 60%,transparent);color:var(--ink-soft)}
.opt:disabled{cursor:default}
.opt.locked:not(.correct):not(.wrong){opacity:.55}
.opt.shaking{animation:optShake .42s}
@keyframes optShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(7px)}60%{transform:translateX(-4px)}80%{transform:translateX(3px)}}

/* feedback en area reservada (sin reflow) */
.feedback-slot{min-height:64px;display:flex;align-items:center;gap:14px;border-radius:var(--r-md);padding:0 4px;opacity:0;transition:opacity .25s}
.feedback-slot.show{opacity:1;background:color-mix(in srgb,var(--rojo) 8%,var(--surface));border:1px solid color-mix(in srgb,var(--rojo) 40%,transparent);padding:12px 16px;animation:fbIn .35s var(--ease-out)}
@keyframes fbIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.feedback-slot .ic{font-size:25px;color:var(--rojo-ink);flex:none}
.feedback-slot .fb-k{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--rojo-ink);font-size:14px}
.feedback-slot .fb-t{color:var(--ink);font-size:clamp(13.5px,1.5vw,16px);line-height:1.4;margin-top:2px}

/* ============================ END ============================ */
.end{text-align:center;justify-content:flex-start}
.end::before, .end::after{content:""; flex:1; min-height:0}
.end .wrap{margin:0 auto; flex:none}
.end-icon{font-size:clamp(56px,10vw,108px);line-height:1}
#scr-win .end-icon{color:var(--verde)}
#scr-lose .end-icon{color:var(--rojo)}
.end h1{font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:-.01em;font-size:clamp(42px,9vw,98px);line-height:.92;margin-top:6px}
#scr-win h1{color:var(--verde-ink)} #scr-lose h1{color:var(--rojo-ink)}
.end .verdict{color:var(--ink-soft);font-size:clamp(15px,1.9vw,20px);max-width:62ch;margin:14px auto 0;line-height:1.55;text-wrap:pretty}
.end .verdict b{color:var(--ink);font-weight:600}
.stats{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin:28px 0}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 26px;min-width:150px;box-shadow:0 8px 22px -18px rgba(20,40,70,.5)}
.stat .sv{font-family:var(--font-display);font-weight:800;font-size:clamp(30px,5vw,46px);line-height:1;font-variant-numeric:tabular-nums}
.stat .sk{color:var(--ink-dim);font-size:12px;letter-spacing:.09em;text-transform:uppercase;margin-top:8px;display:flex;align-items:center;gap:7px;justify-content:center}
.stat.good .sv{color:var(--verde-ink)} .stat.warn .sv{color:var(--amarillo-ink)} .stat.bad .sv{color:var(--rojo-ink)} .stat.neutral .sv{color:var(--ink)}
.end-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.btn-ghost{background:var(--surface);border:1px solid var(--line-strong);color:var(--ink);font-family:var(--font-display);font-weight:700;font-size:clamp(16px,2vw,20px);text-transform:uppercase;letter-spacing:.02em;padding:15px 26px;border-radius:var(--r-md);display:inline-flex;align-items:center;gap:11px;transition:.22s var(--ease-out)}
.btn-ghost:hover{transform:translateY(-3px);border-color:var(--accent);background:var(--accent-soft)}
.btn-ghost.primary{background:var(--verde);color:#fff;border:none;box-shadow:0 14px 32px -14px rgba(0,177,89,.6)}
#scr-lose .btn-ghost.primary{background:var(--rojo);box-shadow:0 14px 32px -14px rgba(255,25,25,.6)}

/* ============================ FX / TOAST ============================ */
#flash{position:fixed;inset:0;z-index:var(--z-flash);pointer-events:none;opacity:0}
#flash.f-good{animation:flashGood .6s var(--ease-out)}
#flash.f-bad{animation:flashBad .55s var(--ease-out)}
@keyframes flashGood{0%{opacity:0;background:radial-gradient(circle at 50% 50%,rgba(0,177,89,.4),transparent 70%)}25%{opacity:1}100%{opacity:0;background:radial-gradient(circle at 50% 50%,rgba(0,177,89,.4),transparent 120%)}}
@keyframes flashBad{0%{opacity:0;background:rgba(255,25,25,.32)}12%{opacity:1}100%{opacity:0;background:rgba(255,25,25,0)}}
#fx-canvas{position:fixed;inset:0;z-index:var(--z-toast);pointer-events:none}
#app.shake{animation:appShake .42s}
@keyframes appShake{0%,100%{transform:translate(0,0)}20%{transform:translate(-6px,3px)}40%{transform:translate(5px,-3px)}60%{transform:translate(-3px,2px)}80%{transform:translate(3px,-2px)}}

#toast{position:fixed;left:50%;bottom:22px;transform:translateX(-50%);z-index:var(--z-toast);background:var(--ink);color:#fff;
  border-radius:999px;padding:11px 22px;font-size:14px;display:flex;align-items:center;gap:9px;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;box-shadow:0 12px 30px -12px rgba(0,0,0,.5)}
#toast.show{opacity:.96;transform:translate(-50%,-4px)}
#toast .ic{font-size:17px;color:var(--amarillo)}

/* ============================ ART (ilustraciones) ============================ */
.art .ac{fill:var(--art-accent)}
.art .ack{stroke:var(--art-accent);fill:none}
.art .ink{fill:#2a3a4d}
.art .inks{stroke:#2a3a4d;fill:none}
.art .sf{fill:#d4deea}
.art .wh{fill:#ffffff}
.art .ln{stroke:#2a3a4d;fill:none}
.art .ln2{stroke:#c2cedd;fill:none;stroke-width:3}
.art .floor{fill:rgba(20,32,46,.07)}
.art .ac-t{fill:var(--art-accent)}
.art .wh-t{fill:#ffffff}
.illus-svg{display:block}

/* ============================ responsive ============================ */
@media (max-width:1040px){
  .sim-body{grid-template-columns:1fr;grid-template-rows:minmax(220px,34%) 1fr}
  .sim-left{grid-template-rows:1fr auto}
  .case-banner{grid-template-columns:minmax(130px,34%) 1fr;gap:14px}
}
@media (max-width:720px){
  .options{grid-template-columns:1fr}
  .scn-id .t{display:none}
  .clockwrap .clock{font-size:42px}
  .brief-head{grid-template-columns:1fr}
  .vitals-panel{flex-wrap:wrap}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.1s !important}
  .screen.enter{animation:none}
  .clock.crit{animation:none}
}

/* ============================ MODAL ============================ */
.modal-backdrop{position:fixed;inset:0;z-index:999;background:rgba(20,32,46,.7);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s var(--ease-out);backdrop-filter:blur(4px)}
.modal-backdrop.show{opacity:1;pointer-events:auto}
.modal{background:var(--surface);border-radius:var(--r-xl);padding:32px;max-width:440px;width:90%;box-shadow:0 24px 50px -16px rgba(10,20,30,.6);transform:translateY(20px) scale(.95);transition:transform .3s var(--ease-out)}
.modal-backdrop.show .modal{transform:translateY(0) scale(1)}
.modal h2{font-family:var(--font-display);font-size:28px;color:var(--ink);margin-bottom:12px;line-height:1.1}
.modal p{color:var(--ink-soft);font-size:15px;line-height:1.5;margin-bottom:28px}
.modal-actions{display:flex;gap:12px;justify-content:flex-end}
.modal-actions .btn-ghost{padding:12px 20px;font-size:16px}
