@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&display=swap');
:root {
  --teal:#1D9E75;--teal-l:#E1F5EE;--teal-m:#5DCAA5;--teal-d:#0F6E56;--teal-dk:#085041;
  --amber:#FAEEDA;--amber-d:#633806;--red-l:#FEE2E2;--red-d:#991B1B;
  --text:#1a1a1a;--text2:#555;--text3:#888;--bg:#fff;--bg2:#f7f8f7;--bg3:#f0f2f0;
  --border:rgba(0,0,0,0.1);--border2:rgba(0,0,0,0.18);
  --radius:8px;--radius-lg:14px;
  --shadow:0 1px 3px rgba(0,0,0,0.06),0 4px 16px rgba(0,0,0,0.04);
  --nav-h:60px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:'DM Sans',sans-serif;color:var(--text);background:var(--bg);font-size:15px;line-height:1.6;}
img{max-width:100%;}
a{color:var(--teal-d);text-decoration:none;}
a:hover{text-decoration:underline;}

/* ── Contenedores ── */
.container{max-width:1100px;margin:0 auto;padding:0 1.25rem;}
@media(min-width:768px){.container{padding:0 2rem;}}

/* ── Botones ── */
.btn{display:inline-flex;align-items:center;justify-content:center;font-family:inherit;font-size:14px;font-weight:500;border:none;border-radius:var(--radius);padding:9px 18px;cursor:pointer;transition:background .15s,transform .1s;text-decoration:none;white-space:nowrap;line-height:1;}
.btn:active{transform:scale(0.97);}
.btn-primary{background:var(--teal);color:#fff;}
.btn-primary:hover{background:var(--teal-d);color:#fff;text-decoration:none;}
.btn-secondary{background:var(--bg);color:var(--text);border:1px solid var(--border2);}
.btn-secondary:hover{background:var(--bg2);text-decoration:none;}
.btn-lg{padding:12px 24px;font-size:15px;}
.btn-full{width:100%;}
.btn-sm{padding:6px 12px;font-size:13px;}

/* ── Formularios ── */
.form-group{margin-bottom:1rem;}
.form-group label{display:block;font-size:13px;font-weight:500;margin-bottom:5px;}
.form-control{width:100%;font-family:inherit;font-size:15px;color:var(--text);background:var(--bg);border:1px solid var(--border2);border-radius:var(--radius);padding:10px 12px;outline:none;transition:border .15s;-webkit-appearance:none;appearance:none;}
.form-control:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(29,158,117,0.1);}
select.form-control{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23888' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;}
textarea.form-control{min-height:80px;resize:vertical;}
.form-hint{font-size:12px;color:var(--text3);margin-top:4px;}
.form-error{font-size:12px;color:var(--red-d);margin-top:4px;}
.form-row{display:grid;grid-template-columns:1fr;gap:12px;}
@media(min-width:480px){.form-row{grid-template-columns:1fr 1fr;}}

/* ── Alertas ── */
.alert{padding:12px 16px;border-radius:var(--radius);font-size:14px;margin-bottom:1rem;line-height:1.5;}
.alert-success{background:var(--teal-l);color:var(--teal-dk);border:1px solid var(--teal-m);}
.alert-error{background:var(--red-l);color:var(--red-d);border:1px solid #FCA5A5;}
.alert-warning{background:var(--amber);color:var(--amber-d);border:1px solid #FCD34D;}

/* ── Navbar ── */
.navbar{position:sticky;top:0;z-index:100;background:rgba(255,255,255,0.97);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);height:var(--nav-h);}
.navbar-inner{display:flex;justify-content:space-between;align-items:center;height:var(--nav-h);}
.navbar-logo{display:flex;align-items:center;gap:9px;font-size:17px;font-weight:700;color:var(--text);text-decoration:none;}
.logo-mark{width:28px;height:28px;background:var(--teal);border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.navbar-links{display:none;}
@media(min-width:900px){.navbar-links{display:flex;gap:2px;}}
.navbar-link{font-size:14px;color:var(--text2);padding:6px 10px;border-radius:var(--radius);text-decoration:none;transition:background .15s;white-space:nowrap;}
.navbar-link:hover{background:var(--bg2);color:var(--text);text-decoration:none;}
.navbar-actions{display:flex;gap:8px;align-items:center;}
/* Hamburger mobile */
.hamburger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none;}
.hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .2s;}
@media(min-width:900px){.hamburger{display:none;}}
.mobile-menu{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:#fff;border-bottom:1px solid var(--border);padding:1rem 1.25rem;z-index:99;box-shadow:0 4px 20px rgba(0,0,0,0.1);}
.mobile-menu.open{display:block;}
.mobile-menu a{display:block;padding:12px 0;font-size:16px;color:var(--text);border-bottom:1px solid var(--border);text-decoration:none;}
.mobile-menu a:last-child{border-bottom:none;}

/* ── Cards ── */
.card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;}
.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border);font-size:14px;font-weight:600;}
.card-body{padding:1.25rem;}

