/* assets/css/lottery.css */

:root{
  --text:#0b0f14;
  --muted:#6b7280;
  --line:rgba(0,0,0,.10);
  --bg:#ffffff;
  --soft:#f6f7f9;
  --card:#ffffff;
  --shadow: 0 10px 22px rgba(0,0,0,.06);
  --radius: 16px;
  --max: 1080px;

  /* você já seta isso por loteria */
  /* --brand: #0DB14B; */
  --brandDark: color-mix(in srgb, var(--brand) 70%, #000 30%);
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
}
a{color:inherit;text-decoration:none}

.wrap{max-width:var(--max); margin:0 auto; padding:14px 14px 44px;}

/* ---------- Topbar / Tabs (se você usa) ---------- */
.topbar{
  display:flex; align-items:center; justify-content:space-between;
  gap:12px;
  padding:10px 2px 12px;
  border-bottom:1px solid var(--line);
  position:sticky; top:0;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  z-index:10;
}
.back{
  font-weight:800;
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 10px; border-radius:999px;
}
.back:hover{background:var(--soft)}
.brand{
  display:flex; align-items:center; gap:10px;
  justify-content:center;
}
.brand img{
  width:30px; height:30px; border-radius:10px;
  border:1px solid rgba(0,0,0,.08);
  background:transparent;
}
.brand .name{font-weight:1000; letter-spacing:-.02em; font-size:20px}

.tabs{display:flex; gap:10px; align-items:center}
.tab{
  padding:9px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  font-weight:850;
  color: var(--muted);
  background:#fff;
  display:inline-flex; align-items:center; gap:8px;
}
.tab.active{color:#fff; border-color: var(--brandDark); background: var(--brandDark);}

/* ---------- Seções e títulos ---------- */
.section{
  margin-top:12px;
}
.section > .card,
.section .hero-classic,
.section .panel,
.section .box{
  border:1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: var(--shadow);
  overflow:hidden;
}

/* Suporta os dois nomes */
.sectionHead, .section-head{
  padding:12px 14px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--brand) 12%, transparent), rgba(0,0,0,0));
  border-bottom:1px solid rgba(0,0,0,.06);
  display:flex; align-items:flex-start; justify-content:space-between; gap:14px;
  flex-wrap:wrap;
}
.sectionHead .title, .section-head h2{
  margin:0;
  font-size:20px;
  letter-spacing:-.03em;
  font-weight:1000;
}
.sectionHead .subtitle, .section-head p{
  margin:5px 0 0;
  color:var(--muted);
  font-size:13px;
  font-weight:650;
}

.muted{color:var(--muted); font-weight:650; margin:0 0 10px; font-size:12.5px}

/* ---------- Cards ---------- */
.card{
  border:1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: var(--shadow);
  padding:12px 14px;
}
.card-title{
  margin:0 0 8px;
  font-size:13px;
  letter-spacing:-.01em;
  display:flex; align-items:center; gap:8px;
  font-weight:1000;
}

/* ---------- Layout helpers ---------- */
.row-between{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.split{
  margin-top:12px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}

/* ---------- Pills / chips ---------- */
.pills{display:flex; flex-wrap:wrap; gap:8px; margin-top:10px}
.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.10);
  background:#fff;
  font-weight:850;
  font-size:12px;
  white-space:nowrap;
}
.pill.ok{
  border-color: color-mix(in srgb, var(--brand) 35%, transparent);
  background: color-mix(in srgb, var(--brand) 8%, #fff);
}
.pill.no{
  border-color: rgba(239,68,68,.30);
  background: rgba(239,68,68,.06);
}

/* ---------- Listas (AQUI é onde seu Top 10 fica bonito) ---------- */
.list{display:grid; gap:8px}

/* suporta .li do seu componente */
.li{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:9px 10px;
  border-radius: 14px;
  border:1px solid rgba(0,0,0,.08);
  background:#fff;
}
.li-main{
  flex:1;
  font-weight:900;
  color:var(--text);
  letter-spacing:-.01em;
}
.li-meta{
  color: var(--muted);
  font-weight: 600;      /* 850 é overkill e não rende legibilidade */
  font-size: 0.9rem;     /* ~14.4px → leitura confortável */
  white-space: nowrap;
}

/* bolinha (badge) padrão */
.ball{
  width:34px; height:34px;
  border-radius:999px;
  display:grid; place-items:center;
  background: var(--brandDark);
  color:#fff;
  font-weight:1000;
  letter-spacing:-.02em;
  border:1px solid rgba(0,0,0,.08);
  box-shadow: 0 10px 18px rgba(0,0,0,.12);
}

/* badges */
.badge{
  min-width:34px;
  height:34px;
  border-radius:999px;
  display:grid; place-items:center;
  border:1px solid rgba(0,0,0,.10);
  background: rgba(0,0,0,.03);
  font-weight:1000;
  font-size:12px;
  padding:0 10px;
}
.badge-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 10px;
  border-radius:999px;
  background: rgba(0,0,0,.03);
  border:1px solid rgba(0,0,0,.10);
  font-weight:1000;
  font-size:12px;
  min-width:72px;
}

/* ---------- Note ---------- */
.note{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  background: color-mix(in srgb, var(--brand) 8%, #fff);
  border:1px solid color-mix(in srgb, var(--brand) 22%, transparent);
  color:#0b3a20;
  font-weight:650;
  font-size:12.5px;
  line-height:1.35;
}

/* ---------- DETAILS como botão ---------- */
details.details-action{border:0; background:transparent; padding:0; margin:0;}
details.details-action summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  background: var(--brandDark);
  border:1px solid var(--brandDark);
  color:#fff;
  font-weight:1000;
  cursor:pointer;
  user-select:none;
}
details.details-action summary:hover{filter:brightness(1.03)}
details.details-action summary::-webkit-details-marker{display:none;}
details.details-action .details-body{
  margin-top:10px;
  padding:10px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.08);
  background:#fff;
}

