:root{
    --bg:#08090b;
    --bg-2:#0e0f0c;
    --card:#15160f;
    --card-2:#1d1e13;
    --line:#3a3318;
    --txt:#f6f2e4;
    --muted:#b6ad8d;
    --primary:#e9b923;       /* dorado del logo */
    --primary-d:#c99a10;
    --accent:#f2cb45;        /* dorado claro · enlaces */
    --green:#1f9d52;         /* verde del logo */
    --green-d:#16823f;
    --warn:#f0a830;
    --danger:#ef4444;
    --info:#38bdf8;
    --radius:14px;
    --shadow:0 8px 28px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
    font-family:"Segoe UI",system-ui,-apple-system,Roboto,Arial,sans-serif;
    background:
        radial-gradient(1100px 560px at 82% -12%,rgba(233,185,35,.12) 0%,transparent 55%),
        radial-gradient(900px 500px at 5% 0%,rgba(31,157,82,.10) 0%,transparent 50%),
        var(--bg);
    background-attachment:fixed;
    color:var(--txt);
    min-height:100vh;
    line-height:1.5;
}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(1120px,92%);margin:0 auto}

/* Topbar */
.topbar{background:rgba(8,9,7,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);box-shadow:0 2px 0 rgba(233,185,35,.18);position:sticky;top:0;z-index:50}
.topbar-admin{background:rgba(8,11,8,.92);border-bottom-color:var(--green);box-shadow:0 2px 0 rgba(31,157,82,.25)}
.topbar-in{display:flex;align-items:center;gap:18px;padding:10px 0;flex-wrap:wrap}
.brand{color:var(--txt);font-size:1.12rem;font-weight:600;display:flex;align-items:center;gap:10px}
.brand:hover{text-decoration:none}
.brand b{color:var(--primary)}
.brand-logo{width:42px;height:42px;border-radius:9px;object-fit:cover;border:1px solid var(--line);box-shadow:0 2px 8px rgba(0,0,0,.5)}
.brand-ball{font-size:1.4rem}
.nav{display:flex;gap:6px;flex-wrap:wrap}
.nav a{color:var(--muted);padding:7px 12px;border-radius:9px;font-weight:500}
.nav a:hover{background:var(--card);color:var(--txt);text-decoration:none}
.nav a.on{background:var(--primary);color:#04130b}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.saldo{color:var(--muted);font-size:.92rem}
.saldo b{color:var(--txt)}

.main{padding:26px 0 60px}
.page-title{font-size:1.7rem;margin:6px 0 20px}

/* Cards */
.card{background:linear-gradient(180deg,var(--card) 0%,var(--bg-2) 100%);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);margin-bottom:18px}
.card h2{margin:0 0 14px;font-size:1.15rem}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.card-head h2{margin:0}
.cols{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:820px){.cols{grid-template-columns:1fr}}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:8px}
.stat{display:flex;flex-direction:column;gap:8px}
.stat-label{color:var(--muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.04em}
.stat-value{font-size:1.7rem;font-weight:700}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line);background:var(--card-2);color:var(--txt);padding:10px 16px;border-radius:10px;font-weight:600;cursor:pointer;font-size:.95rem;transition:.15s}
.btn:hover{filter:brightness(1.12);text-decoration:none}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn-primary{background:var(--primary);border-color:var(--primary);color:#04130b}
.btn-primary:hover{background:var(--primary-d)}
.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}
.btn-ghost{background:transparent}
.btn-sm{padding:6px 11px;font-size:.85rem;border-radius:8px}
.btn-block{width:100%}

/* Forms */
.form{display:flex;flex-direction:column;gap:14px}
.form label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:.92rem}
.form input,.form select,.inline-form select,.inline-form input{
    background:var(--bg);border:1px solid var(--line);color:var(--txt);
    padding:11px 12px;border-radius:10px;font-size:1rem;font-family:inherit;
}
.form input:focus,.form select:focus{outline:2px solid var(--primary);border-color:transparent}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.muted{color:var(--muted);font-weight:400}
.center{text-align:center}
small.muted{font-size:.82rem}