/* ── Grids responsive ── */
.grid-2{display:grid;grid-template-columns:1fr;gap:16px;}
.grid-3{display:grid;grid-template-columns:1fr;gap:16px;}
.grid-4{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(min-width:600px){.grid-2{grid-template-columns:1fr 1fr;}.grid-3{grid-template-columns:1fr 1fr;}.grid-4{grid-template-columns:repeat(4,1fr);}}
@media(min-width:900px){.grid-3{grid-template-columns:repeat(3,1fr);}}

/* ── Auth pages ── */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg2);padding:1.5rem;}
.auth-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;width:100%;max-width:420px;box-shadow:var(--shadow);}
@media(min-width:480px){.auth-card{padding:2.5rem;}}
.auth-title{font-size:22px;font-weight:700;margin-bottom:0.4rem;text-align:center;}
.auth-sub{font-size:14px;color:var(--text3);text-align:center;margin-bottom:1.75rem;}
.auth-footer{text-align:center;margin-top:1.5rem;font-size:13px;color:var(--text3);}
.auth-footer a{color:var(--teal-d);font-weight:500;}

/* ── Tipo toggle registro ── */
.tipo-toggle{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:1.5rem;}
.tipo-opt{border:1px solid var(--border2);border-radius:var(--radius-lg);padding:.9rem;cursor:pointer;text-align:center;transition:all .15s;}
.tipo-opt.selected{border:2px solid var(--teal);background:var(--teal-l);}
.tipo-opt-icon{font-size:22px;margin-bottom:5px;}
.tipo-opt-title{font-size:13px;font-weight:600;}
.tipo-opt-desc{font-size:11px;color:var(--text3);margin-top:2px;}

/* ── Dashboard layout ── */
.dash-layout{display:grid;grid-template-columns:1fr;min-height:calc(100vh - var(--nav-h));}
@media(min-width:768px){.dash-layout{grid-template-columns:220px 1fr;}}
.dash-sidebar{background:var(--bg2);border-right:1px solid var(--border);padding:1rem 0;}
/* Mobile sidebar como tabs horizontales */
@media(max-width:767px){
  .dash-sidebar{border-right:none;border-bottom:1px solid var(--border);padding:0;overflow-x:auto;white-space:nowrap;}
  .dash-nav-item{display:inline-flex!important;padding:12px 16px;border-right:none!important;border-bottom:3px solid transparent;vertical-align:middle;}
  .dash-nav-item.active{border-bottom-color:var(--teal)!important;border-right:none!important;}
  .dash-nav-label{display:none;}
}
.dash-nav-item{display:flex;align-items:center;gap:8px;padding:10px 1.25rem;font-size:14px;color:var(--text2);text-decoration:none;transition:background .15s;cursor:pointer;border:none;background:none;font-family:inherit;width:100%;text-align:left;}
.dash-nav-item:hover,.dash-nav-item.active{background:var(--bg);color:var(--teal-d);font-weight:500;}
@media(min-width:768px){.dash-nav-item.active{border-right:3px solid var(--teal);}}
.dash-main{padding:1.25rem;}
@media(min-width:768px){.dash-main{padding:2rem 2.5rem;}}
.dash-section{display:none;}.dash-section.active{display:block;}