/* ---------- KPIs mini (se você usa) ---------- */
.kpi-mini{
  min-width:140px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  padding:10px 12px;
  background:#fff;
}
.kpi-mini-big{
  font-weight:1000;
  font-size:22px;
  letter-spacing:-.02em;
}

/* ---------- HERO (sem bagunçar o resto) ---------- */
.hero-classic{ padding:20px; }
.hero-classic-header{ margin-bottom:14px; padding-bottom:14px; border-bottom:1px solid var(--line); }
.hero-classic h1{ margin:0 0 8px; font-size:28px; font-weight:1000; letter-spacing:-.03em; }
.hero-classic-sub{ margin:0; font-size:14px; line-height:1.4; }

.hero-classic-numbers{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-top:14px; align-items:center;
}
.hero-classic-ball{
  width:50px; height:50px;
  border-radius:50%;
  background: var(--brand);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-weight:1000;
  font-size:18px;
  box-shadow: 0 6px 16px rgba(0,0,0,.12);
}
.hero-classic-ball.supersete{ width:45px; height:45px; font-size:16px; }

.trevos-container{
  display:flex; align-items:center; gap:8px;
  margin-left:14px; padding-left:14px;
  border-left:2px solid rgba(0,0,0,.10);
}
.hero-classic-trevo{
  width:40px; height:40px;
  border-radius:50%;
  background:#8b5cf6;
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-weight:1000;
}

