/* ============================================================
   landing.css — Vendópolis · tela de apresentação (pitch)
   Builds on pixel-kit.css. Three scrollable directions share
   these section primitives; per-direction modifiers below.
   ============================================================ */

/* ---- Page shell (replaces .px-app for a TALL scrollable frame) ---- */
.lp{
  position:relative;
  width:100%;
  min-height:100%;
  font-family:var(--font-ui);
  color:var(--text);
  background:
    radial-gradient(140% 60% at 50% -8%, #103033 0%, var(--bg0) 48%),
    var(--bg0);
  letter-spacing:.2px;
  overflow:hidden;            /* contain decorative bleed; page itself is the scroll host */
}
.lp::before{ /* scanlines across the whole tall page */
  content:"";position:absolute;inset:0;pointer-events:none;z-index:60;
  background:repeating-linear-gradient(0deg, rgba(0,0,0,.16) 0 2px, rgba(0,0,0,0) 2px 4px);
  mix-blend-mode:multiply;opacity:.5;
}
.lp img{image-rendering:pixelated;}

/* ---- Layout primitives ---- */
.lp-wrap{max-width:1200px;margin:0 auto;padding:0 56px;position:relative;z-index:2;}
.lp-wrap.tight{max-width:1040px;}
html{scroll-behavior:smooth;}
.lp-section{position:relative;padding:84px 0;scroll-margin-top:72px;}
.lp-section.pad-sm{padding:60px 0;}
.lp-band{background:var(--bg1);border-top:4px solid var(--line);border-bottom:4px solid var(--line);
  box-shadow:inset 0 18px 40px rgba(0,0,0,.35);}
.lp-band.sunk{background:#071917;}

/* section heading block */
.lp-kicker{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.18em;font-size:12px;
  color:var(--accent);display:inline-flex;align-items:center;gap:9px;margin-bottom:16px;}
.lp-kicker::before{content:"";width:22px;height:0;border-top:3px solid var(--accent);}
.lp-h2{font-family:var(--font-display);font-size:26px;line-height:1.45;letter-spacing:0;margin:0 0 14px;
  color:var(--text);}
.lp-h2 .hl{color:var(--accent);}
.lp-lead{font-size:18px;line-height:1.7;color:var(--muted);max-width:62ch;margin:0;}
.lp-lead b{color:var(--text);font-weight:600;}

/* eyebrow chip */
.lp-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 12px 7px;background:var(--bg0);
  border:2px solid var(--line);box-shadow:inset 0 0 0 1px var(--bevel-soft);font-size:12.5px;
  font-family:var(--font-tag);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);}
.lp-chip .px-dot{box-shadow:0 0 0 2px var(--line),0 0 8px currentColor;}

/* ===========================================================
   HERO (shared scaffold; directions restyle .lp-hero.dirX)
   =========================================================== */
.lp-hero{position:relative;overflow:hidden;border-bottom:4px solid var(--line);}
.lp-logo{font-family:var(--font-display);line-height:.96;letter-spacing:0;margin:0;
  text-shadow:0 4px 0 var(--line),0 0 26px color-mix(in srgb,var(--accent) 45%,transparent);}
.lp-logo .a{color:var(--accent);}
.lp-logo .b{color:var(--text);}
.lp-sub{font-size:20px;line-height:1.6;color:var(--text);max-width:48ch;}
.lp-sub b{color:var(--accent);}
.lp-by{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-tag);
  text-transform:uppercase;letter-spacing:.2em;font-size:12px;color:var(--muted);}
.lp-by .logo-o{width:22px;height:22px;}

.lp-cta-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.lp-cta-row > *{flex:0 0 auto;}
.lp-cta-row .px-btn{min-width:max-content;}
a.px-btn{text-decoration:none;}
.px-btn.lg{font-size:18px;padding:13px 24px 15px;box-shadow:inset 2px 2px 0 rgba(255,255,255,.45),
  inset -3px -3px 0 rgba(0,0,0,.28),5px 5px 0 0 var(--line);}

/* trust stat trio under hero */
.lp-trust{display:flex;gap:0;border:3px solid var(--line);background:var(--bg0);
  box-shadow:inset 0 0 0 2px var(--bevel-soft),5px 5px 0 rgba(0,0,0,.45);width:max-content;max-width:100%;}
.lp-trust .cell{padding:14px 22px;border-right:3px solid var(--line);text-align:center;}
.lp-trust .cell:last-child{border-right:0;}
.lp-trust .big{font-family:var(--font-display);font-size:22px;color:var(--accent);line-height:1;}
.lp-trust .lbl{font-size:12.5px;color:var(--muted);margin-top:7px;font-family:var(--font-tag);
  text-transform:uppercase;letter-spacing:.1em;}

/* ===========================================================
   SUMMARY — "o que é" stat cards
   =========================================================== */
.lp-grid{display:grid;gap:18px;}
.lp-grid.c4{grid-template-columns:repeat(4,1fr);}
.lp-grid.c3{grid-template-columns:repeat(3,1fr);}
.lp-grid.c2{grid-template-columns:repeat(2,1fr);}

.lp-stat{padding:22px;display:flex;flex-direction:column;gap:8px;}
/* "o jogo" — 2 stats grandes (mais impacto) */
.ar-summary{max-width:780px;margin-left:auto;margin-right:auto;}
.ar-bigstat{align-items:center;text-align:center;gap:10px;padding:34px 26px;}
.ar-bigstat .num{font-size:62px;line-height:1;}
.ar-bigstat .ttl{font-size:14px;letter-spacing:.04em;text-transform:uppercase;font-family:var(--font-tag);color:var(--accent);max-width:9ch;margin:0 auto;}
.ar-bigstat .desc{max-width:32ch;}
.lp-stat .num{font-family:var(--font-display);font-size:30px;line-height:1;color:var(--accent);}
.lp-stat .ttl{font-weight:700;font-size:16px;}
.lp-stat .desc{font-size:14px;line-height:1.6;color:var(--muted);}
.lp-stat .ic{margin-bottom:4px;}

/* ===========================================================
   ROLES — narrador / líder / jogador
   =========================================================== */
.lp-role{padding:0;overflow:hidden;display:flex;flex-direction:column;}
.lp-role .cap{height:96px;position:relative;overflow:hidden;border-bottom:3px solid var(--line);
  background:linear-gradient(160deg,color-mix(in srgb,var(--accent) 24%,var(--bg2)),var(--bg1));
  display:flex;align-items:center;justify-content:center;}
.lp-role .bd{padding:18px;display:flex;flex-direction:column;gap:10px;flex:1;}
.lp-role .name{font-family:var(--font-display);font-size:13px;color:var(--text);}
.lp-role .tagline{font-size:13px;color:var(--accent);font-weight:600;}
.lp-role .desc{font-size:14px;line-height:1.65;color:var(--muted);}
.lp-role .foot{margin-top:auto;padding-top:10px;border-top:2px dashed #123238;display:flex;
  align-items:center;gap:8px;font-size:12.5px;color:var(--muted);}
/* OS PRÉDIOS DA CIDADE — faixa de fora a fora (ex-Banca) */
.lp-predios{display:flex;flex-direction:column;gap:14px;padding:18px 20px;}
.lp-predios-hd{display:flex;align-items:center;gap:12px;}
.lp-predios-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.lp-predio{border:2px solid var(--line);background:var(--bg0);box-shadow:inset 0 -4px 0 var(--bc);
  padding:14px;display:flex;flex-direction:column;gap:9px;}
.lp-predio-ic{width:42px;height:42px;display:grid;place-items:center;border:2px solid var(--line);
  background:radial-gradient(120% 120% at 50% 0%,color-mix(in srgb,var(--bc) 34%,var(--bg0)),var(--bg0));}
.lp-predio-nm{font-family:var(--font-display);font-size:12px;color:var(--bc);}
.lp-predio-tx{margin:0;font-size:13px;line-height:1.55;color:var(--muted);}
.lp-predios-note{margin:0;font-size:13.5px;line-height:1.65;color:var(--muted);
  border-top:2px dashed #123238;padding-top:13px;}
@media (max-width:880px){.lp-predios-grid{grid-template-columns:repeat(2,1fr);}}

/* ===========================================================
   ENERGY & VENDAIS — split explainer
   =========================================================== */
.lp-split{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.lp-econcard{padding:24px;display:flex;flex-direction:column;gap:14px;}
.lp-econcard .top{display:flex;align-items:center;gap:14px;}
.lp-econcard .glyph{width:58px;height:58px;display:grid;place-items:center;background:var(--bg0);
  border:3px solid var(--line);box-shadow:inset 0 0 0 2px var(--bevel-soft);flex:0 0 auto;}
.lp-econcard h3{font-family:var(--font-display);font-size:15px;margin:0;color:var(--accent);}
.lp-econcard .k{font-size:12px;font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.12em;
  color:var(--muted);margin-top:5px;}
.lp-econcard p{font-size:14.5px;line-height:1.7;color:var(--muted);margin:0;}
.lp-econcard p b{color:var(--text);font-weight:600;}

/* the "hidden info" call-out */
.lp-callout{display:flex;gap:16px;align-items:flex-start;padding:20px 22px;background:#071917;
  border:3px solid var(--line);box-shadow:inset 0 0 0 2px var(--bevel-soft),5px 5px 0 rgba(0,0,0,.4);}
.lp-callout .mark{font-family:var(--font-display);font-size:26px;color:var(--orange);flex:0 0 auto;
  line-height:1;margin-top:2px;}
.lp-callout .tx h4{margin:0 0 6px;font-family:var(--font-display);font-size:13px;color:var(--text);}
.lp-callout .tx p{margin:0;font-size:14.5px;line-height:1.7;color:var(--muted);}

/* ===========================================================
   NINE LINES — faturamento ladder
   =========================================================== */
.lp-ladder{display:flex;flex-direction:column-reverse;gap:5px;}
.lp-rung{display:grid;grid-template-columns:46px 1fr auto;align-items:center;gap:16px;
  padding:11px 16px;border:3px solid var(--line);background:var(--bg1);
  box-shadow:inset 0 0 0 2px rgba(31,80,87,.4);position:relative;}
.lp-rung .ln{font-family:var(--font-display);font-size:14px;color:var(--muted);}
.lp-rung .fill{height:13px;background:var(--tcol);box-shadow:inset 0 2px 0 rgba(255,255,255,.35),
  inset 0 -2px 0 rgba(0,0,0,.25);border:2px solid var(--line);}
.lp-rung .val{font-family:var(--font-display);font-size:14px;color:var(--text);white-space:nowrap;
  font-variant-numeric:tabular-nums;}
.lp-rung[data-tier]:hover{transform:translateX(3px);}
.lp-tierhead{display:flex;align-items:center;gap:10px;margin:0 0 10px;}
.lp-tierhead .sw{width:15px;height:15px;border:2px solid var(--line);background:var(--tcol);}
.lp-tierhead .nm{font-family:var(--font-display);font-size:12px;}
.lp-tierhead .meta{font-size:13px;color:var(--muted);}
.lp-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.lp-tiercard{padding:18px;}

/* nine-lines reach matrix — todos os níveis × teto (limitador) */
.lines-matrix{display:grid;grid-template-columns:minmax(160px,1.3fr) repeat(3,1fr);gap:6px;
  border:3px solid var(--line);background:var(--bg0);padding:14px;
  box-shadow:inset 0 0 0 2px var(--bevel-soft),6px 6px 0 rgba(0,0,0,.4);}
.lm-corner{display:flex;align-items:flex-end;padding:0 8px 8px;font-family:var(--font-tag);
  text-transform:uppercase;letter-spacing:.1em;font-size:10px;color:var(--dim);}
.lm-head{display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--bg1);
  border:2px solid var(--line);box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--lc) 22%,transparent);}