/* Auth */
.auth-wrap{display:flex;justify-content:center;padding-top:30px}
.auth-card{width:min(440px,100%);text-align:center;border-color:rgba(233,185,35,.35);box-shadow:0 10px 40px rgba(0,0,0,.55),0 0 0 1px rgba(233,185,35,.08) inset}
.auth-card .form{text-align:left}
.auth-logo{width:140px;height:140px;object-fit:cover;border-radius:18px;border:1px solid var(--line);box-shadow:0 8px 30px rgba(0,0,0,.6),0 0 26px rgba(233,185,35,.15);margin:0 auto 14px}
.auth-title{margin:0 0 6px;font-size:1.5rem}

/* Flash */
.flash{padding:13px 16px;border-radius:11px;margin-bottom:16px;font-weight:500;border:1px solid}
.flash-ok{background:rgba(31,157,82,.16);border-color:var(--green);color:#9be9c4}
.flash-warn{background:rgba(240,168,48,.14);border-color:var(--warn);color:#f3cd8a}
.flash-danger{background:rgba(239,68,68,.14);border-color:var(--danger);color:#f5a3a3}
.flash-info{background:rgba(56,189,248,.14);border-color:var(--info);color:#a6e3fb}

/* Badges */
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.78rem;font-weight:700;border:1px solid transparent}
.badge-ok{background:rgba(31,157,82,.18);color:#7fe3b5;border-color:var(--green)}
.badge-warn{background:rgba(240,168,48,.16);color:#f3cd8a;border-color:var(--warn)}
.badge-danger{background:rgba(239,68,68,.16);color:#f5a3a3;border-color:var(--danger)}
.badge-info{background:rgba(56,189,248,.16);color:#a6e3fb;border-color:var(--info)}
.badge-muted{background:var(--card-2);color:var(--muted);border-color:var(--line)}

/* Tables */
.table{width:100%;border-collapse:collapse;font-size:.92rem}
.table th,.table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
.table th{color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}
.table tr:hover td{background:rgba(255,255,255,.02)}
.win{color:#7fe3b5}

/* Tabs / chips */
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}
.tabs a{padding:8px 14px;border-radius:9px;background:var(--card);border:1px solid var(--line);color:var(--muted);font-weight:600;font-size:.9rem}
.tabs a:hover{color:var(--txt);text-decoration:none}
.tabs a.on{background:var(--primary);color:#04130b;border-color:var(--primary)}
.chip{display:inline-block;background:var(--card-2);border:1px solid var(--line);padding:2px 9px;border-radius:999px;font-size:.76rem;color:var(--muted)}
.link{color:var(--accent);font-weight:600;font-size:.9rem}

/* Matches */
.match-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}
.match-card{display:flex;flex-direction:column;gap:14px}
.match-meta{display:flex;justify-content:space-between;align-items:center}
.match-main{display:flex;align-items:center;justify-content:space-between;gap:8px}
.team{display:flex;align-items:center;gap:8px;font-weight:600;flex:1}
.team-r{justify-content:flex-end;text-align:right}
.cod{background:var(--card-2);border:1px solid var(--line);border-radius:6px;padding:1px 6px;font-size:.72rem;color:var(--muted)}
.score b{font-size:1.3rem}
.vs{color:var(--muted);font-weight:700}
.odds{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;text-align:center}
.odds span{background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:8px 4px;font-size:.82rem;color:var(--muted)}
.odds b{display:block;color:var(--txt);font-size:1rem}
.flag{border-radius:3px;border:1px solid var(--line);vertical-align:middle;object-fit:cover;box-shadow:0 1px 3px rgba(0,0,0,.35)}
.match-date{margin-top:2px;font-size:.84rem;color:var(--txt);border-top:1px dashed var(--line);padding-top:10px}
.match-date .muted{font-size:.78rem}
.match-teams .flag,.combi-teams .flag{margin:0 6px}
.match-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);flex-wrap:wrap}
.match-row:last-child{border-bottom:none}
.match-headline{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;text-align:center}
.match-headline .team{font-size:1.25rem;flex:0;justify-content:center}
.match-headline .full{flex-basis:100%}

/* Bet form */
.bet-tabs{display:flex;gap:10px;margin-bottom:6px}
.bet-tab{flex:1;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:12px;text-align:center;cursor:pointer;font-weight:600}
.odds-pick{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.odds-pick label{cursor:pointer}
.odds-pick input{display:none}
.odds-pick span{display:flex;flex-direction:column;gap:3px;align-items:center;background:var(--bg);border:2px solid var(--line);border-radius:11px;padding:14px 8px;transition:.15s}
.odds-pick small{color:var(--muted)}
.odds-pick input:checked + span{border-color:var(--primary);background:rgba(31,181,115,.12)}
.ganancia-prev{background:var(--bg);border:1px dashed var(--line);border-radius:10px;padding:10px 12px;font-size:.9rem;color:var(--muted)}
.ganancia-prev b{color:var(--txt)}

/* Champion */
.champ-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.champ-pick{cursor:pointer}
.champ-pick input{display:none}
.champ-card{display:flex;flex-direction:column;gap:4px;border:2px solid var(--line);border-radius:11px;padding:14px;background:var(--bg)}
.champ-card small{color:var(--muted)}
.champ-pick input:checked + .champ-card{border-color:var(--primary);background:rgba(31,181,115,.12)}

/* Combinada */
.combi-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.combi-row{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:0}
.combi-teams{display:flex;flex-direction:column}
.combi-opts{display:flex;gap:8px}
.combi-opts label{display:flex;align-items:center;gap:5px;background:var(--bg);border:1px solid var(--line);padding:7px 11px;border-radius:9px;cursor:pointer;font-weight:600}
.combi-opts small{color:var(--muted);font-weight:400}
.combi-opts input:checked ~ small{color:var(--primary)}
.combi-summary{position:sticky;bottom:14px}
.combi-ticket{border:1px solid var(--line);border-radius:11px;padding:12px;margin-bottom:12px;background:var(--bg)}
.combi-ticket-head{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;font-size:.9rem;margin-bottom:8px}
.combi-ticket-list{margin:0;padding-left:18px;color:var(--muted);font-size:.88rem;display:flex;flex-direction:column;gap:4px}

/* CTA / actions */
.cta-card{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.cta-card h3{margin:0 0 4px}
.action-card{transition:.15s}
.action-card:hover{border-color:var(--primary);text-decoration:none}
.action-card h3{margin:0 0 6px}

/* Reglas */
.rules-list{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:9px;font-size:.94rem}
.rules-list li{line-height:1.55}
.rules-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.rule-box{background:var(--bg);border:1px solid var(--line);border-radius:11px;padding:16px}
.rule-box h3{margin:0 0 8px;font-size:1.02rem}
.rule-box p{margin:0;color:var(--muted);font-size:.92rem;line-height:1.55}
.rule-box b,.rules-list b{color:var(--txt)}
code{background:var(--card-2);border:1px solid var(--line);border-radius:5px;padding:1px 6px;font-size:.85em;color:#9be9c4}

/* Bitácora / filtros */
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
.filter-bar select,.filter-bar input[type=text]{background:var(--bg);border:1px solid var(--line);color:var(--txt);padding:9px 11px;border-radius:9px;font-size:.92rem}
.filter-bar input[type=text]{flex:1;min-width:200px}
.table-logs td{font-size:.86rem;vertical-align:top}
.table-logs code{font-size:.8rem}
.pager{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:16px}

/* misc */
.inline-form{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.mini{width:54px;text-align:center}
.row-actions{display:flex;gap:6px;flex-wrap:wrap}
.row-actions form{margin:0}
.footer{border-top:1px solid var(--line);padding:20px 0;color:var(--muted)}
.footer .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
