:root{
  --bg:#0b1220;
  --bg2:#0f1a2e;
  --card:#121f38;
  --card2:#16264a;
  --border:#1f3358;
  --txt:#e8eefc;
  --muted:#8da3c7;
  --blue:#2563eb;
  --blue2:#3b82f6;
  --red:#dc2626;
  --red2:#ef4444;
  --gold:#f59e0b;
  --gold2:#fbbf24;
  --green:#16a34a;
  --green2:#22c55e;
  --purple:#8b5cf6;
  --radius:14px;
  --beadsz:18px;
  --grid-gap:3px;
}
*{margin:0;padding:0;box-sizing:border-box;font-family:'Segoe UI',system-ui,sans-serif}
body{background:linear-gradient(160deg,var(--bg) 0%,var(--bg2) 60%,#0d1526 100%);color:var(--txt);min-height:100vh;padding-bottom:60px}

/* ===== HEADER HORIZONTAL ===== */
.brand{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;flex-direction:row;align-items:center;gap:20px;padding:0 28px;min-height:80px;background:#0b1220;border-bottom:none;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.brand-divider{width:1px;height:26px;background:var(--border);flex-shrink:0}
.brand-spacer{flex:1}
.magna-spark-logo{display:flex;align-items:center;flex-shrink:0;animation:logo-pulse 4s ease-in-out infinite;margin-bottom:0}
.ms-logo-img{width:200px;height:auto;display:block;object-fit:contain;align-self:center}
.ms-shape{width:30px;height:30px;background:linear-gradient(135deg,var(--blue2),var(--green2));border-radius:8px;position:relative;flex-shrink:0}
.ms-shape::after{content:'';position:absolute;top:25%;left:25%;right:25%;bottom:25%;background:#0b1220;transform:rotate(45deg);border-radius:3px}
.ms-title{font-size:1.4rem;font-weight:900;letter-spacing:.8px;color:var(--txt);margin:0;white-space:nowrap}
.ms-title span{background:linear-gradient(90deg,var(--gold2),var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent}
@keyframes logo-pulse{0%,100%{filter:drop-shadow(0 0 8px rgba(34,197,94,.35)) drop-shadow(0 0 8px rgba(59,130,246,.35))}50%{filter:drop-shadow(0 0 16px rgba(34,197,94,.6)) drop-shadow(0 0 16px rgba(59,130,246,.6))}}
nav{display:flex;flex-direction:row;gap:4px;align-items:center}
nav button{background:transparent;border:1px solid var(--border);color:var(--muted);padding:8px 18px;border-radius:8px;cursor:pointer;font-size:.8rem;font-weight:700;transition:.18s;letter-spacing:.5px;min-width:0;text-align:center;white-space:nowrap}
nav button:hover{color:var(--txt);border-color:rgba(37,99,235,.4);background:#12203a}
nav button.active{background:linear-gradient(135deg,#1e3a8a,var(--blue));color:#fff;border-color:transparent;box-shadow:0 0 14px rgba(37,99,235,.4)}

main{max-width:1600px;margin:0 auto;padding:28px 36px 60px;min-width:0}
section.page{display:none}
section.page.visible{display:block;animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
h2.section-title{font-size:1.2rem;margin:26px 0 14px;display:flex;align-items:center;gap:10px}
h2.section-title::before{content:'';width:5px;height:22px;border-radius:3px;background:linear-gradient(var(--gold2),var(--gold))}

/* ===== GAME CARDS ===== */
.games-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:20px}
.game-card{background:linear-gradient(150deg,var(--card),var(--card2));border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:relative;overflow:hidden}
.game-card::before{content:'';position:absolute;inset:0 0 auto 0;height:4px}
.game-card.live::before{background:linear-gradient(90deg,var(--red),var(--gold))}
.game-card.fp::before{background:linear-gradient(90deg,var(--blue),var(--purple))}
.game-card .tag{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:999px;margin-bottom:10px}
.tag.tag-live{background:rgba(220,38,38,.18);color:var(--red2);border:1px solid rgba(220,38,38,.4)}
.tag.tag-fp{background:rgba(139,92,246,.18);color:#a78bfa;border:1px solid rgba(139,92,246,.4)}
.game-card h3{font-size:1.08rem;margin-bottom:8px}
.game-card p{color:var(--muted);font-size:.86rem;line-height:1.55}
.stats{margin-top:14px;display:flex;flex-direction:column;gap:9px}
.stat-row{display:flex;align-items:center;gap:10px;font-size:.8rem}
.stat-row .lbl{width:92px;color:var(--muted);flex-shrink:0}
.bar{flex:1;height:9px;background:#0a1426;border-radius:99px;overflow:hidden}
.bar i{display:block;height:100%;border-radius:99px}
.bar .b-blue{background:linear-gradient(90deg,var(--blue),var(--blue2))}
.bar .b-red{background:linear-gradient(90deg,var(--red),var(--red2))}
.bar .b-gold{background:linear-gradient(90deg,var(--gold),var(--gold2))}
.bar .b-green{background:linear-gradient(90deg,var(--green),var(--green2))}
.pct{width:56px;text-align:right;font-weight:700;font-variant-numeric:tabular-nums}
.pct.c-blue{color:var(--blue2)} .pct.c-red{color:var(--red2)} .pct.c-gold{color:var(--gold2)} .pct.c-green{color:var(--green2)}

/* ===== CATALOGADOR ===== */
.panel{background:linear-gradient(150deg,var(--card),var(--card2));border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-top:16px}
.panel h3{font-size:1rem;margin-bottom:4px}
.panel .sub{color:var(--muted);font-size:.8rem;margin-bottom:14px}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}
.res-btn{flex:1;min-width:110px;padding:14px 10px;border:none;border-radius:10px;font-size:.95rem;font-weight:700;color:#fff;cursor:pointer;transition:.15s;letter-spacing:.3px}
.res-btn:hover{transform:translateY(-2px);filter:brightness(1.12)}
.res-btn.blue{background:linear-gradient(135deg,var(--blue),var(--blue2))}
.res-btn.red{background:linear-gradient(135deg,var(--red),var(--red2))}
.res-btn.gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#1a1206}
.util-row{display:flex;gap:8px;margin-top:10px}
.util-btn{background:transparent;border:1px solid var(--border);color:var(--muted);padding:7px 14px;border-radius:8px;cursor:pointer;font-size:.78rem}
.util-btn:hover{color:var(--txt);border-color:var(--muted)}

.summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-top:16px}
.sum-box{background:#0a1426;border:1px solid var(--border);border-radius:10px;padding:12px;text-align:center}
.sum-box .v{font-size:1.3rem;font-weight:800;font-variant-numeric:tabular-nums}
.sum-box .l{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-top:3px}

.beads{display:flex;gap:5px;flex-wrap:wrap;margin-top:16px;min-height:30px}
.bead{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:800;color:#fff;flex-shrink:0}
.bead.blue{background:var(--blue2)} .bead.red{background:var(--red2)} .bead.gold{background:var(--gold);color:#1a1206}
.bead.num-red{background:var(--red2)} .bead.num-black{background:#1f2937;border:1px solid #4b5563} .bead.num-green{background:var(--green2);color:#06270f}

.signal{margin-top:14px;border-radius:10px;padding:12px 14px;font-size:.85rem;border:1px dashed var(--border);color:var(--muted)}
.signal.hot{border-color:var(--gold);color:var(--gold2);background:rgba(245,158,11,.07)}
.signal.signal-inside{margin:0 0 12px;border-style:solid;border-color:rgba(245,158,11,.35);background:linear-gradient(90deg,rgba(245,158,11,.06),rgba(34,197,94,.06));color:var(--muted);font-weight:600;text-align:center;letter-spacing:.3px;position:relative;overflow:hidden}
.signal.signal-inside.hot{border-color:var(--gold2);color:#fff8d6;background:linear-gradient(90deg,rgba(245,158,11,.18),rgba(220,38,38,.12));animation:signal-neon 1.4s ease-in-out infinite;text-shadow:0 0 8px var(--gold2),0 0 16px rgba(245,158,11,.7)}
@keyframes signal-neon{
  0%,100%{box-shadow:0 0 10px rgba(245,158,11,.45),0 0 22px rgba(245,158,11,.25),inset 0 0 12px rgba(245,158,11,.18);border-color:var(--gold2)}
  50%{box-shadow:0 0 18px rgba(251,191,36,.95),0 0 38px rgba(245,158,11,.7),inset 0 0 18px rgba(251,191,36,.35);border-color:#fde68a}
}

/* ===== DASHBOARD ===== */
.dash-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.dash-head h3{margin:0}
.filter-row{display:flex;gap:6px;flex-wrap:wrap}
.filter-row button{background:#0a1426;border:1px solid var(--border);color:var(--muted);padding:6px 13px;border-radius:999px;cursor:pointer;font-size:.74rem;font-weight:600}
.filter-row button.active{border-color:var(--gold);color:var(--gold2);background:rgba(245,158,11,.08)}
.dash-grid{display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:center}
.donut{width:175px;height:175px;border-radius:50%;position:relative;margin:0 auto;background:#0a1426;transition:.3s}
.donut-hole{position:absolute;inset:24px;background:var(--card);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center}
.donut-hole .dh-v{font-size:1.7rem;font-weight:800;font-variant-numeric:tabular-nums}
.donut-hole .dh-l{font-size:.62rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.legend{display:flex;justify-content:center;gap:14px;margin-top:12px;font-size:.74rem;color:var(--muted);flex-wrap:wrap}
.legend i{width:10px;height:10px;border-radius:3px;display:inline-block;margin-right:5px;vertical-align:-1px}
.legend b{color:var(--txt);margin-left:3px;font-variant-numeric:tabular-nums}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(125px,1fr));gap:10px;align-content:start}
.kpi{background:#0a1426;border:1px solid var(--border);border-radius:10px;padding:12px 8px;text-align:center}
.kpi .v{font-size:1.22rem;font-weight:800;font-variant-numeric:tabular-nums}
.kpi .l{font-size:.62rem;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-top:4px}

.hroad-wrap{margin-top:14px;background:#0a1426;border:1px solid var(--border);border-radius:10px;padding:12px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.hroad-cols{display:grid;gap:var(--grid-gap,3px);margin-bottom:6px}
.hroad-cols span{font-size:.58rem;color:var(--muted);text-align:center;font-weight:700}

.hroad-preds{display:grid;gap:5px;margin-bottom:10px;align-items:end}
.hp-slot{display:flex;flex-direction:column;align-items:center;gap:3px}
.hp-slot .hp-pct{font-size:.66rem;font-weight:800;letter-spacing:.3px;font-variant-numeric:tabular-nums;text-shadow:0 0 6px currentColor}
.hp-slot.blue .hp-pct{color:#7dd3fc}
.hp-slot.red .hp-pct{color:#fda4af}
.hp-slot .hp-cell{width:var(--beadsz,26px);height:var(--beadsz,26px);border-radius:50%;position:relative}
.hp-slot.blue .hp-cell{background:radial-gradient(circle at 35% 28%,#bae6fd 0%,#38bdf8 35%,#1d4ed8 75%,#0b2461 100%);box-shadow:0 0 8px rgba(56,189,248,.9),0 0 18px rgba(37,99,235,.7),inset 0 0 6px rgba(255,255,255,.35)}
.hp-slot.red .hp-cell{background:radial-gradient(circle at 35% 28%,#fecdd3 0%,#fb7185 35%,#dc2626 75%,#5f0a0a 100%);box-shadow:0 0 8px rgba(251,113,133,.9),0 0 18px rgba(220,38,38,.7),inset 0 0 6px rgba(255,255,255,.35)}
.hp-slot .hp-cell::after{content:'';position:absolute;inset:-3px;border-radius:50%;border:1px solid;animation:hp-ring 1.8s ease-in-out infinite;pointer-events:none}
.hp-slot.blue .hp-cell::after{border-color:rgba(125,211,252,.6)}
.hp-slot.red .hp-cell::after{border-color:rgba(253,164,175,.6)}
@keyframes hp-ring{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.18);opacity:0}}

/* Grid externa: numeração de linhas + colunas + matriz */
.hroad-frame{display:grid;grid-template-columns:auto 1fr;column-gap:6px;row-gap:6px;align-items:start;margin-top:6px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.hroad-frame::-webkit-scrollbar{height:6px}
.hroad-frame::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.hroad-frame .hroad-corner{}
.hroad-frame .hroad-cols{margin-bottom:0}
.hroad-rows{display:grid;gap:var(--grid-gap,3px);font-size:.58rem;color:var(--muted);font-weight:700;font-variant-numeric:tabular-nums;align-self:start}
.hroad-rows span{display:flex;align-items:center;justify-content:flex-end;height:var(--beadsz,18px);min-width:18px;padding-right:3px;line-height:1}
.hroad-rows span.row-bottom{color:#fde68a;text-shadow:0 0 4px rgba(245,158,11,.55)}
.hroad{display:grid;gap:var(--grid-gap,3px)}
.hroad span{width:var(--beadsz,18px);height:var(--beadsz,18px);border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,.4)}
.hroad span.blue{background:radial-gradient(circle at 35% 28%,#86aeff,var(--blue) 70%)}
.hroad span.red{background:radial-gradient(circle at 35% 28%,#ff8a8a,var(--red) 70%)}
.hroad span.gold{background:radial-gradient(circle at 35% 28%,#ffe27a,#eab308 70%)}
.hroad span.empty{background:transparent;box-shadow:none;border:1px dashed #24365c}

/* destaque do PADRÃO 5 (5 céls que formaram a sequência) */
.hroad span.streak-hit{box-shadow:0 0 8px rgba(255,255,255,.55),0 0 18px currentColor,0 1px 4px rgba(0,0,0,.4);animation:streak-hit-pulse 1.2s ease-in-out infinite;position:relative;z-index:1;outline:2px solid #fff;outline-offset:1px}
.hroad span.blue.streak-hit{color:#7dd3fc}
.hroad span.red.streak-hit{color:#fda4af}
@keyframes streak-hit-pulse{0%,100%{transform:scale(1);filter:brightness(1.05)}50%{transform:scale(1.18);filter:brightness(1.3)}}

/* ALVOS de entrada projetada (bloco-espelho de 5 céls) */
.hroad span.entry-target{position:relative;z-index:3;border:2px solid #fde68a!important;box-shadow:0 0 14px #fde68a,0 0 28px #f59e0b,inset 0 0 8px rgba(255,255,255,.6);animation:entry-target-pulse .85s ease-in-out infinite}
.hroad span.entry-target.empty{background:radial-gradient(circle at 50% 50%,rgba(251,191,36,.45),rgba(245,158,11,.18) 70%)!important;border:2px dashed #fde68a!important;box-shadow:0 0 14px #fde68a,inset 0 0 8px rgba(255,255,255,.3)}
.hroad span.entry-target::after{content:'◎';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:calc(var(--beadsz,26px) * .55);color:#fff;text-shadow:0 0 5px #000,0 0 10px #f59e0b;font-weight:900;pointer-events:none}
.hroad span.entry-target.result-W{border-color:#22c55e!important;box-shadow:0 0 14px #22c55e,0 0 28px #16a34a,inset 0 0 8px rgba(255,255,255,.4);animation:none}
.hroad span.entry-target.result-W::after{content:'✓';color:#bbf7d0;text-shadow:0 0 6px #16a34a,0 0 12px #22c55e}
.hroad span.entry-target.result-L{border-color:#ef4444!important;box-shadow:0 0 14px #ef4444,0 0 28px #b91c1c,inset 0 0 8px rgba(255,255,255,.4);animation:none}
.hroad span.entry-target.result-L::after{content:'✗';color:#fecaca;text-shadow:0 0 6px #b91c1c,0 0 12px #ef4444}
.hroad span.entry-target.result-T{border-color:#fbbf24!important;box-shadow:0 0 14px #fbbf24,inset 0 0 8px rgba(255,255,255,.4);animation:none}
.hroad span.entry-target.result-T::after{content:'='; color:#fde68a}
@keyframes entry-target-pulse{0%,100%{transform:scale(1);filter:brightness(1.1)}50%{transform:scale(1.28);filter:brightness(1.55)}}

/* ===== PAINEL DE ALERTAS 5× ===== */
.alerts5-panel{margin:14px 0 6px;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:linear-gradient(150deg,rgba(245,158,11,.06),rgba(34,197,94,.04))}
.alerts5-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.alerts5-title{font-size:.84rem;font-weight:800;color:#fde68a;letter-spacing:.3px;display:flex;align-items:center;gap:8px}
.alerts5-stats{display:flex;gap:10px;font-size:.72rem;flex-wrap:wrap}
.a5-stat{padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:#0a1426;font-weight:700}
.a5-stat .v{font-variant-numeric:tabular-nums;font-weight:900;margin-left:4px}
.a5-stat.win{border-color:rgba(34,197,94,.5);color:#bbf7d0}
.a5-stat.loss{border-color:rgba(239,68,68,.5);color:#fecaca}
.a5-stat.tie{border-color:rgba(251,191,36,.45);color:#fde68a}
.a5-stat.pending{border-color:rgba(125,211,252,.4);color:#7dd3fc}
.a5-stat.acc{border-color:rgba(167,139,250,.45);color:#c4b5fd}
.alerts5-list{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:6px;-webkit-overflow-scrolling:touch}
.alerts5-list::-webkit-scrollbar{width:6px}
.alerts5-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.a5-row{display:grid;grid-template-columns:auto 1fr auto;gap:10px;padding:7px 10px;border-radius:8px;background:#0a1426;border:1px solid var(--border);font-size:.74rem;align-items:center}
.a5-row.pending{border-color:rgba(125,211,252,.35);background:linear-gradient(90deg,rgba(125,211,252,.05),#0a1426)}
.a5-row.win{border-color:rgba(34,197,94,.5);background:linear-gradient(90deg,rgba(34,197,94,.08),#0a1426)}
.a5-row.loss{border-color:rgba(239,68,68,.45);background:linear-gradient(90deg,rgba(239,68,68,.08),#0a1426)}
.a5-row.tie{border-color:rgba(251,191,36,.4);background:linear-gradient(90deg,rgba(251,191,36,.08),#0a1426)}
.a5-badge{font-weight:900;font-size:.66rem;padding:3px 8px;border-radius:999px;letter-spacing:.5px;white-space:nowrap}
.a5-badge.b-axis-V{background:rgba(125,211,252,.18);color:#7dd3fc;border:1px solid rgba(125,211,252,.4)}
.a5-badge.b-axis-H{background:rgba(251,191,36,.18);color:#fde68a;border:1px solid rgba(251,191,36,.4)}
.a5-info{color:var(--muted);font-size:.7rem;line-height:1.45}
.a5-info b.c-blue{color:#7dd3fc} .a5-info b.c-red{color:#fda4af}
.a5-result{font-weight:800;font-size:.74rem;letter-spacing:.4px;padding:3px 9px;border-radius:6px;white-space:nowrap}
.a5-result.pending{color:#7dd3fc;background:rgba(125,211,252,.1);border:1px solid rgba(125,211,252,.3)}
.a5-result.win{color:#bbf7d0;background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.5)}
.a5-result.loss{color:#fecaca;background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.5)}
.a5-result.tie{color:#fde68a;background:rgba(251,191,36,.12);border:1px solid rgba(251,191,36,.45)}
.alerts5-actions{display:flex;gap:6px;flex-wrap:wrap}
.a5-btn{background:transparent;border:1px solid var(--border);color:var(--muted);padding:5px 11px;border-radius:7px;cursor:pointer;font-size:.7rem;font-weight:600}
.a5-btn:hover{color:var(--txt);border-color:var(--muted)}
.alerts5-empty{color:var(--muted);font-size:.78rem;text-align:center;padding:14px;font-style:italic}
.a5-cells{display:inline-flex;gap:3px;margin-top:4px}
.a5-cell-pill{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:5px;font-size:.62rem;font-weight:900;border:1px solid var(--border);background:#0a1426}
.a5-cell-pill.win{background:rgba(34,197,94,.18);color:#bbf7d0;border-color:rgba(34,197,94,.5)}
.a5-cell-pill.loss{background:rgba(239,68,68,.18);color:#fecaca;border-color:rgba(239,68,68,.5)}
.a5-cell-pill.tie{background:rgba(251,191,36,.16);color:#fde68a;border-color:rgba(251,191,36,.45)}
.a5-cell-pill.pending{color:#7dd3fc;border-color:rgba(125,211,252,.35)}
.hroad-notes{margin-top:12px;font-size:.72rem;color:var(--muted);line-height:1.7}
.hroad-notes b{color:var(--txt)}

/* ===== PAINEL ESTRATÉGIA 5× ===== */
.strat-5x{margin:0 0 12px;padding:10px 14px;border-radius:10px;border:1px dashed rgba(125,211,252,.25);background:linear-gradient(90deg,rgba(56,189,248,.04),rgba(220,38,38,.04));text-align:center;font-size:.85rem;color:var(--muted);transition:.25s}
.strat-5x .s5-head{font-weight:800;letter-spacing:.4px;font-size:.86rem}
.strat-5x .s5-armed{color:var(--muted);font-weight:600;font-size:.78rem}
.strat-5x.triggered{border-style:solid;border-color:rgba(251,191,36,.65);background:linear-gradient(90deg,rgba(56,189,248,.12),rgba(220,38,38,.14),rgba(245,158,11,.14));animation:s5-pulse 1.2s ease-in-out infinite;color:#fff}
.strat-5x.triggered .s5-head{color:#fde68a;text-shadow:0 0 10px rgba(251,191,36,.85),0 0 22px rgba(245,158,11,.6);font-size:.96rem}
@keyframes s5-pulse{
  0%,100%{box-shadow:0 0 12px rgba(251,191,36,.45),0 0 26px rgba(245,158,11,.25),inset 0 0 14px rgba(251,191,36,.18)}
  50%{box-shadow:0 0 22px rgba(251,191,36,1),0 0 46px rgba(245,158,11,.75),inset 0 0 22px rgba(251,191,36,.4)}
}
.strat-5x .s5-body{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:8px;font-size:.82rem;font-weight:700}
.strat-5x .s5-label{color:#cbd5e1;font-weight:600;font-size:.78rem;letter-spacing:.3px}
.strat-5x .s5-arrow{color:#fde68a;font-size:1.1rem;text-shadow:0 0 8px rgba(245,158,11,.8)}
.strat-5x .s5-detected,.strat-5x .s5-target{padding:3px 12px;border-radius:999px;font-weight:800;letter-spacing:.5px;text-shadow:0 0 8px currentColor}
.strat-5x .s5-blue{background:linear-gradient(90deg,rgba(56,189,248,.25),rgba(29,78,216,.25));color:#7dd3fc;border:1px solid rgba(56,189,248,.5);box-shadow:0 0 10px rgba(56,189,248,.55),inset 0 0 6px rgba(56,189,248,.25)}
.strat-5x .s5-red{background:linear-gradient(90deg,rgba(251,113,133,.25),rgba(220,38,38,.25));color:#fda4af;border:1px solid rgba(251,113,133,.5);box-shadow:0 0 10px rgba(251,113,133,.55),inset 0 0 6px rgba(251,113,133,.25)}
.strat-5x .s5-row{display:flex;gap:8px;justify-content:center;margin-top:10px}
.strat-5x .s5-bead{width:22px;height:22px;border-radius:50%;display:inline-block;position:relative}
.strat-5x .s5-bead.blue{background:radial-gradient(circle at 35% 28%,#bae6fd 0%,#38bdf8 35%,#1d4ed8 75%,#0b2461 100%);box-shadow:0 0 10px rgba(56,189,248,.95),0 0 20px rgba(37,99,235,.6),inset 0 0 6px rgba(255,255,255,.4)}
.strat-5x .s5-bead.red{background:radial-gradient(circle at 35% 28%,#fecdd3 0%,#fb7185 35%,#dc2626 75%,#5f0a0a 100%);box-shadow:0 0 10px rgba(251,113,133,.95),0 0 20px rgba(220,38,38,.6),inset 0 0 6px rgba(255,255,255,.4)}
.strat-5x .s5-bead::after{content:'';position:absolute;inset:-3px;border-radius:50%;border:1px solid currentColor;opacity:.6;animation:s5-bead-ring 1.4s ease-in-out infinite}
.strat-5x .s5-bead.blue::after{color:#7dd3fc}
.strat-5x .s5-bead.red::after{color:#fda4af}
@keyframes s5-bead-ring{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.25);opacity:0}}

/* ===== ESTRATÉGIAS ===== */
.strat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.strat{background:linear-gradient(150deg,var(--card),var(--card2));border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.strat h4{font-size:.95rem;margin-bottom:6px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.strat .use{font-size:.65rem;font-weight:700;padding:3px 8px;border-radius:999px;background:rgba(34,197,94,.15);color:var(--green2);border:1px solid rgba(34,197,94,.35);white-space:nowrap}
.strat p{color:var(--muted);font-size:.8rem;line-height:1.5}

/* ===== ROLETA 2x2 ===== */
.special{border:1px solid rgba(245,158,11,.45);background:linear-gradient(150deg,#16213d,#1a1f33)}
.special h3{color:var(--gold2)}
.pair-select{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}
.pair-select button{background:#0a1426;border:1px solid var(--border);color:var(--muted);padding:8px 14px;border-radius:8px;cursor:pointer;font-size:.78rem;font-weight:600}
.pair-select button.active{border-color:var(--gold);color:var(--gold2);background:rgba(245,158,11,.08)}
.sides{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}
@media(max-width:640px){.sides{grid-template-columns:1fr}}
.side-box{background:#0a1426;border:1px solid var(--border);border-radius:12px;padding:14px}
.side-box.alert{border-color:var(--gold);box-shadow:0 0 14px rgba(245,158,11,.25)}
.side-box h5{font-size:.82rem;margin-bottom:4px}
.side-box .regions{font-size:.7rem;color:var(--muted);margin-bottom:10px}
.side-box .nums{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}
.side-box .nums span{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:700;color:#fff}
.nums span.r{background:var(--red2)} .nums span.b{background:#1f2937;border:1px solid #4b5563} .nums span.g{background:var(--green2);color:#06270f}
.side-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.side-stats div{background:#0e1a30;border-radius:8px;padding:8px 4px;text-align:center}
.side-stats .v{font-weight:800;font-size:1.05rem;font-variant-numeric:tabular-nums}
.side-stats .l{font-size:.6rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}

.bacbo-tab.active{background:linear-gradient(90deg,var(--blue),var(--blue2))!important;color:#fff!important;border-color:transparent!important}
/* ===== ROLETA — CONFIG + ASSERTIVIDADE + BEADS HEADER ===== */
.roleta-cfg-row{display:flex;gap:12px;align-items:stretch;flex-wrap:wrap;margin-top:16px}
.roleta-cfg-card{background:#0a1426;border:1px solid var(--border);border-radius:12px;padding:14px 16px;flex:1 1 280px}
.rcfg-title{font-size:.78rem;font-weight:800;color:var(--gold2);letter-spacing:.4px;margin-bottom:12px}
.rcfg-fields{display:flex;flex-direction:column;gap:10px}
.rcfg-label{display:flex;align-items:center;gap:8px;font-size:.77rem;color:var(--muted)}
.rcfg-label span:first-child{flex:1;min-width:0}
.rcfg-input{width:62px;background:#0b1220;border:1px solid var(--border);color:var(--txt);border-radius:7px;padding:5px 8px;font-size:.82rem;font-weight:700;text-align:center;font-variant-numeric:tabular-nums}
.rcfg-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 2px rgba(245,158,11,.18)}
.rcfg-unit{font-size:.7rem;color:var(--muted);white-space:nowrap}

.roleta-assert{background:#0a1426;border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-width:140px;flex:0 0 auto;text-align:center;transition:.3s}
.roleta-assert.ra-high{border-color:rgba(34,197,94,.5);background:linear-gradient(150deg,rgba(34,197,94,.08),#0a1426)}
.roleta-assert.ra-mid{border-color:rgba(251,191,36,.45);background:linear-gradient(150deg,rgba(251,191,36,.07),#0a1426)}
.roleta-assert.ra-low{border-color:rgba(239,68,68,.45);background:linear-gradient(150deg,rgba(239,68,68,.07),#0a1426)}
.ra-label{font-size:.68rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px}
.ra-pct{font-size:1.7rem;font-weight:900;font-variant-numeric:tabular-nums;line-height:1.1}
.roleta-assert.ra-high .ra-pct{color:var(--green2);text-shadow:0 0 10px rgba(34,197,94,.55)}
.roleta-assert.ra-mid  .ra-pct{color:var(--gold2);text-shadow:0 0 10px rgba(251,191,36,.55)}
.roleta-assert.ra-low  .ra-pct{color:var(--red2);text-shadow:0 0 10px rgba(239,68,68,.55)}
.roleta-assert .ra-pct{color:var(--muted)}
.ra-detail{font-size:.68rem;color:var(--muted);font-variant-numeric:tabular-nums}

.beads-header{display:flex;align-items:center;justify-content:space-between;margin-top:14px;margin-bottom:6px;flex-wrap:wrap;gap:6px}
.beads-count{font-size:.72rem;color:var(--muted);font-variant-numeric:tabular-nums}
.beads-limit-label{display:flex;align-items:center;gap:6px;font-size:.72rem;color:var(--muted)}
.beads-limit-sel{background:#0a1426;border:1px solid var(--border);color:var(--txt);border-radius:7px;padding:4px 8px;font-size:.75rem;cursor:pointer}
.beads-limit-sel:focus{outline:none;border-color:var(--gold)}
.beads-centered{justify-content:center}

footer{text-align:center;color:var(--muted);font-size:.72rem;margin-top:40px;padding:0 20px;line-height:1.6}
footer strong{color:var(--gold2)}

/* ===== STATUS API AO VIVO ===== */
.api-badge{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;font-size:.7rem;font-weight:700;border:1px solid;white-space:nowrap;flex-shrink:0}
.api-badge.offline{background:rgba(100,100,100,.1);color:#6b7280;border-color:rgba(100,100,100,.25)}
.api-badge.online{background:rgba(34,197,94,.12);color:var(--green2);border-color:rgba(34,197,94,.4)}
.api-badge.online::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--green2);display:inline-block;animation:blink-dot 1.4s ease-in-out infinite}
.api-badge.offline::before{content:'';width:7px;height:7px;border-radius:50%;background:#6b7280;display:inline-block}
@keyframes blink-dot{0%,100%{opacity:1}50%{opacity:.25}}
.lt-toast{position:fixed;bottom:76px;right:18px;padding:9px 15px;border-radius:10px;font-size:.78rem;font-weight:600;z-index:1000;box-shadow:0 4px 16px rgba(0,0,0,.55);animation:fade .25s ease;pointer-events:none;border:1px solid;backdrop-filter:blur(6px);max-width:220px}

/* ===== RESPONSIVO ===== */
@media(min-width:1600px){
  main{padding:28px 56px 60px}
  .games-grid{grid-template-columns:repeat(auto-fit,minmax(440px,1fr));gap:24px}
  .dash-grid{grid-template-columns:340px 1fr;gap:32px}
  .ms-title{font-size:1.6rem}
  .ms-shape{width:32px;height:32px}
  :root{--beadsz:22px;--grid-gap:4px}
}
@media(min-width:2000px){
  main{max-width:1900px;margin:0 auto;padding:28px 64px 60px}
  h2.section-title{font-size:1.4rem}
  .games-grid{grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:28px}
  .donut{width:200px;height:200px}
  .donut-hole .dh-v{font-size:2rem}
  .kpi .v{font-size:1.4rem}
}
@media(max-width:1280px){
  main{padding:28px 22px 60px}
  .games-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}
  .dash-grid{grid-template-columns:220px 1fr;gap:18px}
  .ms-title{font-size:1.25rem}
  .ms-shape{width:26px;height:26px}
  nav button{padding:7px 13px;font-size:.76rem}
  .donut{width:160px;height:160px}
}
@media(max-width:1024px){
  body{padding-bottom:40px}
  .brand{height:56px;padding:0 16px;flex-wrap:nowrap;overflow:hidden}
  .brand-divider{display:none}
  nav{flex-wrap:nowrap;overflow-x:auto;gap:4px;scrollbar-width:none;-ms-overflow-style:none}
  nav::-webkit-scrollbar{display:none}
  nav button{padding:7px 12px;font-size:.74rem;flex-shrink:0;white-space:nowrap}
  main{padding:72px 18px 40px;max-width:none}
  .games-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:14px}
  .dash-grid{grid-template-columns:1fr;gap:18px}
  .donut-wrap{display:flex;flex-direction:column;align-items:center}
  .donut{margin:0 auto}
  .kpis{grid-template-columns:repeat(auto-fit,minmax(110px,1fr))}
  :root{--beadsz:16px;--grid-gap:3px}
}
@media(max-width:768px){
  .brand{padding:12px 14px 8px;gap:10px}
  .ms-title{font-size:1.2rem}
  .ms-shape{width:24px;height:24px}
  nav{width:100%;justify-content:center;gap:6px;overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;scrollbar-width:thin}
  nav::-webkit-scrollbar{height:4px}
  nav::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
  nav button{padding:8px 12px;font-size:.76rem;white-space:nowrap;flex:0 0 auto}
  main{padding:100px 14px 22px}
  h2.section-title{font-size:1.05rem;margin:18px 0 10px}
  h2.section-title::before{height:18px;width:4px}
  .games-grid{grid-template-columns:1fr;gap:12px}
  .game-card{padding:16px}
  .game-card h3{font-size:1rem}
  .game-card p{font-size:.82rem;line-height:1.5}
  .stat-row{font-size:.74rem}
  .stat-row .lbl{width:78px}
  .panel{padding:14px;margin-top:12px}
  .panel h3{font-size:.95rem}
  .dash-head{gap:8px;margin-bottom:10px}
  .dash-head h3{font-size:.95rem;width:100%}
  .filter-row{gap:5px}
  .filter-row button{padding:5px 10px;font-size:.7rem}
  .donut{width:140px;height:140px}
  .donut-hole{inset:20px}
  .donut-hole .dh-v{font-size:1.4rem}
  .kpis{grid-template-columns:repeat(auto-fit,minmax(95px,1fr));gap:8px}
  .kpi{padding:10px 6px}
  .kpi .v{font-size:1.05rem}
  .summary{grid-template-columns:repeat(auto-fit,minmax(95px,1fr));gap:8px}
  .sum-box{padding:10px}
  .sum-box .v{font-size:1.1rem}
  .res-btn{padding:12px 8px;font-size:.85rem;min-width:90px}
  :root{--beadsz:14px;--grid-gap:2px}
  .hroad-wrap{padding:10px}
  .pair-select button{padding:7px 11px;font-size:.72rem}
  .sides{grid-template-columns:1fr;gap:10px}
  .side-box{padding:12px}
  .side-stats .v{font-size:.95rem}
  .strat-grid{grid-template-columns:1fr;gap:10px}
  .strat{padding:14px}
  .lt-toast{bottom:14px;right:10px;left:10px;max-width:none}
}
@media(max-width:480px){
  .brand{padding:10px 10px 6px}
  .ms-title{font-size:1.1rem}
  nav button{padding:7px 10px;font-size:.7rem}
  main{padding:110px 10px 18px}
  h2.section-title{font-size:.98rem;margin:14px 0 8px}
  .game-card{padding:14px}
  .game-card h3{font-size:.95rem}
  .game-card p{font-size:.78rem}
  .stat-row{font-size:.7rem;gap:7px}
  .stat-row .lbl{width:64px;font-size:.68rem}
  .bar{height:7px}
  .pct{width:46px;font-size:.7rem}
  .panel{padding:12px}
  .filter-row{gap:4px}
  .filter-row button{padding:4px 8px;font-size:.65rem}
  .dash-head h3{font-size:.88rem}
  .donut{width:120px;height:120px}
  .donut-hole{inset:16px}
  .donut-hole .dh-v{font-size:1.15rem}
  .donut-hole .dh-l{font-size:.55rem}
  .legend{font-size:.66rem;gap:8px}
  .kpis{grid-template-columns:repeat(2,1fr);gap:6px}
  .kpi{padding:8px 4px}
  .kpi .v{font-size:.95rem}
  .kpi .l{font-size:.55rem}
  .summary{grid-template-columns:repeat(2,1fr);gap:6px}
  .sum-box .v{font-size:.98rem}
  .sum-box .l{font-size:.6rem}
  .res-btn{padding:10px 6px;font-size:.78rem;min-width:0}
  .util-btn{padding:5px 10px;font-size:.7rem}
  .signal{padding:10px 12px;font-size:.76rem}
  :root{--beadsz:12px;--grid-gap:2px}
  .hroad-wrap{padding:8px}
  .hroad span,.hp-slot .hp-cell{box-shadow:0 1px 3px rgba(0,0,0,.4)}
  .hp-slot .hp-pct{font-size:.6rem}
  .hroad-notes{font-size:.66rem;line-height:1.55}
  .side-box{padding:10px}
  .side-box .nums span{width:20px;height:20px;font-size:.56rem}
  .side-stats{gap:4px}
  .side-stats div{padding:6px 3px}
  .side-stats .v{font-size:.88rem}
  .side-stats .l{font-size:.54rem}
  .pair-select{gap:5px}
  .pair-select button{padding:6px 9px;font-size:.66rem;flex:1 1 auto}
  .strat h4{font-size:.88rem;flex-wrap:wrap;gap:6px}
  .strat .use{font-size:.6rem;padding:2px 7px}
  .strat p{font-size:.74rem}
  footer{font-size:.66rem;margin-top:28px;padding:0 14px}
  .game-card .tag{font-size:.62rem;padding:3px 8px;margin-bottom:8px}
}
@media(max-width:360px){
  .ms-title{font-size:1rem}
  .ms-shape{width:20px;height:20px}
  nav button{padding:6px 9px;font-size:.65rem}
  main{padding:8px 8px 16px}
  .game-card,.panel,.strat,.side-box{padding:10px}
  .donut{width:108px;height:108px}
  .donut-hole{inset:14px}
  .donut-hole .dh-v{font-size:1rem}
  .kpis{gap:5px}
  .res-btn{font-size:.72rem;padding:9px 4px}
  :root{--beadsz:11px;--grid-gap:2px}
  .stat-row .lbl{width:56px}
}
@media(max-height:500px) and (orientation:landscape) and (max-width:1024px){
  .brand{padding:6px 12px}
  .magna-spark-logo{animation:none}
  nav button{padding:5px 10px;font-size:.7rem}
  main{padding:10px 14px}
  h2.section-title{margin:10px 0 8px}
  .donut{width:110px;height:110px}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .magna-spark-logo{animation:none}
}
@media(hover:none) and (pointer:coarse){
  nav button,.filter-row button,.util-btn,.pair-select button{min-height:36px}
  .res-btn{min-height:46px}
}

/* ============================================================
   CORES STRATEGY — Estratégia das Cores
   ============================================================ */

/* Sub-tab row (Dashboard / Estratégia das Cores) */
.cores-subtab-row {
  display: flex;
  gap: 6px;
  margin-bottom: 16px;
}
.cores-subtab-btn {
  flex: 1;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--muted);
  font-weight: 600;
  font-size: .82rem;
  cursor: pointer;
  transition: background .18s, color .18s, border-color .18s;
}
.cores-subtab-btn.active {
  background: var(--accent, #6366f1);
  color: #fff;
  border-color: var(--accent, #6366f1);
}
.cores-subtab-btn:hover:not(.active) {
  background: var(--card-hover, #23263a);
  color: var(--fg);
}

/* Panel header with toggle */
.cores-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 10px;
}
.cores-panel-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--fg);
}
.cores-panel-desc {
  font-size: .8rem;
  color: var(--muted);
  margin-bottom: 14px;
  line-height: 1.5;
}

/* Toggle switch */
.cores-toggle-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}
.cores-toggle-label {
  font-size: .8rem;
  color: var(--muted);
}
.cores-toggle {
  position: relative;
  width: 40px;
  height: 22px;
}
.cores-toggle input[type="checkbox"] {
  opacity: 0;
  width: 0;
  height: 0;
  position: absolute;
}
.cores-toggle-slider {
  position: absolute;
  inset: 0;
  background: var(--border);
  border-radius: 22px;
  transition: background .2s;
  cursor: pointer;
}
.cores-toggle-slider::before {
  content: '';
  position: absolute;
  left: 3px;
  top: 3px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #fff;
  transition: transform .2s;
}
.cores-toggle input:checked + .cores-toggle-slider {
  background: var(--accent, #6366f1);
}
.cores-toggle input:checked + .cores-toggle-slider::before {
  transform: translateX(18px);
}
.cores-switch-state {
  font-size: .75rem;
  color: var(--muted);
  min-width: 38px;
}

/* Grid container */
.cores-grid-container {
  overflow-x: auto;
  padding-bottom: 8px;
}
.cores-empty {
  color: var(--muted);
  font-size: .85rem;
  padding: 20px 0;
  text-align: center;
}

/* Grid wrapper — CSS grid driven by JS custom props */
.cores-grid-wrap {
  display: inline-grid;
  grid-template-rows: auto auto 1fr;
  min-width: 100%;
}

/* Probability row */
.cores-prob-row {
  display: grid;
  grid-template-columns: repeat(var(--cores-cols, 1), 1fr);
  gap: 2px;
  margin-bottom: 2px;
}
.cores-prob-cell {
  display: flex;
  justify-content: center;
}
.cores-prob-badge {
  display: inline-block;
  padding: 1px 4px;
  border-radius: 4px;
  font-size: .62rem;
  font-weight: 700;
  border: 1px solid var(--prob-color, var(--border));
  color: var(--prob-color, var(--muted));
  background: transparent;
  white-space: nowrap;
}
.cores-prob-high { opacity: 1; }
.cores-prob-mid  { opacity: .75; }
.cores-prob-low  { opacity: .45; }
.cores-col-signal .cores-prob-badge {
  background: color-mix(in srgb, var(--prob-color, #6366f1) 15%, transparent);
  box-shadow: 0 0 0 1px var(--prob-color, #6366f1);
}

/* Column-number row */
.cores-col-nums {
  display: grid;
  grid-template-columns: repeat(var(--cores-cols, 1), 1fr);
  gap: 2px;
  margin-bottom: 2px;
}
.cores-col-nums span {
  text-align: center;
  font-size: .58rem;
  color: var(--muted);
  opacity: .55;
}
.cores-col-num-active {
  color: var(--accent, #6366f1) !important;
  opacity: 1 !important;
  font-weight: 700;
}

/* Matrix */
.cores-matrix {
  display: grid;
  grid-template-columns: repeat(var(--cores-cols, 1), 1fr);
  grid-template-rows: repeat(var(--cores-rows, 9), 1fr);
  gap: 2px;
}
.cores-cell {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .58rem;
  font-weight: 700;
  color: #fff;
  text-shadow: 0 1px 2px rgba(0,0,0,.4);
  position: relative;
}
.cores-empty-cell {
  background: var(--card);
  border: 1px solid var(--border);
  opacity: .35;
}
.cores-filled {
  cursor: default;
}
.cores-col-highlight {
  outline: 1px solid var(--accent, #6366f1);
  outline-offset: 1px;
}

/* Linha Verde — indicador abaixo da célula qualificadora */
.gl-cell-bottom::after {
  content: '';
  position: absolute;
  left: -1px;
  right: -1px;
  bottom: -4px;
  height: 2px;
  background: var(--green2);
  border-radius: 1px;
  z-index: 2;
}
.gl-legend-bar {
  display: inline-block;
  width: 22px;
  height: 3px;
  background: var(--green2);
  border-radius: 2px;
  vertical-align: middle;
}

/* Linha Verde (Cores 1) — indicador acima das últimas 5 colunas */
.cores-lv-indicator {
  display: grid;
  grid-template-columns: repeat(var(--cores-cols, 1), 1fr);
  gap: 2px;
  align-items: center;
  justify-items: center;
  margin-bottom: 3px;
  min-height: 22px;
}
.cores-lv-ind-empty { height: 22px; }
.cores-lv-ind-dot {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  flex-shrink: 0;
  animation: lv-dot-pulse 1.4s ease-in-out infinite;
}
.cores-lv-ind-bar {
  height: 2px;
  width: 100%;
  background: var(--green2);
  border-radius: 1px;
  opacity: .65;
}
.cores-lv-ind-pct {
  font-size: .6rem;
  font-weight: 900;
  color: var(--green2);
  font-variant-numeric: tabular-nums;
  text-align: center;
  line-height: 1;
  text-shadow: 0 0 6px rgba(34,197,94,.55);
}
@keyframes lv-dot-pulse { 0%,100%{filter:brightness(1)} 50%{filter:brightness(1.4)} }

/* Linha Verde (Cores 1) — células da linha validada nas últimas 5 colunas */
.cores-cell.linha-verde-ativa {
  box-shadow:
    0 0 0 2px var(--green2),
    0 0 10px rgba(34,197,94,.55),
    0 1px 4px rgba(0,0,0,.4) !important;
  position: relative;
  z-index: 2;
  animation: lv-cell-pulse 1.4s ease-in-out infinite;
}
.cores-cell.linha-verde-ativa::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: -2px;
  right: -2px;
  height: 2px;
  background: var(--green2);
  border-radius: 1px;
  box-shadow: 0 0 4px rgba(34,197,94,.65);
}
@keyframes lv-cell-pulse {
  0%,100% { box-shadow: 0 0 0 2px var(--green2), 0 0 6px rgba(34,197,94,.4), 0 1px 4px rgba(0,0,0,.4); }
  50%      { box-shadow: 0 0 0 2px #4ade80, 0 0 16px rgba(34,197,94,.85), 0 1px 4px rgba(0,0,0,.4); }
}

/* Linha Verde — união contínua das janelas móveis válidas */
.hroad span.linha-verde-ativa { position: relative; }
.hroad span.linha-verde-ativa::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: calc(100% + var(--grid-gap, 3px));
  height: 2px;
  background-color: #22c55e;
  box-shadow: 0 1px 3px rgba(34,197,94,.45);
  z-index: 5;
}
.hroad span.linha-verde-inicio::after { border-radius: 2px 0 0 2px; }
.hroad span.linha-verde-fim::after {
  width: 100%;
  border-radius: 0 2px 2px 0;
}
.hroad span.linha-verde-inicio.linha-verde-fim::after { border-radius: 2px; }
.hroad span.linha-verde-ativa.empty { border-color: rgba(34,197,94,.4); }

/* Legend */
.cores-legend {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.cores-legend-item {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: .75rem;
  color: var(--muted);
}
.cores-legend-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}

/* ===== CORES 3 — Elementos específicos ===== */
.c3-header-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 12px;
  padding: 10px 14px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
}
.c3-desc-pill {
  font-size: .72rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(99,102,241,.15);
  color: #a5b4fc;
  border: 1px solid rgba(99,102,241,.35);
  letter-spacing: .3px;
}
.c3-reset-btn {
  margin-left: auto;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  padding: 5px 12px;
  border-radius: 8px;
  cursor: pointer;
  font-size: .76rem;
  font-weight: 600;
  transition: .15s;
}
.c3-reset-btn:hover { color: var(--txt); border-color: var(--muted); }
.c3-signal { gap: 10px; flex-wrap: wrap; }
.c3-session-counter {
  font-size: .8rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  padding: 4px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  white-space: nowrap;
  flex-shrink: 0;
}
.c3-session-bar {
  font-size: .8rem;
  color: var(--muted);
  padding: 8px 14px;
  border-radius: 8px;
  background: var(--card);
  border: 1px solid var(--border);
  margin-bottom: 10px;
}
.c3-unresponsive-alert {
  margin-bottom: 10px;
  padding: 11px 16px;
  border-radius: 10px;
  border: 1px solid var(--red2);
  background: rgba(220,38,38,.12);
  color: #fecaca;
  font-weight: 700;
  font-size: .85rem;
  text-align: center;
}
.ces-pct-val { font-weight: 800; }
.ces-pct-insuf { font-weight: 500; opacity: .6; font-size: .8rem; }

/* ===== CORES 2 — Gale selector ===== */
.c2-gale-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 12px;
  padding: 10px 12px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
}
.c2-gale-label {
  font-size: .78rem;
  color: var(--muted);
  font-weight: 600;
  white-space: nowrap;
}
.c2-gale-btn {
  padding: 5px 12px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--muted);
  font-size: .76rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
}
.c2-gale-btn.active {
  background: var(--green);
  color: #fff;
  border-color: var(--green);
}
.c2-gale-btn:hover:not(.active) {
  background: var(--card2);
  color: var(--txt);
}
.c2-assert-display {
  margin-left: auto;
  font-size: .72rem;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.c2-assert-high { color: var(--green2); font-weight: 700; }
.c2-assert-mid  { color: var(--gold2);  font-weight: 600; }

/* ===== CORES — Badge de sinal de entrada ===== */
.cores-entry-signal {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px;
  border-radius: 10px;
  margin-bottom: 10px;
  font-size: .88rem;
  font-weight: 700;
  letter-spacing: .3px;
}
.cores-entry-signal.ces-b {
  background: linear-gradient(90deg, rgba(37,99,235,.18), rgba(59,130,246,.08));
  border: 1px solid var(--blue2);
  color: #bae6fd;
  box-shadow: 0 0 14px rgba(37,99,235,.3);
  animation: ces-pulse-b 1.5s ease-in-out infinite;
}
.cores-entry-signal.ces-r {
  background: linear-gradient(90deg, rgba(220,38,38,.18), rgba(239,68,68,.08));
  border: 1px solid var(--red2);
  color: #fecaca;
  box-shadow: 0 0 14px rgba(220,38,38,.3);
  animation: ces-pulse-r 1.5s ease-in-out infinite;
}
@keyframes ces-pulse-b {
  0%,100% { box-shadow: 0 0 10px rgba(37,99,235,.3); }
  50%      { box-shadow: 0 0 22px rgba(59,130,246,.7); }
}
@keyframes ces-pulse-r {
  0%,100% { box-shadow: 0 0 10px rgba(220,38,38,.3); }
  50%      { box-shadow: 0 0 22px rgba(239,68,68,.7); }
}
.ces-dot {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  flex-shrink: 0;
}
.ces-text { flex: 1; }
.ces-text strong { font-size: 1rem; }

/* ===== CORES 2 — Trend alert (Melhoria 3) ===== */
.c2-trend-alert {
  margin-bottom: 12px;
  padding: 11px 16px;
  border-radius: 10px;
  border: 1px solid var(--gold);
  background: rgba(245,158,11,.12);
  color: var(--gold2);
  font-weight: 700;
  font-size: .85rem;
  text-align: center;
  animation: signal-neon 1.4s ease-in-out infinite;
}

@media (max-width: 500px) {
  .cores-cell { width: 18px; height: 18px; font-size: .52rem; }
  .cores-prob-badge { font-size: .56rem; padding: 1px 2px; }
  .cores-subtab-btn { font-size: .75rem; padding: 7px 6px; }
  .c2-gale-btn { font-size: .7rem; padding: 4px 8px; }
  .c2-assert-display { font-size: .65rem; }
}

/* ============================================================
   CONFLUÊNCIA PRO — Motor de Roadmaps Derivados
   ============================================================ */
:root { --cbeadsz: 20px; }

/* ── Indicador Central de Confluência ── */
.conf-indicator {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: linear-gradient(135deg, #0d1628, #111c35);
  margin-bottom: 18px;
  transition: .3s;
  min-height: 72px;
}
.conf-indicator.idle {
  border-color: var(--border);
  color: var(--muted);
}
.conf-indicator.active.blue {
  border-color: rgba(59,130,246,.7);
  background: linear-gradient(135deg, rgba(29,78,216,.14), rgba(15,23,42,.95));
  box-shadow: 0 0 22px rgba(59,130,246,.25), inset 0 0 18px rgba(59,130,246,.08);
  animation: conf-pulse-blue 1.6s ease-in-out infinite;
}
.conf-indicator.active.red {
  border-color: rgba(239,68,68,.7);
  background: linear-gradient(135deg, rgba(185,28,28,.14), rgba(15,23,42,.95));
  box-shadow: 0 0 22px rgba(239,68,68,.25), inset 0 0 18px rgba(239,68,68,.08);
  animation: conf-pulse-red 1.6s ease-in-out infinite;
}
@keyframes conf-pulse-blue {
  0%,100% { box-shadow: 0 0 16px rgba(59,130,246,.3), inset 0 0 14px rgba(59,130,246,.1); }
  50%      { box-shadow: 0 0 32px rgba(59,130,246,.65), inset 0 0 24px rgba(59,130,246,.2); }
}
@keyframes conf-pulse-red {
  0%,100% { box-shadow: 0 0 16px rgba(239,68,68,.3), inset 0 0 14px rgba(239,68,68,.1); }
  50%      { box-shadow: 0 0 32px rgba(239,68,68,.65), inset 0 0 24px rgba(239,68,68,.2); }
}
.conf-ind-icon { font-size: 2rem; flex-shrink: 0; line-height: 1; }
.conf-ind-content { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.conf-ind-title {
  font-size: .92rem;
  font-weight: 900;
  letter-spacing: .5px;
  text-transform: uppercase;
}
.conf-indicator.idle .conf-ind-title { color: var(--muted); }
.conf-indicator.active.blue .conf-ind-title { color: #93c5fd; text-shadow: 0 0 10px rgba(59,130,246,.7); }
.conf-indicator.active.red  .conf-ind-title { color: #fca5a5; text-shadow: 0 0 10px rgba(239,68,68,.7); }
.conf-ind-color {
  font-size: 1.05rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.conf-indicator.active.blue .conf-ind-color { color: #bfdbfe; }
.conf-indicator.active.red  .conf-ind-color { color: #fecaca; }
.conf-ind-dir {
  font-size: .72rem;
  font-weight: 700;
  padding: 2px 9px;
  border-radius: 999px;
  border: 1px solid;
  opacity: .85;
  letter-spacing: .4px;
}
.conf-indicator.active.blue .conf-ind-dir { border-color: rgba(59,130,246,.5); color: #93c5fd; }
.conf-indicator.active.red  .conf-ind-dir { border-color: rgba(239,68,68,.5);  color: #fca5a5; }
.conf-ind-sub {
  font-size: .72rem;
  color: var(--muted);
  line-height: 1.4;
}

/* ── Estatísticas de rodadas ── */
.conf-stats-bar {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.conf-stat {
  font-size: .7rem;
  color: var(--muted);
  background: #0a1426;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 3px 10px;
  font-variant-numeric: tabular-nums;
}
.conf-stat b { color: var(--txt); }

/* ── Big Road mini ── */
.conf-road-section { margin-bottom: 18px; }
.conf-section-label {
  font-size: .75rem;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .8px;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.conf-section-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
  opacity: .5;
}
.conf-road-wrap {
  background: #09112a;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.conf-road {
  display: inline-grid;
  gap: 4px;
}
/* Big Road beads */
.crd-bead {
  width: var(--cbeadsz, 20px);
  height: var(--cbeadsz, 20px);
  border-radius: 50%;
}
.crd-bead.blue { background: radial-gradient(circle at 35% 28%, #86aeff, var(--blue) 70%); box-shadow: 0 1px 3px rgba(0,0,0,.5); }
.crd-bead.red  { background: radial-gradient(circle at 35% 28%, #ff8a8a, var(--red)  70%); box-shadow: 0 1px 3px rgba(0,0,0,.5); }
.crd-bead.empty { background: transparent; border: 1px dashed #1e3058; }

/* ── Grade dos 3 derivados ── */
.conf-derived-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
@media (max-width: 680px) {
  .conf-derived-grid { grid-template-columns: 1fr; gap: 10px; }
}
.conf-derived-block {
  background: #09112a;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.conf-derived-title {
  font-size: .72rem;
  font-weight: 800;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .7px;
  margin-bottom: 8px;
}
.conf-derived-road {
  display: inline-grid;
  gap: 3px;
}
/* Derived road beads — círculo SÓLIDO vermelho (repetição) / ANEL azul (quebra) */
.drd-bead {
  width: var(--cbeadsz, 20px);
  height: var(--cbeadsz, 20px);
  border-radius: 50%;
  box-sizing: border-box;
}
.drd-bead.red {
  background: radial-gradient(circle at 38% 30%, #fca5a5, var(--red2) 65%);
  box-shadow: 0 1px 3px rgba(0,0,0,.4);
}
.drd-bead.blue {
  background: transparent;
  border: 2px solid var(--blue2);
  box-shadow: 0 0 4px rgba(59,130,246,.35);
}
.drd-bead.empty { background: transparent; border: 1px dashed #1e3058; opacity: .45; }

/* ── Legenda da Confluência Pro ── */
.conf-legend {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  font-size: .7rem;
  color: var(--muted);
  margin-bottom: 12px;
}
.conf-legend-item { display: flex; align-items: center; gap: 6px; }
.conf-legend-bead {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  flex-shrink: 0;
}
.conf-legend-bead.red  { background: var(--red2); }
.conf-legend-bead.blue { background: transparent; border: 2px solid var(--blue2); }

/* ── Notas explicativas ── */
.conf-notes {
  font-size: .7rem;
  color: var(--muted);
  line-height: 1.65;
  padding: 10px 14px;
  border-radius: 8px;
  border: 1px dashed var(--border);
  background: rgba(255,255,255,.02);
}
.conf-notes b { color: var(--txt); }

@media (max-width: 500px) {
  :root { --cbeadsz: 17px; }
  .conf-derived-title { font-size: .66rem; }
  .conf-ind-title { font-size: .8rem; }
  .conf-ind-color { font-size: .92rem; }
}

/* ===== CORES 1 — BADGE NO DASHBOARD PRINCIPAL ===== */
.cores1-dash-badge{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:8px;border:1px solid var(--border);background:#0a1426;font-size:.78rem;font-weight:700;margin:0 0 10px;flex-wrap:wrap;transition:.25s}
.cores1-dash-badge.c1b-blue{border-color:rgba(56,189,248,.55);background:linear-gradient(90deg,rgba(37,99,235,.12),#0a1426);color:#7dd3fc}
.cores1-dash-badge.c1b-red{border-color:rgba(239,68,68,.55);background:linear-gradient(90deg,rgba(220,38,38,.12),#0a1426);color:#fda4af}
.c1b-label{font-size:.66rem;font-weight:900;padding:2px 7px;border-radius:999px;border:1px solid currentColor;opacity:.7;letter-spacing:.5px}
.c1b-arrow{opacity:.5}
.c1b-color{font-weight:800}
.c1b-alert{font-size:.66rem;font-weight:900;letter-spacing:.6px;padding:2px 9px;border-radius:999px;background:rgba(251,146,60,.2);border:1px solid rgba(251,146,60,.6);color:#fdba74;animation:c1b-alert-pulse 1.1s ease-in-out infinite}
@keyframes c1b-alert-pulse{0%,100%{box-shadow:0 0 0 0 rgba(251,146,60,0)}50%{box-shadow:0 0 10px rgba(251,146,60,.6)}}
.cores1-dash-badge.c1b-changed{animation:c1b-changed-glow .9s ease-in-out 3}
@keyframes c1b-changed-glow{0%,100%{box-shadow:none}50%{box-shadow:0 0 18px rgba(251,146,60,.65),0 0 32px rgba(245,158,11,.4)}}

/* ===== LINHA ALTERADA — BEAD COM PADRÃO QUEBRADO ===== */
.hroad span.linha-alterada{outline:2px solid #fb923c!important;outline-offset:2px;animation:linha-alterada-pulse 1s ease-in-out 4;position:relative;z-index:4}
@keyframes linha-alterada-pulse{0%,100%{box-shadow:0 0 6px rgba(251,146,60,.4),0 1px 4px rgba(0,0,0,.4);filter:brightness(1)}50%{box-shadow:0 0 18px rgba(251,146,60,.95),0 0 34px rgba(245,158,11,.6);filter:brightness(1.35)}}