.lm-head .sw{width:13px;height:13px;border:2px solid var(--line);flex:0 0 auto;}
.lm-head .nm{font-family:var(--font-display);font-size:12px;color:var(--lc);}
.lm-head .rg{margin-left:auto;font-family:var(--font-tag);font-size:10px;letter-spacing:.05em;color:var(--muted);}
.lm-line{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 12px;min-height:40px;
  background:var(--bg1);border:2px solid var(--line);}
.lm-line .ln{font-family:var(--font-display);font-size:13px;color:var(--text);}
.lm-line .val{font-family:var(--font-display);font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums;}
.lm-cell{position:relative;min-height:40px;border:2px solid var(--line);background:#0a1614;
  display:grid;place-items:center;}
.lm-cell:not(.on){opacity:.42;}
.lm-cell.on{background:color-mix(in srgb,var(--lc) 28%,#0a1614);
  box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--lc) 40%,transparent);}
.lm-cell.cap{box-shadow:inset 0 4px 0 0 var(--lc),inset 0 0 0 2px color-mix(in srgb,var(--lc) 50%,transparent);}
.lm-cell .teto{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.08em;font-size:9px;
  color:var(--lc);background:var(--bg0);border:2px solid var(--lc);padding:2px 6px 3px;}
.lm-note{margin:12px 2px 0;font-size:13.5px;line-height:1.65;color:var(--muted);}
.lm-note b{color:var(--text);font-weight:600;}

/* ===========================================================
   ROUND CYCLE — 4 steps
   =========================================================== */
.lp-cycle{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:3px solid var(--line);
  background:var(--bg0);box-shadow:inset 0 0 0 2px var(--bevel-soft),6px 6px 0 rgba(0,0,0,.4);}
.lp-step{padding:22px 20px;border-right:3px solid var(--line);position:relative;
  display:flex;flex-direction:column;gap:10px;}
.lp-step:last-child{border-right:0;}
.lp-step .no{font-family:var(--font-display);font-size:13px;color:var(--accent);
  display:flex;align-items:center;gap:8px;}
.lp-step .no .dot{width:9px;height:9px;background:var(--accent);box-shadow:0 0 0 2px var(--line);}
.lp-step h4{margin:0;font-family:var(--font-display);font-size:13px;color:var(--text);line-height:1.5;}
.lp-step p{margin:0;font-size:13.5px;line-height:1.65;color:var(--muted);}
.lp-step .arrow{position:absolute;right:-12px;top:50%;transform:translateY(-50%);z-index:3;
  width:20px;height:20px;background:var(--bg2);border:3px solid var(--line);
  display:grid;place-items:center;color:var(--accent);font-size:11px;}
.lp-step:last-child .arrow{display:none;}

