/* === Fontes auto-hospedadas (estabilidade no evento, sem depender do Google) === */
@font-face{font-family:'Fredoka';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/fredoka-400.woff2') format('woff2')}
@font-face{font-family:'Fredoka';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/fredoka-500.woff2') format('woff2')}
@font-face{font-family:'Fredoka';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/fredoka-600.woff2') format('woff2')}
@font-face{font-family:'Fredoka';font-style:normal;font-weight:700;font-display:swap;src:url('assets/fonts/fredoka-700.woff2') format('woff2')}
@font-face{font-family:'Pacifico';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/pacifico-400.woff2') format('woff2')}
@font-face{font-family:'Rye';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/rye-400.woff2') format('woff2')}
:root{
  --navy:#11272F; --navy2:#0B1A22; --panel:#143542; --panel2:#0E2730; --line:#26505E;
  --cream:#F4EAD2; --creamDim:#C9BA96; --gold:#E8A33D; --goldLt:#F2B441;
  --teal:#2FB7D6; --tealDk:#1E94B0; --orange:#E2622E; --red:#C73B33; --olive:#93A02E; --purple:#8B57C4;
  --shadow:0 8px 26px rgba(0,0,0,.4);
  --disp:'Rye','Georgia',serif; --ui:'Fredoka',system-ui,-apple-system,Segoe UI,Roboto,sans-serif; --script:'Pacifico',cursive;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--ui); color:var(--cream); background:var(--navy2); min-height:100vh; line-height:1.45}
body::before{content:"";position:fixed;inset:0;z-index:-2;background:url('assets/fundo.jpg') center center/cover no-repeat fixed}
body::after{content:"";position:fixed;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(7,16,22,.72) 0%,rgba(7,16,22,.80) 55%,rgba(7,16,22,.9) 100%)}
body[data-role="gestao"]::after{background:linear-gradient(180deg,rgba(7,16,22,.90) 0%,rgba(7,16,22,.93) 60%,rgba(7,16,22,.95) 100%)}
body[data-role="publico"]::after{background:linear-gradient(180deg,rgba(7,16,22,.58) 0%,rgba(7,16,22,.72) 55%,rgba(7,16,22,.85) 100%)}
button{font-family:var(--ui); cursor:pointer; border:none; color:inherit}
input,select{font-family:var(--ui)}
.wrap{max-width:1280px; margin:0 auto; padding:0 22px}
h2{font-family:var(--disp); color:var(--goldLt); font-size:24px; margin:0 0 14px; font-weight:400; letter-spacing:.5px}
h3{font-size:13px; letter-spacing:2px; text-transform:uppercase; color:var(--creamDim); margin:16px 0 8px; font-weight:600; display:flex; align-items:center; gap:7px}
h3 .star{color:var(--gold)}

.topbar{position:sticky; top:0; z-index:20; background:rgba(8,18,24,.82); backdrop-filter:blur(10px); border-bottom:2px solid var(--line)}
#bunting{display:block; width:100%; height:22px}
.tb-inner{display:flex; align-items:center; gap:18px; padding:12px 22px; flex-wrap:wrap}
.logo{height:40px; width:auto; filter:drop-shadow(0 2px 8px rgba(0,0,0,.45)); flex:none}
.ttl{flex:1; min-width:180px}
.kick{font-size:11.5px; letter-spacing:2.2px; color:var(--creamDim); font-weight:600}
.ttl .title{font-family:var(--disp); font-size:clamp(20px,2.4vw,30px); line-height:1}
.ttl .title .a{color:var(--goldLt)} .ttl .title .b{color:var(--teal)}
.tb-right{display:flex; align-items:center; gap:12px; flex-wrap:wrap}
.total-chip{display:inline-flex; align-items:center; gap:8px; background:var(--panel2); border:2px dashed var(--gold); border-radius:999px; padding:7px 16px; font-weight:600; white-space:nowrap}
.total-chip b{font-size:20px; color:var(--goldLt)}
.roletag{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:13px;padding:7px 14px;border-radius:999px;white-space:nowrap}
.roletag.adm{background:rgba(232,163,61,.16);color:var(--goldLt);border:2px solid var(--gold)}
.roletag.pub{background:rgba(47,183,214,.16);color:var(--teal);border:2px solid var(--teal)}
.linkbtn{background:transparent; border:2px solid var(--line); color:var(--cream); border-radius:10px; padding:9px 12px; font-weight:600; font-size:13px; white-space:nowrap; text-decoration:none; display:inline-flex; align-items:center; gap:6px}
.linkbtn:hover{border-color:var(--gold)}
.conn{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--creamDim)}
.conn .dot{width:9px;height:9px;border-radius:50%;background:var(--olive)}
.conn.off .dot{background:var(--red)} .conn.off{color:#f0a59f}

.panel{background:var(--panel); border:2px solid var(--gold); border-radius:18px; box-shadow:var(--shadow); padding:20px 20px 22px; position:relative}
.panel.flat{border-color:var(--line)}
main{padding:24px 0 64px}

/* labels visíveis + agrupamentos de campo */
.flabel{font-size:12px; letter-spacing:1px; text-transform:uppercase; color:var(--creamDim); font-weight:600; margin:2px 0 6px}
.fgroup{flex:1; min-width:120px}
.operrow{display:flex; flex-direction:column; margin:0 0 16px}
.operrow .input{width:100%}
.pitem.off{opacity:.62}
.pitem.off .pn{cursor:default}
.offtag{display:inline-block; font-size:11px; letter-spacing:.5px; text-transform:uppercase; font-weight:700; color:var(--creamDim); border:1px solid var(--line); border-radius:999px; padding:1px 8px; margin-left:6px; vertical-align:middle}
.li-by{color:var(--teal); font-weight:600}
.li-ed{color:var(--gold); font-weight:600}
.riskbox{margin-top:16px; border:1.5px dashed var(--red); border-radius:14px; padding:12px 14px; background:rgba(199,59,51,.07)}
.riskbox .risktt{font-size:12px; letter-spacing:1.5px; text-transform:uppercase; font-weight:700; color:#f0a59f; margin-bottom:6px}

.cards{display:grid; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); gap:12px}
.act{display:flex; align-items:center; gap:12px; padding:15px 15px 15px 18px; border-radius:14px; background:linear-gradient(180deg,#173d4b,#0e2a34); border:2px solid var(--gold); text-align:left; position:relative; overflow:hidden; box-shadow:0 6px 16px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.05); transition:transform .08s, box-shadow .15s}
.act::before{content:""; position:absolute; left:0; top:0; bottom:0; width:6px; background:var(--gold)}
.act.k-o::before{background:var(--orange)} .act.k-t::before{background:var(--teal)} .act.k-r::before{background:var(--red)} .act.k-g::before{background:var(--olive)} .act.k-p::before{background:var(--purple)} .act.k-gold::before{background:var(--goldLt)}
.act:hover{transform:translateY(-2px); box-shadow:0 11px 24px rgba(0,0,0,.5)} .act:active{transform:scale(.99)}
.act .ai{font-size:26px; flex:none; width:34px; text-align:center; filter:drop-shadow(0 2px 3px rgba(0,0,0,.45))}
.act .at{flex:1; min-width:0}
.act .at .atl{font-weight:700; font-size:15px; line-height:1.15}
.act .at .ats{font-size:12.5px; color:var(--creamDim)}
.act .av{font-weight:800; font-size:22px; flex:none; min-width:56px; text-align:center; padding:7px 10px; border-radius:11px; background:rgba(0,0,0,.32); border:1.5px solid currentColor; line-height:1}
.av.o{color:var(--orange)} .av.t{color:var(--teal)} .av.r{color:#ff7d74} .av.g{color:#c2d058} .av.p{color:#caa6f5} .av.gold{color:var(--goldLt)}

.cols2{display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:18px}
.formrow{display:flex; gap:8px; flex-wrap:wrap}
.input{flex:1; min-width:120px; background:var(--panel2); border:2px solid var(--line); color:var(--cream); border-radius:12px; padding:12px 14px; font-size:15px; outline:none}
.input:focus{border-color:var(--gold)}
select.input{appearance:none; background-image:linear-gradient(45deg,transparent 50%,var(--creamDim) 50%),linear-gradient(135deg,var(--creamDim) 50%,transparent 50%); background-position:calc(100% - 18px) 18px,calc(100% - 12px) 18px; background-size:6px 6px,6px 6px; background-repeat:no-repeat; padding-right:34px}
.btn{background:var(--gold); color:#1a1006; font-weight:700; border-radius:12px; padding:12px 18px; font-size:15px; box-shadow:var(--shadow)}
.btn.teal{background:var(--teal); color:#04222b}
.btn.ghost{background:transparent; border:2px solid var(--line); color:var(--cream); box-shadow:none; font-weight:600}
.btn.danger{background:transparent; border:2px solid var(--red); color:#ffb3ad; box-shadow:none}
.btn:active{transform:translateY(1px)} .btn:disabled{opacity:.45; cursor:not-allowed}

.plist{display:flex; flex-direction:column; gap:8px; margin-top:6px}
.pitem{display:flex; align-items:center; gap:10px; background:var(--panel2); border:1px solid var(--line); border-radius:12px; padding:10px 12px}
.pitem .pn{flex:1; font-weight:600; cursor:pointer}
.pitem .pn:hover{color:var(--goldLt)}
.pitem .pp{font-weight:700; color:var(--goldLt)}
.iconbtn{background:transparent; border:none; font-size:16px; padding:6px; border-radius:8px; color:var(--creamDim)}
.iconbtn:hover{color:var(--cream); background:rgba(255,255,255,.06)}
.subhint{font-size:13px; color:var(--creamDim); margin-top:10px}

.log{display:flex; flex-direction:column; gap:8px; max-height:300px; overflow:auto; padding-right:4px}
.logitem{display:flex; align-items:center; gap:10px; background:var(--panel2); border:1px solid var(--line); border-radius:12px; padding:9px 11px}
.logitem .li-ic{font-size:18px; flex:none}
.logitem .li-b{flex:1; min-width:0}
.logitem .li-t{font-weight:600; font-size:13.5px}
.logitem .li-s{font-size:13px; color:var(--creamDim)}
.logitem .li-p{font-weight:700; color:var(--olive); flex:none}
.logitem .li-p.neg{color:var(--red)}
.toolbar{display:flex; gap:8px; flex-wrap:wrap; margin-top:14px}

.empty{text-align:center; color:var(--creamDim); padding:24px 14px}
.empty .big{font-size:34px}
.empty p{margin:8px 0 14px}

.ac-head{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:8px; flex-wrap:wrap}
.live{display:inline-flex; align-items:center; gap:8px; font-weight:600; color:var(--teal); font-size:13px; letter-spacing:1px}
.live .dot{width:10px; height:10px; border-radius:50%; background:var(--teal); box-shadow:0 0 0 0 rgba(47,183,214,.6); animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(47,183,214,.5)}70%{box-shadow:0 0 0 12px rgba(47,183,214,0)}100%{box-shadow:0 0 0 0 rgba(47,183,214,0)}}
@media(prefers-reduced-motion:reduce){.live .dot{animation:none}}

.ac-dest{display:grid; grid-template-columns:1fr 1fr; gap:18px}
.dest{background:var(--panel); border:2px dashed var(--gold); border-radius:18px; padding:22px; text-align:center; box-shadow:var(--shadow)}
.dest .ic{font-size:46px; line-height:1}
.dest .lbl{font-size:13px; letter-spacing:2px; font-weight:600; color:var(--creamDim); margin:8px 0 4px; text-transform:uppercase}
.dest .name{font-family:var(--ui); font-weight:800; letter-spacing:.2px; font-size:clamp(28px,4.2vw,46px); color:var(--goldLt); line-height:1.05; min-height:1.05em}
.dest .sub{font-size:15px; color:var(--cream); opacity:.9; margin-top:6px}
.dest .pts{font-weight:700; font-size:30px; color:var(--teal); margin-top:6px}
.dest .prize{font-size:13px; color:var(--gold); margin-top:8px; min-height:1em}
.dest.empty2 .name{color:var(--creamDim); font-family:var(--ui); font-size:20px; font-weight:500}

.ac-teams{display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:18px}
.team{border-radius:18px; padding:18px 20px; background:var(--panel2); border:2px solid var(--line); box-shadow:var(--shadow)}
.team.lead{border-color:var(--goldLt); box-shadow:0 0 0 1px var(--goldLt), var(--shadow)}
.team .tn{display:flex; align-items:center; gap:10px; font-weight:700; font-size:20px}
.team .tn .dot{width:14px; height:14px; border-radius:50%}
.team .tn .crown{margin-left:auto; font-size:22px}
.team .avg{font-size:44px; font-weight:700; margin-top:8px; line-height:1}
.team .avg small{font-size:14px; font-weight:500; color:var(--creamDim)}
.team .meta{font-size:13px; color:var(--creamDim); margin-top:3px}
.bar{height:10px; border-radius:6px; background:rgba(255,255,255,.08); margin-top:12px; overflow:hidden}
.bar > i{display:block; height:100%; border-radius:6px}

.ac-rank{display:grid; grid-template-columns:1fr 1fr; gap:10px}
@media(max-width:760px){.ac-rank{grid-template-columns:1fr}}
.row{display:flex; align-items:center; gap:12px; background:var(--panel2); border:1px solid var(--line); border-radius:14px; padding:12px 16px}
.row .pos{font-family:var(--ui); font-weight:700; font-size:19px; width:34px; text-align:center; color:var(--creamDim); flex:none}
.row .medal{font-size:24px; width:34px; text-align:center; flex:none}
.row .who{flex:1; min-width:0}
.row .who .n{font-weight:600; font-size:18px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.uchip{font-size:12px; font-weight:600; padding:3px 10px; border-radius:999px; display:inline-block; margin-top:3px}
.u-savassi{background:rgba(47,183,214,.18); color:var(--teal); border:1px solid var(--teal)}
.u-castelo{background:rgba(232,163,61,.18); color:var(--goldLt); border:1px solid var(--gold)}
.row .rp{font-weight:700; font-size:26px; color:var(--goldLt); flex:none}
.row.top1{border-color:var(--goldLt); background:linear-gradient(180deg, rgba(242,180,65,.14), var(--panel2)); grid-column:1/-1}
.row.top1 .rp{font-size:32px}

.scrim{position:fixed; inset:0; background:rgba(5,12,16,.66); z-index:40; display:flex; align-items:center; justify-content:center; padding:16px}
.scrim[hidden]{display:none}
.sheet{background:var(--navy); border:2px solid var(--gold); border-radius:20px; width:100%; max-width:560px; padding:20px; box-shadow:var(--shadow); max-height:88vh; overflow:auto}
.sheet h3{font-family:var(--disp); color:var(--goldLt); margin:0 0 4px; font-size:24px; letter-spacing:0; text-transform:none}
.sheet .sub{color:var(--creamDim); font-size:13px; margin-bottom:14px}
.chiplist{display:flex; flex-wrap:wrap; gap:8px; margin-bottom:6px; max-height:46vh; overflow:auto; padding:2px}
.pchip{display:flex; align-items:center; gap:7px; background:var(--panel2); border:2px solid var(--line); border-radius:999px; padding:9px 15px; font-weight:600; font-size:14px}
.pchip .du{width:9px; height:9px; border-radius:50%}
.pchip.sel{border-color:var(--goldLt); background:rgba(242,180,65,.16); color:var(--goldLt)}
.sheet .actions{display:flex; gap:8px; margin-top:16px}
.sheet .actions .btn{flex:1; justify-content:center; text-align:center}
.muted{color:var(--creamDim); font-size:13px}

/* PIN gate */
.gate{position:fixed; inset:0; z-index:50; display:flex; align-items:center; justify-content:center; padding:18px; background:rgba(5,12,16,.5); backdrop-filter:blur(4px)}
.gate[hidden]{display:none}
.gatecard{background:var(--navy); border:2px dashed var(--gold); border-radius:22px; padding:30px 26px; max-width:420px; width:100%; text-align:center; box-shadow:var(--shadow)}
.gatecard img{height:42px; margin-bottom:6px}
.gatecard h1{font-family:var(--disp); color:var(--goldLt); font-size:26px; font-weight:400; margin:8px 0 2px}
.gatecard p{color:var(--creamDim); font-size:14px; margin:0 0 18px}
.gatecard .input{text-align:center; letter-spacing:6px; font-size:22px; width:100%; margin-bottom:12px}
.gatecard .btn{width:100%; justify-content:center}
.gateerr{color:#f0a59f; font-size:13px; min-height:18px; margin-top:8px; font-weight:600}

#toast{position:fixed; left:50%; bottom:30px; transform:translateX(-50%) translateY(20px); z-index:60; background:var(--panel); border:2px solid var(--goldLt); color:var(--cream); padding:12px 22px; border-radius:999px; font-weight:600; box-shadow:var(--shadow); opacity:0; pointer-events:none; transition:opacity .25s, transform .25s; max-width:92vw; text-align:center}
#toast.show{opacity:1; transform:translateX(-50%) translateY(0)}

.confetti{position:fixed; top:-12px; z-index:55; width:10px; height:14px; border-radius:2px; pointer-events:none; will-change:transform,opacity}
@keyframes fall{to{transform:translateY(106vh) rotate(640deg); opacity:.2}}
@media(prefers-reduced-motion:reduce){.confetti{display:none!important}}

@media(max-width:820px){
  .cols2{grid-template-columns:1fr}
  .ac-dest,.ac-teams{grid-template-columns:1fr}
  .tb-inner{gap:12px}
}

/* ---------- META DO DIA ---------- */
.meta-box{margin-top:6px}
.meta-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px}
@media(max-width:600px){.meta-grid{grid-template-columns:1fr}}
.metacard{background:var(--panel2); border:2px solid var(--line); border-radius:16px; padding:14px 16px}
.metacard .mt{display:flex; align-items:center; justify-content:space-between; gap:10px}
.metacard .mt .lab{font-size:15px; font-weight:600; color:var(--cream)}
.metacard .mt .num{font-family:var(--ui); font-weight:700; font-size:24px; color:var(--goldLt)}
.metabar{height:14px; border-radius:8px; background:rgba(255,255,255,.08); margin-top:10px; overflow:hidden}
.metabar > i{display:block; height:100%; border-radius:8px; transition:width .5s ease}
.metapct{text-align:center; margin-top:12px; font-weight:600; color:var(--cream)}
.metapct b{font-family:var(--ui); font-weight:800; font-size:22px; color:var(--goldLt)}

/* ---------- PÓDIO TOP 3 ---------- */
.podium{display:flex; align-items:flex-end; justify-content:center; gap:16px; margin-top:6px}
.pod{flex:1; max-width:330px; display:flex; flex-direction:column; align-items:center}
.pod .pcard{width:100%; background:linear-gradient(180deg,#173d4b,#0e2a34); border:2px dashed var(--gold); border-radius:16px 16px 0 0; box-shadow:var(--shadow); padding:14px 12px 12px; text-align:center}
.pod.p1 .pcard{border-color:var(--goldLt); box-shadow:0 0 0 1px var(--goldLt), 0 0 26px rgba(242,180,65,.35), var(--shadow)}
.pod .medal{font-size:40px; line-height:1}
.pod .pn{font-weight:700; font-size:18px; margin-top:4px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.pod .pp{font-family:var(--ui); font-weight:800; font-size:30px; color:var(--goldLt); line-height:1.15}
.pod .stand{width:100%; border-radius:0 0 5px 5px; display:flex; align-items:center; justify-content:center; font-family:var(--disp); color:#0b1a22; font-size:32px; box-shadow:inset 0 2px 0 rgba(255,255,255,.28)}
.pod.p1 .stand{height:118px; background:linear-gradient(180deg,#F2B441,#cf8a23)}
.pod.p2 .stand{height:86px; background:linear-gradient(180deg,#cfd6da,#9aa6ad)}
.pod.p3 .stand{height:62px; background:linear-gradient(180deg,#d59155,#a9683a)}
.pod.empty .pcard{opacity:.45} .pod.empty .medal{filter:grayscale(1); opacity:.7}
@media(max-width:600px){.pod .pp{font-size:24px} .pod .stand{font-size:24px} .pod .pn{font-size:15px} .pod .medal{font-size:30px}}

/* animação ao assumir a liderança */
.flash{animation:flashlead 1.4s ease}
@keyframes flashlead{0%{box-shadow:var(--shadow)}22%{box-shadow:0 0 0 6px rgba(242,180,65,.6), 0 0 46px rgba(242,180,65,.55), var(--shadow)}100%{box-shadow:var(--shadow)}}

/* ---------- MODO TELÃO ---------- */
#telaoBar{display:none}
#exitTelao{display:none; position:fixed; right:16px; bottom:16px; z-index:30}
body.telao .topbar{display:none}
body.telao #exitTelao{display:inline-flex}
body.telao #telaoBar{display:flex; align-items:center; gap:18px; position:sticky; top:0; z-index:20; background:rgba(8,18,24,.85); backdrop-filter:blur(10px); border-bottom:2px solid var(--line); padding:16px 26px}
body.telao #telaoBar .logo{height:48px; width:auto; filter:drop-shadow(0 2px 8px rgba(0,0,0,.45))}
body.telao #telaoBar .tt{font-family:var(--disp); font-size:32px; line-height:1}
body.telao #telaoBar .tt .a{color:var(--goldLt)} body.telao #telaoBar .tt .b{color:var(--teal)}
body.telao #telaoBar .tot{margin-left:auto; font-weight:600; background:var(--panel2); border:2px solid var(--gold); border-radius:999px; padding:9px 20px; font-size:18px}
body.telao #telaoBar .tot b{font-family:var(--disp); font-size:28px; color:var(--goldLt)}
body.telao .ac-head{display:none}
body.telao #rankSection{display:none}
/* telão = placar, não dashboard: esconde a grade detalhada de equipes */
body.telao #teamsSection{display:none}
body.telao main{padding-top:26px}
body.telao .dest{padding:30px 26px}
body.telao .dest .ic{font-size:62px}
body.telao .dest .name{font-size:clamp(36px,5.2vw,64px)}
body.telao .dest .pts{font-size:42px}
body.telao .dest .lbl{font-size:15px}
body.telao .pod .medal{font-size:50px}
body.telao .pod .pn{font-size:22px}
body.telao .pod .pp{font-size:38px}
body.telao .pod.p1 .stand{height:150px}
body.telao .team .avg{font-size:52px}

/* ---------- foco visível + números tabulares ---------- */
button:focus-visible, .act:focus-visible, .iconbtn:focus-visible, .linkbtn:focus-visible, .pchip:focus-visible{ outline:3px solid var(--goldLt); outline-offset:3px }
.total-chip b, .li-p, .row .rp, .team .avg, .dest .pts, .av, .pod .pp, .metacard .mt .num, .metapct b, .pp, #telaoTotal, #telaoBar .tot b{ font-variant-numeric:tabular-nums }

/* ---------- frase decorativa (Pacifico) ---------- */
.tagline{font-family:var(--script); color:var(--gold); font-size:20px; text-align:center; margin:2px 0 4px; opacity:.92}
body.telao .tagline{font-size:30px; margin:2px 0 10px}
@media(max-width:600px){.tagline{font-size:17px}}

/* ---------- último lançamento ao vivo ---------- */
#lastSection{margin-top:14px}
.lastbar{display:flex; align-items:center; gap:12px; background:linear-gradient(90deg, rgba(232,163,61,.18), rgba(14,39,48,.5)); border:2px solid var(--gold); border-radius:14px; padding:11px 16px; box-shadow:var(--shadow)}
.lastbar .lk{font-size:12px; letter-spacing:1.5px; text-transform:uppercase; color:var(--creamDim); font-weight:700; flex:none}
.lastbar .lp{font-weight:800; font-size:22px; color:var(--goldLt); flex:none; font-variant-numeric:tabular-nums}
.lastbar .lt{flex:1; min-width:0; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.lastbar.flashlast{animation:lastpop 1s ease}
@keyframes lastpop{0%{transform:scale(1)}30%{transform:scale(1.015)}100%{transform:scale(1)}}
body.telao .lastbar{padding:16px 22px}
body.telao .lastbar .lp{font-size:30px}
body.telao .lastbar .lt{font-size:22px}
@media(prefers-reduced-motion:reduce){.lastbar.flashlast{animation:none}}

/* ---------- FAIXA DE REGRAS DE PONTUAÇÃO ---------- */
.rulesbar{display:flex; flex-wrap:wrap; align-items:center; gap:10px 16px; margin-top:26px; padding:13px 18px; background:rgba(8,18,24,.55); border:1.5px solid var(--line); border-radius:14px; font-size:14px; color:var(--cream)}
.rulesbar .rk{font-size:11.5px; letter-spacing:1.5px; text-transform:uppercase; font-weight:700; color:var(--gold)}
.rulesbar .ri{display:inline-flex; align-items:center; gap:6px; white-space:nowrap}
.rulesbar .ri b{font-weight:700}
.rulesbar .ri.cas{color:var(--creamDim); white-space:normal}
.rulesbar .ri.cas b{color:var(--cream)}
body.telao .rulesbar{margin-top:18px; font-size:17px; padding:15px 22px; gap:12px 22px; justify-content:center}
body.telao .rulesbar .rk{font-size:13px}
@media(max-width:600px){.rulesbar{font-size:13px}}
