/* =========================================================
   Campeonato de Tenis (live) — estilos · mobile-first
   Paleta: tierra batida + crema + verde tinta + lima pelota
   ========================================================= */
:root{
  --clay:#c75b39; --clay-dk:#a8472b;
  --cream:#f5efe2; --cream-2:#ece3d0;
  --ink:#1d3a2e;  --ink-2:#28503f;
  --ball:#d6e64a;
  --line:rgba(29,58,46,.14);
  --shadow:0 18px 40px -18px rgba(29,58,46,.4);
  --r:18px;
  --sans:"Hanken Grotesk",system-ui,sans-serif;
  --serif:"Fraunces",Georgia,serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);line-height:1.55;overflow-x:hidden;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}

.grain{position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ---------- CABECERA FIJA (categorías) ---------- */
.topbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:.7rem;
  padding:.55rem .9rem;background:rgba(245,239,226,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);}
.topbar__brand{font-family:var(--serif);font-weight:700;font-size:1.05rem;display:flex;align-items:center;gap:.45rem;letter-spacing:-.02em;color:var(--ink);flex:0 0 auto;}
.nav__ball{width:15px;height:15px;border-radius:50%;background:var(--ball);box-shadow:inset -3px -3px 0 rgba(29,58,46,.12);position:relative;flex:0 0 auto;}
.nav__ball::before{content:"";position:absolute;inset:0;border-radius:50%;border:1.5px solid var(--ink);clip-path:inset(0 50% 0 0 round 50%);transform:scaleX(.55);}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden;padding:1.6rem 1.1rem 1.5rem;
  background:radial-gradient(120% 80% at 80% -10%,rgba(214,230,74,.25),transparent 60%),linear-gradient(180deg,var(--cream),var(--cream-2));}