/* ── KPI grids ── */
.kpi-grid-3{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:1.25rem;}
@media(min-width:480px){.kpi-grid-3{grid-template-columns:repeat(3,1fr);}}
.kpi-grid-4{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:1.25rem;}
@media(min-width:768px){.kpi-grid-4{grid-template-columns:repeat(4,1fr);}}
.kpi{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.1rem;}
.kpi-val{font-size:24px;font-weight:700;color:var(--teal);}
.kpi-label{font-size:12px;color:var(--text3);margin-top:2px;}

/* ── Partido items ── */
.partido-row{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:8px;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px;}
.partido-row:last-child{border-bottom:none;}
.estado-badge{font-size:11px;font-weight:500;padding:3px 9px;border-radius:8px;white-space:nowrap;}
.estado-confirmado{background:var(--teal-l);color:var(--teal-d);}
.estado-completado{background:var(--bg3);color:var(--text2);}
.estado-pendiente{background:var(--amber);color:var(--amber-d);}
.estado-publicado{background:#EFF6FF;color:#1E40AF;}

/* ── Rating bars ── */
.rating-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.rating-label{font-size:12px;color:var(--text2);min-width:110px;flex-shrink:0;}
.rating-bar{flex:1;height:6px;background:var(--bg3);border-radius:4px;overflow:hidden;}
.rating-fill{height:100%;background:var(--teal);border-radius:4px;}
.rating-val{font-size:12px;color:var(--text3);min-width:28px;text-align:right;}

/* ── Árbitros grid ── */
.arb-grid{display:grid;grid-template-columns:1fr;gap:14px;}
@media(min-width:480px){.arb-grid{grid-template-columns:repeat(2,1fr);}}
@media(min-width:900px){.arb-grid{grid-template-columns:repeat(3,1fr);}}
.arb-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem;cursor:pointer;transition:border-color .15s,box-shadow .15s;text-decoration:none;color:inherit;display:block;}
.arb-card:hover{border-color:var(--teal-m);box-shadow:var(--shadow);text-decoration:none;}

/* ── Toggle buttons ── */
.tog-group{display:flex;gap:6px;flex-wrap:wrap;}
.tog{font-family:inherit;font-size:13px;color:var(--text2);border:1px solid var(--border2);border-radius:var(--radius);padding:7px 12px;cursor:pointer;background:var(--bg);transition:all .15s;white-space:nowrap;}
.tog.on{background:var(--teal-l);color:var(--teal-dk);border-color:var(--teal-m);font-weight:500;}

/* ── Disponibilidad días ── */
.disp-dias{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-top:.5rem;}
.dia-tog{text-align:center;padding:8px 4px;border-radius:6px;border:1px solid var(--border2);cursor:pointer;font-size:12px;transition:all .15s;}
.dia-tog.on{background:var(--teal-l);color:var(--teal-d);border-color:var(--teal-m);font-weight:500;}

/* ── Extra items ── */
.extra-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.extra-it{display:flex;align-items:flex-start;gap:8px;padding:9px 11px;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;background:var(--bg);transition:all .15s;font-size:13px;}
.extra-it.on{border-color:var(--teal-m);background:var(--teal-l);}

/* ── Desglose precio ── */
.precio-live{background:var(--teal-l);border:1px solid var(--teal-m);border-radius:var(--radius);padding:1rem;margin-top:.75rem;}
.pd-row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;border-bottom:1px solid rgba(29,158,117,.15);}
.pd-row:last-child{border-bottom:none;}

/* ── Sección hero ── */
.hero{padding:3.5rem 0 3rem;text-align:center;}
@media(min-width:768px){.hero{padding:5rem 0 4rem;}}
.hero h1{font-size:32px;font-weight:700;line-height:1.2;letter-spacing:-.02em;margin-bottom:1.1rem;}
@media(min-width:600px){.hero h1{font-size:40px;}}
@media(min-width:900px){.hero h1{font-size:48px;}}