.hero-8boxes{ margin-top:14px; }
.hero-box-row{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:10px;
  margin-top:10px;
}
.hero-box-card{
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  padding:12px 12px;
  background:#fff;
  min-height:92px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.hero-box-label{
  color:var(--muted);
  font-weight:900;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.hero-box-value{
  margin-top:7px;
  font-weight:1000;
  font-size:17px;
  letter-spacing:-.02em;
}
.hero-box-sub{
  margin-top:3px;
  color:var(--muted);
  font-size:12px;
  font-weight:650;
}
.status-box.badge-acc{
  border-color: rgba(245,158,11,.35);
  background: rgba(245,158,11,.08);
}
.status-box.badge-win{
  border-color: color-mix(in srgb, var(--brand) 35%, transparent);
  background: color-mix(in srgb, var(--brand) 8%, #fff);
}

.hero-classic-buttons{
  display:flex;
  justify-content:center;
  gap:10px;
  margin-top:16px;
  flex-wrap:wrap;
}
.btn{
  padding:10px 12px;
  border-radius: 14px;
  border:1px solid var(--line);
  background:#fff;
  font-weight:850;
  display:inline-flex; align-items:center; gap:10px;
}
.btn:hover{background:var(--soft)}
.btn-primary{background: var(--brandDark); border-color: var(--brandDark); color:#fff;}
.btn-secondary{background:#fff}

/* ---------- Responsivo ---------- */
@media (max-width: 980px){
  .split{grid-template-columns:1fr;}
  .hero-box-row{ grid-template-columns:repeat(2, 1fr); }
}
@media (max-width: 520px){
  .hero-classic h1{ font-size:22px; }
  .hero-classic-ball{ width:44px; height:44px; font-size:16px; }
  .hero-box-row{ grid-template-columns:1fr; }
}
/* =========================================================
   PATCH: classes usadas pelos components (summary/repetition)
   Cole no FINAL do assets/css/lottery.css
   ========================================================= */

/* Alias de compatibilidade (caso algum header use .brand-name) */
.brand-name{ font-weight: 1000; letter-spacing: -.02em; }

.brand-name{
  font-weight: 1000;
  letter-spacing: -.02em;
  font-size: 28px;                 /* ✅ maior */
  color: var(--brandDark, var(--brand));  /* ✅ cor da loteria */
}

/* Grid 2x2 do Resumo (summary.php usa .grid2) */
.grid2{
  margin-top: 12px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  align-items: start; /* 🔧 CHAVE: alinha os cards pelo topo */
}

@media (max-width: 820px){
  .grid2{ grid-template-columns: 1fr; }
}


/* Tipografia “grande” usada nos cards do resumo e repetição */
.big{
  font-size: 28px;
  font-weight: 1000;
  letter-spacing: -.03em;
  line-height: 1.05;
  margin: 2px 0 6px;
}
@media (max-width: 520px){
  .big{ font-size: 24px; }
}

/* Mini-barras da Repetição (repetition.php usa tudo isso) */
.mini-bars{
  margin-top: 12px;
  display: grid;
  gap: 8px;
}
.mini-row{
  display:grid;
  grid-template-columns: 34px 1fr 52px;
  gap: 10px;
  align-items:center;
  padding: 8px 10px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  background: #fff;
}
.mini-row.hit{
  border-color: color-mix(in srgb, var(--brand) 35%, rgba(0,0,0,.08));
  box-shadow: 0 10px 18px color-mix(in srgb, var(--brand) 14%, transparent);
}
.mini-label{
  font-weight: 1000;
  color:#111;
  text-align:center;
}
.mini-track{
  height: 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.06);
  overflow:hidden;
  border: 1px solid rgba(0,0,0,.06);
}
.mini-fill{
  height: 100%;
  width: 0%;
  border-radius: 999px;
  background: color-mix(in srgb, var(--brandDark) 82%, #000);
}
.mini-val{
  text-align:right;
  font-weight: 900;
  color: #111;
  font-size: 12px;
}

/* Se quiser um “ar” mais leve no mobile */
@media (max-width: 520px){
  .mini-row{ grid-template-columns: 28px 1fr 46px; padding: 7px 9px; }
  .mini-track{ height: 9px; }
}

/* =========================================================
   PATCH: Grade completa (heatmap) — arruma a “zica”
   ========================================================= */

.heat{
  display:grid;
  grid-template-columns: repeat(10, minmax(0, 1fr));
  gap: 10px;
}

@media (max-width: 980px){
  .heat{ grid-template-columns: repeat(8, minmax(0, 1fr)); }
}
@media (max-width: 720px){
  .heat{ grid-template-columns: repeat(6, minmax(0, 1fr)); }
}
@media (max-width: 520px){
  .heat{ grid-template-columns: repeat(5, minmax(0, 1fr)); }
}

.heat-cell{
  appearance:none;
  border:1px solid rgba(0,0,0,.10);
  background:#fff;
  border-radius: 14px;
  padding: 10px 8px;
  cursor:pointer;
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap: 6px;

  box-shadow: 0 10px 18px rgba(0,0,0,.06);
  transition: transform .12s ease, filter .12s ease, border-color .12s ease;
}

.heat-cell:hover{
  transform: translateY(-1px);
  filter: brightness(1.02);
  border-color: color-mix(in srgb, var(--brand) 25%, rgba(0,0,0,.10));
}

.heat-n{
  font-weight: 1000;
  font-size: 18px;
  letter-spacing: -.02em;
  color: #111;

  width: 38px;
  height: 38px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  background: var(--brandDark);
  color: #fff;
}

.heat-f{
  font-size: 12px;
  font-weight: 900;
  color: var(--muted);
}

/* Ajuste extra: evita “estourar” texto tipo 300x */
.heat-f{ line-height: 1; }

/* Mobile: deixa mais compacto */
@media (max-width: 520px){
  .heat-cell{ padding: 9px 6px; border-radius: 12px; }
  .heat-n{ width: 34px; height: 34px; font-size: 16px; }
  .heat-f{ font-size: 11px; }
}

.big .rep-of{
  font-size:.95rem;   /* aumenta */
  font-weight:800;
  opacity:.85;
  margin-left:.25rem;
}


/* =========================================================
   Destaques finais (UX correto):
   TOP MAIS = AZUL
   TOP MENOS = VERMELHO
   ========================================================= */

/* TOP 10 MAIS sorteadas — AZUL (estável / frequente) */
.heat-cell.heat-top{
  background: linear-gradient(180deg, rgba(37,99,235,.20), rgba(37,99,235,.08));
  border-color: rgba(37,99,235,.70);
  box-shadow: 0 16px 30px rgba(37,99,235,.20);
}
.heat-cell.heat-top .heat-n{
  background: #1d4ed8;
  color:#fff;
  outline: 4px solid rgba(37,99,235,.30);
}
.heat-cell.heat-top .heat-f{
  color: #1e3a8a;
  font-weight: 1000;
}

/* TOP 10 MENOS sorteadas — VERMELHO (raro / alerta leve) */
.heat-cell.heat-low{
  background: linear-gradient(180deg, rgba(239,68,68,.16), rgba(239,68,68,.06));
  border-color: rgba(239,68,68,.55);
  box-shadow: 0 14px 26px rgba(239,68,68,.18);
}
.heat-cell.heat-low .heat-n{
  background: #b91c1c;
  color:#fff;
  outline: 3px dashed rgba(239,68,68,.28);
}
.heat-cell.heat-low .heat-f{
  color: #7f1d1d;
  font-weight: 950;
}


/* Repetição: linha do resultado (hit) bem destacada e na cor da loteria */

.mini-row.hit{
  border: 2px solid var(--brand);
  background: color-mix(in srgb, var(--brand) 10%, #fff);
  box-shadow: 0 12px 22px color-mix(in srgb, var(--brand) 22%, transparent);
}
.mini-row.hit .mini-fill{
  background: var(--brand);
}
.mini-row.hit .mini-label,
.mini-row.hit .mini-val{
  font-weight: 1000;
}

/* =========================================================
   PATCH: Pares x Ímpares — sublinha “universo” embaixo da barra
   Cole no FINAL do assets/css/lottery.css
   ========================================================= */

.mini-sub{
  margin-top:6px;
  display:flex;
  justify-content:space-between;
  gap:10px;
  font-size:12px;
  line-height:1.1;
}
.mini-sub-hist{
  font-weight:900;
  color: var(--text);
}
.mini-sub-univ{
  font-weight:850;
  color: var(--muted);
  white-space:nowrap;
}

@media (max-width: 520px){
  .mini-sub{
    font-size:11px;
    flex-direction:column;
    gap:4px;
  }
  .mini-sub-univ{ white-space:normal; }
}

/* parity: reutiliza padrão do repetição (details) */
.details{ padding:14px; }
.details-sum{
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  font-weight:900;
}
.details[open] .details-sum{ margin-bottom:10px; }

.kpi-inline{
  display:inline-flex;
  align-items:center;
  padding:2px 10px;
  border-radius:999px;
  background: rgba(16,185,129,.10);
  border:1px solid var(--line);
  font-weight:950;
}

.mini-row{
  grid-template-columns: 64px 1fr 64px;
}

.mini-label{
  white-space:nowrap;
  font-variant-numeric: tabular-nums;
}

.mini-sub{
  margin-top:6px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  font-size:12px;
  line-height:1.15;
}
.mini-sub-hist{
  font-weight:900;
  color:var(--text);
}
.mini-sub-univ{
  font-weight:850;
  color:var(--muted);
}

.details-action + .details-action {
  margin-top: 8px;
}

.grid2 .details-action + .details-action{
  margin-top: 0;
}


.parity-last-meta {
  color: #374151;          /* cinza escuro, não “apagado” */
  font-weight: 700;
}

.parity-last-meta strong {
  color: #111827;          /* quase preto */
  font-weight: 900;
}

details.details-action{
  width:100%;
}

/* =========================================================
   MODAL Premiação — VERSÃO FINAL SIMPLIFICADA
========================================================= */
#prizeModal.modal{
  display:none;
  position:fixed;
  inset:0;
  z-index:9999;
  padding: 12px;
}
#prizeModal.modal.open{ display:block; }

html.modal-open,
body.modal-open{
  overflow:hidden;
  height:100%;
  position: fixed;
  width: 100%;
}

#prizeModal .modal-backdrop{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(2px);
}

/* Card */
#prizeModal .modal-card{
  position:relative;
  width:100%;
  max-width:760px;
  margin: 6vh auto;
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: 0 22px 60px rgba(0,0,0,.25);
  padding: 16px;
  max-height: calc(100vh - 24px);
  overflow:auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

/* DESKTOP - layout original (3 colunas) */
#prizeModal .prize-table{
  display:grid;
  gap:10px;
  margin-top:12px;
}

#prizeModal .prize-row{
  display:grid;
  grid-template-columns: minmax(0, 1fr) 120px 170px;
  gap: 10px;
  align-items:center;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
}

#prizeModal .prize-row.prize-head{
  background: var(--soft);
  font-weight: 950;
}

#prizeModal .prize-row > div{ min-width:0; }

#prizeModal .col-desc{ white-space: normal; overflow-wrap: anywhere; }
#prizeModal .col-num{ text-align:center; font-weight: 950; font-variant-numeric: tabular-nums; white-space: nowrap; }
#prizeModal .col-val{ text-align:right; font-weight: 950; font-variant-numeric: tabular-nums; white-space: nowrap; }

#prizeModal .prize-row.hit{ border: 2px solid var(--brand); background: color-mix(in srgb, var(--brand) 8%, #fff); }
#prizeModal .prize-row.warm{ background: color-mix(in srgb, var(--brand) 4%, #fff); }

#prizeModal .prize-sep{
  margin: 6px 2px 0;
  padding: 10px 12px;
  border-radius: 12px;
  background: var(--soft);
  border: 1px solid var(--line);
  font-weight: 950;
  text-align:center;
}