.hero__court{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;opacity:.7;
  -webkit-mask:radial-gradient(135% 100% at 50% 42%,#000 30%,transparent 82%);
          mask:radial-gradient(135% 100% at 50% 42%,#000 30%,transparent 82%);}
.hero__court .court-line{fill:none;stroke:var(--clay);stroke-width:1.1;stroke-opacity:.5;vector-effect:non-scaling-stroke;stroke-linejoin:round;}
.hero__court .court-net{stroke:var(--ink);stroke-width:1.3;stroke-opacity:.4;stroke-dasharray:1 5;stroke-linecap:round;vector-effect:non-scaling-stroke;}
.hero__inner{position:relative;z-index:2;max-width:880px;margin:0 auto;text-align:center;}
.hero__title{font-family:var(--serif);font-weight:600;font-size:clamp(2.4rem,11vw,5rem);line-height:.95;letter-spacing:-.03em;}
.hero__sub{margin-top:.6rem;font-weight:600;color:var(--ink-2);font-size:clamp(.95rem,3.6vw,1.2rem);}

.actualizado{display:inline-block;margin-top:1rem;font-size:.78rem;color:var(--ink-2);font-weight:600;letter-spacing:.01em;}

/* ---------- AVISO ---------- */
.aviso{max-width:760px;margin:1.4rem auto 0;padding:1rem 1.2rem;border-radius:14px;font-weight:600;line-height:1.5;}
.aviso--config{background:#fff6d6;border:1px solid #e7cf6a;color:#6b5300;}
.aviso--error{background:#fde3dd;border:1px solid #e09a86;color:#8a2c14;}
.aviso--info{background:var(--cream-2);border:1px solid var(--line);}

/* ---------- PESTAÑAS CATEGORÍA (en la cabecera) ---------- */
.cat-tabs{display:flex;gap:.4rem;flex:1;justify-content:flex-end;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:.15rem 0;}
.cat-tabs::-webkit-scrollbar{display:none;}
.tab{font-family:var(--sans);font-weight:700;font-size:.82rem;background:var(--cream);border:1.5px solid var(--line);color:var(--ink);
  border-radius:100px;padding:.42rem .9rem;min-height:38px;white-space:nowrap;cursor:pointer;transition:.2s;flex:0 0 auto;}
.tab:hover{border-color:var(--clay);}
.tab--on{background:var(--ink);color:var(--cream);border-color:var(--ink);}

/* ---------- SECTION ---------- */
.section{padding:2.4rem 1.1rem;max-width:1080px;margin:0 auto;}
.section--alt{background:var(--ink);color:var(--cream);max-width:none;}
.section--alt .section__title{color:var(--cream);}
.section--alt .section__kicker{color:var(--ball);}
.section__head{margin-bottom:1.4rem;}
.section__kicker{font-weight:800;text-transform:uppercase;letter-spacing:.18em;font-size:.7rem;color:var(--clay);}
.section__title{font-family:var(--serif);font-weight:600;letter-spacing:-.02em;font-size:clamp(1.9rem,8vw,3rem);line-height:1;margin-top:.3rem;}

/* ---------- TABLA CLASIFICACIÓN ---------- */
.tabla-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r);border:1px solid var(--line);box-shadow:0 10px 26px -20px rgba(29,58,46,.5);background:var(--cream);}
.tabla{width:100%;border-collapse:collapse;min-width:340px;}
.tabla th,.tabla td{padding:.7rem .5rem;text-align:center;font-size:.92rem;white-space:nowrap;}
.tabla th{font-size:.66rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-2);font-weight:800;border-bottom:2px solid var(--line);background:var(--cream-2);}
.tabla td{border-bottom:1px solid var(--line);font-weight:600;}
.tabla tr:last-child td{border-bottom:none;}
.tabla .pos{font-family:var(--serif);font-weight:700;color:var(--clay);width:2.2rem;}
.tabla .name{text-align:left;font-family:var(--serif);font-weight:600;font-size:1.02rem;width:99%;padding-left:.8rem;}
.tabla th.name{text-align:left;padding-left:.8rem;}
.tabla .pts{font-family:var(--serif);font-weight:800;font-size:1.05rem;background:rgba(214,230,74,.25);}
.tabla th.pts{background:var(--ball);color:var(--ink);}
.tabla .fila-top td{background:rgba(214,230,74,.12);}
.tabla .fila-top .pos{color:var(--ink);background:var(--ball);border-radius:8px;}

/* ---------- CRUCES ---------- */
.cruces{display:grid;grid-template-columns:1fr;gap:.7rem;}
.cruce{background:rgba(245,239,226,.07);border:1px solid rgba(245,239,226,.2);border-radius:14px;padding:.7rem .9rem;position:relative;}
.cruce--jugado{background:rgba(245,239,226,.12);}
.cruce__lado{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.3rem 0;font-weight:600;font-size:.98rem;}
.cruce__lado+.cruce__lado{border-top:1px solid rgba(245,239,226,.18);}
.cruce__nombre{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cruce__marca{font-family:var(--serif);font-weight:700;background:rgba(245,239,226,.14);border-radius:6px;padding:.05rem .55rem;min-width:1.7em;text-align:center;}
.cruce__pend{opacity:.4;}
.cruce__lado.gana{color:var(--ball);font-weight:800;}
.cruce__lado.gana .cruce__marca{background:var(--ball);color:var(--ink);}
.cruce__estado{position:absolute;top:.6rem;right:.9rem;font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;font-weight:800;color:rgba(245,239,226,.55);}
.vacio{opacity:.7;font-weight:600;}

/* ---------- FOOTER ---------- */
.footer{background:var(--ink);color:var(--cream);text-align:center;padding:2.4rem 1.1rem;display:grid;gap:.5rem;}
.footer__brand{font-family:var(--serif);font-weight:700;font-size:1.4rem;}
.footer__brand em{color:var(--clay);font-style:italic;}
.footer p{font-size:.82rem;opacity:.8;}
.footer__top{font-weight:700;color:var(--ball);justify-self:center;margin-top:.3rem;}

@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;}}

/* ---------- RESPONSIVE ---------- */
@media (min-width:680px){
  .cruces{grid-template-columns:1fr 1fr;}
}
@media (min-width:860px){
  .topbar{padding:.7rem 2rem;}
  .hero{padding:2.4rem 2rem 2.4rem;}
  .section{padding:3.6rem 2rem;}
  .section--alt{padding-inline:2rem;}
  .cruces{grid-template-columns:repeat(3,1fr);max-width:1080px;margin-inline:auto;}
  .tabla th,.tabla td{padding:.85rem .7rem;}
}
@media (max-width:460px){
  .tabla .hide-s{display:none;}
}
