:root {
    --gold:    #f59e0b; --silver: #94a3b8; --bronze: #cd7f32;
    --bg:      #0a0f1e; --surface: #111827; --surface2: #1a2236;
    --accent:  #3b82f6; --text: #f1f5f9;   --muted: #64748b;
}
* { margin:0; padding:0; box-sizing:border-box; }
body { background:var(--bg); color:var(--text); font-family:'DM Sans',sans-serif; min-height:100vh; overflow-x:hidden; }
/* Marca d'água do logo */
body::after {
    content:''; position:fixed; inset:0; pointer-events:none; z-index:0;
    background-image: url('/fluxo/public/campeonatos/logo.png');
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 80% auto;
    opacity: 0.06;
}
body::before {
    content:''; position:fixed; inset:0; pointer-events:none; z-index:0;
    background: radial-gradient(ellipse 80% 60% at 50% -10%, rgba(59,130,246,.15) 0%, transparent 60%),
radial-gradient(ellipse 50% 40% at 90% 100%, rgba(245,158,11,.1) 0%, transparent 55%);
}
.wrap { position:relative; z-index:1; max-width:1100px; margin:0 auto; padding:0 20px; }

/* Header */
.page-header { padding:48px 0 32px; text-align:center; }
.label-live {
    display:inline-flex; align-items:center; gap:8px;
    background:rgba(239,68,68,.15); border:1px solid rgba(239,68,68,.3);
    border-radius:100px; padding:4px 16px;
    font-size:.75rem; font-weight:700; letter-spacing:.1em;
    color:#f87171; text-transform:uppercase; margin-bottom:20px;
}
.dot { width:8px; height:8px; border-radius:50%; background:#ef4444; animation:pulse 1.5s infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.3)} }
.page-title {
    font-family:'Bebas Neue',sans-serif;
    font-size:clamp(2.5rem,7vw,5rem);
    letter-spacing:.05em; line-height:1;
    background:linear-gradient(135deg,#fff 30%,var(--gold));
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.page-sub { color:var(--muted); font-size:.95rem; margin-top:10px; }

/* Separador de categoria */
.cat-sep {
    font-family:'Bebas Neue',sans-serif; font-size:1.6rem; letter-spacing:.08em;
    display:flex; align-items:center; gap:14px; margin:32px 0 16px;
}
.cat-sep::after { content:''; flex:1; height:1px; background:linear-gradient(90deg,currentColor,transparent); opacity:.2; }
.cat-sep.elite     { color:var(--gold);   }
.cat-sep.master    { color:var(--silver); }
.cat-sep.masculino { color:#60a5fa;}
.cat-sep.feminino  { color:#f472b6;}
.cat-sep.geral     { color:#a78bfa;}

/* Pódio */
.podio-wrap { display:flex; align-items:flex-end; justify-content:center; gap:12px; margin:20px 0 32px; }
.podio-item { flex:1; max-width:280px; text-align:center; }
.podio-avatar {
    width:64px; height:64px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-family:'Bebas Neue',sans-serif; font-size:1.6rem;
    margin:0 auto 10px; border:3px solid;
}
.pos-1 .podio-avatar { background:rgba(245,158,11,.2); border-color:var(--gold);   color:var(--gold);   }
.pos-2 .podio-avatar { background:rgba(148,163,184,.15);border-color:var(--silver); color:var(--silver); }
.pos-3 .podio-avatar { background:rgba(205,127,50,.15); border-color:var(--bronze); color:var(--bronze); }
.podio-nome { font-weight:700; font-size:.95rem; margin-bottom:4px; }
.podio-pts  { font-family:'Bebas Neue',sans-serif; font-size:2rem; }
.pos-1 .podio-pts { color:var(--gold);   font-size:2.6rem; }
.pos-2 .podio-pts { color:var(--silver); }
.pos-3 .podio-pts { color:var(--bronze); }
.pos-icon { font-size:1.4rem; margin-bottom:6px; }
.podio-degrau { border-radius:12px 12px 0 0; margin-top:10px; }
.pos-1 .podio-degrau { height:80px; background:linear-gradient(180deg,rgba(245,158,11,.25),rgba(245,158,11,.05)); border:1px solid rgba(245,158,11,.3); }
.pos-2 .podio-degrau { height:54px; background:linear-gradient(180deg,rgba(148,163,184,.15),rgba(148,163,184,.03)); border:1px solid rgba(148,163,184,.2); }
.pos-3 .podio-degrau { height:38px; background:linear-gradient(180deg,rgba(205,127,50,.15),rgba(205,127,50,.03)); border:1px solid rgba(205,127,50,.2); }

/* Cards de ranking */
.ranking-card {
    background:var(--surface); border:1px solid rgba(255,255,255,.06);
    border-radius:16px; overflow:hidden; margin-bottom:10px;
    transition:transform .2s,border-color .2s;
    animation:slideIn .4s ease both;
}
.ranking-card:hover { transform:translateX(4px); border-color:rgba(255,255,255,.12); }
@keyframes slideIn { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
@keyframes slideUp  { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
.ranking-card.pos-1 { border-color:rgba(245,158,11,.35); background:linear-gradient(135deg,rgba(245,158,11,.08),var(--surface)); }
.ranking-card.pos-2 { border-color:rgba(148,163,184,.2); }
.ranking-card.pos-3 { border-color:rgba(205,127,50,.25); }

.ranking-inner { display:flex; align-items:center; padding:14px 18px; gap:14px; }
.rank-num { font-family:'Bebas Neue',sans-serif; font-size:1.8rem; min-width:44px; text-align:center; color:var(--muted); }
.pos-1 .rank-num { color:var(--gold);   font-size:2rem; }
.pos-2 .rank-num { color:var(--silver); }
.pos-3 .rank-num { color:var(--bronze); }
.rank-info { flex:1; min-width:0; }
.rank-nome { font-weight:700; font-size:1rem; margin-bottom:2px; }
.rank-meta { font-size:.73rem; color:var(--muted); display:flex; gap:10px; flex-wrap:wrap; margin-bottom:3px; }
.rank-meta span { display:flex; align-items:center; gap:4px; }
.rank-etapas { display:flex; gap:5px; flex-wrap:wrap; justify-content:flex-end; }
.etapa-chip { display:flex; flex-direction:column; align-items:center; background:var(--surface2); border-radius:8px; padding:4px 8px; min-width:38px; }
.ec-label { font-size:.65rem; color:var(--muted); }
.ec-val   { font-weight:700; font-size:.88rem; }
.etapa-chip.descartada { opacity:.35; text-decoration:line-through; }
.etapa-chip.sem-dado   { opacity:.2; }
.etapa-chip.melhor     { background:rgba(245,158,11,.15); border:1px solid rgba(245,158,11,.3); }
.ec-val.gold { color:var(--gold); }
.rank-total { font-family:'Bebas Neue',sans-serif; font-size:2.1rem; min-width:76px; text-align:right; white-space:nowrap; }
.pos-1 .rank-total { color:var(--gold); }
.rank-total small { font-size:.85rem; color:var(--muted); font-family:'DM Sans',sans-serif; font-weight:400; }
.progress-bar-wrap { height:3px; background:rgba(255,255,255,.05); }
.progress-bar-fill { height:100%; transition:width .8s ease; background:var(--accent); }
.pos-1 .progress-bar-fill { background:var(--gold);   }
.pos-2 .progress-bar-fill { background:var(--silver); }
.pos-3 .progress-bar-fill { background:var(--bronze); }

/* Footer */
.footer-info { text-align:center; padding:20px 0 40px; color:var(--muted); font-size:.8rem; display:flex; align-items:center; justify-content:center; gap:20px; flex-wrap:wrap; }
.refresh-bar  { position:fixed; top:0; left:0; right:0; height:3px; background:transparent; z-index:100; }
.refresh-fill { height:100%; background:linear-gradient(90deg,var(--accent),var(--gold)); width:0%; transition:width linear; }
@media(max-width:600px){ .rank-etapas{display:none} .podio-wrap{gap:6px} }
/* ── Botão flutuante de regras ── */
.btn-regras-fab {
    position: fixed; bottom: 28px; right: 28px; z-index: 999;
    width: 54px; height: 54px; border-radius: 50%; border: none; cursor: pointer;
    background: linear-gradient(135deg, #1e3a5f, #2563eb);
    color: #fff; font-size: 1.3rem;
    box-shadow: 0 4px 18px rgba(37,99,235,.5);
    display: flex; align-items: center; justify-content: center;
    transition: transform .2s, box-shadow .2s;
}
.btn-regras-fab:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 24px rgba(37,99,235,.7);
}

/* ── Modal de regras ── */
.modal-regras-overlay {
    display: none; position: fixed; inset: 0; z-index: 1000;
    background: rgba(0,0,0,.7); backdrop-filter: blur(4px);
    align-items: center; justify-content: center; padding: 20px;
}
.modal-regras-box {
    background: #0f1b2d; border: 1px solid rgba(255,255,255,.1);
    border-radius: 20px; max-width: 680px; width: 100%;
    max-height: 85vh; display: flex; flex-direction: column;
    box-shadow: 0 24px 64px rgba(0,0,0,.6);
    animation: slideUp .25s ease;
}
.modal-regras-header {
    padding: 24px 28px 20px; border-bottom: 1px solid rgba(255,255,255,.08);
    display: flex; align-items: center; justify-content: space-between; flex-shrink: 0;
}
.modal-regras-label {
    font-size: .7rem; font-weight: 700; letter-spacing: .1em;
    text-transform: uppercase; color: #60a5fa; margin-bottom: 4px;
}
.modal-regras-titulo {
    font-size: 1.15rem; font-weight: 800; color: #fff;
}
.modal-regras-fechar {
    background: rgba(255,255,255,.08); border: none; cursor: pointer;
    color: #9ca3af; width: 36px; height: 36px; border-radius: 50%;
    font-size: 1rem; display: flex; align-items: center; justify-content: center;
    transition: background .2s;
}
.modal-regras-fechar:hover { background: rgba(255,255,255,.15); }
.modal-regras-body {
    padding: 24px 28px; overflow-y: auto; flex: 1;
    color: rgba(255,255,255,.82); font-size: .93rem; line-height: 1.75;
    white-space: pre-wrap; word-break: break-word;
}
.modal-regras-footer {
    padding: 16px 28px; border-top: 1px solid rgba(255,255,255,.08);
    text-align: right; flex-shrink: 0;
}
.modal-regras-btn-fechar {
    background: linear-gradient(135deg, #1e3a5f, #2563eb); border: none;
    color: #fff; padding: 10px 28px; border-radius: 10px; cursor: pointer;
    font-weight: 700; font-size: .88rem; transition: opacity .2s;
}
.modal-regras-btn-fechar:hover { opacity: .85; }