/* loop variant (direction C board) */
.lp-loop{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.lp-loop .lp-step{border:3px solid var(--line);background:var(--bg1);
  box-shadow:5px 5px 0 rgba(0,0,0,.4);}

/* ===========================================================
   COURSES & CERTIFICATES
   =========================================================== */
.lp-courses{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.lp-course{padding:14px;display:flex;flex-direction:column;gap:9px;position:relative;}
.lp-course .ord{position:absolute;right:10px;top:10px;font-family:var(--font-display);
  font-size:11px;color:var(--dim);}
.lp-course .nm{font-weight:700;font-size:14px;line-height:1.3;padding-right:18px;}
.lp-course .ef{font-size:12.5px;line-height:1.55;color:var(--muted);}
.lp-course .cost{display:flex;align-items:center;gap:8px;margin-top:auto;padding-top:9px;
  border-top:2px dashed #123238;}

.lp-certs{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.lp-cert{padding:22px;display:flex;gap:18px;align-items:flex-start;}
.lp-cert .seal{width:72px;height:72px;flex:0 0 auto;display:grid;place-items:center;
  background:var(--bg0);border:3px solid var(--line);
  box-shadow:inset 0 0 0 2px var(--accent),inset 0 0 18px color-mix(in srgb,var(--accent) 35%,transparent);}
.lp-cert .seal .px-display{font-size:11px;color:var(--accent);text-align:center;line-height:1.5;}
.lp-cert h4{margin:0 0 4px;font-family:var(--font-display);font-size:13px;color:var(--text);}
.lp-cert .req{font-size:12px;color:var(--accent);font-family:var(--font-tag);letter-spacing:.08em;
  text-transform:uppercase;margin-bottom:9px;}
.lp-cert p{margin:0;font-size:14px;line-height:1.65;color:var(--muted);}

/* ===========================================================
   CLOSING CTA
   =========================================================== */
.lp-close{text-align:center;position:relative;overflow:hidden;border-top:4px solid var(--line);}
.lp-close .lp-logo{margin-bottom:22px;}
.lp-close h2{font-family:var(--font-display);font-size:28px;line-height:1.5;margin:0 auto 18px;
  max-width:22ch;}
.lp-close .sub{font-size:18px;color:var(--muted);max-width:54ch;margin:0 auto 30px;line-height:1.7;}
.lp-foot{border-top:3px solid var(--line);padding:26px 0;display:flex;align-items:center;
  justify-content:space-between;gap:20px;flex-wrap:wrap;}
.lp-foot .px-tag{font-size:11px;}

/* ===========================================================
   DIRECTION B — "Sala de Treinamento" (dossier helpers)
   =========================================================== */
.lp-heroB{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center;
  padding:64px 0 72px;}
.lp-screen{position:relative;height:420px;border:4px solid var(--line);background:var(--bg0);
  box-shadow:inset 0 0 0 3px var(--bevel),6px 6px 0 rgba(0,0,0,.5);overflow:hidden;}
.lp-screen .scanbar{position:absolute;left:0;right:0;top:0;height:30px;z-index:4;
  background:linear-gradient(var(--bg2),var(--bg1));border-bottom:3px solid var(--line);
  display:flex;align-items:center;gap:7px;padding:0 11px;}
.lp-screen .scanbar .lt{width:11px;height:11px;border:2px solid var(--line);}
.lp-screen .room{position:absolute;inset:30px 0 0 0;}
.lp-credbar{display:flex;align-items:stretch;border-top:4px solid var(--line);
  border-bottom:4px solid var(--line);background:var(--bg1);}
.lp-credbar .c{flex:1;display:flex;align-items:center;gap:12px;padding:18px 24px;
  border-right:3px solid var(--line);font-size:14.5px;color:var(--muted);}
.lp-credbar .c:last-child{border-right:0;}
.lp-credbar .c b{color:var(--text);font-weight:600;}

/* spec-row: sticky-ish label column + content (dossier rhythm) */
.lp-row{display:grid;grid-template-columns:300px 1fr;gap:40px;align-items:start;}
.lp-row .lab{position:relative;}
.lp-row .lab .num{font-family:var(--font-display);font-size:34px;color:var(--bevel);line-height:1;
  margin-bottom:14px;}
.lp-rowsep{height:0;border-top:3px dashed #123238;margin:0;}

/* ===========================================================
   DIRECTION C — "Tabuleiro" (board helpers)
   =========================================================== */
.lp-heroC{position:relative;text-align:center;padding:72px 0 64px;}
.lp-board{position:relative;border:4px solid var(--line);background:#0c2620;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:32px 32px;
  box-shadow:inset 0 0 0 3px var(--bevel-soft),inset 0 0 80px 20px rgba(0,0,0,.45),8px 8px 0 rgba(0,0,0,.45);
  padding:30px;}
.lp-token{display:inline-grid;place-items:center;width:40px;height:40px;background:var(--accent);
  border:3px solid var(--line);box-shadow:inset 2px 2px 0 rgba(255,255,255,.4),inset -2px -2px 0 rgba(0,0,0,.3);
  font-family:var(--font-display);font-size:13px;color:#04201c;}

/* ===========================================================
   PIXEL SCENES (built in landingScene.jsx)
   =========================================================== */
/* city skyline */
.sky{position:absolute;left:0;right:0;bottom:0;height:300px;pointer-events:none;}
.sky .bld{position:absolute;bottom:0;background:var(--bg2);border:3px solid var(--line);
  border-bottom:0;box-shadow:inset 2px 0 0 rgba(255,255,255,.04),inset -3px 0 0 rgba(0,0,0,.4);}
.sky .bld .win{position:absolute;width:10px;height:12px;background:#0c2226;
  box-shadow:0 0 0 1px rgba(0,0,0,.4);}
.sky .bld .win.lit{background:var(--litc);box-shadow:0 0 6px var(--litc),0 0 0 1px rgba(0,0,0,.4);}
.sky .street{position:absolute;left:0;right:0;bottom:0;height:14px;background:var(--line);}

/* floor / room scene */
.room{position:relative;width:100%;height:100%;overflow:hidden;
  background:url(assets/sprites/floor.png);background-size:84px 84px;image-rendering:pixelated;
  box-shadow:inset 0 0 90px 24px rgba(0,0,0,.5);}
.room .rwall{position:absolute;inset:0 0 auto 0;height:46%;
  background:url(assets/sprites/wall2.png);background-size:108px 108px;image-rendering:pixelated;
  border-bottom:6px solid var(--wood-dark);box-shadow:0 6px 0 rgba(0,0,0,.35),inset 0 -10px 18px rgba(0,0,0,.3);}
.room .desk{position:absolute;}

/* bobbing character (avatar block + name plate) */
.lp-char{display:flex;flex-direction:column;align-items:center;gap:8px;}
.lp-char .px-ava{animation:px-bob 2.4s steps(3) infinite;}
.lp-char .plate{font-size:12px;font-weight:700;background:var(--bg0);padding:2px 8px;
  border:2px solid var(--line);white-space:nowrap;}

/* coin scatter / decorative */
@keyframes lp-bob2{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.lp-float{animation:lp-bob2 2.8s steps(4) infinite;}

/* ===========================================================
   HOME · PROPOSTA Merion × VendaMais
   =========================================================== */

/* --- top nav --- */
.hm-nav{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:16px;color:var(--text);
  padding:14px 56px;background:color-mix(in srgb,var(--bg0) 88%,transparent);
  border-bottom:3px solid var(--line);backdrop-filter:blur(2px);max-width:100%;}
.hm-nav .brand{display:flex;align-items:center;gap:11px;}
.hm-nav .logo-o{width:24px;height:24px;}
.hm-nav .x{color:var(--dim);font-size:13px;font-family:var(--font-tag);}
.hm-nav .vm{font-family:var(--font-display);font-size:13px;color:var(--text);}
.hm-nav .links{display:inline-flex;gap:22px;margin-left:8px;}
.hm-nav .links a{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.1em;
  font-size:11.5px;color:var(--muted);text-decoration:none;cursor:pointer;}
.hm-nav .links a:hover{color:var(--cyan);}
/* Prospect City — nav: Merion à esquerda, menu no centro, VendaMais à direita */
.hm-nav.nav3{display:grid;grid-template-columns:1fr auto 1fr;}
.nav3 .brand{justify-self:start;}
.nav3 .links{justify-self:center;margin-left:0;}
.nav3 .brand-vm-side{justify-self:end;}

/* --- proposal eyebrow badge --- */
.hm-badge{display:inline-flex;align-items:center;gap:10px;padding:7px 14px 8px;
  background:var(--bg0);border:2px solid var(--cyan);
  box-shadow:inset 0 0 0 1px var(--line),0 0 16px color-mix(in srgb,var(--cyan) 30%,transparent);
  font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.16em;font-size:12px;color:var(--cyan);}

/* Merion pixel-art mark (header) */
.merion-mark{filter:drop-shadow(0 0 5px rgba(0,255,212,.45));flex:0 0 auto;}
/* VendaMais pixel-art mark */
.vendamais-mark{filter:drop-shadow(0 0 5px rgba(254,82,49,.4));flex:0 0 auto;}

/* logo lockup helper (Vendópolis word) */
.logo-o{display:inline-block;background:
  conic-gradient(from 45deg, var(--cyan), var(--lime), var(--cyan));
  border:3px solid var(--line);box-shadow:inset 2px 2px 0 rgba(255,255,255,.4),inset -2px -2px 0 rgba(0,0,0,.3);}

/* --- "hoje → proposta" context --- */
.hm-shift{display:grid;grid-template-columns:1fr 64px 1fr;gap:0;align-items:stretch;}
.hm-shift .arrow{display:grid;place-items:center;font-family:var(--font-display);font-size:20px;
  color:var(--cyan);background:var(--bg0);border-top:3px solid var(--line);border-bottom:3px solid var(--line);}
.hm-shift .side{padding:28px 26px;border:3px solid var(--line);background:var(--bg1);}
.hm-shift .side.now{background:#0c1614;}
.hm-shift .side.next{background:linear-gradient(160deg,color-mix(in srgb,var(--cyan) 12%,var(--bg2)),var(--bg1));}
.hm-shift .tg{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.14em;font-size:11px;
  color:var(--muted);margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.hm-shift .side.next .tg{color:var(--cyan);}
.hm-shift h3{font-family:var(--font-display);font-size:15px;line-height:1.5;margin:0 0 12px;color:var(--text);}
.hm-shift p{font-size:14.5px;line-height:1.7;color:var(--muted);margin:0;}
.hm-shift p b{color:var(--text);font-weight:600;}

/* --- the hub: district of rooms --- */
.hub{position:relative;border:4px solid var(--line);background:#081d1b;
  background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);
  background-size:36px 36px;
  box-shadow:inset 0 0 0 3px var(--bevel-soft),inset 0 0 90px 24px rgba(0,0,0,.5),8px 8px 0 rgba(0,0,0,.45);
  padding:30px 30px 26px;}
.hub-head{display:flex;align-items:center;gap:12px;margin-bottom:22px;}
.hub-head .px-tag{font-size:11px;}
.hub-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.room-card{position:relative;border:3px solid var(--line);background:var(--bg1);
  box-shadow:inset 0 0 0 2px rgba(31,80,87,.35),5px 5px 0 rgba(0,0,0,.4);
  display:flex;flex-direction:column;min-height:220px;overflow:hidden;transition:transform .06s steps(2);}
.room-card:hover{transform:translateY(-3px);}
.room-card .awning{height:14px;background:repeating-linear-gradient(90deg,var(--rc,#1f5057) 0 14px,#0a2a2e 14px 28px);
  border-bottom:3px solid var(--line);}
.room-card .scene{height:96px;position:relative;display:grid;place-items:center;
  background:radial-gradient(120% 90% at 50% 20%,color-mix(in srgb,var(--rc,#1f5057) 28%,var(--bg0)),var(--bg0));
  border-bottom:3px solid var(--line);}
.room-card .bd{padding:14px;display:flex;flex-direction:column;gap:7px;flex:1;}
.room-card .nm{font-family:var(--font-display);font-size:12px;color:var(--text);line-height:1.4;}
.room-card .kind{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.1em;font-size:10px;color:var(--muted);}
.room-card .desc{font-size:13px;line-height:1.55;color:var(--muted);}
.room-card .st{margin-top:auto;padding-top:9px;display:flex;align-items:center;gap:7px;
  border-top:2px dashed #123238;}
.room-card.flagship{border-color:var(--cyan);box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--cyan) 30%,transparent),
  0 0 22px color-mix(in srgb,var(--cyan) 22%,transparent),5px 5px 0 rgba(0,0,0,.45);}
.room-card.soon{opacity:.92;}
.room-card.soon .scene{filter:grayscale(.4);}
.st-live{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.1em;font-size:10px;color:var(--lime);}
.st-soon{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.1em;font-size:10px;color:var(--dim);}

/* --- Prospect City feature --- */
.pa{display:grid;grid-template-columns:1.1fr .9fr;gap:0;border:4px solid var(--line);
  background:var(--bg1);box-shadow:inset 0 0 0 3px var(--bevel-soft),8px 8px 0 rgba(0,0,0,.45);overflow:hidden;}
.pa > *{min-width:0;}
.pa .stage{position:relative;min-height:430px;border-right:4px solid var(--line);overflow:hidden;
  background:#06100f;}
.pa .stage .scanbar{position:absolute;left:0;right:0;top:0;height:30px;z-index:5;
  background:linear-gradient(var(--bg2),var(--bg1));border-bottom:3px solid var(--line);
  display:flex;align-items:center;gap:7px;padding:0 11px;}
.pa .stage .room{position:absolute;inset:30px 0 0 0;}
.pa .stage .pa-shot{position:absolute;top:30px;left:0;width:100%;height:calc(100% - 30px);
  object-fit:cover;object-position:center 44%;display:block;image-rendering:pixelated;}
.pa .bd{padding:34px 34px 30px;display:flex;flex-direction:column;}
.pa .bd .ribbon{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;margin-bottom:16px;
  padding:5px 11px 6px;background:var(--cyan);color:#04201c;border:2px solid var(--line);
  box-shadow:3px 3px 0 var(--line);font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.1em;font-size:11px;}
.pa .bd h3{font-family:var(--font-display);font-size:24px;line-height:1.3;margin:0 0 6px;}
.pa .bd .was{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.12em;font-size:11px;
  color:var(--muted);margin-bottom:16px;}
.pa .bd .was s{color:var(--dim);}
.pa .bd p{font-size:15px;line-height:1.7;color:var(--muted);margin:0 0 18px;}
.pa .bd p b{color:var(--text);font-weight:600;}
.pa-facts{display:flex;gap:0;border:3px solid var(--line);background:var(--bg0);width:100%;margin-bottom:22px;}
.pa-facts .c{flex:1;min-width:0;padding:11px 8px;border-right:3px solid var(--line);text-align:center;}
.pa-facts .c:last-child{border-right:0;}
.pa-facts .big{font-family:var(--font-display);font-size:18px;color:var(--cyan);white-space:nowrap;}
.pa-facts .lbl{font-size:9.5px;color:var(--muted);margin-top:6px;font-family:var(--font-tag);white-space:nowrap;
  text-transform:uppercase;letter-spacing:.02em;}

/* --- conversão físico → digital (de/para rows) --- */
.conv{display:flex;flex-direction:column;gap:10px;}
.conv-row{display:grid;grid-template-columns:1fr 52px 1fr;align-items:stretch;gap:0;
  border:3px solid var(--line);background:var(--bg1);box-shadow:4px 4px 0 rgba(0,0,0,.35);}
.conv-row .from,.conv-row .to{padding:16px 20px;display:flex;flex-direction:column;gap:5px;}
.conv-row .from{background:#0c1614;}
.conv-row .to{background:linear-gradient(160deg,color-mix(in srgb,var(--cyan) 10%,var(--bg2)),var(--bg1));}
.conv-row .mid{display:grid;place-items:center;background:var(--bg0);color:var(--cyan);
  font-family:var(--font-display);font-size:13px;border-left:3px solid var(--line);border-right:3px solid var(--line);}
.conv-row .role{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.1em;font-size:10px;color:var(--muted);}
.conv-row .to .role{color:var(--cyan);}
.conv-row .what{font-size:14.5px;line-height:1.5;color:var(--text);font-weight:600;}
.conv-row .how{font-size:13px;line-height:1.55;color:var(--muted);}

/* --- de treinamento a diagnóstico (situações observadas) --- */
.diag{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.diag-card{padding:20px;display:flex;flex-direction:column;gap:11px;position:relative;
  border:3px solid var(--line);background:var(--bg1);
  box-shadow:inset 0 0 0 2px rgba(31,80,87,.35),5px 5px 0 rgba(0,0,0,.4);
  transition:transform .06s steps(2);}
.diag-card:hover{transform:translateY(-3px);}
.diag-card .slot{width:50px;height:50px;display:grid;place-items:center;background:var(--bg0);
  border:3px solid var(--line);box-shadow:inset 0 0 0 2px var(--bevel-soft);}
.diag-card .nm{font-family:var(--font-display);font-size:12px;color:var(--cyan);line-height:1.4;}
.diag-card .desc{font-size:13.5px;line-height:1.6;color:var(--muted);}

/* --- a parceria (split) --- */
.party{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.party-card{padding:26px;}
.party-card .top{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.party-card .top .nm{font-family:var(--font-display);font-size:15px;}
.party-card ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;}
.party-card li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;line-height:1.55;color:var(--muted);}
.party-card li b{color:var(--text);font-weight:600;}
.party-card li .px-dot{margin-top:5px;flex:0 0 auto;}
.party-plus{display:grid;place-items:center;}

/* generic two-up icon-fact list (reused) */
.hm-points{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}

/* ===========================================================
   PROSPECT ARENA PAGE — extra components
   =========================================================== */

/* energy cost table inside lp-econcard */
.ar-cost-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;
  border-top:2px dashed #123238;font-size:13px;}
.ar-cost-row .lbl{color:var(--muted);}
.ar-cost-row .val{font-family:var(--font-tag);font-size:12px;color:var(--text);}

/* live scoreboard rows */
.ar-score-row{display:flex;align-items:center;gap:12px;padding:11px 16px;}

/* mini-cidade — mapa top-down (preview de interface) */
.citymap{border:4px solid var(--line);background:var(--bg1);
  box-shadow:inset 0 0 0 3px var(--bevel-soft),8px 8px 0 rgba(0,0,0,.45);overflow:hidden;}
.citymap .scanbar{height:32px;background:linear-gradient(var(--bg2),var(--bg1));border-bottom:3px solid var(--line);
  display:flex;align-items:center;gap:7px;padding:0 12px;}
.cm-board{position:relative;height:340px;background:#0a201d;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:34px 34px;box-shadow:inset 0 0 90px 24px rgba(0,0,0,.5);}
.cm-road{position:absolute;left:0;right:0;height:13%;background:#06120f;
  border-top:3px solid var(--line);border-bottom:3px solid var(--line);
  display:grid;place-items:center;}
.cm-road.top{top:1%;}
.cm-road.bottom{bottom:1%;}
.cm-road .lane{display:block;width:100%;height:0;
  border-top:3px dashed color-mix(in srgb,var(--lime) 55%,transparent);opacity:.7;}
.cm-lot{position:absolute;border:3px solid var(--line);background:var(--bg1);
  box-shadow:inset 0 0 0 2px rgba(31,80,87,.35),4px 4px 0 rgba(0,0,0,.45);
  display:flex;flex-direction:column;overflow:hidden;transition:transform .06s steps(2);}
.cm-lot:hover{transform:translateY(-2px);}
.cm-roof{height:48%;display:grid;place-items:center;border-bottom:3px solid var(--line);
  background:radial-gradient(120% 110% at 50% 0%,color-mix(in srgb,var(--bc) 34%,var(--bg0)),var(--bg0));}
.cm-info{flex:1;display:flex;flex-direction:column;justify-content:center;gap:3px;padding:5px 10px;}
.cm-nm{font-family:var(--font-display);font-size:11px;color:var(--bc);line-height:1.3;}
.cm-sub{font-size:11px;color:var(--muted);line-height:1.35;}
.cm-empresa{box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--bc) 35%,transparent),4px 4px 0 rgba(0,0,0,.45);}
.cm-voice{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.07em;font-size:9px;color:var(--lime);}
.cm-walker{position:absolute;transform:translate(-50%,-50%);z-index:3;filter:drop-shadow(2px 3px 0 rgba(0,0,0,.5));}
.cm-walker.w0{animation:cm-stroll-a 4.4s steps(6) infinite;}
.cm-walker.w1{animation:cm-stroll-b 5.2s steps(6) infinite;}
.cm-walker.w2{animation:cm-stroll-c 4.8s steps(6) infinite;}
@keyframes cm-stroll-a{0%,100%{transform:translate(-58%,-50%)}50%{transform:translate(-34%,-60%)}}
@keyframes cm-stroll-b{0%,100%{transform:translate(-42%,-58%)}50%{transform:translate(-62%,-44%)}}
@keyframes cm-stroll-c{0%,100%{transform:translate(-50%,-44%)}50%{transform:translate(-50%,-64%)}}
.cm-walker.you{z-index:4;animation:none;transform:translate(-50%,-50%);}
.cm-walker.you .px-ava{box-shadow:0 0 0 2px var(--lime),0 0 12px rgba(155,212,0,.6);}
.cm-you{position:absolute;left:50%;top:calc(100% + 2px);transform:translateX(-50%);white-space:nowrap;
  font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:8px;color:var(--lime);
  background:var(--bg0);border:1px solid var(--lime);padding:1px 5px;}
.cm-walker:hover{animation-play-state:paused;z-index:9;}
.cm-wtip{display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);z-index:9;
  white-space:nowrap;background:var(--bg0);border:2px solid var(--line);box-shadow:3px 3px 0 rgba(0,0,0,.5);
  padding:6px 9px;font-family:var(--font-display);font-size:10px;color:var(--text);text-align:center;}
.cm-wtip::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--line);}
.cm-wtip em{display:block;font-family:var(--font-tag);font-style:normal;text-transform:uppercase;letter-spacing:.05em;
  font-size:8px;color:var(--muted);margin-top:3px;}
.cm-walker:hover .cm-wtip{display:block;}
/* Cola do líder dentro do card da cidade */
.cm-cola{padding:12px 16px;border-top:3px solid var(--line);background:var(--bg0);}
.cm-cola-hd{display:flex;align-items:center;gap:6px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.06em;font-size:10px;color:var(--cyan);margin-bottom:10px;}
.cm-legend{display:flex;flex-wrap:wrap;gap:8px 18px;padding:12px 16px;border-top:3px solid var(--line);
  background:var(--bg0);font-size:11.5px;color:var(--muted);}
.cm-legend span{display:inline-flex;align-items:center;gap:6px;}
/* HUD do mapa: placar + concorrência */
.cm-hud{position:absolute;top:12px;right:12px;z-index:6;background:rgba(4,16,15,.88);
  border:2px solid var(--line);box-shadow:inset 0 0 0 2px var(--bevel-soft),3px 3px 0 rgba(0,0,0,.5);
  padding:8px 10px;display:flex;flex-direction:column;gap:5px;min-width:150px;}
.cm-hud-ttl{display:flex;align-items:center;gap:6px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.08em;font-size:9px;color:var(--cyan);margin-bottom:2px;}
.cm-hud-row{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--muted);
  font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.04em;}
.cm-hud-row .dot{width:8px;height:8px;border:1px solid var(--line);flex:0 0 auto;}
.cm-hud-row b{margin-left:auto;color:var(--text);font-family:var(--font-display);font-size:10px;}
.cm-conc{display:flex;align-items:center;gap:6px;margin-top:3px;padding-top:6px;border-top:2px dashed #123238;
  font-size:9px;color:var(--pink);font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;}
.cm-conc b{margin-left:auto;font-family:var(--font-display);font-size:11px;color:var(--pink);}
/* Mortolino rondando uma empresa */
.cm-mortolino{position:absolute;z-index:5;display:flex;flex-direction:column;align-items:center;gap:3px;
  transform:translate(-50%,-50%);animation:cm-roam 3.2s steps(8) infinite;
  filter:drop-shadow(0 0 7px rgba(237,20,91,.7));}
.cm-mortolino .lbl{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:9px;
  color:var(--pink);background:var(--bg0);border:1px solid var(--pink);padding:1px 5px;white-space:nowrap;}
@keyframes cm-roam{0%,100%{transform:translate(-58%,-50%)}50%{transform:translate(-30%,-64%)}}
.cm-lot.warn{box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--pink) 65%,transparent),
  0 0 18px rgba(237,20,91,.45),4px 4px 0 rgba(0,0,0,.45);}
/* prédios clicáveis (visão do líder) */
.cm-clickable{cursor:pointer;}
.cm-clickable:hover{transform:translateY(-3px);
  box-shadow:inset 0 0 0 2px var(--bc),0 0 16px color-mix(in srgb,var(--bc) 45%,transparent),4px 4px 0 rgba(0,0,0,.45);}
.cm-lot.is-active{transform:translateY(-3px);
  box-shadow:inset 0 0 0 2px var(--bc),0 0 22px color-mix(in srgb,var(--bc) 60%,transparent),4px 4px 0 rgba(0,0,0,.45);}
.cm-lot.is-done{opacity:.62;}
.cm-lot.is-done .cm-enter{color:var(--lime);}
.cm-enter{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:9px;color:var(--bc);margin-top:3px;}
/* HUD do líder: energia + caixa (canto superior esquerdo) */
.cm-leader{position:absolute;top:12px;left:12px;z-index:6;background:rgba(4,16,15,.9);
  border:2px solid var(--line);box-shadow:inset 0 0 0 2px var(--bevel-soft),3px 3px 0 rgba(0,0,0,.5);
  padding:8px 10px;display:flex;flex-direction:column;gap:5px;min-width:152px;}
.cm-leader-ttl{display:flex;align-items:center;gap:6px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.07em;font-size:9px;color:var(--lime);margin-bottom:2px;}
.cm-leader-row{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--muted);
  font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.04em;}
.cm-leader-row b{margin-left:auto;color:var(--text);font-family:var(--font-display);font-size:10px;}

/* ===== TELAS DO JOGO — seletor de visões (HUD pixel-art) ===== */
.gs-tabs{display:flex;justify-content:center;gap:8px;margin-bottom:10px;}
.gs-tab{font-family:var(--font-display);font-size:12px;color:var(--muted);background:var(--bg1);
  border:3px solid var(--line);box-shadow:inset 5px 0 0 var(--tc),3px 3px 0 rgba(0,0,0,.4);padding:11px 20px 11px 22px;cursor:pointer;
  text-transform:uppercase;letter-spacing:.04em;transition:transform .06s steps(2);}
.gs-tab:hover{color:var(--tc);transform:translateY(-2px);}
.gs-tab.on{color:#04201c;background:var(--tc);border-color:var(--tc);box-shadow:inset 2px 2px 0 rgba(255,255,255,.4),3px 3px 0 var(--line);}
.gs-sub{display:flex;justify-content:center;gap:6px;margin-bottom:14px;}
.gs-subtab{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.08em;font-size:11px;
  color:var(--muted);background:var(--bg0);border:2px solid var(--line);padding:7px 16px;cursor:pointer;}
.gs-subtab:hover{color:var(--text);}
.gs-subtab.on{color:var(--cyan);box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--cyan) 40%,transparent);}
/* segunda linha de sub-abas (dentro do auditório) */
.gs-sub-in{margin-top:-8px;margin-bottom:14px;}
.gs-sub-in .gs-subtab{font-size:10px;padding:5px 13px;background:var(--bg1);}
.gs-sub-in .gs-subtab.on{color:var(--lime);box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--lime) 40%,transparent);}
.gs-note{margin:14px auto 0;text-align:center;font-size:13.5px;line-height:1.6;color:var(--muted);max-width:62ch;}

/* moldura da tela */
.gs-screen{border:4px solid var(--line);background:var(--bg1);
  box-shadow:inset 0 0 0 3px var(--bevel-soft),8px 8px 0 rgba(0,0,0,.45);overflow:hidden;}
.gs-screen .scanbar{height:32px;background:linear-gradient(var(--bg2),var(--bg1));border-bottom:3px solid var(--line);
  display:flex;align-items:center;gap:7px;padding:0 12px;}
.gs-body{position:relative;padding:22px;min-height:430px;background:#07140f;
  background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:32px 32px;}

/* painéis internos reutilizáveis */
.gs-panel{border:3px solid var(--line);background:var(--bg1);box-shadow:inset 0 0 0 2px rgba(31,80,87,.3);padding:13px 15px;}
.gs-panel + .gs-panel{margin-top:12px;}
.gs-panel.warn{box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--pink) 35%,transparent);}
.gs-panel-hd{display:flex;align-items:center;gap:7px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.08em;font-size:10px;color:var(--muted);margin-bottom:10px;}
.gs-evt{margin:0 0 6px;font-size:13px;line-height:1.55;color:var(--muted);}
.gs-evt:last-child{margin-bottom:0;}
.gs-evt b{color:var(--text);}

/* narrador */
.gs-narr{display:grid;grid-template-columns:1.2fr 1fr;gap:14px;}
.gs-score{display:flex;align-items:center;gap:10px;padding:7px 0;border-top:2px solid var(--line);font-size:13px;}
.gs-score:first-of-type{border-top:0;padding-top:0;}
.gs-score .pos{font-family:var(--font-display);font-size:11px;color:var(--dim);width:14px;}
.gs-score .nm{flex:1;font-weight:600;}
.gs-score .delta{font-size:11px;color:var(--lime);font-family:var(--font-tag);}
.gs-score .val{font-family:var(--font-display);font-size:13px;color:var(--cyan);}
.gs-fase{text-align:center;padding:4px 0 14px;}
.gs-btns{display:flex;gap:8px;}

/* narrador interativo — faixa rodada/fase + placar colapsável/scrollável + alertas pilháveis */
.gs-roundbar{display:flex;align-items:center;gap:22px;border:3px solid var(--line);background:var(--bg0);
  box-shadow:inset 0 0 0 2px var(--bevel-soft);padding:13px 18px;margin-bottom:14px;flex-wrap:wrap;}
.gs-round{display:flex;flex-direction:column;gap:3px;}
.gs-round .lbl,.gs-phase .lbl{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.1em;font-size:9px;color:var(--muted);}
.gs-round .big{font-family:var(--font-display);font-size:30px;color:var(--cyan);line-height:1;}
.gs-round .of{font-size:14px;color:var(--dim);}
.gs-phase{display:flex;flex-direction:column;gap:3px;padding-left:22px;border-left:3px solid var(--line);}
.gs-phase .ph{font-family:var(--font-display);font-size:16px;color:var(--orange);line-height:1;}
.gs-phasedots{display:flex;gap:5px;margin-top:4px;}
.gs-phasedots .pd{width:9px;height:9px;border:2px solid var(--line);background:var(--bg2);}
.gs-phasedots .pd.on{background:var(--orange);box-shadow:0 0 0 1px var(--line),0 0 7px var(--orange);}
.gs-roundtimer{margin-left:auto;}
.gs-roundbtns{display:flex;gap:8px;}

.gs-scoreboard{max-height:286px;overflow-y:auto;}
.gs-scoreboard::-webkit-scrollbar{width:9px;}
.gs-scoreboard::-webkit-scrollbar-track{background:var(--bg0);}
.gs-scoreboard::-webkit-scrollbar-thumb{background:var(--line);border:2px solid var(--bg0);}
.gs-team{border-top:2px solid var(--line);}
.gs-team:first-child{border-top:0;}
.gs-team-row{display:flex;align-items:center;gap:9px;width:100%;background:none;border:0;cursor:pointer;
  padding:8px 6px;font-size:13px;color:var(--text);text-align:left;font-family:inherit;}
.gs-team-row:hover{background:rgba(255,255,255,.035);}
.gs-team-row .pos{font-family:var(--font-display);font-size:11px;color:var(--dim);width:14px;flex:0 0 auto;}
.gs-team-row .nm{flex:1;font-weight:600;}
.gs-team-row .conc{display:inline-flex;align-items:center;gap:3px;font-family:var(--font-tag);font-size:10px;color:var(--pink);}
.gs-team-row .val{font-family:var(--font-display);font-size:12px;color:var(--cyan);white-space:nowrap;}
.gs-team-row .chev{font-size:10px;color:var(--dim);width:12px;flex:0 0 auto;}
.gs-team-row .chev.open{color:var(--cyan);}
.gs-team-players{display:flex;flex-wrap:wrap;gap:6px;padding:2px 6px 12px 29px;}
.gs-pl{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);
  background:var(--bg0);border:2px solid var(--line);padding:4px 9px;}
.gs-pl .pdot{width:6px;height:6px;background:var(--dim);border:1px solid var(--line);flex:0 0 auto;}
.gs-pl.lider{color:var(--lime);border-color:color-mix(in srgb,var(--lime) 50%,var(--line));}
.gs-pl.lider .pdot{background:var(--lime);}
.gs-pl .ptag{font-family:var(--font-tag);text-transform:uppercase;font-size:8px;letter-spacing:.08em;color:var(--lime);}
/* destaque da equipe do jogador no placar */
.gs-team.you{background:color-mix(in srgb,var(--cyan) 10%,transparent);box-shadow:inset 3px 0 0 var(--cyan);}
.gs-team.you .nm{color:var(--cyan);}
.you-tag{margin-left:7px;font-family:var(--font-tag);text-transform:uppercase;font-size:8px;letter-spacing:.06em;
  color:#04201c;background:var(--cyan);padding:1px 5px;}
.gs-you-banner{display:flex;align-items:center;gap:11px;padding:9px 12px;margin-bottom:9px;
  background:color-mix(in srgb,var(--cyan) 14%,var(--bg0));border:2px solid color-mix(in srgb,var(--cyan) 50%,var(--line));}
.gs-you-banner .pos{font-family:var(--font-display);font-size:17px;color:var(--cyan);}
.gs-you-banner .lbl{flex:1;font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:10px;color:var(--muted);}
.gs-you-banner .val{font-family:var(--font-display);font-size:13px;color:var(--text);}

.gs-alerts{cursor:pointer;}
.gs-alerts .gs-panel-hd .cnt{margin-left:auto;font-family:var(--font-display);font-size:10px;color:var(--pink);
  border:2px solid var(--pink);padding:1px 7px;}
.gs-alert{display:flex;align-items:flex-start;gap:9px;font-size:12.5px;line-height:1.5;color:var(--muted);
  border:2px solid var(--line);background:var(--bg0);padding:9px 11px;position:relative;}
.gs-alert .dot{width:8px;height:8px;flex:0 0 auto;margin-top:4px;border:1px solid var(--line);}
.gs-alert b{color:var(--text);}
.gs-alerts.open .gs-alert + .gs-alert{margin-top:8px;}
.gs-alerts:not(.open) .gs-alert + .gs-alert{display:none;}
.gs-alerts:not(.open) .gs-alert:first-child{
  box-shadow:4px 6px 0 0 var(--bg1),4px 6px 0 2px var(--line),9px 12px 0 0 var(--bg2),9px 12px 0 2px var(--line);}
.gs-alert-hint{display:block;margin-top:12px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.06em;font-size:9px;color:var(--dim);}
.gs-alerts:not(.open) .gs-alert-hint{margin-top:20px;}

/* empresa */
.gs-empresa{position:relative;padding-top:8px;}
.gs-conc-badge{display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:10px;color:var(--pink);
  background:var(--bg0);border:2px solid var(--pink);padding:6px 10px;}
.gs-conc-badge b{font-family:var(--font-display);}
.gs-placar{position:absolute;top:-6px;right:0;background:rgba(4,16,15,.92);border:2px solid var(--line);
  padding:8px 11px;min-width:130px;box-shadow:3px 3px 0 rgba(0,0,0,.4);}
.gs-placar-hd{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.08em;font-size:9px;color:var(--cyan);margin-bottom:6px;}
.gs-placar-row{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--muted);font-family:var(--font-tag);padding:1px 0;}
.gs-placar-row .dot{width:7px;height:7px;border:1px solid var(--line);flex:0 0 auto;}
.gs-placar-row b{margin-left:auto;color:var(--text);font-family:var(--font-display);font-size:10px;}
.gs-emp-title{font-family:var(--font-display);font-size:12px;color:var(--text);text-align:center;margin:46px 0 14px;}
.gs-carteira{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-height:412px;overflow-y:auto;padding-right:7px;}
.gs-carteira::-webkit-scrollbar{width:9px;}
.gs-carteira::-webkit-scrollbar-track{background:var(--bg0);}
.gs-carteira::-webkit-scrollbar-thumb{background:var(--line);border:2px solid var(--bg0);}
.gs-client{border:3px solid var(--line);background:var(--bg0);box-shadow:inset 0 0 0 2px rgba(31,80,87,.3);
  display:flex;flex-direction:column;}
.gs-client-hd{display:flex;align-items:center;gap:6px;padding:8px 10px;border-bottom:3px solid var(--line);
  background:radial-gradient(120% 100% at 50% 0%,color-mix(in srgb,var(--tc) 28%,var(--bg0)),var(--bg0));}
.gs-client-hd .nm{flex:1;font-family:var(--font-display);font-size:11px;color:var(--tc);line-height:1.35;}
.gs-client-hd .val{margin-left:auto;font-family:var(--font-display);font-size:10px;color:var(--text);white-space:nowrap;}
.gs-client-tag{display:flex;align-items:center;gap:8px;padding:7px 11px 0;}
.gs-client-tag .lvl{font-family:var(--font-display);font-size:11px;color:var(--tc);}
.gs-client-tag .tier{font-family:var(--font-tag);font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);}
.gs-sg-meta{color:var(--muted);font-size:11px;font-family:var(--font-tag);}
.gs-req{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:11px;}
.gs-req-i{display:flex;align-items:center;gap:6px;font-family:var(--font-display);font-size:13px;color:var(--text);}
.gs-client-ft{margin-top:auto;display:flex;align-items:center;gap:6px;padding:8px 10px;border-top:2px dashed #123238;
  font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:9px;}