/* =========================================================
   MOBILE - SOLUÇÃO SIMPLES E FUNCIONAL
========================================================= */
@media (max-width:560px){
  #prizeModal.modal{ padding: 10px; }
  #prizeModal .modal-card{ margin: 10vh auto; padding: 12px; max-height: calc(100vh - 20px); }
  
  /* RESETA COMPLETAMENTE o layout mobile */
  #prizeModal .prize-table{
    display: block !important; /* Volta ao fluxo normal */
  }
  
  #prizeModal .prize-row{
    display: block !important; /* Bloco simples, sem grid */
    margin-bottom: 10px;
    padding: 12px;
  }
  
  /* HEADER: mostra apenas "FAIXA" */
  #prizeModal .prize-row.prize-head{
    text-align: center;
    padding: 10px;
    margin-bottom: 15px;
    font-size: 13px;
    opacity: 0.7;
  }
  
  /* Esconde "Ganhadores" e "Valor" apenas no header */
  #prizeModal .prize-row.prize-head .col-num,
  #prizeModal .prize-row.prize-head .col-val{
    display: none !important;
  }
  
  /* LINHAS NORMAIS: layout vertical simples */
  #prizeModal .prize-row:not(.prize-head) .col-desc{
    display: block;
    font-weight: 950;
    font-size: 15px;
    margin-bottom: 8px;
  }
  
  #prizeModal .prize-row:not(.prize-head) .col-num{
    display: block;
    font-size: 14px;
    color: var(--text);
    margin-bottom: 4px;
    text-align: left !important;
  }
  
  #prizeModal .prize-row:not(.prize-head) .col-val{
    display: block;
    font-size: 16px;
    font-weight: 1000;
    color: var(--brand);
    text-align: left !important;
  }
  
  #prizeModal .prize-row.hit{ border-left: 4px solid var(--brand); background: color-mix(in srgb, var(--brand) 8%, #fff); }
  #prizeModal .prize-sep{ margin: 12px 0 6px; padding: 10px; font-size: 13px; }
}

/* =========================================================
   CORREÇÃO APENAS PARA O PROBLEMA DO MOBILE
========================================================= */
@media (max-width: 560px) {
  /* GARANTE que todas as células apareçam */
  #prizeModal .prize-row:not(.prize-head) .col-num,
  #prizeModal .prize-row:not(.prize-head) .col-val {
    display: block !important;
    text-align: left !important;
    white-space: normal !important; /* PERMITE QUEBRA DE LINHA */
  }
  
  /* CORRIGE o texto dos ganhadores */
  #prizeModal .prize-row:not(.prize-head) .col-num {
    font-size: 14px;
    line-height: 1.4;
    margin: 4px 0;
  }
  
  /* Header ainda simplificado */
  #prizeModal .prize-row.prize-head .col-num,
  #prizeModal .prize-row.prize-head .col-val {
    display: none;
  }
}

/* ---- Normalidade & Raridade ---- */

.stat-card .card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  font-weight:900;
  font-size:12px;
  border:1px solid var(--line);
  background: var(--soft);
}

