:root{
    --green:#0a7b3e; --green-d:#06602f; --yellow:#ffd400; --yellow-d:#e6bf00;
    --blue:#1b3fb3; --bg:#0e1512; --card:#ffffff; --ink:#152019; --muted:#6b7c73;
    --line:#e4eae6; --red:#d23b3b; --radius:16px; --shadow:0 6px 20px rgba(8,40,24,.10);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
    font-family:'Inter',system-ui,Segoe UI,Roboto,sans-serif;
    color:var(--ink); background:linear-gradient(160deg,#0a7b3e 0%,#075c2e 100%);
    background-attachment:fixed; min-height:100vh; line-height:1.45;
}
a{color:var(--green); text-decoration:none}
h1,h2,h3{margin:.2em 0 .5em}
.muted{color:var(--muted)}
.small{font-size:.85rem}
.center{text-align:center}
/* Texto auxiliar que fica direto sobre o fundo verde precisa ser claro p/ ler */
.container > .muted,
.container > p.muted,
.container > .center.small{color:rgba(255,255,255,.9)}
/* Títulos soltos sobre o fundo verde (ex.: subtítulos do admin) em branco */
.container > h2,
.container > h3{color:#fff; text-shadow:0 1px 2px rgba(0,0,0,.2)}

/* layout */
.topbar{
    display:flex; align-items:center; justify-content:space-between; gap:12px;
    padding:12px 16px; background:rgba(255,255,255,.96); backdrop-filter:blur(6px);
    position:sticky; top:0; z-index:10; box-shadow:0 2px 12px rgba(0,0,0,.12);
}
.brand{font-weight:800; font-size:1.05rem; color:var(--green-d)}
.nav{display:flex; align-items:center; gap:14px; font-weight:600; font-size:.92rem}
.nav a{color:var(--ink)}
.nav a.admin-link{color:var(--blue)}
.nav .me{color:var(--muted); font-weight:600}
.container{max-width:760px; margin:0 auto; padding:18px 14px 40px}
.foot{text-align:center; color:rgba(255,255,255,.7); font-size:.8rem; padding:18px}
.page-title{color:#fff; text-shadow:0 1px 2px rgba(0,0,0,.25)}
body:has(.login-wrap) .page-title{color:var(--ink)}

/* botões */
.btn{display:inline-block; border:0; cursor:pointer; font-weight:700; font-size:.95rem;
    padding:11px 18px; border-radius:12px; background:#eef3f0; color:var(--ink); transition:.15s}
.btn:hover{filter:brightness(.97)}
.btn-primary{background:var(--yellow); color:#3a2e00}
.btn-primary:hover{background:var(--yellow-d)}
.btn-block{display:block; width:100%; text-align:center}
.btn:disabled{opacity:.5; cursor:not-allowed}
.link-btn{background:none;border:0;color:var(--green);cursor:pointer;font:inherit;font-weight:600;padding:0}
.link-btn.danger{color:var(--red)}
.inline{display:inline}

/* flash */
.flash{padding:11px 14px; border-radius:12px; margin-bottom:12px; font-weight:600}
.flash-ok{background:#e3f6ea; color:#0a7b3e; border:1px solid #b9e6c9}
.flash-err{background:#fde8e8; color:#b32424; border:1px solid #f5c2c2}

/* cards / login */
.login-wrap{min-height:80vh; display:flex; align-items:center; justify-content:center}
.login-card{background:var(--card); border-radius:var(--radius); padding:28px 24px; width:100%; max-width:380px;
    box-shadow:var(--shadow); text-align:center}
.login-logo{font-size:2.6rem}
.login-form{display:flex; flex-direction:column; gap:14px; margin:18px 0 10px; text-align:left}
label{font-weight:600; font-size:.9rem; display:block}
input,select{width:100%; padding:11px 12px; border:1.5px solid var(--line); border-radius:10px;
    font:inherit; margin-top:5px; background:#fff}
input:focus,select:focus{outline:none; border-color:var(--green)}
.card{background:var(--card); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow); margin-bottom:16px}

/* lista de jogos */
.game-list{display:flex; flex-direction:column; gap:12px}
.game-card{display:block; background:var(--card); border-radius:var(--radius); padding:14px 16px;
    box-shadow:var(--shadow); border-left:6px solid var(--line); color:var(--ink)}
.game-card.st-open{border-left-color:var(--yellow)}
.game-card.st-live{border-left-color:var(--red)}
.game-card.st-final{border-left-color:var(--green)}
.game-head{display:flex; justify-content:space-between; font-size:.78rem; color:var(--muted); font-weight:600; text-transform:uppercase; letter-spacing:.03em}
.matchup{display:flex; align-items:center; justify-content:space-between; gap:10px; margin:10px 0}
.matchup.big{margin:16px 0}
.team{display:flex; flex-direction:column; align-items:center; gap:4px; flex:1; text-align:center}
.team .flag{font-size:1.8rem; line-height:1}
.matchup.big .flag{font-size:2.6rem}
/* bandeiras como imagem (funcionam em PC e celular) */
.flag-img{width:26px; height:auto; border-radius:3px; box-shadow:0 1px 3px rgba(0,0,0,.25); vertical-align:middle; display:inline-block}
.team .flag .flag-img{width:42px}
.matchup.big .flag .flag-img{width:60px}
.flag-emoji{font-size:1.6rem; line-height:1}
.matchup.big .flag-emoji{font-size:2.4rem}
.tname{font-weight:700; font-size:.95rem}
.score{font-size:1.4rem; font-weight:800; min-width:70px; text-align:center}
.matchup.big .score{font-size:2rem}
.score .x{color:var(--muted); font-weight:600}
.game-foot{display:flex; justify-content:space-between; font-size:.85rem; color:var(--muted); margin-top:6px}
.prize{font-weight:700; color:var(--green-d)}
.badges{display:flex; flex-wrap:wrap; gap:6px; margin-top:10px}
.card-winners{margin-top:10px; padding-top:10px; border-top:1px solid var(--line); font-size:.88rem; display:flex; align-items:center; gap:6px; flex-wrap:wrap}
.card-winners b{font-weight:700}
.cw-final{color:var(--green-d)}
.cw-live{color:#b32424}
.cw-dot{width:8px; height:8px; border-radius:50%; background:#e0303c; animation:pulse 1.4s infinite; flex:none}
.cw-amount{margin-left:auto; color:var(--green-d); font-weight:700}
.badge{font-size:.72rem; font-weight:700; padding:3px 9px; border-radius:20px}
.b-open{background:#fff6cc; color:#7a5c00}
.b-live{background:#fde0e0; color:#b32424}
.b-final{background:#e3f6ea; color:#0a7b3e}
.b-locked{background:#eceff0; color:#5b6b62}
.b-mine{background:#e1ecff; color:#1b3fb3}
.b-warn{background:#ffe9d6; color:#a85b18}

/* detalhe */
.back{display:inline-block; color:#fff; margin-bottom:10px; font-weight:600; opacity:.9}
.detail-card{background:var(--card); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow); margin-bottom:16px; border-top:6px solid var(--yellow)}
.detail-card.st-live{border-top-color:var(--red)}
.detail-card.st-final{border-top-color:var(--green)}
.prize-line{text-align:center; color:var(--green-d); font-weight:600; margin-top:6px}

/* palpite form */
.score-inputs{display:flex; align-items:flex-end; justify-content:center; gap:14px; margin:8px 0 16px}
.si{display:flex; flex-direction:column; align-items:center; gap:6px; max-width:130px}
.si-team{font-size:.8rem; font-weight:700; text-align:center; color:var(--muted)}
.si input{width:74px; text-align:center; font-size:1.5rem; font-weight:800; padding:8px}
.si-x{font-size:1.3rem; color:var(--muted); font-weight:700; padding-bottom:12px}
.locked-note{text-align:center; color:var(--muted); font-weight:600}

/* meus palpites */
.mine-list{display:flex; flex-direction:column; gap:8px}
.mine-item{display:flex; align-items:center; gap:12px; padding:8px 12px; background:#f5f9f7; border-radius:10px}
.mine-item.hit{background:#e3f6ea; border:1px solid #b9e6c9}
.mscore{font-weight:800; font-size:1.05rem}
.hit-tag{color:var(--green); font-weight:700; font-size:.85rem}

/* live winners */
.live-box{background:var(--card); border-radius:var(--radius); padding:16px 18px; box-shadow:var(--shadow); margin-bottom:16px; border-top:4px solid var(--green)}
.live-box.lb-live{border-top-color:var(--red)}
.live-box.lb-final{border-top-color:var(--green)}
.lb-head{display:flex; align-items:center; gap:10px; margin-bottom:12px; flex-wrap:wrap}
.lb-tag{display:inline-flex; align-items:center; gap:7px; font-size:.72rem; font-weight:800; text-transform:uppercase; letter-spacing:.05em; padding:5px 11px; border-radius:20px}
.tag-live{background:#fde0e0; color:#b32424}
.tag-final{background:#e3f6ea; color:#0a7b3e}
.lb-dot{width:8px; height:8px; border-radius:50%; background:#e0303c; box-shadow:0 0 0 0 rgba(224,48,60,.6); animation:pulse 1.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(224,48,60,.55)}70%{box-shadow:0 0 0 7px rgba(224,48,60,0)}100%{box-shadow:0 0 0 0 rgba(224,48,60,0)}}
.lb-sub{color:var(--muted); font-weight:600; font-size:.9rem}
.lw-label{font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--muted); margin:0 0 8px}
.lw-amount{margin:10px 0 0; color:var(--ink); font-size:.95rem}
.lw-amount b{color:var(--green-d)}
.lw-empty{font-weight:700; font-size:1.02rem; margin:0 0 4px; color:var(--ink)}
.lw-hint{margin:0; color:var(--muted); font-size:.88rem}
.winners{display:flex; flex-wrap:wrap; gap:8px}
.winner-chip{display:inline-flex; align-items:center; background:#fff; border:1.5px solid var(--green); color:var(--green-d); font-weight:700; padding:6px 14px; border-radius:20px; font-size:.92rem}
.lb-final .winner-chip{background:var(--green); border-color:var(--green); color:#fff}

/* tabelas */
.ptable,.rank-table,.adm-table{width:100%; border-collapse:collapse; font-size:.92rem; color:var(--ink)}
/* rank-table e adm-table ficam soltas sobre o verde: ganham fundo branco p/ leitura */
.rank-table,.adm-table{background:#fff; border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden}
.ptable th,.rank-table th,.adm-table th{text-align:left; color:var(--muted); font-size:.78rem; text-transform:uppercase; padding:10px 8px; border-bottom:2px solid var(--line)}
.ptable td,.rank-table td,.adm-table td{padding:11px 8px; border-bottom:1px solid var(--line); color:var(--ink)}
.rank-table th:first-child,.rank-table td:first-child,.adm-table th:first-child,.adm-table td:first-child{padding-left:16px}
.rank-table th:last-child,.rank-table td:last-child,.adm-table th:last-child,.adm-table td:last-child{padding-right:16px}
.adm-table tr:last-child td,.rank-table tr:last-child td{border-bottom:0}
.row-hit{background:#e3f6ea; font-weight:700}
.rank-table .pos{font-size:1.1rem; font-weight:800; width:40px}
.rank-table .top{font-weight:700}
.rank-table .money,.adm-table td .money{color:var(--green-d); font-weight:700}

/* admin */
.admin-tabs{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px}
.tab{background:rgba(255,255,255,.85); padding:8px 14px; border-radius:20px; font-weight:600; font-size:.88rem; color:var(--ink)}
.tab.active{background:var(--yellow); color:#3a2e00}
.stat-grid{display:flex; gap:12px; margin-bottom:16px}
.stat{flex:1; background:var(--card); border-radius:var(--radius); padding:16px; text-align:center; box-shadow:var(--shadow)}
.stat-n{font-size:1.8rem; font-weight:800; color:var(--green-d)}
.stat-l{color:var(--muted); font-size:.82rem; font-weight:600}
.admin-actions{margin-bottom:16px; display:flex; gap:10px; flex-wrap:wrap}
.pp-title{display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin:4px 0 10px}
.pp-title .x{color:var(--muted)}
.pp-count{font-size:.72rem; font-weight:700; color:var(--muted); background:#eef3f0; padding:3px 9px; border-radius:20px; text-transform:uppercase}
.btn-sm{padding:7px 12px; font-size:.85rem}
.filter-bar{display:flex; align-items:flex-end; gap:14px; flex-wrap:wrap; margin-bottom:14px; background:rgba(255,255,255,.92); padding:12px 14px; border-radius:var(--radius); box-shadow:var(--shadow)}
.filter-bar label{font-weight:600}
.filter-bar select{margin-top:5px}
.collapse-all{display:flex; gap:8px}
.page-title.sub{font-size:1.2rem; margin-top:20px}
/* cards recolhíveis */
.collapsible{padding:0; overflow:hidden}
.collapse-toggle{width:100%; background:none; border:0; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:10px; padding:14px 16px; font:inherit; color:var(--ink); text-align:left}
.collapse-toggle:hover{background:#f7faf8}
.ct-main{display:flex; align-items:center; gap:9px; flex-wrap:wrap; min-width:0}
.ct-stage{font-size:.7rem; font-weight:700; text-transform:uppercase; color:var(--muted); background:#eef3f0; padding:2px 8px; border-radius:12px}
.ct-title{font-weight:700; font-size:1rem}
.ct-title .x{color:var(--muted)}
.ct-score{font-weight:800; color:var(--green-d)}
.chevron{color:var(--muted); transition:transform .2s; flex:none; font-size:.9rem}
.collapsible.collapsed .chevron{transform:rotate(-90deg)}
.collapse-body{padding:0 16px 14px}
.collapsible.collapsed .collapse-body{display:none}
.form-grid{display:flex; flex-direction:column; gap:14px}
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.result-form{display:flex; flex-direction:column; gap:12px; align-items:flex-start}
.result-form select{max-width:320px}
.pin-form input{width:90px; display:inline-block; margin:0 6px 0 0}
.search-row{display:flex; gap:8px; align-items:center}
.search-row input{width:auto}
.search-results{margin-top:10px; display:flex; flex-direction:column; gap:6px; max-height:320px; overflow:auto}
.sr-item{display:flex; justify-content:space-between; gap:10px; align-items:center; padding:8px 10px; background:#f5f9f7; border-radius:8px; font-size:.86rem}
.sr-item button{padding:5px 10px; font-size:.8rem}
hr{border:0; border-top:1px solid var(--line); margin:14px 0}

.empty{text-align:center; background:var(--card); border-radius:var(--radius); padding:30px 18px; box-shadow:var(--shadow)}

/* avisos da home */
.alert-pending{background:#fff6cc; border:1px solid #f0d76b; border-radius:var(--radius); padding:12px 14px; margin-bottom:14px; color:#5a4500}
.alert-pending strong{display:block; margin-bottom:8px}
.pending-list{display:flex; flex-wrap:wrap; gap:8px}
.pending-chip{background:#fff; border:1px solid #e7d99a; border-radius:20px; padding:6px 12px; font-weight:700; font-size:.85rem; color:#4a3a00}
.pending-chip .pc-when{color:var(--muted); font-weight:600; margin-left:4px}
.alert-acc{background:#e3f6ea; border:1px solid #b9e6c9; border-radius:var(--radius); padding:12px 14px; margin-bottom:14px; color:#0a6b36; font-weight:600}

/* contagem regressiva */
.countdown{text-align:center; margin-top:10px; font-weight:700; color:var(--green-d); background:#eef7f1; border-radius:12px; padding:8px}
.cd-clock{font-variant-numeric:tabular-nums; letter-spacing:.5px}
.acc-note{display:block; font-size:.85rem; color:var(--green-d); font-weight:600}

/* bônus */
.bonus-list{display:flex; flex-direction:column; gap:14px}
.bonus-card .bonus-head{display:flex; justify-content:space-between; align-items:flex-start; gap:10px}
.bonus-card.b-resolved{border-left:6px solid var(--green)}
.bonus-form{display:flex; flex-wrap:wrap; align-items:center; gap:10px; margin-top:8px}
.bonus-form input[type=text]{flex:1; min-width:160px; margin-top:0}
.bonus-opts{display:flex; flex-wrap:wrap; gap:8px; width:100%}
.opt{display:flex; align-items:center; gap:6px; background:#f5f9f7; border:1.5px solid var(--line); border-radius:20px; padding:7px 14px; cursor:pointer; font-weight:600}
.opt input{width:auto; margin:0}
.opt:has(input:checked){background:var(--yellow); border-color:var(--yellow-d); color:#3a2e00}
.bonus-result p{margin:4px 0}
.check{display:flex; align-items:center; gap:8px; font-weight:600}
.check input{width:auto; margin:0}
.audit{background:#eef3f7; border-radius:8px; padding:8px 10px; font-size:.85rem; color:#3a4a5a}
textarea{width:100%; padding:11px 12px; border:1.5px solid var(--line); border-radius:10px; font:inherit; margin-top:5px; resize:vertical}
textarea:focus{outline:none; border-color:var(--green)}

@media (max-width:560px){
    .grid2{grid-template-columns:1fr}
    .nav{gap:10px; font-size:.85rem}
    .brand{font-size:.95rem}
    .stat-n{font-size:1.4rem}
}