.gs-leader{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px;align-items:start;}
/* líder · sugestões de todos os jogadores */
.gs-sugs{display:flex;flex-direction:column;gap:8px;}
.gs-sug{border:2px solid var(--line);background:var(--bg0);padding:9px 11px;}
.gs-sug-hd{display:flex;align-items:center;gap:7px;margin-bottom:7px;}
.gs-sug-hd .who{font-family:var(--font-display);font-size:11px;color:var(--text);}
.gs-sug-hd .tag{margin-left:auto;font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;
  font-size:8px;color:var(--dim);}
.gs-sug-line{display:flex;gap:9px;font-size:11px;line-height:1.5;}
.gs-sug-line + .gs-sug-line{margin-top:3px;}
.gs-sug-line .k{flex:0 0 62px;font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.04em;
  font-size:9px;color:var(--muted);padding-top:1px;}
.gs-sug-line .v{flex:1;color:var(--muted);}
/* líder · botão para a cidade */
.gs-gocity .gs-evt{margin:0 0 4px;}
.gs-gocity .px-btn{width:100%;justify-content:center;margin-top:9px;}
.gs-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:14px;
  border-top:3px solid var(--line);padding-top:13px;}
.gs-energy{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.06em;font-size:11px;color:var(--muted);}
.gs-energy b{font-family:var(--font-display);color:var(--orange);}
.gs-voice{display:inline-flex;align-items:center;gap:6px;}
.gs-voice .lbl{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.06em;font-size:10px;color:var(--lime);margin-left:5px;}

