/* ============================================================
   SetLiga — Sistema de diseño para Ventenis
   Origen: Claude Design · handoff del sistema de diseño (Epic 10, rebrand 11.2)
   Tipografías: Archivo (display) + IBM Plex Mono (datos/números)
   ============================================================ */

:root{
  /* --- Tokens FIJOS de Ventenis/SetLiga --- */
  --sl-bg:#EEF1F4;
  --sl-ink:#0C1521;          /* navy casi negro: header, hero, footer */
  --sl-ink-raised:#13202F;
  --sl-text:#14202E;
  --sl-text-2:#5a6b7b;
  --sl-text-3:#8593a0;
  --sl-text-4:#9aa7b4;
  --sl-border:#E4E8ED;
  --sl-border-soft:#EEF1F4;
  --sl-surface:#ffffff;
  --sl-surface-2:#F7F9FB;    /* cabeceras de tabla / inputs */
  --sl-surface-3:#F4F6F8;
  --sl-danger:#C2562F;
  /* sobre fondo oscuro */
  --sl-on-dark:#ffffff;
  --sl-on-dark-2:#9fb0c0;
  --sl-on-dark-3:#7b8a99;
  --sl-on-dark-4:#6f8090;

  /* Tipografía */
  --sl-font:'Archivo',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --sl-mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;

  /* Radios */
  --sl-r-sm:7px; --sl-r-md:9px; --sl-r-lg:12px; --sl-r-xl:14px;

  /* Espaciado: escala base 4px (DESIGN.md) expuesta como tokens (Story 1.8). */
  --sl-s-1:4px; --sl-s-2:8px; --sl-s-3:12px; --sl-s-4:16px; --sl-s-5:24px; --sl-s-6:32px;

  /* --- THEMEABLE por liga (white-label): solo el acento + su tinta --- */
  --sl-accent:#C7F23D;       /* lima SetLiga; cada liga lo reemplaza */
  --sl-accent-ink:#0C1521;   /* texto legible sobre el acento */
  --sl-accent-rgb:199, 242, 61; /* componentes RGB del default (para rgba()) */

  --sl-maxw:1180px;
  --sl-shadow:0 1px 2px rgba(12,21,33,.04);

  /* Derivados del acento (Story 10.5): legibles sobre blanco (deep) y sobre navy
     (soft). deep al 45% de acento garantiza ≥4.5:1 sobre blanco con TODOS los
     presets (72% fallaba con lima/naranja/teal); fallback sin color-mix = navy
     (a11y por delante del tinte). */
  --sl-accent-deep:var(--sl-ink);
  --sl-accent-soft:var(--sl-accent);
}
@supports (color:color-mix(in srgb,red,blue)){
  :root{
    --sl-accent-deep:color-mix(in srgb,var(--sl-accent) 45%,#0C1521);
    --sl-accent-soft:color-mix(in srgb,var(--sl-accent) 70%,#fff);
  }
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sl-font);
  background:var(--sl-bg);
  color:var(--sl-text);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
::selection{background:var(--sl-accent);color:var(--sl-accent-ink)}
input::placeholder{color:#9aa7b4}
@keyframes sl-rise{from{transform:translateY(10px);opacity:.5}to{transform:none;opacity:1}}

/* Scrollbar fina para tablas con scroll horizontal */
.sl-scroll-x{overflow-x:auto}
.sl-scroll-x::-webkit-scrollbar{height:8px}
.sl-scroll-x::-webkit-scrollbar-thumb{background:#cdd5dd;border-radius:99px}

/* ---------- Layout shell ---------- */
.sl-page{min-height:100vh;display:flex;flex-direction:column}
.sl-main{flex:1;animation:sl-rise .35s ease both}
.sl-container{max-width:var(--sl-maxw);margin:0 auto;padding-left:var(--sl-s-5);padding-right:var(--sl-s-5)}
.sl-section{padding-top:26px;padding-bottom:40px}
.sl-mono{font-family:var(--sl-mono)}

/* ---------- Header / nav ---------- */
.sl-header{position:sticky;top:0;z-index:40;background:var(--sl-ink);border-bottom:1px solid rgba(255,255,255,.08)}
.sl-header__inner{max-width:var(--sl-maxw);margin:0 auto;min-height:62px;padding:0 24px;display:flex;align-items:center;gap:24px}
.sl-brand{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none}
.sl-brand__dot{width:13px;height:13px;border-radius:50%;background:var(--sl-accent);box-shadow:0 0 0 3px rgba(var(--sl-accent-rgb),.18)}
.sl-brand__name{font-weight:900;letter-spacing:.06em;font-size:18px;color:#fff}
.sl-brand__name b{color:var(--sl-accent);font-weight:900}
.sl-nav{display:flex;align-items:center;gap:2px;margin-left:6px;flex-wrap:wrap}
.sl-nav__link{position:relative;background:none;border:0;color:var(--sl-on-dark-3);font-family:inherit;font-weight:600;font-size:13.5px;letter-spacing:.02em;padding:10px 14px;cursor:pointer}
.sl-nav__link:hover{color:#cdd6df}
/* Enlace activo: blanco + subrayado de acento (diseño 1a, Story 10.5) */
.sl-nav__link--active{color:#fff;font-weight:700}
.sl-nav__link--active::after{content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;background:var(--sl-accent);border-radius:2px}
.sl-header__right{margin-left:auto;display:flex;align-items:center;gap:14px}
.sl-edition{font-family:var(--sl-mono);font-size:11px;font-weight:600;letter-spacing:.12em;color:var(--sl-on-dark-3);border:1px solid rgba(255,255,255,.14);border-radius:6px;padding:5px 9px}
/* Nav dropdowns + badges de cola (Story 10.1) */
.sl-nav__group{position:relative;display:inline-flex}
.sl-nav__trigger{display:inline-flex;align-items:center;gap:5px}
.sl-nav__caret{font-size:8.5px;opacity:.75;margin-left:1px}
.sl-nav__menu{position:absolute;top:calc(100% + 6px);left:0;z-index:60;display:none;min-width:196px;background:var(--sl-surface);border:1px solid var(--sl-border);border-radius:var(--sl-r-lg);box-shadow:0 14px 34px rgba(9,18,29,.28);padding:6px}
.sl-nav__group:hover>.sl-nav__menu,
.sl-nav__group--open>.sl-nav__menu{display:block}
.sl-nav__item{display:flex;align-items:center;justify-content:space-between;gap:12px;font-weight:600;font-size:13.5px;color:var(--sl-text);padding:9px 11px;border-radius:var(--sl-r-sm);text-decoration:none;white-space:nowrap}
.sl-nav__item:hover,.sl-nav__item:focus-visible{background:var(--sl-surface-3);outline:none}
/* Ítem activo del menú: acento suave + dot (diseño 1a, Story 10.5) */
.sl-nav__item--active{color:var(--sl-accent-deep);background:rgba(var(--sl-accent-rgb),.09);font-weight:700}
.sl-nav__item--active:hover,.sl-nav__item--active:focus-visible{background:rgba(var(--sl-accent-rgb),.14)}
.sl-nav__item-dot{flex:none;width:6px;height:6px;border-radius:50%;background:var(--sl-accent)}
.sl-nav__item-tag{font-family:var(--sl-mono);font-size:9.5px;letter-spacing:.08em;color:var(--sl-text-3);font-weight:600}
/* Badge de cola: píldora translúcida del acento (diseño 1a, Story 10.5) */
.sl-nav__badge{font-family:var(--sl-mono);font-size:10px;font-weight:700;line-height:1.5;background:rgba(var(--sl-accent-rgb),.16);color:var(--sl-accent-soft);border-radius:99px;padding:2px 7px;margin-left:7px}
.sl-user{display:flex;align-items:center;gap:8px}
.sl-user__avatar{width:30px;height:30px;border-radius:50%;background:var(--sl-ink-raised);color:var(--sl-accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}
.sl-user__name{color:#cdd6df;font-size:13px;font-weight:600}
.sl-user__logout{background:none;border:0;color:var(--sl-on-dark-3);font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;padding:4px}
.sl-user__logout:hover{color:#fff}

/* ---------- Footer ---------- */
.sl-footer{background:var(--sl-ink);border-top:1px solid rgba(255,255,255,.07);margin-top:auto}
.sl-footer__inner{max-width:var(--sl-maxw);margin:0 auto;padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.sl-footer__meta{font-family:var(--sl-mono);font-size:11.5px;color:var(--sl-on-dark-4);letter-spacing:.05em}

/* ---------- Hero (oscuro) ---------- */
.sl-hero{position:relative;background:var(--sl-ink);overflow:hidden}
.sl-hero__inner{position:relative;max-width:var(--sl-maxw);margin:0 auto;padding:30px 24px 26px}
.sl-hero--tall .sl-hero__inner{padding:48px 24px 40px}
.sl-eyebrow{font-family:var(--sl-mono);font-size:12px;letter-spacing:.22em;color:var(--sl-accent);font-weight:600;margin-bottom:10px}
.sl-breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:8px;font-family:var(--sl-mono);font-size:11.5px;letter-spacing:.1em;color:var(--sl-on-dark-4);margin-bottom:14px}
.sl-breadcrumb a{color:#8fa0b0}
.sl-breadcrumb a:hover{color:#fff}
.sl-breadcrumb .sl-bc-here{color:var(--sl-accent)}
.sl-h1{margin:0;font-size:46px;font-weight:900;letter-spacing:-.01em;color:#fff;line-height:.96}
.sl-h1--lg{font-size:54px;letter-spacing:-.02em;line-height:.95}
.sl-lead{margin:12px 0 0;color:var(--sl-on-dark-2);font-size:15px;max-width:540px}
.sl-hero__row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}
/* pista de tenis decorativa */
.sl-court{position:absolute;right:-40px;top:14px;bottom:14px;width:360px;opacity:.10;pointer-events:none}
.sl-court::before{content:"";position:absolute;inset:0;border:2px solid var(--sl-accent);border-radius:4px}
.sl-court::after{content:"";position:absolute;left:50%;top:0;bottom:0;width:2px;background:var(--sl-accent);transform:translateX(-50%)}

/* stats en hero */
.sl-stats{display:flex;gap:10px}
.sl-stat{background:var(--sl-ink-raised);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:12px 16px;min-width:84px}
.sl-stat__num{font-family:var(--sl-mono);font-size:24px;font-weight:600;color:#fff}
.sl-stat__label{font-size:11px;letter-spacing:.06em;color:var(--sl-on-dark-3);margin-top:2px}

/* ---------- Botones ---------- */
.sl-btn{display:inline-flex;align-items:center;gap:var(--sl-s-2);font-family:var(--sl-font);font-weight:700;font-size:14px;padding:var(--sl-s-3) 18px;border-radius:var(--sl-r-md);border:0;cursor:pointer;transition:filter .12s,border-color .12s}
.sl-btn--primary{background:var(--sl-accent);color:var(--sl-accent-ink)}
.sl-btn--primary:hover{filter:brightness(1.04)}
.sl-btn--dark{background:var(--sl-ink);color:#fff}
.sl-btn--ghost{background:none;color:var(--sl-text-2);border:1.5px solid var(--sl-border);font-weight:600}
.sl-btn--ghost:hover{border-color:var(--sl-ink);color:var(--sl-text)}
.sl-btn--sm{font-size:12.5px;padding:9px 13px}
.sl-btn--block{width:100%;justify-content:center}

/* ---------- Cards ---------- */
.sl-card{background:var(--sl-surface);border:1px solid var(--sl-border);border-radius:var(--sl-r-lg);box-shadow:var(--sl-shadow)}
.sl-card--pad{padding:22px}
.sl-card--xl{border-radius:var(--sl-r-xl)}
.sl-card--link{cursor:pointer;transition:border-color .12s,transform .12s}
.sl-card--link:hover{border-color:var(--sl-ink)}

.sl-grid{display:grid;gap:var(--sl-s-4)}
.sl-grid-2{grid-template-columns:repeat(2,1fr)}
.sl-grid-3{grid-template-columns:repeat(3,1fr)}
.sl-grid-4{grid-template-columns:repeat(4,1fr)}

/* ---------- Badges / pills ---------- */
.sl-badge{font-family:var(--sl-mono);font-weight:600;font-size:13px;letter-spacing:.1em;color:var(--sl-ink);background:var(--sl-bg);border-radius:var(--sl-r-sm);padding:6px 11px;display:inline-block}
.sl-badge--danger{color:var(--sl-danger);background:#fdf2f0}
.sl-badge--pending{color:#92400e;background:#fffbeb}
.sl-badge--champion{color:#7c3aed;background:#f5f3ff}
.sl-match--champion .sl-bm__win{font-weight:700;color:var(--sl-accent)}
.sl-pill{font-family:var(--sl-mono);font-size:11px;font-weight:600;letter-spacing:.08em;border-radius:99px;padding:5px 11px;display:inline-block}
.sl-pill--live{color:var(--sl-accent-ink);background:var(--sl-accent)}
.sl-pill--done{color:var(--sl-text-3);background:var(--sl-border-soft)}

/* ---------- Avatares ---------- */
.sl-av{flex:none;width:38px;height:38px;border-radius:9px;background:var(--sl-surface-3);color:var(--sl-text-2);display:flex;align-items:center;justify-content:center;font-family:var(--sl-mono);font-weight:600;font-size:12px;letter-spacing:.04em}
.sl-av--round{border-radius:50%;width:34px;height:34px}
.sl-av--top{background:var(--sl-ink);color:var(--sl-accent)}

/* ---------- Tablas ---------- */
.sl-table{width:100%;border-collapse:collapse;background:var(--sl-surface)}
.sl-table thead th{background:var(--sl-surface-2);font-family:var(--sl-mono);font-size:10.5px;letter-spacing:.1em;color:#7a8896;font-weight:600;text-transform:uppercase;text-align:left;padding:13px 20px;border-bottom:1px solid var(--sl-border);white-space:nowrap}
.sl-table tbody td{padding:14px 20px;border-bottom:1px solid var(--sl-border-soft);font-size:14px;vertical-align:middle}
.sl-table tbody tr:last-child td{border-bottom:0}
.sl-th-c,.sl-td-c{text-align:center}
.sl-num{font-family:var(--sl-mono)}
.sl-rank{font-family:var(--sl-mono);font-size:18px;font-weight:600;color:#aab5c0}
.sl-pair{display:flex;align-items:center;gap:13px;min-width:0}
.sl-pair__name{font-weight:700;font-size:14.5px;color:var(--sl-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sl-pair__tag{font-size:11.5px;color:var(--sl-text-3);margin-top:1px}
.sl-cell-pj{text-align:center;font-family:var(--sl-mono);font-size:16px;font-weight:500;color:var(--sl-text-2)}
.sl-cell-pg{text-align:center;font-family:var(--sl-mono);font-size:16px;font-weight:600;color:var(--sl-text)}
.sl-cell-pp{text-align:center;font-family:var(--sl-mono);font-size:16px;font-weight:500;color:var(--sl-text-4)}
/* fila líder */
.sl-row--top{background:rgba(var(--sl-accent-rgb),.06)}
.sl-row--top td:first-child{box-shadow:inset 4px 0 0 var(--sl-accent)}
.sl-row--top .sl-rank{color:var(--sl-ink)}
/* barra de efectividad */
.sl-eff{display:flex;align-items:center;gap:11px;min-width:150px}
.sl-bar{flex:1;height:7px;background:#EAEEF2;border-radius:99px;overflow:hidden}
.sl-bar>i{display:block;height:100%;background:#9fb3c4;border-radius:99px}
.sl-row--top .sl-bar>i{background:var(--sl-accent)}
.sl-eff__pct{font-family:var(--sl-mono);font-size:13px;font-weight:600;color:var(--sl-text);min-width:40px;text-align:right}
.sl-legend{display:flex;align-items:center;gap:16px;margin-top:12px;font-size:12px;color:var(--sl-text-3);flex-wrap:wrap}
.sl-legend .sl-chip{width:10px;height:10px;border-radius:3px;background:var(--sl-accent);display:inline-block;margin-right:6px;vertical-align:-1px}

/* ---------- Tabs de grupo ---------- */
.sl-tabs{display:flex;gap:4px;margin-top:22px;flex-wrap:wrap}
.sl-tab{background:rgba(255,255,255,.04);color:var(--sl-on-dark-2);border:1px solid rgba(255,255,255,.10);border-radius:8px 8px 0 0;font-family:var(--sl-mono);font-weight:600;font-size:12.5px;letter-spacing:.08em;padding:11px 20px;cursor:pointer}
.sl-tab--active{background:#fff;color:var(--sl-ink);border-color:#fff}
.sl-pane{display:none}
.sl-pane--active{display:block}

/* ---------- Partidos ---------- */
.sl-matches{display:flex;flex-direction:column;gap:10px}
.sl-match{background:var(--sl-surface);border:1px solid var(--sl-border);border-radius:11px;padding:14px 18px;font-size:14px;color:var(--sl-text)}
.sl-match .sl-mono{color:var(--sl-text);font-weight:600}
.sl-section-head{display:flex;align-items:baseline;justify-content:space-between;margin:10px 2px 14px}
.sl-section-head h2{margin:0;font-size:15px;font-weight:800;letter-spacing:.02em;color:var(--sl-text)}
.sl-section-head .sl-meta{font-family:var(--sl-mono);font-size:12px;color:var(--sl-text-3)}

/* ---------- Buscador ---------- */
.sl-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.sl-search{position:relative;flex:1;min-width:240px}
.sl-search__icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#9aa7b4;font-size:14px}
.sl-search input{width:100%;font-family:var(--sl-font);font-size:14px;color:var(--sl-text);background:#fff;border:1px solid var(--sl-border);border-radius:var(--sl-r-md);padding:12px 14px 12px 36px;outline:none}
.sl-search input:focus{border-color:var(--sl-ink)}
.sl-count{font-family:var(--sl-mono);font-size:13px;color:var(--sl-text-2);background:#fff;border:1px solid var(--sl-border);border-radius:var(--sl-r-md);padding:11px 14px}
.sl-count b{color:var(--sl-text)}

/* ---------- Formularios ---------- */
/* Anchos del diseño v2 (Story 10.5): jugador 480px (1e), organizador 560px (1d). */
.sl-auth-container{max-width:480px;padding-top:48px;padding-bottom:60px}
.sl-auth-container--wide{max-width:560px}
.sl-auth-eyebrow{color:var(--sl-text-3)}
.sl-auth-title{color:var(--sl-text);font-size:30px;margin:2px 0 18px}
.sl-form .sl-field{display:block;margin-bottom:18px}
.sl-form .sl-label{display:block;font-family:var(--sl-mono);font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--sl-text-2);margin-bottom:7px;text-transform:uppercase}
.sl-form input,.sl-form select,.sl-form textarea{width:100%;font-family:var(--sl-font);font-size:15px;color:var(--sl-text);background:var(--sl-surface-2);border:1.5px solid var(--sl-border);border-radius:var(--sl-r-md);padding:12px 14px;outline:none}
.sl-form .sl-num-input,.sl-form input[type=number],.sl-form input[name=age],.sl-form input[name=phone]{font-family:var(--sl-mono)}
.sl-form input:focus,.sl-form select:focus,.sl-form textarea:focus{border-color:var(--sl-ink);background:#fff}
.sl-form .sl-help{display:block;font-size:12px;color:var(--sl-text-3);margin-top:7px}
.sl-form .sl-error,.sl-form .errorlist{color:var(--sl-danger);font-size:13px;font-weight:600;margin:4px 0 0;padding:0;list-style:none}
.sl-form .sl-error--auth{margin-bottom:14px}
.sl-form-footnote{margin:16px 0 0;font-size:13px;color:var(--sl-text-3)}
.sl-form-link{color:var(--sl-text-2);font-weight:600}
.sl-grid-form{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
.sl-actions{display:flex;align-items:center;gap:12px;margin-top:8px;flex-wrap:wrap}

/* ---------- Estado vacío ---------- */
.sl-empty{padding:40px 20px;text-align:center;color:var(--sl-text-3);font-size:14px}

/* ---------- Mensajes flash (django.contrib.messages, Story 3.1) ---------- */
.sl-flashes-wrap{padding-top:var(--sl-s-5)}
.sl-flashes{margin:0;padding:0;list-style:none;display:grid;gap:var(--sl-s-2)}
.sl-flash{font-size:14px;font-weight:600;border-radius:var(--sl-r-md);padding:12px 16px;border:1.5px solid var(--sl-border);background:var(--sl-surface);color:var(--sl-text)}
.sl-flash--success{border-color:var(--sl-accent)}
.sl-flash--error{border-color:var(--sl-danger);color:var(--sl-danger)}

/* ---------- Piso de accesibilidad: foco visible por teclado (Story 1.8, AC#7) ----------
   Outline ink en superficies claras (contenido); outline acento en el header/hero
   oscuros, donde un outline navy quedaría invisible. */
.sl-btn:focus-visible,
.sl-card--link:focus-visible,
.sl-search input:focus-visible{outline:2px solid var(--sl-ink);outline-offset:2px}
.sl-nav__link:focus-visible,
.sl-brand:focus-visible,
.sl-user__logout:focus-visible,
.sl-tab:focus-visible{outline:2px solid var(--sl-accent);outline-offset:2px}

/* ---------- Utilidades y variantes de pantalla (Story 1.8) ----------
   Reemplazan los style="…" inline movidos desde los templates (AC#2). Reusan
   el patrón sl-* existente; no son un framework de utilidades nuevo. */
.sl-card--clip{overflow:hidden}
.sl-card--tabbed{overflow:hidden;border-radius:0 var(--sl-r-lg) var(--sl-r-lg) var(--sl-r-lg)}
.sl-container--narrow{max-width:680px}
.sl-between{display:flex;align-items:center;justify-content:space-between}
.sl-arrow{color:#c3ccd5;font-size:18px}
.sl-min0{min-width:0}
.sl-strong{color:var(--sl-text)}
/* anchos de columna de tabla */
.sl-w-54{width:54px}.sl-w-64{width:64px}.sl-w-70{width:70px}
.sl-w-170{width:170px}.sl-w-190{width:190px}.sl-w-240{width:240px}
/* base.html */
.sl-brand__name--sm{font-size:14px}
.sl-user__form{margin:0}
/* jugadores_list */
.sl-name{font-weight:600;font-size:14px;color:var(--sl-text)}
.sl-cell-muted{color:var(--sl-text-2)}
.sl-cell-phone{font-size:13px;color:var(--sl-text-2)}
.sl-cell-email{font-size:13px;color:#3a6a8f}
.sl-cell-email--muted{font-size:13px;color:var(--sl-text-4)}
/* category_groups: barra de efectividad en pasos de 10% (sin style inline, AC#8) */
.sl-fill--0{width:0}.sl-fill--1{width:10%}.sl-fill--2{width:20%}.sl-fill--3{width:30%}
.sl-fill--4{width:40%}.sl-fill--5{width:50%}.sl-fill--6{width:60%}.sl-fill--7{width:70%}
.sl-fill--8{width:80%}.sl-fill--9{width:90%}.sl-fill--10{width:100%}
.sl-legend__note{color:#aab5c0}
.sl-section-head--gap{margin-top:26px}
/* list_tournaments */
.sl-card--tournament{padding:var(--sl-s-5);display:block}
.sl-card__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.sl-card__title{margin:0 0 4px;font-size:24px;font-weight:800;color:var(--sl-text)}
.sl-card__desc{margin:0 0 20px;font-size:13.5px;color:var(--sl-text-3)}
.sl-card__foot{display:flex;gap:var(--sl-s-5);border-top:1px solid var(--sl-border-soft);padding-top:var(--sl-s-4)}
.sl-stat-num{font-size:20px;font-weight:600;color:var(--sl-text)}
.sl-stat-cap{font-size:11px;color:var(--sl-text-3);letter-spacing:.04em}
/* Story 2.1: accion de gestion "Editar" por tarjeta, renderizada FUERA del
   <a> de la tarjeta (no se puede anidar <a> en <a>); alineada debajo a la derecha. */
.sl-card-actions{display:flex;justify-content:flex-end;margin-top:var(--sl-s-2)}
/* categorias_torneo */
.sl-card--cat{border-radius:13px;padding:20px;display:flex;flex-direction:column;gap:var(--sl-s-4)}
.sl-cat__title{margin:0;font-size:17px;font-weight:800;color:var(--sl-text)}
.sl-cat__meta{display:flex;gap:14px;margin-top:10px;font-family:var(--sl-mono);font-size:12px;color:var(--sl-text-3)}

/* ---------- Llave de eliminación directa (Story 4.3) ---------- */
.sl-bracket{display:flex;gap:var(--sl-s-5);align-items:flex-start;padding-bottom:var(--sl-s-2)}
.sl-bracket__round{flex:0 0 auto;min-width:240px;display:flex;flex-direction:column}
.sl-bm__slots{margin-top:var(--sl-s-2)}
.sl-bm__slot{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.sl-bm__slot + .sl-bm__slot{margin-top:var(--sl-s-2);padding-top:var(--sl-s-2);border-top:1px solid var(--sl-border-soft)}
.sl-bm__name{font-weight:600;color:var(--sl-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sl-bm__name--tbd{font-weight:500;color:var(--sl-text-3)}
.sl-bm__win{color:var(--sl-accent-ink);background:var(--sl-accent);border-radius:var(--sl-r-sm);padding:0 6px}
.sl-bm__tag{font-family:var(--sl-mono);font-size:11px;letter-spacing:.06em;color:var(--sl-text-3);white-space:nowrap}

/* ---------- Re-sorteo y ajuste manual (Story 4.4) ---------- */
.sl-inline-form{display:inline-flex;align-items:center;gap:var(--sl-s-2);margin:0}
.sl-btn--danger{background:none;color:#b42318;border:1.5px solid #f3b9b2;font-weight:600}
.sl-btn--danger:hover{border-color:#b42318;background:#fdf2f0}
.sl-select{font-family:var(--sl-font);font-size:13px;color:var(--sl-text);background:var(--sl-surface-2);border:1.5px solid var(--sl-border);border-radius:var(--sl-r-md);padding:8px 10px;outline:none}
.sl-select:focus{border-color:var(--sl-ink);background:#fff}
.sl-move-list{margin:0;padding:0;list-style:none;display:grid;gap:var(--sl-s-3)}
.sl-move-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sl-s-3);flex-wrap:wrap}
.sl-move-name{font-weight:600;color:var(--sl-text)}
.sl-move-label{font-family:var(--sl-mono);font-size:12px;color:var(--sl-text-3)}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  .sl-grid-4{grid-template-columns:repeat(2,1fr)}
  .sl-grid-3{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  .sl-h1{font-size:34px}
  .sl-h1--lg{font-size:38px}
  .sl-grid-2,.sl-grid-3,.sl-grid-form{grid-template-columns:1fr}
  .sl-header__inner{flex-wrap:wrap;padding:8px 16px;gap:10px}
  .sl-nav{order:3;width:100%;overflow-x:auto;flex-wrap:nowrap}
  /* Móvil (Story 10.1): aplana los dropdowns en la tira scrollable — la nav móvil
     enriquecida es "siguiente paso" del diseño; aquí solo evitamos que el menú
     absoluto quede recortado por overflow-x. */
  .sl-nav__trigger{display:none}
  .sl-nav__group,
  .sl-nav__menu,
  .sl-nav__group--open>.sl-nav__menu,
  .sl-nav__group:hover>.sl-nav__menu{display:contents}
  .sl-nav__item{color:var(--sl-on-dark-3);font-weight:600;font-size:13.5px;padding:10px 12px;border-radius:0}
  .sl-edition{display:none}
  .sl-container{padding-left:var(--sl-s-4);padding-right:var(--sl-s-4)}
  .sl-hero__inner{padding:24px 16px 22px}
}

/* ---------- Catálogo de planes (Story 7.1) ---------- */
.sl-plan-card{display:flex;flex-direction:column;padding:24px;border-radius:var(--sl-r-xl)}
.sl-plan-card--featured{border-color:var(--sl-accent);box-shadow:0 0 0 2px var(--sl-accent)}
.sl-plan-name{font-size:20px;font-weight:700;color:var(--sl-text);margin:0 0 4px}
.sl-plan-tagline{font-size:13.5px;color:var(--sl-text-2);margin:0 0 20px;min-height:36px}
.sl-plan-price{display:flex;align-items:baseline;gap:6px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--sl-border)}
.sl-plan-price__amount{font-family:var(--sl-mono);font-size:34px;font-weight:700;color:var(--sl-text)}
.sl-plan-price__currency{font-family:var(--sl-mono);font-size:14px;color:var(--sl-text-3)}
.sl-plan-price__period{font-family:var(--sl-mono);font-size:12px;color:var(--sl-text-3)}
.sl-plan-features{list-style:none;padding:0;margin:0;display:grid;gap:10px;flex:1}
.sl-plan-feature{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:var(--sl-text-2)}
.sl-plan-feature__label{flex:1}
.sl-plan-feature__val{font-family:var(--sl-mono);font-size:13px;font-weight:600;color:var(--sl-text);white-space:nowrap}
.sl-plan-check{color:var(--sl-accent-ink);background:var(--sl-accent);border-radius:50%;width:18px;height:18px;flex:none;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;margin-top:1px}
.sl-plan-x{color:var(--sl-text-4);flex:none;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:16px;margin-top:1px}
.sl-plan-eyebrow{font-family:var(--sl-mono);font-size:12px;letter-spacing:.22em;color:var(--sl-text-3);font-weight:600;margin-bottom:10px}
.sl-plan-feature__val--sm{font-family:var(--sl-mono);font-size:11px;font-weight:600;color:var(--sl-text);text-align:right;max-width:120px}
.sl-plan-note{margin-top:24px;font-size:13px;color:var(--sl-text-3)}

/* ---------- Dominio propio: alta en una fila + token con copiar (Story 10.2) ---------- */
.sl-input-row{display:flex;gap:10px;align-items:stretch;flex-wrap:wrap}
.sl-input-row>input{flex:1 1 220px;min-width:0}
.sl-input-row>.sl-btn{flex:none;white-space:nowrap}
.sl-token{display:flex;align-items:center;gap:8px;min-width:0}
.sl-token__value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;color:var(--sl-text-2);background:var(--sl-surface-3);border:1px solid var(--sl-border);border-radius:var(--sl-r-sm);padding:5px 9px}
.sl-copy--done{color:var(--sl-accent-ink);background:var(--sl-accent);border-color:var(--sl-accent)}

/* ---------- Dominio propio: tabla-grid sin desbordes (Story 10.5, diseño 1b) ---------- */
.sl-h2{margin:0 0 14px;font-size:17px;font-weight:800;color:var(--sl-text)}
.sl-stack{display:flex;flex-direction:column;gap:14px}
.sl-stack>.sl-domain-note{margin:0}
.sl-hero__pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--sl-mono);font-size:11px;letter-spacing:.1em;color:var(--sl-on-dark-3);border:1px solid rgba(255,255,255,.14);border-radius:99px;padding:7px 13px;white-space:nowrap}
.sl-dot{flex:none;width:7px;height:7px;border-radius:50%}
.sl-dot--ok{background:#33B564}
.sl-dot--warn{background:#E8A23D}
.sl-domains__head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding:20px 28px 14px}
.sl-domains__head h2{margin:0}
.sl-domains__count{font-family:var(--sl-mono);font-size:12px;color:var(--sl-text-3);white-space:nowrap}
.sl-domain-grid{display:grid;grid-template-columns:minmax(0,1.5fr) 170px minmax(0,1.25fr) 240px;gap:12px;align-items:center;padding:15px 28px;border-bottom:1px solid var(--sl-border-soft)}
.sl-domain-grid:last-child{border-bottom:0}
.sl-domain-grid--head{padding:11px 28px;background:var(--sl-surface-2);border-top:1px solid var(--sl-border);border-bottom:1px solid var(--sl-border);font-family:var(--sl-mono);font-size:11px;letter-spacing:.08em;color:var(--sl-text-3);text-transform:uppercase}
.sl-domain-grid__end{text-align:right}
.sl-domain-name{display:flex;align-items:center;gap:8px;min-width:0}
.sl-domain-name>.sl-mono{font-size:13.5px;color:var(--sl-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sl-badge--primary{flex:none;font-family:var(--sl-mono);font-size:10px;font-weight:600;letter-spacing:.08em;color:var(--sl-accent-deep);background:rgba(var(--sl-accent-rgb),.1);border-radius:99px;padding:3px 8px;text-transform:uppercase}
.sl-state{display:inline-flex;align-items:center;gap:7px;font-family:var(--sl-mono);font-size:12px;color:var(--sl-text);background:var(--sl-surface-3);border:1px solid var(--sl-border);border-radius:99px;padding:4px 11px;white-space:nowrap}
.sl-state--pending{background:#FDF6EA;border-color:#F2E3C4}
.sl-domain-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}
.sl-domain-note{margin:14px 0 0;font-family:var(--sl-mono);font-size:12px;color:var(--sl-text-3);overflow-wrap:anywhere}
.sl-muted-cell{font-family:var(--sl-mono);font-size:12.5px;color:var(--sl-text-4)}
@media (max-width:860px){
  .sl-domain-grid{grid-template-columns:1fr;gap:8px}
  .sl-domain-grid--head{display:none}
  .sl-domain-actions{justify-content:flex-start}
}

/* ---------- Apariencia: swatches de acento + preview reactivo (Story 10.3/10.5) ---------- */
.sl-swatches{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin:2px 0 0}
.sl-swatch{width:34px;height:34px;border-radius:10px;border:0;cursor:pointer;padding:0;box-shadow:inset 0 0 0 1px rgba(12,21,33,.12)}
.sl-swatch:focus-visible,.sl-swatch:focus-within{outline:2px solid var(--sl-ink);outline-offset:2px}
.sl-swatch--active{box-shadow:0 0 0 2px #fff,0 0 0 4px currentColor}
.sl-swatch--blue{background:#2499F5;color:#2499F5}
.sl-swatch--lime{background:#C7F23D;color:#C7F23D}
.sl-swatch--orange{background:#FF8A3D;color:#FF8A3D}
.sl-swatch--purple{background:#8B7BFF;color:#8B7BFF}
.sl-swatch--teal{background:#12B5A0;color:#12B5A0}
/* Selector libre: rueda cónica que hospeda un <input type=color> accesible */
.sl-swatch--custom{position:relative;display:inline-block;background:conic-gradient(#FF5D5D,#FFC53D,#3DDC72,#2499F5,#8B7BFF,#FF5D5D);overflow:hidden}
.sl-swatch--custom input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;margin:0;border:0;padding:0}
.sl-swatch-divider{width:1px;height:26px;background:var(--sl-border);margin:0 4px}
.sl-form .sl-input--hex{width:112px;flex:none;font-family:var(--sl-mono);font-size:13px;padding:9px 12px}

/* Layout 2 columnas: form + panel de preview (Story 10.5, diseño 1c) */
.sl-grid-appearance{display:grid;grid-template-columns:minmax(0,1fr) 384px;gap:16px;align-items:start}
.sl-form-section{border-top:1px solid var(--sl-border-soft);padding-top:22px;margin-top:22px}
/* fieldset semántico sin el chrome nativo (a11y: conserva legend para el grupo).
   Sin borde en el fieldset (evita el quirk del legend-en-el-borde y el solape de
   floats); la línea divisoria va en el propio legend. */
.sl-form .sl-fieldset{border:0;margin-inline:0;padding:0;min-width:0;margin-top:22px}
.sl-fieldset>legend{display:block;width:100%;border-top:1px solid var(--sl-border-soft);padding:22px 0 0;margin-bottom:11px}
.sl-switch-row{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}
.sl-switch-row__text{min-width:0}
.sl-switch-title{display:flex;align-items:center;gap:9px;font-weight:700;font-size:14.5px;color:var(--sl-text);margin-bottom:5px}
.sl-switch-desc{margin:0;font-size:12.5px;color:var(--sl-text-3);max-width:460px}
.sl-tag{font-family:var(--sl-mono);font-size:9.5px;font-weight:600;letter-spacing:.1em;color:var(--sl-text-3);border:1px solid var(--sl-border);border-radius:99px;padding:3px 8px;white-space:nowrap;text-transform:uppercase}
/* Switch accesible sobre el checkbox nativo */
.sl-switch{position:relative;display:inline-block;flex:none;width:42px;height:24px}
.sl-form .sl-switch input[type=checkbox]{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:pointer}
.sl-switch__track{position:absolute;inset:0;border-radius:99px;background:#CDD5DD;transition:background .12s;pointer-events:none}
.sl-switch__track::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(12,21,33,.25);transition:transform .12s}
.sl-switch input:checked+.sl-switch__track{background:var(--sl-accent)}
.sl-switch input:checked+.sl-switch__track::after{transform:translateX(18px)}
.sl-switch input:focus-visible+.sl-switch__track{outline:2px solid var(--sl-ink);outline-offset:2px}
.sl-switch input:disabled{cursor:not-allowed}
.sl-switch input:disabled+.sl-switch__track{opacity:.45}
/* File-card (archivo actual) y dropzone (vacío); el input file nativo cubre el
   área (opacity 0) → clic y drag&drop nativos, sin JS de upload (CSP-safe). */
.sl-file-card{display:flex;align-items:center;gap:14px;background:var(--sl-surface-2);border:1.5px solid var(--sl-border);border-radius:11px;padding:12px 14px}
.sl-file-card__thumb{flex:none;width:50px;height:50px;border-radius:10px;background:var(--sl-ink);display:flex;align-items:center;justify-content:center;overflow:hidden}
.sl-file-card__thumb img{width:100%;height:100%;object-fit:cover}
.sl-file-card__meta{min-width:0;flex:1}
.sl-file-card__name{font-family:var(--sl-mono);font-size:13px;color:var(--sl-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sl-file-card__sub{font-size:11.5px;color:var(--sl-text-3);margin-top:3px}
.sl-file-btn{position:relative;overflow:hidden}
.sl-form .sl-file-btn input[type=file]{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}
.sl-file-btn:focus-within{outline:2px solid var(--sl-ink);outline-offset:2px}
.sl-file-clear{display:inline-flex;align-items:center;gap:6px;color:var(--sl-danger);font-weight:700;font-size:12.5px;white-space:nowrap;cursor:pointer}
.sl-form .sl-file-clear input[type=checkbox]{width:14px;height:14px;margin:0;padding:0;accent-color:var(--sl-danger)}
.sl-dropzone{position:relative;display:block;border:1.5px dashed #C9D2DB;border-radius:11px;padding:26px 20px;text-align:center;background:#FBFCFD;cursor:pointer}
.sl-form .sl-dropzone input[type=file]{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}
.sl-dropzone:focus-within{outline:2px solid var(--sl-ink);outline-offset:2px}
.sl-dropzone__hint{display:block;font-size:13.5px;color:var(--sl-text-2)}
.sl-dropzone__hint b{color:var(--sl-accent-deep);font-weight:700}
.sl-dropzone__meta{display:block;font-family:var(--sl-mono);font-size:11px;color:var(--sl-text-4);margin-top:6px}
/* Panel de vista previa con mock (Story 10.5, diseño 1c) */
.sl-preview__head{padding:16px 20px;border-bottom:1px solid var(--sl-border-soft);display:flex;align-items:center;justify-content:space-between}
.sl-preview__label{font-family:var(--sl-mono);font-size:11.5px;letter-spacing:.14em;color:var(--sl-accent-deep);font-weight:600}
.sl-preview__live{font-family:var(--sl-mono);font-size:10.5px;color:var(--sl-text-3);letter-spacing:.08em}
.sl-preview__bar{background:var(--sl-ink);padding:13px 18px;display:flex;align-items:center;gap:8px}
.sl-preview__dot{flex:none;width:9px;height:9px;border-radius:50%;background:var(--sl-accent)}
.sl-preview__brand{font-weight:900;font-size:13px;letter-spacing:.05em;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sl-preview__brand b{color:var(--sl-accent)}
.sl-preview__mark{margin-left:auto;font-family:var(--sl-mono);font-size:9.5px;color:var(--sl-on-dark-3);white-space:nowrap}
.sl-preview__body{padding:18px 20px 20px}
.sl-preview__title{font-weight:800;font-size:17px;color:var(--sl-text);margin:0 0 12px}
.sl-preview__row{display:flex;align-items:center;gap:9px;margin-bottom:16px}
.sl-pill--soft{color:var(--sl-accent-deep);background:rgba(var(--sl-accent-rgb),.1)}
.sl-preview__list{border:1px solid var(--sl-border-soft);border-radius:10px;overflow:hidden}
.sl-preview__item{position:relative;display:flex;align-items:center;gap:10px;padding:10px 14px}
.sl-preview__item+.sl-preview__item{border-top:1px solid var(--sl-border-soft)}
.sl-preview__item--lead::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--sl-accent)}
.sl-preview__pos{font-family:var(--sl-mono);font-size:12px;color:var(--sl-text-3)}
.sl-preview__name{font-weight:700;font-size:12.5px;color:var(--sl-text)}
.sl-preview__meter{margin-left:auto;flex:none;width:64px;height:5px;border-radius:99px;background:#EAEEF2;overflow:hidden}
.sl-preview__meter i{display:block;height:100%;background:var(--sl-accent)}
.sl-preview__meter--70 i{width:70%}
.sl-preview__meter--52 i{width:52%}
.sl-preview__note{margin:14px 0 0;font-size:11.5px;color:var(--sl-text-3)}
@media (max-width:980px){
  .sl-grid-appearance{grid-template-columns:1fr}
}

/* ---------- Registros: sufijo de subdominio integrado (Story 10.4) ---------- */
.sl-input-affix{display:flex;align-items:stretch}
.sl-input-affix>input{flex:1;min-width:0;border-top-right-radius:0;border-bottom-right-radius:0;border-right:0}
.sl-affix{display:flex;align-items:center;padding:0 13px;font-family:var(--sl-mono);font-size:13px;color:var(--sl-text-2);background:var(--sl-surface-3);border:1.5px solid var(--sl-border);border-left:0;border-top-right-radius:var(--sl-r-md);border-bottom-right-radius:var(--sl-r-md);white-space:nowrap}
.sl-input-affix:focus-within .sl-affix{border-color:var(--sl-ink)}

/* ---------- Registros: divisor «O» + acciones alternativas (Story 10.5, 1d/1e) ---------- */
.sl-divider{display:flex;align-items:center;gap:12px;margin:20px 0 14px}
.sl-divider::before,.sl-divider::after{content:"";flex:1;height:1px;background:var(--sl-border-soft)}
.sl-divider span{font-family:var(--sl-mono);font-size:10px;letter-spacing:.16em;color:var(--sl-text-4)}
.sl-alt-actions{display:flex;flex-direction:column;gap:10px}
.sl-btn--alt{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;background:var(--sl-surface);border:1px solid #D9DFE5;border-radius:var(--sl-r-md);font-size:13.5px;font-weight:500;color:var(--sl-text-3);padding:12px 0;white-space:nowrap;cursor:pointer}
.sl-btn--alt b{color:var(--sl-text);font-weight:700}
.sl-btn--alt:hover{border-color:var(--sl-ink);color:var(--sl-text-2)}
.sl-btn--alt:focus-visible{outline:2px solid var(--sl-ink);outline-offset:2px}

/* ---------- Utilidad accesible: label solo para lectores de pantalla ---------- */
.sl-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
