/* ═══════════════════════════════════════
   SERIES PÁDEL LOK — CSS
  3 Ligas · 15 Divisiones · Theme Ready
   ═══════════════════════════════════════ */

:root {
  --lok-green: #9cf06f;
  --lok-green-2: #85df57;
  --lok-bg: #070909;
  --lok-bg-soft: #0e1212;
  --lok-card: #111515;
  --lok-border: #1e2828;
  --lok-text: #f6f7f7;
  --lok-heading: #ffffff;
  --lok-muted: #a8b1b1;
  --lok-danger: #ff4d4d;
  --lok-btn-text: #070909;
  --lok-topbar-bg: rgba(7,9,9,.88);
  --lok-overlay: linear-gradient(160deg,rgba(7,9,9,.72) 20%,rgba(7,9,9,.48) 50%,rgba(10,20,15,.42) 80%,rgba(7,9,9,.58) 100%);
  --lok-card-soft: rgba(255,255,255,.04);
  --lok-logo-filter: brightness(0) invert(1);
  --lok-footer-muted: #445555;
  /* Liga colors */
  --liga-elite: #ffc850;
  --liga-pro: #7dd4fc;
  --liga-open: #a7fd7e;
  /* Legacy div colors (mapped to ligas) */
  --d1-color: #ffc850;
  --d2-color: #7dd4fc;
  --d3-color: #a7fd7e;
  --d4-color: #ff8a65;
  --d5-color: #ce93d8;
}

*, *::before, *::after { box-sizing: border-box; }
body { margin:0; background:var(--lok-bg); color:var(--lok-text); font-family:'Inter',sans-serif; -webkit-font-smoothing:antialiased; transition:background-color .25s ease, color .25s ease; }
img { max-width:100%; display:block; }
a { color:var(--lok-green); text-decoration:none; }

/* ── TOPBAR ── */
.lok-topbar { position:fixed; top:0; left:0; right:0; z-index:900; background:var(--lok-topbar-bg); backdrop-filter:blur(14px); border-bottom:1px solid var(--lok-border); }
.lok-brand { display:flex; align-items:center; gap:0; text-decoration:none; }
.lok-logo-img { height:54px; filter:var(--lok-logo-filter); }
.lok-brand-text { display:flex; flex-direction:row; align-items:center; line-height:1; }
.lok-brand-series { font-size:1.85rem; font-weight:900; color:var(--lok-heading); letter-spacing:.2px; text-transform:uppercase; padding-right:14px; margin-right:14px; border-right:2px solid rgba(255,255,255,.18); }
.lok-brand-name { display:none; }
.lok-nav { display:flex; gap:22px; }
.lok-nav a { color:var(--lok-muted); font-size:.82rem; font-weight:500; letter-spacing:.3px; transition:color .2s; }
.lok-nav a:hover, .lok-nav a.active-nav { color:var(--lok-heading); }

/* ── BUTTONS ── */
.btn-lok { display:inline-flex; align-items:center; gap:6px; background:var(--lok-green); color:var(--lok-btn-text); font-weight:700; font-size:.82rem; padding:10px 22px; border-radius:8px; border:none; cursor:pointer; transition:background .2s,transform .15s; }
.btn-lok:hover { background:var(--lok-green-2); transform:translateY(-1px); color:var(--lok-btn-text); }
.btn-lok-outline { display:inline-flex; align-items:center; gap:6px; background:transparent; color:var(--lok-green); font-weight:600; font-size:.82rem; padding:10px 22px; border-radius:8px; border:1.5px solid var(--lok-green); cursor:pointer; transition:background .2s; }
.btn-lok-outline:hover { background:rgba(167,253,126,.08); color:var(--lok-green); }
.btn-lok-sm { font-size:.78rem; padding:7px 16px; background:var(--lok-green); color:var(--lok-btn-text); font-weight:700; border-radius:6px; border:none; cursor:pointer; display:inline-flex; align-items:center; }
.btn-lg-lok { font-size:.95rem; padding:14px 32px; }

.theme-toggle-btn { width:38px; height:38px; border-radius:10px; border:1px solid var(--lok-border); background:var(--lok-card); color:var(--lok-heading); cursor:pointer; display:inline-flex; align-items:center; justify-content:center; transition:all .2s ease; }
.theme-toggle-btn:hover { border-color:var(--lok-green); color:var(--lok-green); transform:translateY(-1px); }

/* ── MOBILE NAV ── */
.mob-menu-btn { background:transparent; border:1px solid var(--lok-border); color:var(--lok-muted); font-size:1.15rem; padding:8px 12px; border-radius:8px; cursor:pointer; }
.mob-nav-panel { position:fixed; top:0; right:-320px; width:300px; height:100vh; background:var(--lok-bg-soft); z-index:1100; padding:32px 24px; transition:right .35s; border-left:1px solid var(--lok-border); display:flex; flex-direction:column; }
.mob-nav-panel.open { right:0; }
.mob-close { position:absolute; top:18px; right:18px; background:transparent; border:none; color:var(--lok-muted); font-size:1.3rem; cursor:pointer; }
.mob-logo { height:28px; margin-bottom:28px; filter:var(--lok-logo-filter); }
.mob-nav-panel nav { display:flex; flex-direction:column; gap:14px; }
.mob-nav-panel nav a { color:var(--lok-muted); font-size:.92rem; font-weight:500; }
.mob-nav-panel nav a:hover { color:var(--lok-heading); }
.mob-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:1050; }
.mob-overlay.show { display:block; }