/* empresa v2 — cabeçalho + voz + grid + faixas + sugestão + votação */
.gs-emp-head{display:flex;align-items:center;gap:14px;margin-bottom:12px;}
.gs-emp-name{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-display);font-size:15px;color:var(--text);}
.gs-emp-energy{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-tag);
  text-transform:uppercase;letter-spacing:.06em;font-size:10px;color:var(--muted);}
.gs-emp-energy b{font-family:var(--font-display);color:var(--orange);}
.gs-voicebar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;border:2px solid var(--line);
  background:var(--bg0);padding:8px 12px;margin-bottom:14px;}
.gs-vc{display:inline-flex;align-items:center;gap:7px;padding:3px 9px 3px 3px;border:2px solid transparent;}
.gs-vc .vn{font-size:12px;color:var(--muted);display:inline-flex;align-items:center;gap:6px;}
.gs-vc .vl{font-family:var(--font-tag);text-transform:uppercase;font-size:8px;letter-spacing:.06em;color:var(--lime);
  border:1px solid var(--lime);padding:1px 4px;}
.gs-vc.talking{border-color:var(--lime);box-shadow:0 0 0 1px var(--line),0 0 10px color-mix(in srgb,var(--lime) 45%,transparent);}
.gs-vc.talking .vn{color:var(--text);}
.gs-vc.talking .px-ava{animation:px-bob 1.6s steps(3) infinite;}
.gs-voice-now{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-family:var(--font-tag);
  text-transform:uppercase;letter-spacing:.06em;font-size:10px;color:var(--lime);}