.pill-muted{ opacity:.85; }
.pill-ok{ background: color-mix(in srgb, var(--brand) 12%, #fff); border-color: color-mix(in srgb, var(--brand) 28%, var(--line)); }
.pill-great{ background: color-mix(in srgb, var(--brand) 18%, #fff); border-color: color-mix(in srgb, var(--brand) 40%, var(--line)); }
.pill-warn{ background: color-mix(in srgb, #f59e0b 14%, #fff); border-color: color-mix(in srgb, #f59e0b 35%, var(--line)); }
.pill-bad{ background: color-mix(in srgb, #ef4444 12%, #fff); border-color: color-mix(in srgb, #ef4444 35%, var(--line)); }

.meter{ margin-top: 12px; }
.meter-track{
  height: 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--line) 45%, #fff);
  overflow:hidden;
}
.meter-fill{
  height: 100%;
  border-radius: 999px;
  background: var(--brand);
}
.meter-meta{
  margin-top: 8px;
  display:flex;
  justify-content:space-between;
  font-size:12px;
}

.stat-details{
  margin-top: 12px;
  border-top:1px solid var(--line);
  padding-top: 10px;
}
.stat-summary{
  cursor:pointer;
  font-weight:950;
  list-style:none;
}
.stat-summary::-webkit-details-marker{ display:none; }

.mini-table{ margin-top: 10px; }
.mini-row{
  display:grid;
  grid-template-columns: 1.4fr .6fr .6fr .6fr;
  gap:10px;
  padding: 8px 0;
  border-top: 1px dashed color-mix(in srgb, var(--line) 60%, #fff);
}
.mini-head{
  border-top:0;
  padding-top:0;
  font-size:12px;
  font-weight:950;
  color: var(--muted);
}
.mini-dim{ opacity:.55; }
.ta-r{ text-align:right; }
.tiny{ font-size:12px; }

.rarity-grid{
  display:grid;
  grid-template-columns: 1fr 220px;
  gap: 12px;
  align-items: stretch;
  margin-top: 10px;
}
@media (max-width: 820px){
  .rarity-grid{ grid-template-columns: 1fr; }
}

.kpi{
  border:1px solid var(--line);
  background: var(--soft);
  border-radius: 14px;
  padding: 10px 12px;
  margin-bottom: 10px;
}
.kpi-value{
  font-weight: 1000;
  font-size: 20px;
  letter-spacing: -0.02em;
}

/* Mini "radar" (barras) */
.radar-bars{ margin-top:10px; display:grid; gap:8px; }
.rb-row{ display:grid; grid-template-columns: 128px 1fr 52px; gap:10px; align-items:center; }
@media (max-width: 520px){
  .rb-row{ grid-template-columns: 110px 1fr 48px; }
}
.rb-track{
  height:10px;
  border-radius:999px;
  background: color-mix(in srgb, var(--line) 55%, #fff);
  overflow:hidden;
}
.rb-fill{
  height:100%;
  border-radius:999px;
  background: var(--brand);
}
.rb-name{
  font-weight:900;
  font-size:12px;
  text-transform:capitalize;
  color: var(--text);
}
.rb-val{
  text-align:right;
  font-weight:900;
  font-size:12px;
  color:var(--muted);
}

/* =========================
   Diagnóstico — Intro
========================= */

.info-card{
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--brand) 6%, #fff),
    #fff 70%
  );
  border: 1px solid var(--line);
}

.info-card .card-head h3{
  font-size: 15px;
  font-weight: 900;
  display: flex;
  align-items: center;
  gap: 6px;
}

.info-card p{
  margin: 6px 0;
}

.info-list{
  margin: 8px 0 6px 18px;
  padding: 0;
}

.info-list li{
  margin: 6px 0;
  line-height: 1.45;
  color: var(--text);
}

.info-list li strong{
  font-weight: 900;
}

.info-card .tiny{
  opacity: .8;
}

/* =========================
   Sobreposição Histórica
========================= */

.overlap-grid{
  display:grid;
  grid-template-columns: 1.6fr .8fr;
  gap: 14px;
  margin-top: 10px;
}

@media (max-width: 920px){
  .overlap-grid{ grid-template-columns: 1fr; }
}

.overlap-big{
  font-size: 14px;
  line-height: 1.35;
  color: var(--text);
  margin-top: 2px;
}

.overlap-big strong{
  font-weight: 950;
}

.overlap-criteria{
  margin-top: 10px;
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
}

.oc-item{
  background: color-mix(in srgb, var(--brand) 6%, #fff);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 10px 12px;
  min-width: 140px;
  flex: 1;
}

.oc-k{
  font-size: 12px;
  font-weight: 850;
  letter-spacing: .01em;
}

.oc-v{
  margin-top: 2px;
  display:flex;
  align-items: baseline;
  gap: 8px;
  font-size: 16px;
}

.oc-v strong{
  font-size: 18px;
  font-weight: 950;
}

.overlap-side{
  display:flex;
  flex-direction: column;
  gap: 10px;
}

/* Reaproveita seu estilo .kpi, mas garante "cara premium" */
.overlap-side .kpi{
  background: var(--soft);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px 14px;
}

.overlap-side .kpi-value{
  font-weight: 950;
  font-size: 22px;
  letter-spacing: -0.02em;
}

.overlap-side .kpi-label{
  font-size: 12px;
  font-weight: 850;
}

/* Ajusta o details pra ficar igual aos outros */
.card.stat-card .stat-details{
  margin-top: 12px;
}

.card.stat-card .stat-summary{
  font-weight: 900;
}

/* Mini-table dentro da sobreposição */
.card.stat-card .mini-table{
  margin-top: 10px;
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow:hidden;
  background: #fff;
}

.card.stat-card .mini-row{
  display:grid;
  grid-template-columns: 1fr .6fr .4fr .5fr;
  gap: 10px;
  padding: 10px 12px;
  border-top: 1px solid var(--line);
  align-items:center;
  font-size: 13px;
}

.card.stat-card .mini-row:first-child{ border-top: none; }

.card.stat-card .mini-head{
  background: color-mix(in srgb, var(--brand) 7%, #fff);
  font-size: 12px;
  font-weight: 950;
  color: color-mix(in srgb, var(--text) 85%, #000);
}

.card.stat-card .mini-row strong{
  font-weight: 950;
}

.ta-r{ text-align:right; }

.overlap-main{
  padding-right: 6px;
}

@media (max-width: 920px){
  .overlap-main{ padding-right: 0; }
}

/* refinamentos: sobreposição */

.overlap-subhead{
  margin-top: 10px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .02em;
  text-transform: uppercase;
  opacity: .9;
}

.overlap-criteria-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

@media (max-width: 720px){
  .overlap-criteria-grid{ grid-template-columns: 1fr; }
}

.overlap-note{
  margin-top: 10px;
}

.overlap-side-box{
  background: color-mix(in srgb, var(--brand) 4%, #fff);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 12px;
}

/* ============================
   Diagnóstico — texto introdutório
============================ */

.diagnostico-intro{
  background: linear-gradient(
    180deg,
    rgba(16,185,129,.10),
    rgba(16,185,129,.04)
  );
  border-left: 4px solid var(--brand);
  border-radius: 12px;
  padding: 16px 18px;
}

.diagnostico-intro p{
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.55;
  color: #374151; /* MAIS forte que muted */
}

.diagnostico-intro strong{
  color: var(--text);
  font-weight: 650;
}

.diagnostico-text {
  text-align: justify;
  text-justify: inter-word;
  line-height: 1.55;
  max-width: 980px;       /* evita linhas longas demais */
}

.diagnostico-text strong {
  font-weight: 700;
}

/* =========================================================
   FIX DEFINITIVO: conflito de .mini-row
   - Repetição = .mini-bars .mini-row
   - Tabelas (normalidade/raridade/sobreposição) = .mini-table .mini-row
   Cole NO FINAL do lottery.css
   ========================================================= */

/* ---------- Mini-table (normalidade/raridade etc.) ---------- */
.mini-table { margin-top: 10px; }

.mini-table .mini-row{
  display:grid;
  grid-template-columns: 1.4fr .6fr .6fr .6fr;
  gap:10px;
  padding: 8px 0;
  border-top: 1px dashed color-mix(in srgb, var(--line) 60%, #fff);
  align-items:center;
  background: transparent;
  border-radius: 0;
}

.mini-table .mini-head{
  border-top:0;
  padding-top:0;
  font-size:12px;
  font-weight:950;
  color: var(--muted);
}

.mini-table .mini-dim{ opacity:.55; }

/* ---------- Repetição (cards com barras) ---------- */
.mini-bars{
  margin-top: 12px;
  display: grid;
  gap: 8px;
}

.mini-bars .mini-row{
  display:grid;
  grid-template-columns: 64px 1fr 64px; /* seu layout “bonito” */
  gap: 10px;
  align-items:center;
  padding: 8px 10px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  background: #fff;
}

@media (max-width: 520px){
  .mini-bars .mini-row{
    grid-template-columns: 52px 1fr 56px;
    padding: 7px 9px;
  }
}

.mini-bars .mini-row.hit{
  border: 2px solid var(--brand);
  background: color-mix(in srgb, var(--brand) 10%, #fff);
  box-shadow: 0 12px 22px color-mix(in srgb, var(--brand) 22%, transparent);
}

.mini-bars .mini-track{
  height: 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.06);
  overflow:hidden;
  border: 1px solid rgba(0,0,0,.06);
}

.mini-bars .mini-fill{
  height: 100%;
  border-radius: 999px;
  background: var(--brand);
}

.mini-bars .mini-label{
  white-space:nowrap;
  font-variant-numeric: tabular-nums;
  font-weight: 1000;
  text-align:center;
}

.mini-bars .mini-val{
  text-align:right;
  font-weight: 900;
  color: #111;
  font-size: 12px;
}

/* =========================
   Concurso picker (isolado) — COMPACTO
========================= */
#heroStats .contestPick{
  margin-top: 12px;
  display: inline-flex;       /* ✅ não ocupa 100% */
  align-items: center;
  gap: 10px;

  padding: 10px 12px;
  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
  border-radius: 999px;

  box-shadow: 0 10px 18px rgba(0,0,0,.06);
}

#heroStats .cp-label{
  font-size: 12px;
  font-weight: 900;
  color: rgba(17,17,17,.72);
  letter-spacing: .02em;
  text-transform: none;
}

#heroStats .cp-input{
  width: 86px;
  border: 0;
  outline: 0;
  background: transparent;

  font-weight: 1000;
  font-size: 14px;
  color: #111;
  text-align: left;

  padding: 2px 0;
  -webkit-appearance: none;
}

#heroStats .cp-btn{
  border: 0;
  background: var(--brand, #7e22ce);
  color: #fff;
  font-weight: 950;
  padding: 8px 12px;
  border-radius: 999px;
  cursor: pointer;
}

#heroStats .cp-link{
  color: rgba(17,17,17,.80);
  font-weight: 950;
  text-decoration: none;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
}

#heroStats .cp-warn{
  margin: 8px 0 0;
  color: rgba(17,17,17,.72);
  font-weight: 800;
  font-size: 13px;
}

@media (max-width: 520px){
  #heroStats .contestPick{
    display:flex;             /* ✅ no mobile ocupa a largura */
    width: 100%;
    justify-content: space-between;
  }
  #heroStats .cp-input{
    width: 110px;
    text-align: center;
  }
}

/* =========================
   📌 Diagnóstico do sorteio (limpo e sem conflito)
========================= */

.card.card-diagnostico{
  margin-bottom: 20px;
  border-left: 6px solid var(--line);
  position: relative;
}

/* Estados */
.card.card-diagnostico.ok{
  border-left-color: #22c55e;
  background: linear-gradient(90deg, rgba(34,197,94,.14), transparent 65%);
  box-shadow: 0 0 0 1px color-mix(in srgb, #22c55e 18%, transparent);
}
.card.card-diagnostico.warn{
  border-left-color: #f59e0b;
  background: linear-gradient(90deg, rgba(245,158,11,.14), transparent 65%);
  box-shadow: 0 0 0 1px color-mix(in srgb, #f59e0b 22%, transparent);
}
.card.card-diagnostico.danger{
  border-left-color: #ef4444;
  background: linear-gradient(90deg, rgba(239,68,68,.14), transparent 65%);
  box-shadow: 0 0 0 1px color-mix(in srgb, #ef4444 28%, transparent);
}

/* Texto do diagnóstico: cria “respiro” antes das pills */
.card.card-diagnostico .diag-text{
  display:block;
  margin-top: 6px;
  margin-bottom: 14px;  /* ✅ AQUI é o descolar de verdade */
  line-height: 1.45;
}

/* Linha das pills: faixa separada */
.card.card-diagnostico .pill-row{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
  padding-top: 10px;
  border-top: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
}

/* Pills (Top %, Normalidade, Acumular/Sair prêmio) */
.card.card-diagnostico .pill-row .pill{
  display:inline-flex;
  align-items:center;
  margin: 0 !important;   /* mata margin antigo */
  padding: 5px 11px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.03);
  color: var(--text);
}

/* pills do Poisson no diagnóstico */
.card.card-diagnostico .pill.pill-warn{
  border-color: color-mix(in srgb, var(--brand) 45%, var(--line));
}
.card.card-diagnostico .pill.pill-mid{
  border-color: color-mix(in srgb, var(--brand) 28%, var(--line));
}
.card.card-diagnostico .pill.pill-ok{
  border-color: color-mix(in srgb, var(--brand) 18%, var(--line));
}

@media (max-width: 640px){
  .card.card-diagnostico .diag-text{ margin-bottom: 12px; }
  .card.card-diagnostico .pill-row{ padding-top: 10px; }
}


/* =========================
   📦 Poisson / Volume de apostas (mantém o seu)
========================= */

.volume-poisson .poisson-head{ margin-top: 2px; margin-bottom: 10px; }
.volume-poisson .poisson-title{ font-weight: 950; letter-spacing: -0.02em; font-size: 18px; line-height: 1.15; }
.volume-poisson .poisson-sub{ margin-top: 4px; font-size: 12px; }

.poisson-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 10px;
}
@media (max-width: 820px){ .poisson-grid{ grid-template-columns: 1fr; } }

.poisson-mini{
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px 12px 10px;
  background: linear-gradient(180deg, rgba(255,255,255,.7), rgba(255,255,255,1));
}

.poisson-k{ font-size: 12px; font-weight: 900; color: var(--muted); letter-spacing: 0.01em; }
.poisson-v{ margin-top: 6px; font-weight: 1000; letter-spacing: -0.03em; font-size: 38px; line-height: 1; color: var(--text); }
.poisson-unit{ font-size: 16px; font-weight: 950; opacity: .85; margin-left: 2px; }
.poisson-hint{ margin-top: 6px; font-size: 12px; font-weight: 900; color: var(--muted); }
.poisson-note{ margin-top: 10px; font-size: 12px; }

/* borda base */
.poisson-mini.none{ border-color: color-mix(in srgb, var(--brand) 18%, var(--line)); }
.poisson-mini.atleast{ border-color: color-mix(in srgb, var(--brand) 35%, var(--line)); }

/* níveis */
.poisson-mini.pill-warn{
  border-color: color-mix(in srgb, var(--brand) 65%, var(--line)) !important;
  background: linear-gradient(180deg, color-mix(in srgb, var(--brand) 10%, #fff) 0%, #fff 75%);
}
.poisson-mini.pill-mid{
  border-color: color-mix(in srgb, var(--brand) 45%, var(--line)) !important;
  background: linear-gradient(180deg, color-mix(in srgb, var(--brand) 6%, #fff) 0%, #fff 80%);
}
.poisson-mini.pill-ok{
  border-color: color-mix(in srgb, var(--brand) 30%, var(--line)) !important;
  background: linear-gradient(180deg, color-mix(in srgb, var(--brand) 4%, #fff) 0%, #fff 85%);
}

.poisson-mini .poisson-k{ color: color-mix(in srgb, var(--text) 55%, var(--muted)); }
.poisson-mini .poisson-hint{ color: color-mix(in srgb, var(--text) 45%, var(--muted)); }

@media (max-width: 820px){
  .poisson-mini .poisson-v{ font-size: 40px; }
}

/* Descola o 1º card do título "Resumo do sorteio" */
.section > .section-head + .card{
  margin-top: 16px; /* ajusta aqui: 12/16/20 */
}
/* TOPBAR DAS ESTATÍSTICAS - MELHORADA */
.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.2rem 0;
    margin-bottom: 2rem;
    border-bottom: 2px solid rgba(0,0,0,.1);
    background: white;
}

.back {
    background: #f8f9fa;
    color: #495057;
    padding: 0.6rem 1.2rem;
    border-radius: 8px;
    font-weight: 600;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    border: 1px solid #dee2e6;
}

.back:hover {
    background: #e9ecef;
    text-decoration: none;
}

.brand {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.brand img {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,.1);
}

.brand-name {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--brand);
}

.tabs {
    display: flex;
    gap: 0.5rem;
}

.tab {
    background: var(--brand);
    color: white;
    padding: 0.6rem 1.2rem;
    border-radius: 8px;
    font-weight: 600;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.tab:hover {
    background: color-mix(in srgb, var(--brand) 80%, #000);
    text-decoration: none;
}

.seo-intro{
  margin: 10px 0 14px;
}

.seo-intro details{
  background: rgba(0,0,0,.03);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 14px;
  padding: 10px 14px;
}

.seo-intro summary{
  cursor: pointer;
  font-weight: 800;
  list-style: none;
}

.seo-intro summary::-webkit-details-marker{ display:none; }

.seo-intro-body{
  margin-top: 8px;
  color: rgba(0,0,0,.78);
  line-height: 1.55;
}

.seo-intro-body p{ margin: 0 0 8px; }

.metric-hint{
  margin: 4px 0 0;
  font-size: 0.85rem;
  color: rgba(0,0,0,.65);
}

.metric-hint-inline{
  font-size: .85em;
  font-weight: 600;
  color: rgba(0,0,0,.65);
}

/* Hint abaixo do título, sem mexer no resto do layout */
.stat-card .metric-hint-below{
  margin-top: 4px;
  font-size: 0.82rem;
  line-height: 1.25;
  color: rgba(0,0,0,.55);
}

/* No mobile, garante que o bloco do título + hint não “esprema” as pills */
@media (max-width: 576px){
  .stat-card .card-head{
    gap: 10px; /* se já tiver gap, isso só ajusta */
  }

  .stat-card .card-head > div:first-child{
    min-width: 0; /* evita overflow esquisito */
  }

  .stat-card .metric-hint-below{
    font-size: 0.78rem;
  }
}

/* Hint embaixo do título, SEM entrar no flex do header */
.stat-card .card-head h2 .metric-hint-under{
  display: block;          /* força ficar embaixo */
  margin-top: 4px;
  font-size: 0.82rem;
  font-weight: 400;
  line-height: 1.25;
  opacity: .65;
  text-align: left;        /* garante que não centraliza */
}

@media (max-width: 576px){
  .stat-card .card-head h2 .metric-hint-under{
    font-size: 0.78rem;
    margin-top: 3px;
  }
}

/* ===== RARITY GRID (layout base) ===== */
.stat-card .rarity-grid{
  display: grid;
  grid-template-columns: 1fr 260px; /* main + coluna KPIs */
  gap: 16px;
  align-items: start;
}

/* KPI column vira "mini-cards" bem compactos */
.stat-card .rarity-kpis{
  display: grid;
  grid-template-columns: 1fr;  /* desktop: um embaixo do outro */
  gap: 10px;
}

/* KPI card mais "dashboard" e menos trambolho */
.stat-card .rarity-kpis .kpi{
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 14px;
  padding: 12px 14px;
  background: rgba(0,0,0,.02);
}

.stat-card .rarity-kpis .kpi .kpi-label{
  font-size: .85rem;
  font-weight: 600;
  opacity: .7;
}

.stat-card .rarity-kpis .kpi .kpi-value{
  margin-top: 6px;
  font-size: 1.35rem;
  font-weight: 800;
  line-height: 1.1;
}

/* ===== MOBILE: KPIs viram 2 colunas compactas (Top | Ranking) ===== */
@media (max-width: 768px){
  .stat-card .rarity-grid{
    grid-template-columns: 1fr; /* vira uma coluna */
  }

  .stat-card .rarity-kpis{
    order: 2; /* coloca KPIs DEPOIS do bloco principal */
    grid-template-columns: 1fr 1fr; /* Top e Ranking lado a lado */
    gap: 10px;
  }

  .stat-card .rarity-kpis .kpi{
    padding: 10px 12px;
  }

  .stat-card .rarity-kpis .kpi .kpi-value{
    font-size: 1.15rem;
  }
}

/* ===== MOBILE PEQUENO: se ficar apertado, empilha ===== */
@media (max-width: 420px){
  .stat-card .rarity-kpis{
    grid-template-columns: 1fr;
  }
}

/* Hint embaixo do título (igual você já fez no Normalidade) */
.stat-card .metric-hint-under{
  display:block;
  margin-top:4px;
  font-size:.82rem;
  font-weight:400;
  line-height:1.25;
  opacity:.65;
  text-align:left;
}

/* KPIs compactos em faixa */
.stat-card .rarity-kpi-row{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:10px;
  margin-top:10px;
}

/* KPI estilo dashboard (compacto, sem caixote gigante) */
.stat-card .kpi.kpi-compact{
  border:1px solid rgba(0,0,0,.10);
  border-radius:14px;
  padding:10px 12px;
  background:rgba(0,0,0,.02);
  display:flex;
  justify-content:space-between;
  align-items:baseline;
}

.stat-card .kpi.kpi-compact .kpi-label{
  font-size:.85rem;
  font-weight:600;
  opacity:.7;
}

.stat-card .kpi.kpi-compact .kpi-value{
  font-size:1.15rem;
  font-weight:800;
  line-height:1.1;
}

/* Rarity grid: SEM sidebar */
.stat-card .rarity-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap:14px;
  margin-top:12px;
}

/* Mobile pequeno: KPIs empilham */
@media (max-width: 420px){
  .stat-card .rarity-kpi-row{
    grid-template-columns: 1fr;
  }
}
/* faixa dos KPIs */
.stat-card .rarity-kpi-row{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:12px;
  margin-top:12px;
}

/* cards KPIs com vida */
.stat-card .kpi.kpi-compact{
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  padding: 12px 14px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  display:flex;
  justify-content: space-between;
  align-items: center;
}

/* faixa de acento (verde) no topo do KPI */
.stat-card .kpi.kpi-compact::before{
  content:"";
  position:absolute;
  left:0; top:0; right:0;
  height: 4px;
  background: rgba(22,163,74,.85); /* verde */
}

/* label */
.stat-card .kpi.kpi-compact .kpi-label{
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .2px;
  opacity: .75;
  margin: 0;
}

/* valor mais “dashboard” */
.stat-card .kpi.kpi-compact .kpi-value{
  font-size: 1.35rem;
  font-weight: 900;
  line-height: 1;
}

/* deixa o Top ainda mais “importante” com um badge de contexto */
.stat-card .kpi.kpi-compact .kpi-value small{
  display:block;
  margin-top:4px;
  font-size: .78rem;
  font-weight: 700;
  opacity: .65;
}

/* mobile pequeno */
@media (max-width: 420px){
  .stat-card .rarity-kpi-row{ grid-template-columns: 1fr; }
  .stat-card .kpi.kpi-compact{ padding: 12px 14px; }
  .stat-card .kpi.kpi-compact .kpi-value{ font-size: 1.25rem; }
}

/* ===== PCA mini-table (sem inline widths) ===== */
.mini-table.pca-mini .mini-row{
  grid-template-columns: 1.2fr 1fr 1fr; /* Métrica | PC1 | PC2 */
}

.mini-table.pca-mini .mini-row > div{ min-width:0; }

.mini-table.pca-mini .pca-cell{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
}

.mini-table.pca-mini .rb-track{
  flex: 1;
  display:block;
  min-width:0;
  max-width:180px; /* desktop */
}

.mini-table.pca-mini .pca-val{
  display:inline-block;
  min-width:56px;
  text-align:right;
  font-variant-numeric: tabular-nums;
  font-weight:900;
}

.mini-table.pca-mini .pca-col-label{
  display:none; /* aparece só no mobile */
  font-size:12px;
  font-weight:950;
  color: var(--muted);
  width: 38px;
  text-align:left;
}

/* Mobile: card por linha + labels PC1/PC2 */
@media (max-width: 560px){
  .mini-table.pca-mini .mini-row.mini-head{ display:none; }

  .mini-table.pca-mini .mini-row{
    display:block;
    padding:10px 12px;
    border-radius:14px;
    background:#fff;
    border:1px solid rgba(0,0,0,.08);
    margin-top:8px;
  }

  .mini-table.pca-mini .pca-metric{
    font-weight:950;
    margin-bottom:8px;
  }

  .mini-table.pca-mini .pca-cell{
    justify-content:space-between;
    margin-top:6px;
  }

  .mini-table.pca-mini .pca-col-label{ display:inline-block; }
  .mini-table.pca-mini .rb-track{ max-width:none; }
}