/* ── HERO ── */
.hero-lok { position:relative; min-height:100vh; display:flex; align-items:center; padding:110px 0 60px; overflow:hidden; }
.hero-slideshow { position:absolute; inset:0; z-index:0; }
.hero-slideshow .slide { position:absolute; inset:0; background-size:cover; background-position:center; z-index:1; opacity:0; transform:scale(1.15); transition:opacity 1.8s ease, transform 10s linear; filter:brightness(0.85) saturate(1.1) contrast(1.02); }
.hero-slideshow .slide.active { opacity:1; transform:scale(1); z-index:2; }
.hero-slideshow .slide.fade-out { opacity:0; transform:scale(1.1); z-index:1; }
.hero-overlay { position:absolute; inset:0; z-index:3; background:var(--lok-overlay); }
.hero-wrap { position:relative; z-index:4; }
.hero-content { max-width:720px; }
.hero-chip { display:inline-block; background:rgba(167,253,126,.1); color:var(--lok-green); font-size:.72rem; font-weight:700; padding:6px 16px; border-radius:50px; letter-spacing:1px; margin-bottom:22px; border:1px solid rgba(167,253,126,.2); }
.hero-title { font-size:3.4rem; font-weight:900; line-height:1.06; margin:0 0 22px; color:#fff; }
.hero-title span { color:var(--lok-green); }
.hero-desc { font-size:1.08rem; color:var(--lok-muted); max-width:560px; line-height:1.7; margin-bottom:32px; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:40px; }
.hero-kpis { display:flex; gap:16px; flex-wrap:wrap; }
.kpi-card { background:var(--lok-card-soft); border:1px solid var(--lok-border); border-radius:10px; padding:14px 22px; text-align:center; min-width:110px; backdrop-filter:blur(4px); }
.kpi-value { font-size:1.6rem; font-weight:900; color:var(--lok-green); }
.kpi-label { font-size:.7rem; color:var(--lok-muted); margin-top:2px; }
.slide-indicators { position:absolute; bottom:32px; left:50%; transform:translateX(-50%); z-index:5; display:flex; gap:10px; }
.slide-ind { width:40px; height:4px; border-radius:2px; background:rgba(255,255,255,.2); cursor:pointer; transition:all .4s; border:none; padding:0; }
.slide-ind.active { background:var(--lok-green); width:60px; }

/* ── SEARCH ── */
.search-toggle-btn { background:transparent; border:1px solid var(--lok-border); color:var(--lok-muted); font-size:.9rem; padding:8px 12px; border-radius:8px; cursor:pointer; transition:all .2s; }
.search-toggle-btn:hover { color:var(--lok-green); border-color:var(--lok-green); }
.search-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.85); z-index:2000; align-items:flex-start; justify-content:center; padding-top:15vh; backdrop-filter:blur(8px); }
.search-overlay.active { display:flex; }
.search-modal { width:90%; max-width:600px; }
.search-header { display:flex; align-items:center; gap:12px; background:var(--lok-card); border:1px solid var(--lok-border); border-radius:12px; padding:16px 20px; }
.search-icon { color:var(--lok-green); font-size:1rem; }
.search-header input { flex:1; background:transparent; border:none; outline:none; color:var(--lok-heading); font-size:1rem; font-family:inherit; }
.search-header input::placeholder { color:var(--lok-muted); }
.search-close { background:transparent; border:none; color:var(--lok-muted); font-size:1.1rem; cursor:pointer; padding:4px; }
.search-close:hover { color:var(--lok-heading); }
.search-results { margin-top:8px; max-height:50vh; overflow-y:auto; }
.search-group { margin-top:8px; }
.search-group-title { font-size:.7rem; font-weight:700; color:var(--lok-muted); letter-spacing:1px; text-transform:uppercase; padding:8px 16px; }
.search-item { display:flex; align-items:center; padding:12px 16px; color:var(--lok-text); text-decoration:none; border-radius:8px; transition:background .2s; font-size:.88rem; }
.search-item:hover { background:rgba(167,253,126,.06); color:var(--lok-heading); }
.search-sub { color:var(--lok-muted); font-size:.75rem; margin-left:8px; }
.search-empty { padding:20px 16px; color:var(--lok-muted); text-align:center; font-size:.88rem; }

/* ── BRAND STRIP ── */
.brand-strip { background:var(--lok-bg-soft); border-top:1px solid var(--lok-border); border-bottom:1px solid var(--lok-border); padding:16px 0; }
.strip-label { font-size:.68rem; font-weight:700; color:var(--lok-green); letter-spacing:2px; text-transform:uppercase; }
.strip-logo { height:22px; filter:var(--lok-logo-filter); opacity:.65; }
.strip-tag { font-size:.78rem; color:var(--lok-muted); letter-spacing:.5px; }
.strip-socials { display:flex; gap:14px; }
.strip-socials a { color:var(--lok-muted); font-size:1rem; transition:color .2s; }
.strip-socials a:hover { color:var(--lok-green); }

/* ── SECTION COMMONS ── */
.section-pad { padding:80px 0; }
.section-chip { display:inline-block; background:rgba(167,253,126,.08); color:var(--lok-green); font-size:.7rem; font-weight:700; padding:5px 14px; border-radius:50px; letter-spacing:.8px; margin-bottom:14px; text-transform:uppercase; border:1px solid rgba(167,253,126,.15); }
.section-title { font-size:2.2rem; font-weight:900; color:var(--lok-heading); margin:0 0 14px; line-height:1.15; }
.section-title span { color:var(--lok-green); }
.section-desc { color:var(--lok-muted); font-size:.95rem; line-height:1.7; margin-bottom:20px; }

/* ── IMG STACK ── */
.img-stack { position:relative; }
.img-main { border-radius:14px; width:100%; aspect-ratio:4/5; object-fit:cover; filter:brightness(0.85) saturate(1.1); }
.img-secondary { position:absolute; bottom:-30px; right:-30px; width:50%; border-radius:14px; border:4px solid var(--lok-bg); aspect-ratio:1; object-fit:cover; box-shadow:0 12px 40px rgba(0,0,0,.5); filter:brightness(0.85) saturate(1.1); }
.img-badge { position:absolute; top:18px; left:18px; background:rgba(7,9,9,.85); color:var(--lok-green); font-size:.65rem; font-weight:800; padding:10px 14px; border-radius:10px; line-height:1.2; text-align:center; letter-spacing:1.5px; border:1px solid var(--lok-border); }

/* ── FEATURES GRID ── */
.features-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:28px; }
.feat-item { display:flex; gap:14px; align-items:flex-start; }
.feat-icon { width:42px; height:42px; min-width:42px; border-radius:10px; background:rgba(167,253,126,.1); color:var(--lok-green); display:flex; align-items:center; justify-content:center; font-size:.95rem; }
.feat-title { font-size:.85rem; font-weight:700; color:var(--lok-heading); margin-bottom:3px; }
.feat-desc { font-size:.78rem; color:var(--lok-muted); line-height:1.5; }

/* ── DIVISIONES ── */
.divisiones-section { background:var(--lok-bg-soft); }
.div-grid { display:grid; grid-template-columns:repeat(5, 1fr); gap:16px; }
.div-card { display:block; background:var(--lok-card); border:1px solid var(--lok-border); border-radius:14px; padding:28px 20px; text-align:center; transition:transform .3s,border-color .3s; text-decoration:none; color:inherit; cursor:pointer; }
.div-card:hover { transform:translateY(-4px); color:inherit; }
.div-card-d1 { border-top:3px solid var(--d1-color); }
.div-card-d2 { border-top:3px solid var(--d2-color); }
.div-card-d3 { border-top:3px solid var(--d3-color); }
.div-card-d4 { border-top:3px solid var(--d4-color); }
.div-card-d5 { border-top:3px solid var(--d5-color); }
.div-icon { font-size:1.4rem; margin-bottom:12px; }
.div-card-d1 .div-icon { color:var(--d1-color); }
.div-card-d2 .div-icon { color:var(--d2-color); }
.div-card-d3 .div-icon { color:var(--d3-color); }
.div-card-d4 .div-icon { color:var(--d4-color); }
.div-card-d5 .div-icon { color:var(--d5-color); }
.div-card-d1:hover { border-color:var(--d1-color); }
.div-card-d2:hover { border-color:var(--d2-color); }
.div-card-d3:hover { border-color:var(--d3-color); }
.div-card-d4:hover { border-color:var(--d4-color); }
.div-card-d5:hover { border-color:var(--d5-color); }
.div-name { font-size:1rem; font-weight:900; color:var(--lok-heading); letter-spacing:.5px; margin-bottom:8px; }
.div-desc { font-size:.78rem; color:var(--lok-muted); line-height:1.5; margin-bottom:12px; min-height:48px; }
.div-detail { font-size:.72rem; color:var(--lok-muted); background:rgba(255,255,255,.03); padding:6px 12px; border-radius:6px; margin-bottom:10px; }
.div-cta { font-size:.72rem; font-weight:700; color:var(--lok-green); opacity:.7; transition:opacity .3s; }
.div-card:hover .div-cta { opacity:1; }