.gs-vc.muted{opacity:.5;}
.gs-vc.muted .vn{text-decoration:line-through;text-decoration-color:var(--dim);}
.gs-vc.pickable{cursor:pointer;border-color:var(--line);}
.gs-vc.pickable:hover{border-color:var(--lime);}
.gs-vc-hand{margin-left:1px;font-size:12px;filter:drop-shadow(0 0 4px rgba(255,200,0,.6));}
/* controle de voz do líder */
.gs-voice-ctl{display:inline-flex;align-items:center;gap:6px;}
.gs-voice-ctl .lbl{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-tag);
  text-transform:uppercase;letter-spacing:.06em;font-size:9px;color:var(--muted);}
.gs-voice-mode{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.05em;font-size:9px;
  color:var(--muted);background:var(--bg1);border:2px solid var(--line);padding:5px 9px;cursor:pointer;}
.gs-voice-mode:hover{color:var(--text);}
.gs-voice-mode.on{color:#04201c;background:var(--lime);border-color:var(--lime);}
/* levantar a mão (jogador) */
.gs-hand{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.05em;font-size:10px;
  color:var(--muted);background:var(--bg1);border:2px solid var(--line);padding:6px 11px;cursor:pointer;}
.gs-hand:hover{color:var(--text);border-color:var(--orange);}
.gs-hand.on{color:#231a04;background:var(--orange);border-color:var(--orange);}
.gs-voice-hint{margin:-8px 0 14px;font-size:11px;color:var(--cyan);}
.gs-emp-grid{display:grid;grid-template-columns:1.45fr 1fr;gap:14px;align-items:start;}
.gs-emp-sub{display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-family:var(--font-display);font-size:12px;color:var(--text);margin-bottom:12px;}
.gs-market-btn{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.06em;font-size:10px;color:var(--cyan);background:var(--bg0);
  border:2px solid color-mix(in srgb,var(--cyan) 45%,var(--line));padding:6px 11px;cursor:pointer;}
.gs-market-btn:hover{background:var(--cyan);color:#04201c;}

/* MERCADO — tabuleiro (popup) */
.mkt-overlay{position:absolute;inset:0;z-index:40;background:rgba(2,8,8,.84);
  display:flex;justify-content:center;align-items:flex-start;padding:22px;}
.mkt{width:100%;max-width:1000px;max-height:100%;overflow:auto;border:4px solid var(--line);background:var(--bg1);
  box-shadow:inset 0 0 0 3px var(--bevel-soft),8px 8px 0 rgba(0,0,0,.55);}
.mkt .scanbar{height:32px;background:linear-gradient(var(--bg2),var(--bg1));border-bottom:3px solid var(--line);
  display:flex;align-items:center;gap:7px;padding:0 12px;position:sticky;top:0;z-index:2;}
.mkt-x{margin-left:10px;background:none;border:0;color:var(--dim);cursor:pointer;font-size:13px;font-family:inherit;}
.mkt-x:hover{color:var(--text);}
.mkt-body{display:flex;flex-direction:column;gap:14px;padding:16px;}
/* Linha 1 — faturamento + concorrência */
.mkt-top{display:grid;grid-template-columns:1fr 1.5fr;gap:14px;align-items:stretch;}
/* Linha 3 — escada horizontal das 9 linhas */
.mkt-ladder-h{display:grid;grid-template-columns:repeat(9,1fr);gap:6px;}
.mkt-col{display:flex;flex-direction:column;border:2px solid var(--line);background:var(--bg0);min-height:104px;}
.mkt-col-track{flex:1;display:flex;flex-direction:column;gap:5px;align-items:center;justify-content:flex-end;padding:8px 5px;}
.mkt-col-hd{display:flex;flex-direction:column;align-items:center;gap:1px;padding:5px 2px 6px;
  border-top:2px solid var(--line);background:var(--bg1);box-shadow:inset 0 -4px 0 var(--tc);}
.mkt-col-hd .ln{font-family:var(--font-display);font-size:12px;color:var(--tc);}
.mkt-col-hd .val{font-family:var(--font-display);font-size:8px;color:var(--muted);font-variant-numeric:tabular-nums;}
.mkt-col-hd .val::after{content:" V$";color:var(--dim);}
.mkt-token{position:relative;display:inline-flex;align-items:center;justify-content:center;max-width:100%;
  height:26px;padding:0 10px;font-family:var(--font-display);font-size:10px;white-space:nowrap;
  color:#04201c;background:var(--tc);border:3px solid var(--line);cursor:default;
  box-shadow:inset 2px 2px 0 rgba(255,255,255,.35),inset -2px -2px 0 rgba(0,0,0,.3);}
.mkt-token.lost{filter:grayscale(.6);opacity:.65;}
.mkt-tip{display:none;position:absolute;bottom:calc(100% + 7px);left:50%;transform:translateX(-50%);z-index:6;
  white-space:nowrap;background:var(--bg0);border:2px solid var(--line);box-shadow:3px 3px 0 rgba(0,0,0,.5);
  padding:6px 9px;font-family:var(--font-display);font-size:10px;color:var(--text);text-align:center;}
.mkt-tip::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:5px solid transparent;border-top-color:var(--line);}
.mkt-tip em{display:block;font-family:var(--font-tag);font-style:normal;text-transform:uppercase;
  letter-spacing:.05em;font-size:8px;color:var(--muted);margin-top:3px;}
.mkt-token:hover .mkt-tip{display:block;}
/* Linha 2 — prospects (cooldown + risco lado a lado) */
.mkt-prospects{border:3px solid var(--line);background:var(--bg0);padding:12px;}
.mkt-prospects-hd{display:flex;align-items:center;gap:6px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.06em;font-size:10px;color:var(--muted);margin-bottom:11px;}
.mkt-pz-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.mkt-pz.cooldown{border-left:3px solid var(--cyan);padding-left:11px;}
.mkt-pz.risco{border-left:3px solid var(--orange);padding-left:11px;}
.mkt-pz-lbl{display:flex;align-items:center;gap:6px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.05em;font-size:9px;margin-bottom:8px;}
.mkt-pz.cooldown .mkt-pz-lbl{color:var(--cyan);}
.mkt-pz.risco .mkt-pz-lbl{color:var(--orange);}
.mkt-pz-tokens{display:flex;gap:7px;flex-wrap:wrap;min-height:26px;align-items:center;}
.mkt-pz-empty{font-size:11px;color:var(--dim);}
.mkt-fat{border:3px solid color-mix(in srgb,var(--cyan) 45%,var(--line));background:#08201f;padding:13px;
  display:flex;flex-direction:column;gap:4px;justify-content:center;}
.mkt-fat .lbl{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:9px;color:var(--cyan);}
.mkt-fat .big{font-family:var(--font-display);font-size:26px;color:var(--cyan);line-height:1;}
.mkt-fat .big em{font-style:normal;font-size:13px;color:var(--muted);}
.mkt-fat .pos{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:9px;color:var(--muted);}
.mkt-conc{border:3px solid color-mix(in srgb,var(--pink) 45%,var(--line));background:#140a10;padding:13px;
  display:flex;flex-direction:column;}
.mkt-conc-hd{display:flex;align-items:center;gap:7px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.06em;font-size:10px;color:var(--pink);margin-bottom:10px;}
.mkt-conc-hd b{font-family:var(--font-display);}
.mkt-conc-main{display:flex;align-items:center;gap:14px;margin-bottom:8px;}
.mkt-conc-tokens{display:flex;gap:7px;flex-wrap:wrap;}
.mkt-mortolino{display:flex;flex-direction:column;align-items:center;gap:4px;margin-left:auto;padding:2px 6px;
  filter:drop-shadow(0 0 7px rgba(237,20,91,.6));animation:cm-roam 3.2s steps(8) infinite;}
.mkt-mortolino .lbl{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:9px;color:var(--pink);}
.mkt-conc-note{margin:auto 0 0;font-size:11px;line-height:1.55;color:var(--dim);}
/* Rodapé — legenda de níveis */
.mkt-legend{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;font-size:11px;color:var(--muted);
  border-top:2px solid var(--line);padding-top:13px;}
.mkt-legend span{display:inline-flex;align-items:center;gap:8px;}
.mkt-legend .sw{width:11px;height:11px;border:2px solid var(--line);flex:0 0 auto;}

/* faixas de cliente */
.gs-faixa{padding:9px 11px;border-top:2px dashed #123238;}
.gs-faixa.cur{border-top:0;}
.gs-faixa.other{background:rgba(255,255,255,.02);}
.gs-faixa-lbl{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:8px;color:var(--muted);margin-bottom:6px;}
.gs-faixa .gs-req{padding:0;}
.gs-faixa-btn{margin-left:auto;font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:8px;
  color:var(--cyan);background:none;border:0;cursor:pointer;padding:0;}
.gs-client.open{box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--tc) 35%,transparent);}

/* sugestão de rodada (jogador) */
.gs-suggest{margin-top:14px;}
.gs-sg-sec{padding:10px 0;border-top:2px dashed #123238;}
.gs-sg-sec:first-of-type{border-top:0;padding-top:2px;}
.gs-sg-lbl{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:9px;color:var(--cyan);margin-bottom:8px;}
.gs-sg-row{display:flex;align-items:center;gap:9px;padding:4px 0;}
.gs-sg-row .cl{flex:1;font-size:12.5px;color:var(--text);}
.gs-sg-row .cost{font-family:var(--font-tag);font-size:10px;color:var(--muted);}
.gs-sg-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;
  border-top:3px solid var(--line);padding-top:12px;}
.gs-sg-total{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:10px;color:var(--muted);}
.gs-sg-total b{font-family:var(--font-display);color:var(--orange);}

/* votação (liderança) */
.gs-vote{display:flex;flex-direction:column;gap:7px;}
.gs-vote-opt{display:flex;align-items:center;gap:9px;width:100%;text-align:left;cursor:pointer;
  background:var(--bg0);border:2px solid var(--line);color:var(--muted);font-size:12px;padding:8px 10px;font-family:inherit;}
.gs-vote-opt:hover{color:var(--text);}
.gs-vote-opt .vradio{width:11px;height:11px;border:2px solid var(--line);flex:0 0 auto;}
.gs-vote-opt.on{color:var(--cyan);border-color:color-mix(in srgb,var(--cyan) 50%,var(--line));}
.gs-vote-opt.on .vradio{background:var(--cyan);box-shadow:inset 0 0 0 2px var(--bg0);}
.gs-vote-hint{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:9px;color:var(--dim);margin-top:3px;}

/* ===== AUDITÓRIO (Abertura · Evento · Conferência) ===== */
.aud-lobby{display:flex;align-items:center;gap:12px;flex-wrap:wrap;border:2px solid var(--line);
  background:var(--bg0);padding:8px 12px;margin-bottom:12px;}
.aud-live,.aud-onlynarr{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-tag);
  text-transform:uppercase;letter-spacing:.06em;font-size:10px;color:var(--muted);}