/* ── Stats bar ── */
.stats-bar{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg2);}
.stat-item{padding:1.25rem .75rem;text-align:center;border-right:1px solid var(--border);}
.stat-item:last-child{border-right:none;}
.stat-val{font-size:24px;font-weight:700;color:var(--teal);}
@media(min-width:600px){.stat-val{font-size:30px;}}
.stat-label{font-size:12px;color:var(--text3);margin-top:2px;}

/* ── FAQ ── */
.faq-item{border-bottom:1px solid var(--border);}
.faq-q{width:100%;text-align:left;font-family:inherit;font-size:15px;font-weight:500;padding:1rem 0;background:none;border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;color:var(--text);}
.faq-icon{font-size:18px;color:var(--teal);flex-shrink:0;transition:transform .2s;min-width:20px;text-align:center;}
.faq-a{font-size:14px;color:var(--text2);line-height:1.75;padding-bottom:1rem;display:none;}
.faq-item.open .faq-a{display:block;}
.faq-item.open .faq-icon{transform:rotate(45deg);}

/* ── Footer ── */
.footer{border-top:1px solid var(--border);padding:1.5rem 0;background:var(--bg2);}
.footer-inner{display:flex;flex-direction:column;gap:12px;align-items:center;text-align:center;}
@media(min-width:600px){.footer-inner{flex-direction:row;justify-content:space-between;text-align:left;}}
.footer-links{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;}

/* ── Utilidades ── */
.hidden{display:none!important;}
.mt1{margin-top:.5rem;}
.mt2{margin-top:1rem;}
.mt3{margin-top:1.5rem;}
.section-pad{padding:3rem 0;}
@media(min-width:768px){.section-pad{padding:4rem 0;}}
.text-center{text-align:center;}
.fw{font-weight:600;}
.text-teal{color:var(--teal);}
.text-muted{color:var(--text3);}

/* ── Tarifa árbitro ── */
.tarifa-ref-box{background:var(--bg2);border-radius:var(--radius);padding:.9rem 1rem;}
.tarifa-ref-row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;border-bottom:1px solid var(--border);}
.tarifa-ref-row:last-child{border-bottom:none;}

/* ── Bloque partido publicar ── */
.partido-bloque{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1.25rem;position:relative;}
.bloque-num{position:absolute;top:-11px;left:1.25rem;background:var(--teal);color:#fff;font-size:12px;font-weight:700;padding:3px 12px;border-radius:10px;}

/* ── Tabla admin responsive ── */
.admin-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
.admin-table{width:100%;border-collapse:collapse;font-size:12px;min-width:600px;}
.admin-table th{padding:8px 10px;text-align:left;color:#777;font-weight:600;font-size:11px;border-bottom:1px solid var(--border);background:var(--bg2);white-space:nowrap;}
.admin-table td{padding:8px 10px;border-bottom:1px solid var(--border);vertical-align:middle;}
.admin-table tr:last-child td{border-bottom:none;}
.admin-table tr:hover td{background:var(--bg2);}
.bs{font-size:10px;padding:2px 7px;border-radius:6px;font-weight:500;white-space:nowrap;}
.bk{background:var(--teal-l);color:var(--teal-d);}
.bw{background:var(--amber);color:var(--amber-d);}
.bp{background:#EFF6FF;color:#1E40AF;}
.br{background:var(--red-l);color:var(--red-d);}

/* ── Selección árbitros múltiples ── */
.arb-sel-grid{display:grid;grid-template-columns:1fr;gap:10px;}
@media(min-width:480px){.arb-sel-grid{grid-template-columns:repeat(2,1fr);}}
@media(min-width:768px){.arb-sel-grid{grid-template-columns:repeat(3,1fr);}}
.arb-sel-card{border:2px solid var(--border);border-radius:var(--radius-lg);padding:1rem;cursor:pointer;transition:all .15s;background:#fff;}
.arb-sel-card:hover{border-color:var(--teal-m);}
.arb-sel-card.selected{border-color:var(--teal);background:var(--teal-l);}
.arb-sel-card .check{width:22px;height:22px;border-radius:50%;border:2px solid var(--border2);display:flex;align-items:center;justify-content:center;float:right;font-size:12px;transition:all .15s;}
.arb-sel-card.selected .check{background:var(--teal);border-color:var(--teal);color:#fff;}