/* ── DIVISION COLOR BADGES ── */
.d1-div { background:rgba(255,200,80,.12); color:var(--d1-color); }
.d2-div { background:rgba(125,212,252,.12); color:var(--d2-color); }
.d3-div { background:rgba(167,253,126,.12); color:var(--d3-color); }
.d4-div { background:rgba(255,138,101,.12); color:var(--d4-color); }
.d5-div { background:rgba(206,147,216,.12); color:var(--d5-color); }

/* ── LIGA COLOR BADGES ── */
.elite-div { background:rgba(255,200,80,.12); color:var(--liga-elite); }
.pro-div { background:rgba(125,212,252,.12); color:var(--liga-pro); }
.open-div { background:rgba(167,253,126,.12); color:var(--liga-open); }

/* ── LIGA SECTION (3-Liga Index) ── */
.ligas-grid { display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:22px; }
.liga-column { display:flex; flex-direction:column; gap:14px; }
.liga-group { margin-bottom:0; border-radius:16px; padding:22px 20px; border:1px solid var(--lok-border); background:var(--lok-card); height:100%; }
.liga-group.liga-group-elite { border-top:3px solid var(--liga-elite); }
.liga-group.liga-group-pro { border-top:3px solid var(--liga-pro); }
.liga-group.liga-group-open { border-top:3px solid var(--liga-open); }
.liga-group-header { display:flex; align-items:flex-start; gap:14px; margin-bottom:18px; }
.liga-group-icon { width:48px; height:48px; min-width:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
.liga-group-icon.elite { background:rgba(255,200,80,.12); color:var(--liga-elite); }
.liga-group-icon.pro { background:rgba(125,212,252,.12); color:var(--liga-pro); }
.liga-group-icon.open { background:rgba(167,253,126,.12); color:var(--liga-open); }
.liga-group-name { font-size:1.3rem; font-weight:900; color:var(--lok-heading); }
.liga-group-desc { font-size:.78rem; color:var(--lok-muted); }
.liga-group-copy { font-size:.82rem; color:#c7d0d0; line-height:1.55; margin:8px 0 0; }
.liga-group-tag { font-size:.68rem; font-weight:700; padding:4px 12px; border-radius:6px; letter-spacing:.5px; }
.liga-group-tag.elite { background:rgba(255,200,80,.12); color:var(--liga-elite); }
.liga-group-tag.pro { background:rgba(125,212,252,.12); color:var(--liga-pro); }
.liga-group-tag.open { background:rgba(167,253,126,.12); color:var(--liga-open); }
.liga-div-title { font-size:.67rem; font-weight:800; color:var(--lok-muted); letter-spacing:1.1px; text-transform:uppercase; margin-top:2px; margin-bottom:-4px; padding-left:2px; }
.liga-div-outside { display:grid; grid-template-columns:repeat(5, minmax(0, 1fr)); gap:10px; padding:10px; border-radius:12px; border:1px solid var(--lok-border); background:rgba(255,255,255,.015); }
.liga-div-chip { display:flex; align-items:center; justify-content:center; min-height:44px; border-radius:10px; border:1px solid var(--lok-border); text-decoration:none; font-size:.84rem; font-weight:900; letter-spacing:.45px; transition:transform .2s,border-color .2s,box-shadow .2s; }
.liga-div-outside.elite .liga-div-chip { color:var(--liga-elite); border-color:rgba(255,200,80,.28); background:rgba(255,200,80,.06); }
.liga-div-outside.pro .liga-div-chip { color:var(--liga-pro); border-color:rgba(125,212,252,.28); background:rgba(125,212,252,.06); }
.liga-div-outside.open .liga-div-chip { color:var(--liga-open); border-color:rgba(167,253,126,.28); background:rgba(167,253,126,.06); }
.liga-div-chip:hover { transform:translateY(-2px); }
.liga-div-outside.elite .liga-div-chip:hover { border-color:var(--liga-elite); box-shadow:0 8px 20px rgba(255,200,80,.16); }
.liga-div-outside.pro .liga-div-chip:hover { border-color:var(--liga-pro); box-shadow:0 8px 20px rgba(125,212,252,.16); }
.liga-div-outside.open .liga-div-chip:hover { border-color:var(--liga-open); box-shadow:0 8px 20px rgba(167,253,126,.16); }
.liga-div-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:12px; }
.liga-div-card { display:flex; align-items:center; background:linear-gradient(180deg, rgba(255,255,255,.012), rgba(255,255,255,0)); border:1px solid var(--lok-border); border-radius:13px; padding:10px 13px; text-align:left; transition:transform .22s,border-color .22s, box-shadow .22s; text-decoration:none; color:inherit; cursor:pointer; min-height:72px; }
.liga-div-card:hover { transform:translateY(-4px); color:inherit; }
.liga-div-card.elite { border-top:3px solid var(--liga-elite); }
.liga-div-card.pro { border-top:3px solid var(--liga-pro); }
.liga-div-card.open { border-top:3px solid var(--liga-open); }
.liga-div-card:hover.elite { border-color:var(--liga-elite); box-shadow:0 10px 24px rgba(255,200,80,.12); }
.liga-div-card:hover.pro { border-color:var(--liga-pro); box-shadow:0 10px 24px rgba(125,212,252,.12); }
.liga-div-card:hover.open { border-color:var(--liga-open); box-shadow:0 10px 24px rgba(167,253,126,.12); }
.liga-div-top { display:flex; align-items:center; justify-content:space-between; width:100%; margin-bottom:0; }
.liga-div-badge { display:inline-flex; align-items:center; border:1px solid var(--lok-border); background:rgba(255,255,255,.018); color:#8e9b9b; font-size:.62rem; font-weight:700; padding:3px 8px; border-radius:999px; text-transform:uppercase; letter-spacing:.45px; }
.liga-div-num { font-size:1.88rem; font-weight:900; margin-bottom:0; line-height:1; letter-spacing:.6px; }
.liga-div-card .div-name { display:none; }
.liga-div-card.elite .liga-div-num { color:var(--liga-elite); }
.liga-div-card.pro .liga-div-num { color:var(--liga-pro); }
.liga-div-card.open .liga-div-num { color:var(--liga-open); }
.liga-global-copy { margin-top:16px; font-size:.84rem; color:#dce2e2; text-align:center; border-top:1px solid var(--lok-border); padding-top:16px; }

/* ── LIGA FILTER TABS (Clasificación) ── */
.liga-filter-tabs { display:flex; gap:6px; margin-bottom:16px; }
.liga-filter-tab { background:var(--lok-card); border:1px solid var(--lok-border); color:var(--lok-muted); font-size:.8rem; font-weight:700; padding:9px 22px; border-radius:10px; cursor:pointer; transition:all .2s; letter-spacing:.3px; }
.liga-filter-tab.active { color:#070909; }
.liga-filter-tab.active.tab-elite { background:var(--liga-elite); border-color:var(--liga-elite); }
.liga-filter-tab.active.tab-pro { background:var(--liga-pro); border-color:var(--liga-pro); }
.liga-filter-tab.active.tab-open { background:var(--liga-open); border-color:var(--liga-open); }
.liga-filter-tab.active.tab-all { background:var(--lok-green); border-color:var(--lok-green); }
.liga-filter-tab:hover:not(.active) { border-color:rgba(167,253,126,.3); color:var(--lok-heading); }

/* ── MI ÁREA ── */
.mi-area-page { padding-top:90px; min-height:100vh; padding-bottom:60px; }
.login-wrap { max-width:420px; margin:60px auto 0; }
.login-card { background:var(--lok-card); border:1px solid var(--lok-border); border-radius:16px; padding:40px 32px; }
.login-logo { text-align:center; margin-bottom:24px; }
.login-logo img { height:36px; margin:0 auto 12px; }
.login-title { font-size:1.4rem; font-weight:900; color:var(--lok-heading); text-align:center; margin-bottom:6px; }
.login-subtitle { font-size:.82rem; color:var(--lok-muted); text-align:center; margin-bottom:24px; }
.login-field { margin-bottom:18px; }
.login-label { display:block; font-size:.75rem; font-weight:700; color:var(--lok-muted); margin-bottom:6px; text-transform:uppercase; letter-spacing:.5px; }
.login-input { width:100%; background:var(--lok-bg); border:1px solid var(--lok-border); color:var(--lok-heading); font-size:.9rem; padding:12px 16px; border-radius:10px; outline:none; font-family:inherit; transition:border-color .2s; }
.login-input:focus { border-color:var(--lok-green); }
.login-input::placeholder { color:rgba(168,177,177,.5); }
.login-btn { width:100%; margin-top:8px; justify-content:center; font-size:.9rem; padding:14px; }
.login-error { background:rgba(255,77,77,.1); color:var(--lok-danger); font-size:.82rem; padding:10px 14px; border-radius:8px; margin-bottom:16px; display:none; }
.login-error.show { display:block; }
.register-success { background:rgba(156,240,111,.08); color:var(--lok-green); font-size:.82rem; padding:10px 14px; border-radius:8px; margin-bottom:16px; border:1px solid rgba(156,240,111,.2); display:none; }
.register-success.show { display:block; }
/* Google Sign-In button */
.google-signin-btn { display:flex; align-items:center; justify-content:center; background:#fff; color:#1f1f1f; font-size:.88rem; font-weight:600; padding:11px 16px; border-radius:10px; cursor:pointer; border:1px solid #dadce0; transition:background .2s,box-shadow .2s; user-select:none; }
.google-signin-btn:hover { background:#f8f8f8; box-shadow:0 1px 6px rgba(0,0,0,.2); }
/* Auth divider */
.auth-divider { display:flex; align-items:center; gap:10px; margin:18px 0; }
.auth-divider::before,.auth-divider::after { content:''; flex:1; height:1px; background:var(--lok-border); }
.auth-divider span { font-size:.75rem; color:var(--lok-muted); font-weight:500; }
/* Tabs */
.auth-tabs { display:flex; background:var(--lok-bg); border:1px solid var(--lok-border); border-radius:10px; padding:3px; margin-bottom:20px; }
.auth-tab { flex:1; background:transparent; border:none; color:var(--lok-muted); font-size:.82rem; font-weight:700; padding:9px; border-radius:8px; cursor:pointer; transition:all .2s; font-family:inherit; }
.auth-tab.active { background:var(--lok-card); color:var(--lok-heading); box-shadow:0 1px 4px rgba(0,0,0,.3); }
/* Password toggle */
.login-pwd-wrap { position:relative; }
.login-pwd-wrap .login-input { padding-right:44px; }
.pwd-toggle { position:absolute; right:12px; top:50%; transform:translateY(-50%); background:none; border:none; color:var(--lok-muted); cursor:pointer; padding:4px; font-size:.9rem; line-height:1; }
.pwd-toggle:hover { color:var(--lok-heading); }
.dashboard-wrap { display:none; }
.dash-welcome { margin-bottom:32px; }
.dash-welcome h1 { font-size:1.8rem; font-weight:900; color:var(--lok-heading); margin:0 0 6px; }
.dash-welcome h1 span { color:var(--lok-green); }
.dash-welcome p { color:var(--lok-muted); font-size:.88rem; margin:0; }
.dash-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.dash-card { background:var(--lok-card); border:1px solid var(--lok-border); border-radius:14px; overflow:hidden; }
.dash-card-title { display:flex; align-items:center; gap:10px; padding:18px 20px; border-bottom:1px solid var(--lok-border); font-size:.88rem; font-weight:800; color:var(--lok-heading); }
.dash-card-title i { color:var(--lok-green); }
.dash-card-body { padding:20px; }
.dash-card.full-width { grid-column:1/-1; }
.dash-logout { margin-top:28px; text-align:center; }
.dash-logout-btn { background:transparent; border:1px solid var(--lok-border); color:var(--lok-muted); font-size:.78rem; font-weight:600; padding:8px 20px; border-radius:8px; cursor:pointer; transition:all .2s; }
.dash-logout-btn:hover { border-color:var(--lok-danger); color:var(--lok-danger); }
.mini-clasif-table { width:100%; border-collapse:collapse; font-size:.8rem; }
.mini-clasif-table th { color:var(--lok-muted); font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:.5px; padding:8px 10px; text-align:left; border-bottom:1px solid var(--lok-border); }
.mini-clasif-table td { padding:8px 10px; border-bottom:1px solid rgba(255,255,255,.03); }
.mini-clasif-table .my-team { background:rgba(167,253,126,.06); }
.mini-clasif-table .my-team td:first-child { box-shadow:inset 3px 0 0 var(--lok-green); }
.match-mini { display:flex; justify-content:space-between; align-items:center; padding:10px 0; border-bottom:1px solid rgba(255,255,255,.03); }
.match-mini:last-child { border-bottom:none; }
.match-mini-teams { font-size:.82rem; font-weight:700; color:var(--lok-heading); }
.match-mini-teams span { color:var(--lok-muted); font-weight:400; font-size:.75rem; }
.match-mini-score { font-size:.9rem; font-weight:900; }
.match-mini-date { font-size:.72rem; color:var(--lok-muted); }

/* ── PISTAS VISUAL (ENFRENTAMIENTO) ── */
.enfrentamiento-section { background:var(--lok-bg); }
.pistas-visual { display:flex; gap:20px; justify-content:center; flex-wrap:wrap; }
.pista-card { background:var(--lok-card); border:1px solid var(--lok-border); border-radius:16px; padding:32px 24px; text-align:center; min-width:180px; flex:1; max-width:220px; position:relative; transition:transform .3s,border-color .3s; }
.pista-card:hover { transform:translateY(-4px); }
.pista-p1 { border-top:3px solid var(--lok-green); }
.pista-p2 { border-top:3px solid #7dd4fc; }
.pista-p3 { border-top:3px solid #ffc850; }
.pista-pm { border-top:3px solid #ce93d8; }
.pista-value { font-size:3rem; font-weight:900; line-height:1; }
.pista-p1 .pista-value { color:var(--lok-green); }
.pista-p2 .pista-value { color:#7dd4fc; }
.pista-p3 .pista-value { color:#ffc850; }
.pista-pm .pista-value { color:#ce93d8; }
.pista-label { font-size:.75rem; color:var(--lok-muted); font-weight:600; text-transform:uppercase; letter-spacing:1px; margin-bottom:12px; }
.pista-name { font-size:1.3rem; font-weight:900; color:var(--lok-heading); margin-bottom:2px; }
.pista-type { font-size:.78rem; color:var(--lok-muted); margin-bottom:10px; }
.pista-note { font-size:.72rem; color:var(--lok-muted); background:rgba(255,255,255,.03); padding:6px 10px; border-radius:6px; }
.enfrentamiento-total { font-size:1.1rem; font-weight:800; color:var(--lok-heading); margin-bottom:6px; }
.enfrentamiento-total strong { color:var(--lok-green); }
.enfrentamiento-desempate { font-size:.82rem; color:var(--lok-muted); margin-bottom:0; }
.enfrentamiento-reglas { display:flex; gap:20px; justify-content:center; flex-wrap:wrap; margin-top:40px; }
.regla-item { display:flex; gap:14px; align-items:flex-start; background:var(--lok-card); border:1px solid var(--lok-border); border-radius:12px; padding:20px; flex:1; min-width:260px; max-width:340px; }
.regla-icon { width:40px; height:40px; min-width:40px; border-radius:10px; background:rgba(167,253,126,.08); color:var(--lok-green); display:flex; align-items:center; justify-content:center; font-size:.95rem; }
.regla-item strong { color:var(--lok-heading); font-size:.85rem; }
.regla-item span { color:var(--lok-muted); font-size:.78rem; line-height:1.5; }

/* ── LIGA / CLASIFICACIÓN ── */
.liga-section { background:var(--lok-bg-soft); }
.liga-tabs { display:flex; gap:6px; background:var(--lok-card); border:1px solid var(--lok-border); border-radius:10px; padding:4px; flex-wrap:wrap; }
.liga-tab { background:transparent; border:none; color:var(--lok-muted); font-size:.78rem; font-weight:700; padding:8px 20px; border-radius:8px; cursor:pointer; transition:all .2s; letter-spacing:.5px; white-space:nowrap; }
.liga-tab.active { background:var(--lok-green); color:#070909; }
.liga-panel { display:none; }
.liga-panel.active { display:block; }
.liga-table-wrap { overflow-x:auto; border-radius:12px; border:1px solid var(--lok-border); background:var(--lok-card); }
.liga-table { width:100%; border-collapse:collapse; font-size:.84rem; }
.liga-table thead th { background:rgba(255,255,255,.03); padding:13px 14px; text-align:left; font-weight:700; font-size:.72rem; color:var(--lok-muted); text-transform:uppercase; letter-spacing:.5px; border-bottom:1px solid var(--lok-border); white-space:nowrap; }
.th-pts { color:var(--lok-green)!important; }
.liga-row td { padding:13px 14px; border-bottom:1px solid rgba(255,255,255,.03); white-space:nowrap; }
.liga-pos { width:36px; text-align:center; }
.pos-num { background:rgba(255,255,255,.06); color:var(--lok-muted); font-weight:800; font-size:.72rem; display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px; border-radius:6px; }
.liga-top1 { background:rgba(167,253,126,.07)!important; }
.liga-top1 .pos-num { background:rgba(167,253,126,.18); color:var(--lok-green); }
.liga-top1 td:first-child { box-shadow:inset 3px 0 0 var(--lok-green); }
.liga-top2 { background:rgba(167,253,126,.04)!important; }
.liga-top2 .pos-num { background:rgba(167,253,126,.12); color:var(--lok-green); }
.liga-top2 td:first-child { box-shadow:inset 3px 0 0 rgba(167,253,126,.65); }
.liga-desc { background:rgba(255,77,77,.07)!important; }
.liga-desc .pos-num { background:rgba(255,77,77,.15); color:var(--lok-danger); }
.liga-desc td:first-child { box-shadow:inset 3px 0 0 var(--lok-danger); }
.liga-desc2 { background:rgba(255,77,77,.04)!important; }
.liga-desc2 .pos-num { background:rgba(255,77,77,.1); color:var(--lok-danger); }
.liga-desc2 td:first-child { box-shadow:inset 3px 0 0 rgba(255,77,77,.6); }
.liga-team { font-weight:700; color:var(--lok-heading); }
.liga-team-dot { display:inline-block; width:8px; height:8px; border-radius:50%; margin-right:8px; vertical-align:middle; }
.liga-pts { font-weight:900; color:var(--lok-green); font-size:.95rem; }
.liga-form { display:flex; gap:4px; }
.f-w { background:rgba(167,253,126,.18); color:var(--lok-green); font-size:.65rem; font-weight:800; padding:3px 7px; border-radius:4px; }
.f-l { background:rgba(255,77,77,.15); color:var(--lok-danger); font-size:.65rem; font-weight:800; padding:3px 7px; border-radius:4px; }
.liga-legend { display:flex; gap:18px; flex-wrap:wrap; padding:14px 20px; font-size:.72rem; color:var(--lok-muted); align-items:center; }
.legend-dot { display:inline-block; width:10px; height:10px; border-radius:3px; margin-right:5px; vertical-align:middle; }
.legend-up { background:var(--lok-green); }
.legend-down { background:var(--lok-danger); }

/* ── DIVISION HEADERS (clasificación page) ── */
.division-block { margin-bottom:28px; }
.division-block:last-child { margin-bottom:0; }
.division-header { display:flex; align-items:center; gap:12px; padding:16px 20px; border-radius:12px 12px 0 0; border:1px solid var(--lok-border); border-bottom:none; }
.division-header-d1-div { background:linear-gradient(90deg, rgba(255,200,80,.1), transparent); border-left:3px solid var(--d1-color); }
.division-header-d2-div { background:linear-gradient(90deg, rgba(125,212,252,.1), transparent); border-left:3px solid var(--d2-color); }
.division-header-d3-div { background:linear-gradient(90deg, rgba(167,253,126,.1), transparent); border-left:3px solid var(--d3-color); }
.division-header-d4-div { background:linear-gradient(90deg, rgba(255,138,101,.1), transparent); border-left:3px solid var(--d4-color); }
.division-header-d5-div { background:linear-gradient(90deg, rgba(206,147,216,.1), transparent); border-left:3px solid var(--d5-color); }
.division-header-icon { font-size:1rem; }
.division-header-d1-div .division-header-icon { color:var(--d1-color); }
.division-header-d2-div .division-header-icon { color:var(--d2-color); }
.division-header-d3-div .division-header-icon { color:var(--d3-color); }
.division-header-d4-div .division-header-icon { color:var(--d4-color); }
.division-header-d5-div .division-header-icon { color:var(--d5-color); }
.division-header-name { font-size:1rem; font-weight:900; color:var(--lok-heading); letter-spacing:.5px; }
.division-header-count { font-size:.72rem; color:var(--lok-muted); margin-left:auto; }

/* ── PARTIDOS / ENFRENTAMIENTOS ── */
.partido-list { display:flex; flex-direction:column; gap:14px; }
.partido-card { background:var(--lok-card); border:1px solid var(--lok-border); border-radius:12px; padding:18px 20px; transition:border-color .3s; }
.partido-card:hover { border-color:rgba(167,253,126,.25); }
.partido-meta { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; }
.partido-div { font-size:.68rem; font-weight:700; padding:4px 10px; border-radius:6px; letter-spacing:.3px; }
.partido-fecha { font-size:.75rem; color:var(--lok-muted); }
.partido-teams { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; }
.partido-team { display:flex; align-items:center; gap:8px; font-weight:700; font-size:.9rem; color:var(--lok-heading); }
.partido-team-right { text-align:right; }
.partido-team-dot { display:inline-block; width:8px; height:8px; border-radius:50%; }
.partido-vs { font-size:.7rem; color:var(--lok-muted); font-weight:700; letter-spacing:1px; }
.partido-estado { font-size:.7rem; font-weight:700; padding:4px 10px; border-radius:6px; }
.partido-estado.validado { background:rgba(167,253,126,.1); color:var(--lok-green); }
.resultado-score { display:flex; align-items:center; gap:6px; }
.score-local, .score-visit { font-size:1.4rem; font-weight:900; min-width:28px; text-align:center; }
.score-local.win, .score-visit.win { color:var(--lok-green); }
.score-sep { color:var(--lok-muted); font-size:.8rem; }
.pista-badge { font-size:.7rem; padding:4px 10px; border-radius:6px; font-weight:600; }
.pista-badge.win  { background:rgba(167,253,126,.1); color:var(--lok-green); }
.pista-badge.lose { background:rgba(255,77,77,.08); color:rgba(255,77,77,.7); }
.pista-badge.pista-live { background:rgba(255,200,80,.1); color:#ffc850; }

/* ── RANKING / PODIO ── */
.ranking-section { background:var(--lok-bg-soft); }
.podio { display:flex; justify-content:center; align-items:flex-end; gap:20px; margin-bottom:10px; }
.podio-item { background:var(--lok-card); border:1px solid var(--lok-border); border-radius:14px; padding:24px 20px; text-align:center; width:200px; transition:transform .3s; cursor:pointer; }
.podio-item:hover { transform:translateY(-4px); }
.podio-1 { order:2; padding-bottom:36px; border-color:var(--lok-green); }
.podio-2 { order:1; }
.podio-3 { order:3; }
.podio-avatar { width:52px; height:52px; border-radius:50%; background:rgba(255,255,255,.06); display:flex; align-items:center; justify-content:center; margin:0 auto 10px; font-size:1.2rem; color:var(--lok-muted); }
.podio-avatar-1 { background:rgba(167,253,126,.12); color:var(--lok-green); border:2px solid var(--lok-green); }
.podio-pts { font-size:1.5rem; font-weight:900; color:var(--lok-green); }
.podio-name { font-size:.9rem; font-weight:800; color:var(--lok-heading); margin-top:4px; }
.podio-team { font-size:.72rem; color:var(--lok-muted); margin-top:2px; }
.podio-meta { font-size:.68rem; color:var(--lok-muted); margin-top:6px; }
.podio-medal { margin-top:8px; font-size:.85rem; font-weight:800; }
.ranking-table th:nth-child(3),
.ranking-table td:nth-child(3) { max-width:120px; overflow:hidden; text-overflow:ellipsis; }
.rnk-div { font-size:.65rem; font-weight:700; padding:3px 8px; border-radius:5px; white-space:nowrap; }

/* ── CLASIFICACIÓN PAGE ── */
.clasif-page { padding-top:90px; min-height:100vh; padding-bottom:60px; }
.clasif-header { display:flex; justify-content:space-between; align-items:flex-end; gap:20px; flex-wrap:wrap; padding:28px 0 20px; }
.clasif-title { font-size:2rem; font-weight:900; color:var(--lok-heading); margin:0 0 4px; }
.clasif-title span { color:var(--lok-green); }
.clasif-subtitle { font-size:.82rem; color:var(--lok-muted); margin:0; }
.clasif-main-tabs { display:flex; gap:8px; }
.main-tab { background:var(--lok-card); border:1px solid var(--lok-border); color:var(--lok-muted); font-size:.82rem; font-weight:700; padding:10px 24px; border-radius:10px; cursor:pointer; transition:all .2s; }
.main-tab.active { background:var(--lok-green); color:#070909; border-color:var(--lok-green); }
.main-tab:hover:not(.active) { border-color:rgba(167,253,126,.3); color:var(--lok-heading); }
.clasif-filters { margin-bottom:24px; }

/* ── ASCENSOS ── */
.ascensos-section { background:var(--lok-bg); }
.reto-card { background:var(--lok-card); border:1px solid var(--lok-border); border-radius:16px; overflow:hidden; transition:transform .3s,border-color .3s; }
.reto-card:hover { transform:translateY(-4px); border-color:rgba(167,253,126,.2); }
.reto-header { display:flex; justify-content:space-between; align-items:center; padding:16px 20px; border-bottom:1px solid var(--lok-border); }
.reto-badge { font-size:.72rem; font-weight:800; padding:5px 14px; border-radius:8px; letter-spacing:.5px; }
.reto-badge-1 { background:rgba(255,77,77,.12); color:var(--lok-danger); }
.reto-badge-2 { background:rgba(255,200,80,.12); color:#ffc850; }
.reto-stakes { font-size:.72rem; color:var(--lok-muted); font-weight:600; font-style:italic; }
.reto-matchup { display:flex; align-items:center; justify-content:space-between; padding:24px 20px; gap:12px; }
.reto-team { display:flex; align-items:center; gap:12px; }
.reto-team strong { font-size:.88rem; color:var(--lok-heading); display:block; }
.reto-team span { font-size:.72rem; color:var(--lok-muted); }
.reto-team-icon { width:42px; height:42px; min-width:42px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:.95rem; }
.reto-challenger .reto-team-icon { background:rgba(167,253,126,.12); color:var(--lok-green); }
.reto-icon-defend { background:rgba(255,77,77,.1)!important; color:var(--lok-danger)!important; }
.reto-vs { text-align:center; }
.reto-vs span { font-size:.8rem; font-weight:800; color:var(--lok-muted); letter-spacing:2px; background:rgba(255,255,255,.04); padding:6px 14px; border-radius:8px; }
.reto-detail { font-size:.78rem; color:var(--lok-muted); padding:14px 20px; border-top:1px solid rgba(255,255,255,.04); }
.reto-matchup-mini { padding:20px; display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.reto-pair { display:flex; align-items:center; gap:8px; font-size:.78rem; color:var(--lok-muted); background:rgba(255,255,255,.03); padding:8px 12px; border-radius:8px; }
.reto-pair i { color:var(--lok-green); font-size:.65rem; }
.reto-from { font-weight:800; color:var(--lok-green); }
.reto-to { font-weight:800; color:var(--lok-danger); }
.reto-rules { display:flex; gap:20px; justify-content:center; flex-wrap:wrap; }
.reto-rule { display:flex; gap:14px; align-items:flex-start; background:var(--lok-card); border:1px solid var(--lok-border); border-radius:12px; padding:20px; flex:1; min-width:260px; max-width:340px; transition:transform .3s; }
.reto-rule:hover { transform:translateY(-2px); }
.reto-rule-icon { width:40px; height:40px; min-width:40px; border-radius:10px; background:rgba(255,77,77,.08); color:var(--lok-danger); display:flex; align-items:center; justify-content:center; font-size:.95rem; }
.reto-rule strong { color:var(--lok-heading); font-size:.85rem; display:block; margin-bottom:4px; }
.reto-rule span { color:var(--lok-muted); font-size:.78rem; line-height:1.5; }

/* ── GESTIÓN ── */
.gestion-section { background:var(--lok-bg-soft); }
.gestion-item { background:var(--lok-card); border:1px solid var(--lok-border); border-radius:14px; padding:28px 22px; height:100%; transition:transform .3s,border-color .3s; }
.gestion-item:hover { transform:translateY(-3px); border-color:rgba(167,253,126,.2); }
.gestion-icon { width:44px; height:44px; border-radius:10px; background:rgba(167,253,126,.1); color:var(--lok-green); display:flex; align-items:center; justify-content:center; font-size:1rem; margin-bottom:16px; }
.gestion-title { font-size:.9rem; font-weight:800; color:var(--lok-heading); margin-bottom:8px; }
.gestion-desc { font-size:.8rem; color:var(--lok-muted); line-height:1.6; }

/* ── FAQ (2-column grid) ── */
.faq-section { background:var(--lok-bg); }
.faq-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; max-width:1100px; margin:0 auto; }
.faq-item { background:var(--lok-card); border:1px solid var(--lok-border); border-radius:12px; overflow:hidden; transition:border-color .3s; }
.faq-item[open] { border-color:rgba(167,253,126,.25); }
.faq-item summary { display:flex; justify-content:space-between; align-items:center; padding:18px 22px; font-size:.88rem; font-weight:700; color:var(--lok-heading); cursor:pointer; list-style:none; }
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary i { color:var(--lok-muted); font-size:.75rem; transition:transform .3s; min-width:16px; }
.faq-item[open] summary i { transform:rotate(180deg); color:var(--lok-green); }
.faq-item p { padding:0 22px 18px; margin:0; font-size:.82rem; color:var(--lok-muted); line-height:1.7; }

/* ── CTA ── */
.cta-section { position:relative; padding:100px 0; overflow:hidden; }
.cta-bg { position:absolute; inset:0; background-size:cover; background-position:center; filter:brightness(0.5) saturate(1.2); }
.cta-overlay { position:absolute; inset:0; background:rgba(7,9,9,.82); }
.cta-wrap { position:relative; z-index:2; }
.cta-logo { height:50px; filter:brightness(0) invert(1); margin:0 auto 24px; opacity:.6; }
.cta-title { font-size:2.2rem; font-weight:900; color:#fff; margin:0 0 16px; line-height:1.2; }
.cta-title span { color:var(--lok-green); }
.cta-desc { color:var(--lok-muted); font-size:.95rem; max-width:520px; margin:0 auto 28px; line-height:1.7; }
.cta-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ── FOOTER ── */
.footer-lok { background:var(--lok-bg-soft); border-top:1px solid var(--lok-border); padding:40px 0; }
.footer-links { display:flex; flex-direction:column; gap:8px; }
.footer-links a { color:var(--lok-muted); font-size:.85rem; transition:color .2s; }
.footer-links a:hover { color:var(--lok-green); }

/* ── LOADING ── */
.liga-loading { text-align:center; padding:40px 20px; color:var(--lok-muted); font-size:.88rem; }
.liga-loading i { margin-right:8px; color:var(--lok-green); }

/* ── DETAIL PAGES ── */
.detail-page { padding-top:90px; min-height:100vh; }
.detail-back { margin-bottom:24px; padding-top:20px; }
.btn-sm-lok { font-size:.78rem; padding:7px 16px; }
.detail-header { background:var(--lok-card); border:1px solid var(--lok-border); border-radius:14px; overflow:hidden; margin-bottom:28px; }
.detail-color-bar { height:4px; }
.detail-header-content { padding:28px 24px; }
.detail-name { font-size:1.8rem; font-weight:900; color:var(--lok-heading); margin:0 0 12px; }
.detail-meta { display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.detail-badge { font-size:.75rem; color:var(--lok-muted); background:rgba(255,255,255,.04); padding:5px 12px; border-radius:6px; }
.detail-badge-link { text-decoration:none; transition:background .2s; }
.detail-badge-link:hover { background:rgba(167,253,126,.08); color:var(--lok-green); }
.detail-section { margin-bottom:32px; }
.detail-section-title { font-size:1rem; font-weight:800; color:var(--lok-heading); margin:0 0 18px; }
.detail-error { text-align:center; padding:80px 20px; color:var(--lok-danger); font-size:1.1rem; }
.player-link { color:var(--lok-green); text-decoration:none; font-weight:700; }
.player-link:hover { text-decoration:underline; }
.team-link { color:var(--lok-green); text-decoration:none; font-weight:700; }
.team-link:hover { text-decoration:underline; }
.player-avatar-lg { width:64px; height:64px; border-radius:50%; background:rgba(255,255,255,.06); display:flex; align-items:center; justify-content:center; font-size:1.5rem; color:var(--lok-muted); border:2px solid var(--lok-border); }

/* ── STATS GRID ── */
.stats-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(140px, 1fr)); gap:12px; }
.stat-card { background:var(--lok-card); border:1px solid var(--lok-border); border-radius:12px; padding:20px 16px; text-align:center; }
.stat-val { font-size:1.5rem; font-weight:900; color:var(--lok-heading); }
.stat-lbl { font-size:.72rem; color:var(--lok-muted); margin-top:4px; text-transform:uppercase; letter-spacing:.5px; }
.stat-card.stat-highlight { border-color:rgba(167,253,126,.3); }
.stat-card.stat-highlight .stat-val { color:var(--lok-green); }
.stat-card.stat-win .stat-val { color:var(--lok-green); }
.stat-card.stat-lose .stat-val { color:var(--lok-danger); }
.zona-ascenso { color:var(--lok-green)!important; text-transform:uppercase; font-size:.85rem; }
.zona-descenso { color:var(--lok-danger)!important; text-transform:uppercase; font-size:.85rem; }
.zona-normal { color:var(--lok-muted)!important; text-transform:uppercase; font-size:.85rem; }

/* ── PISTA BREAKDOWN ── */
.pista-breakdown { display:grid; grid-template-columns:repeat(auto-fill, minmax(200px, 1fr)); gap:14px; }
.pista-break-card { background:var(--lok-card); border:1px solid var(--lok-border); border-radius:12px; overflow:hidden; }
.pista-break-header { display:flex; justify-content:space-between; align-items:center; padding:14px 16px; border-bottom:2px solid var(--lok-border); }
.pista-break-name { font-size:1.1rem; font-weight:900; }
.pista-break-pts { font-size:.72rem; color:var(--lok-muted); }
.pista-break-body { display:flex; justify-content:space-around; padding:16px 12px; }
.pista-break-stat { text-align:center; }
.pista-break-num { font-size:1.2rem; font-weight:800; color:var(--lok-heading); display:block; }
.pista-break-stat span:last-child { font-size:.68rem; color:var(--lok-muted); }
.pista-break-bar { height:4px; background:rgba(255,255,255,.06); margin:0 16px; border-radius:2px; }
.pista-break-fill { height:100%; border-radius:2px; transition:width .6s ease; }
.pista-break-pct { text-align:center; font-size:.72rem; color:var(--lok-muted); padding:8px 0 12px; }

/* ══════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════ */
@media (max-width:1199px) {
  .div-grid { grid-template-columns:repeat(3, 1fr); }
  .liga-div-grid { grid-template-columns:repeat(3, 1fr); }
}
@media (max-width:991px) {
  .lok-nav { display:none; }
  .lok-logo-img { height:46px; }
  .lok-brand-series { font-size:1.45rem; }
  .liga-div-outside { gap:8px; padding:8px; }
  .hero-title { font-size:2.4rem; }
  .section-title { font-size:1.7rem; }
  .features-grid { grid-template-columns:1fr; }
  .ligas-grid { grid-template-columns:1fr 1fr; }
  .div-grid { grid-template-columns:repeat(2, 1fr); }
  .liga-div-grid { grid-template-columns:repeat(2, 1fr); }
  .dash-grid { grid-template-columns:1fr; }
  .pistas-visual { gap:12px; }
  .pista-card { min-width:140px; padding:24px 16px; }
  .pista-value { font-size:2.2rem; }
  .enfrentamiento-reglas { flex-direction:column; align-items:center; }
  .regla-item { max-width:100%; }
  .reto-rules { flex-direction:column; align-items:center; }
  .reto-rule { max-width:100%; }
  .reto-matchup { flex-direction:column; text-align:center; gap:16px; }
  .reto-team { flex-direction:column; }
  .reto-defender { flex-direction:column-reverse; }
  .stats-grid { grid-template-columns:repeat(auto-fill, minmax(120px, 1fr)); }
  .pista-breakdown { grid-template-columns:1fr 1fr; }
  .faq-grid { grid-template-columns:1fr; }
  .clasif-header { flex-direction:column; align-items:flex-start; }
}
@media (max-width:767px) {
  .hero-lok { padding:90px 0 40px; }
  .hero-title { font-size:1.9rem; }
  .section-pad { padding:50px 0; }
  .section-title { font-size:1.5rem; }
  .ligas-grid { grid-template-columns:1fr; }
  .liga-div-outside { grid-template-columns:repeat(5, minmax(0, 1fr)); }
  .liga-div-chip { min-height:40px; font-size:.8rem; }
  .liga-div-title { margin-bottom:-2px; }
  .div-grid { grid-template-columns:1fr; }
  .liga-div-grid { grid-template-columns:1fr 1fr; }
  .podio { flex-direction:column; align-items:center; }
  .podio-1, .podio-2, .podio-3 { order:unset; }
  .podio-item { width:100%; max-width:280px; }
  .pistas-visual { flex-direction:column; align-items:center; }
  .pista-card { max-width:100%; width:100%; }
  .img-secondary { right:-15px; bottom:-15px; }
  .cta-title { font-size:1.6rem; }
  .detail-name { font-size:1.4rem; }
  .pista-breakdown { grid-template-columns:1fr; }
  .reto-matchup-mini { grid-template-columns:1fr; }
}
@media (max-width:575px) {
  .lok-logo-img { height:38px; }
  .lok-brand { gap:8px; }
  .lok-brand-text { gap:6px; }
  .lok-brand-series { font-size:1rem; }
  .hero-title { font-size:1.5rem; }
  .hero-kpis { gap:10px; }
  .kpi-card { min-width:80px; padding:10px 12px; }
  .kpi-value { font-size:1.2rem; }
  .liga-table { font-size:.75rem; }
  .liga-table thead th { padding:10px 8px; font-size:.65rem; }
  .liga-row td { padding:10px 8px; }
  .partido-teams { flex-wrap:wrap; gap:6px; }
  .stats-grid { grid-template-columns:repeat(2, 1fr); }
  .clasif-title { font-size:1.4rem; }
}