.aud-onlynarr{color:var(--lime);}
.aud-note{margin:0 0 12px;font-size:12.5px;line-height:1.55;color:var(--dim);}
.aud-note b{color:var(--text);}
.aud-teams{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.aud-team{border:2px solid var(--line);background:var(--bg0);box-shadow:inset 4px 0 0 var(--bc);padding:9px 11px;}
.aud-team.you{border-color:color-mix(in srgb,var(--cyan) 55%,var(--line));background:color-mix(in srgb,var(--cyan) 9%,var(--bg0));}
.aud-team-hd{display:flex;align-items:center;gap:7px;margin-bottom:8px;}
.aud-team-hd .nm{font-family:var(--font-display);font-size:11px;color:var(--bc);}
.aud-team-hd .you-tag{margin-left:auto;font-family:var(--font-tag);text-transform:uppercase;font-size:8px;
  letter-spacing:.06em;color:var(--cyan);border:1px solid var(--cyan);padding:1px 5px;}
.aud-team-pl{display:flex;flex-direction:column;gap:4px;}
.aud-pl{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--muted);}
.aud-pl .pdot{width:7px;height:7px;border:1px solid var(--line);background:var(--bc);flex:0 0 auto;}
.aud-pl.lider{color:var(--text);}
.aud-pl .ptag{margin-left:4px;font-family:var(--font-tag);text-transform:uppercase;font-size:7px;letter-spacing:.06em;
  color:var(--lime);border:1px solid var(--lime);padding:0 4px;}
.aud-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px;
  border-top:3px solid var(--line);padding-top:13px;}
.aud-wait{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.05em;font-size:10px;color:var(--muted);}
.aud-dot{display:inline-block;width:8px;height:8px;border:1px solid var(--line);vertical-align:middle;margin-right:2px;}
/* votação — passos */
.aud-vote-step + .aud-vote-step{margin-top:12px;padding-top:12px;border-top:2px dashed #123238;}
.aud-step-lbl{display:block;font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;
  font-size:9px;color:var(--cyan);margin-bottom:8px;}
/* evento */
.aud-clients{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-top:4px;}
.aud-cli{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--text);
  border:2px solid var(--line);background:var(--bg0);box-shadow:inset 3px 0 0 var(--cyan);padding:6px 10px;}
.aud-cli-note{font-size:11px;color:var(--dim);}
.aud-evt-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.aud-evt-ttl{display:block;font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:9px;margin-bottom:7px;}
.aud-evt-ttl.up{color:var(--lime);}
.aud-evt-ttl.dn{color:var(--pink);}
.aud-evt-row{display:flex;justify-content:space-between;gap:10px;font-size:11.5px;color:var(--muted);padding:3px 0;}
.aud-evt-row b{color:var(--text);font-weight:600;}
/* conferência — palco em suspense */
.aud-conf-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px;}
.aud-conf-step{font-family:var(--font-display);font-size:12px;color:var(--cyan);}
.aud-conf-hint{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.05em;font-size:10px;color:var(--muted);}
.aud-stage{position:relative;height:260px;display:grid;place-items:center;border:3px solid var(--line);
  background:radial-gradient(120% 90% at 50% 0%,#0c2522,#050f0d 70%);box-shadow:inset 0 0 70px 18px rgba(0,0,0,.6);overflow:hidden;}
.aud-stage.risk{box-shadow:inset 0 0 70px 18px rgba(0,0,0,.6),inset 0 0 0 2px color-mix(in srgb,var(--pink) 45%,transparent);}
.aud-stage-card{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px;
  min-width:200px;border:3px solid var(--line);background:var(--bg1);box-shadow:inset 0 0 0 2px var(--bc),6px 6px 0 rgba(0,0,0,.5);padding:16px 20px;}
.aud-stage-nm{font-family:var(--font-display);font-size:14px;color:var(--bc);display:flex;align-items:center;gap:7px;}
.aud-stage-nm .you-tag{font-family:var(--font-tag);text-transform:uppercase;font-size:8px;letter-spacing:.06em;
  color:var(--cyan);border:1px solid var(--cyan);padding:1px 5px;}
.aud-stage-row{display:flex;justify-content:space-between;gap:18px;width:100%;font-size:11px;color:var(--muted);
  font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.04em;}
.aud-stage-row b{font-family:var(--font-display);font-size:11px;color:var(--text);}
.aud-mort{z-index:3;}
/* tag de local no ciclo (como funciona) */
.lp-step-at{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.06em;font-size:9px;color:var(--cyan);margin:2px 0 6px;}
/* auditório acessado pela cidade — moldura + nav de momentos */
.gs-aud{display:flex;flex-direction:column;gap:12px;}
.gs-aud-nav{display:flex;gap:6px;flex-wrap:wrap;}
.gs-audtab{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.06em;font-size:10px;
  color:var(--muted);background:var(--bg1);border:2px solid var(--line);padding:5px 12px;cursor:pointer;}
.gs-audtab:hover{color:var(--text);}
.gs-audtab.on{color:#04201c;background:var(--cyan);border-color:var(--cyan);}
/* narrador · barra "ir para a cidade" no painel */
.gs-narr-go{display:flex;align-items:center;gap:12px;justify-content:space-between;flex-wrap:wrap;
  border:2px solid var(--line);background:var(--bg0);padding:8px 12px;margin-bottom:14px;}
/* prédio do auditório em destaque no mapa */
.cm-aud .cm-roof{background:radial-gradient(120% 110% at 50% 0%,color-mix(in srgb,var(--bc) 46%,var(--bg0)),var(--bg0));}
/* walkers (empresas) clicáveis na visão do narrador */
.cm-walker.clickable{cursor:pointer;}
.cm-walker.clickable:hover .px-ava{box-shadow:0 0 0 2px var(--lime),0 0 12px rgba(155,212,0,.6);}
/* empresas como pequenos prédios fixos na rua */
.cm-co{position:absolute;transform:translate(-50%,-50%);z-index:3;width:74px;
  border:2px solid var(--line);background:var(--bg1);overflow:visible;
  box-shadow:inset 0 0 0 2px rgba(31,80,87,.35),3px 3px 0 rgba(0,0,0,.45);}
.cm-co-roof{display:flex;align-items:center;justify-content:center;gap:4px;height:19px;border-bottom:2px solid var(--line);
  background:radial-gradient(130% 130% at 50% 0%,color-mix(in srgb,var(--bc) 40%,var(--bg0)),var(--bg0));}
.cm-co-roof .ini{font-family:var(--font-display);font-size:9px;color:var(--bc);}
.cm-co-nm{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.04em;font-size:8px;color:var(--muted);
  text-align:center;padding:3px 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cm-co.you{border-color:color-mix(in srgb,var(--cyan) 60%,var(--line));box-shadow:inset 0 0 0 2px var(--cyan),3px 3px 0 rgba(0,0,0,.45);}
.cm-co.clickable{cursor:pointer;}
.cm-co.clickable:hover{transform:translate(-50%,-50%) translateY(-2px);
  box-shadow:inset 0 0 0 2px var(--lime),0 0 12px color-mix(in srgb,var(--lime) 45%,transparent),3px 3px 0 rgba(0,0,0,.45);}
.cm-co .cm-you{top:auto;bottom:calc(100% + 3px);}
.cm-co .cm-wtip{bottom:calc(100% + 8px);}
/* DnD das equipes (narrador) */
.aud-pl.drag{cursor:grab;}
.aud-pl.drag:active{cursor:grabbing;}
.aud-team.drop{border-color:var(--lime);background:color-mix(in srgb,var(--lime) 12%,var(--bg0));box-shadow:inset 4px 0 0 var(--bc),0 0 0 2px color-mix(in srgb,var(--lime) 45%,transparent);}
.aud-pl-empty{font-size:10px;color:var(--dim);font-style:italic;}

/* cidade + pop-up do líder */
.gs-cidade{display:flex;flex-direction:column;gap:12px;}
.gs-city-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.gs-city-bar-hint{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-tag);
  text-transform:uppercase;letter-spacing:.05em;font-size:10px;color:var(--muted);}
.gs-cidade-stage{position:relative;}
.gs-cola-clients{max-height:150px;overflow-y:auto;padding-right:6px;}
.gs-cola-clients::-webkit-scrollbar{width:9px;}
.gs-cola-clients::-webkit-scrollbar-track{background:var(--bg0);}
.gs-cola-clients::-webkit-scrollbar-thumb{background:var(--line);border:2px solid var(--bg0);}
.gs-cola-tip{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.05em;font-size:10px;color:var(--lime);}
.gs-popup{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;width:min(440px,84%);
  background:var(--bg1);border:4px solid var(--line);box-shadow:inset 0 0 0 3px var(--bevel-soft),8px 8px 0 rgba(0,0,0,.55);}
.gs-popup{--pc:var(--pink);}
.gs-popup-hd{display:flex;align-items:center;gap:8px;padding:11px 13px;border-bottom:3px solid var(--line);
  background:var(--bg2);font-family:var(--font-display);font-size:12px;color:var(--pc);}
.gs-popup-hd .x{margin-left:auto;color:var(--dim);cursor:pointer;}
.gs-popup-hd .x:hover{color:var(--text);}
.gs-popup-bd{padding:15px;}
.gs-popup-bd > p{margin:0 0 11px;font-size:13px;line-height:1.6;color:var(--muted);}
.gs-popup-bd > p b{color:var(--orange);}
.gs-buy{display:flex;flex-direction:column;gap:7px;}
.gs-buy-row{display:flex;align-items:center;gap:10px;padding:9px 11px;border:2px solid var(--line);background:var(--bg0);}
.gs-buy-row .nm{font-weight:600;font-size:13px;}
.gs-buy-row .cost{margin-left:auto;font-family:var(--font-tag);font-size:11px;color:var(--muted);}
.gs-buy-row .px-stepper{margin-left:0;}
.px-stepper button:disabled{opacity:.32;cursor:not-allowed;}
.gs-popup-note{margin:13px 0 0;font-size:12px;color:var(--dim);line-height:1.5;}
/* Universidade — lista de cursos + certificados */
.gs-course-list{display:flex;flex-direction:column;gap:6px;max-height:196px;overflow-y:auto;padding-right:6px;}
.gs-course-list::-webkit-scrollbar{width:9px;}
.gs-course-list::-webkit-scrollbar-track{background:var(--bg0);}
.gs-course-list::-webkit-scrollbar-thumb{background:var(--line);border:2px solid var(--bg0);}
.gs-course{display:flex;align-items:center;gap:9px;width:100%;text-align:left;cursor:pointer;font-family:inherit;
  padding:8px 10px;border:2px solid var(--line);background:var(--bg0);color:var(--text);}
.gs-course:hover:not(:disabled){border-color:color-mix(in srgb,var(--lime) 55%,var(--line));}
.gs-course.on{border-color:var(--lime);background:#0d1f0a;}
.gs-course:disabled{opacity:.4;cursor:not-allowed;}
.gs-course .nm{font-size:12px;font-weight:600;}
.gs-course .ef{margin-left:auto;font-family:var(--font-tag);font-size:10px;color:var(--muted);text-align:right;}
.gs-ck{width:15px;height:15px;border:2px solid var(--line);background:var(--bg1);flex:0 0 auto;position:relative;}
.gs-course.on .gs-ck{background:var(--lime);border-color:var(--lime);}
.gs-course.on .gs-ck::after{content:"";position:absolute;left:3px;top:0;width:5px;height:9px;
  border:solid var(--bg0);border-width:0 2px 2px 0;transform:rotate(40deg);}
.gs-cert-row{display:flex;gap:8px;margin-top:12px;}
.gs-cert{flex:1;display:flex;align-items:center;gap:6px;padding:7px 9px;border:2px solid var(--line);
  background:var(--bg0);color:var(--muted);}
.gs-cert.on{border-color:var(--cc);color:var(--text);background:color-mix(in srgb,var(--cc) 12%,var(--bg0));}
.gs-cert .nm{font-family:var(--font-display);font-size:10px;}
.gs-cert .st{margin-left:auto;font-family:var(--font-tag);font-size:9px;text-transform:uppercase;letter-spacing:.04em;}
/* Caixa 24h — recolher faturamento */
.gs-caixa{display:flex;flex-direction:column;gap:11px;}
.gs-caixa .px-btn{align-self:center;}
.gs-caixa-line{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:11px 13px;border:2px solid var(--line);background:var(--bg0);}
.gs-caixa-line .lbl{font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.05em;font-size:10px;color:var(--muted);}
.gs-caixa-line .amt{font-family:var(--font-display);font-size:17px;color:var(--text);}
.gs-caixa-line .amt.up{color:var(--lime);}
.gs-caixa-line.total{border-color:color-mix(in srgb,var(--orange) 45%,var(--line));}
.gs-caixa-line.total .amt{color:var(--orange);}
/* Rodapé do popup — barra de energia */
.gs-popup-ft{display:flex;align-items:center;gap:10px;padding:11px 15px;border-top:3px solid var(--line);background:var(--bg2);}
.gs-popup-ft .lbl{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-tag);
  text-transform:uppercase;letter-spacing:.05em;font-size:9px;color:var(--muted);}
.gs-popup-ft b{font-family:var(--font-display);font-size:11px;color:var(--orange);}
.gs-energy-bar{flex:1;height:10px;border:2px solid var(--line);background:var(--bg0);overflow:hidden;}
.gs-energy-bar span{display:block;height:100%;background:var(--orange);transition:width .12s steps(4);}
.gs-popup-ft .px-btn{margin-left:4px;white-space:nowrap;}
/* Arsenal — confirmação de saída (entra uma vez por rodada) */
.gs-popup-confirm{position:absolute;inset:0;z-index:3;background:rgba(5,12,12,.93);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px;text-align:center;}
.gs-popup-confirm p{margin:0;max-width:300px;font-size:13px;line-height:1.6;color:var(--muted);}
.gs-popup-confirm p b{color:var(--pink);}
.gs-popup-confirm-btns{display:flex;gap:9px;flex-wrap:wrap;justify-content:center;}
/* Cola do líder na cidade */
.gs-cola{border:3px solid var(--line);background:var(--bg0);padding:12px 14px;}
.gs-cola-hd{display:flex;align-items:center;gap:6px;font-family:var(--font-tag);text-transform:uppercase;
  letter-spacing:.06em;font-size:10px;color:var(--cyan);margin-bottom:10px;}
.gs-cola-grid{display:flex;flex-wrap:wrap;gap:7px;}
.gs-cola-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:2px solid var(--line);
  background:var(--bg1);font-family:var(--font-tag);text-transform:uppercase;letter-spacing:.04em;font-size:10px;color:var(--muted);}
.gs-cola-chip b{font-family:var(--font-display);font-size:10px;color:var(--text);}
.gs-cola-note{margin:11px 0 0;font-size:11.5px;line-height:1.55;color:var(--dim);}

/* Home — hero com a cidade-metaverso de fundo (imagem) */
.home-hero{
  background:
    linear-gradient(180deg, rgba(6,14,24,.74) 0%, rgba(6,14,24,.40) 38%, rgba(6,14,24,.50) 62%, rgba(6,14,24,.90) 100%) center/cover no-repeat,
    url(assets/vendopolis-city-hero.png) center 40% / cover no-repeat;
  background-color:#0a1226;
}

/* Prospect City — hero com a cidade de fundo (imagem) */
.arena-hero{
  background:
    linear-gradient(180deg, rgba(4,14,13,.72) 0%, rgba(4,14,13,.34) 42%, rgba(4,14,13,.40) 64%, rgba(4,14,13,.86) 100%) center/cover no-repeat,
    url(assets/prospect-city-hero.png) center 42% / cover no-repeat;
  background-color:#06100f;
}
/* caixinha translúcida (fosca) atrás dos textos do hero */
.hero-box{display:inline-block;background:rgba(4,16,15,.5);border:2px solid var(--line);
  box-shadow:inset 0 0 0 2px var(--bevel-soft),4px 4px 0 rgba(0,0,0,.35);
  padding:12px 22px;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);}

/* barra de stats encaixada no rodapé do hero (ponte) */
.lp-trust-bridge{position:relative;z-index:6;display:flex;justify-content:center;
  margin-top:-38px;margin-bottom:6px;padding:0 24px;}
.hm-point{padding:22px;display:flex;flex-direction:column;gap:9px;}
.hm-point .px-tag{font-size:10px;}
.hm-point h4{font-family:var(--font-display);font-size:13px;line-height:1.5;margin:0;color:var(--text);}
.hm-point p{font-size:14px;line-height:1.65;color:var(--muted);margin:0;}
