  .skip-link {
    position: absolute;
    top: -100%;
    left: 16px;
    z-index: 9999;
    background: var(--accent, #2d7a3a);
    color: #fff;
    padding: 8px 16px;
    border-radius: 0 0 6px 6px;
    font-family: 'Inter', sans-serif;
    font-size: 12px;
    text-decoration: none;
    transition: top 0.15s;
  }
  .skip-link:focus { top: 0; }

  :root {
    /* Colores base — modo claro */
    --bg:             #f4f4ef;
    --surface:        #ffffff;
    --surface-2:      #ebebe6;
    --border:         #ddddd8;
    --text:           #111111;
    --text-muted:     #666660;
    --text-dim:       #999994;

    /* Acento — verde (contratos, mercado) */
    --accent:         #15803d;
    --accent-rgb:     21, 128, 61;
    --accent-light:   #dcfce7;
    --accent-contrast:#ffffff;
    --accent-hover:   #166534;
    --accent2:        #c84b00;

    /* Semánticos */
    --success:        #16a34a;
    --success-light:  #dcfce7;
    --danger:         #dc2626;
    --danger-light:   #fee2e2;
    --warning:        #d97706;
    --warning-light:  #fef3c7;

    /* Estado NBA */
    --signed:  #15803d;
    --pending: #8a4e00;
    --gone:    #dc2626;
    --resign:  #1d4ed8;

    /* Espaciado */
    --space-1:   4px;
    --space-2:   8px;
    --space-3:  12px;
    --space-4:  16px;
    --space-5:  20px;
    --space-6:  24px;
    --space-8:  32px;
    --space-10: 40px;
    --space-12: 48px;
    --space-16: 64px;

    /* Tipografía */
    --font-xs:   0.75rem;
    --font-sm:   0.875rem;
    --font-base: 1rem;
    --font-md:   1.125rem;
    --font-lg:   1.5rem;
    --font-xl:   2rem;
    --font-2xl:  3rem;
    --font-3xl:  4.5rem;

    /* Forma */
    --radius-sm:   4px;
    --radius-md:   8px;
    --radius-lg:   12px;
    --radius-xl:   16px;
    --radius-full: 9999px;

    /* Sombras */
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.07);
    --shadow-md: 0 4px 12px rgba(0,0,0,0.10);
    --shadow-lg: 0 8px 24px rgba(0,0,0,0.14);

    /* Transición */
    --transition: 150ms ease;
  }

  [data-theme="dark"] {
    --bg:             #0f1117;
    --surface:        #1a1f2e;
    --surface-2:      #242938;
    --border:         #2d3348;
    --text:           #e8eaf0;
    --text-muted:     #8892a4;
    --text-dim:       #4a5268;

    --accent:         #4ade80;
    --accent-rgb:     74, 222, 128;
    --accent-light:   #14532d;
    --accent-contrast:#111111;
    --accent-hover:   #86efac;
    --accent2:        #ff6b35;

    --success:        #22c55e;
    --success-light:  #14532d;
    --danger:         #f87171;
    --danger-light:   #7f1d1d;
    --warning:        #fbbf24;
    --warning-light:  #78350f;

    --signed:  #4ade80;
    --pending: #fbbf24;
    --gone:    #f87171;
    --resign:  #60a5fa;

    --shadow-sm: 0 1px 3px rgba(0,0,0,0.30);
    --shadow-md: 0 4px 12px rgba(0,0,0,0.40);
    --shadow-lg: 0 8px 24px rgba(0,0,0,0.50);
  }

  * { margin: 0; padding: 0; box-sizing: border-box; }

  body, body * {
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, fill 0.2s ease;
  }

  .update-dot, .state-loading::before,
  .section, .home-card::after { transition: none !important; }

  body {
    background: var(--bg);
    color: var(--text);
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    font-size: 16px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    min-height: 100vh;
  }

  /* HEADER */
  header {
    background: var(--surface);
    padding: 0 32px;
    position: sticky;
    top: 0;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 56px;
  }

  .logo { display: flex; align-items: baseline; gap: 10px; }

  .logo-title {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 28px;
    letter-spacing: 2px;
    color: var(--text);
    line-height: 1;
  }

  .logo-year {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 22px;
    color: var(--accent);
    letter-spacing: 1px;
  }

  .header-right {
    display: flex;
    align-items: center;
    gap: 20px;
  }

  /* LANGUAGE TOGGLE */
  .lang-toggle {
    display: flex;
    align-items: center;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 4px;
    overflow: hidden;
    height: 32px;
  }

  .lang-btn {
    background: none;
    border: none;
    color: var(--text-muted);
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    padding: 0 12px;
    height: 100%;
    cursor: pointer;
    transition: all 0.2s;
  }

  .lang-btn.active {
    background: var(--accent);
    color: var(--accent-contrast);
  }

  .lang-divider {
    width: 1px;
    height: 100%;
    background: var(--border);
  }

  .header-meta { display: flex; align-items: center; gap: 10px; }

  .last-update {
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
  }

  .update-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--accent);
    animation: pulse 2s infinite;
    flex-shrink: 0;
  }

  @keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.3; }
  }

  /* TABS */
  nav:not(.ag-footer-projects):not(.ag-footer-pubs):not(.mobile-nav) {
    background: var(--bg);
    padding: 0 32px;
    display: flex;
    gap: 0;
    overflow-x: auto;
    scrollbar-width: none;
    position: sticky;
    top: 56px;
    z-index: 99;
  }

  nav:not(.ag-footer-projects):not(.ag-footer-pubs):not(.mobile-nav)::-webkit-scrollbar { display: none; }

  .tab {
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--text-muted);
    padding: 16px 24px;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    transition: all 0.2s;
    white-space: nowrap;
    background: none;
    border-left: none; border-right: none; border-top: none;
    display: flex; align-items: center; gap: 8px;
  }

  .tab:hover { color: var(--text); }
  .tab.active { color: var(--accent); border-bottom-color: var(--accent); }

  .tab-count {
    background: var(--surface-2);
    color: var(--text-muted);
    font-size: 10px;
    padding: 2px 6px;
    border-radius: 10px;
  }

  .tab.active .tab-count {
    background: rgba(var(--accent-rgb),0.15);
    color: var(--accent);
  }

  /* MAIN */
  main { padding: 32px; max-width: 1400px; margin: 0 auto; }

  .section { display: none; animation: fadeIn 0.3s ease; }
  .section.active { display: block; }

  @keyframes fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
  }

  /* SECTION HEADER */
  .section-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 28px;
  }

  .section-header-text { flex: 1; min-width: 0; }

  .share-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
    background: none;
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text-muted);
    cursor: pointer;
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 6px 10px;
    transition: border-color var(--transition), color var(--transition);
  }

  .share-btn:hover { border-color: var(--accent); color: var(--accent); }
  .share-btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

  .team-view-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 24px;
  }

  .team-view-top .team-view-back { margin-bottom: 0; }

  .section-title {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 36px;
    letter-spacing: 2px;
    line-height: 1;
    margin-bottom: 6px;
  }

  .section-subtitle {
    font-family: 'DM Mono', monospace;
    font-size: 11px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1.5px;
  }

  /* FILTERS */
  .filters {
    display: flex;
    gap: 12px;
    margin-bottom: 24px;
    flex-wrap: wrap;
    align-items: flex-end;
  }

  .filter-group { display: flex; flex-direction: column; gap: 4px; }
  .filter-group--btns { flex-direction: row; align-items: center; gap: 8px; padding-top: 14px; }
  .filter-role-btn {
    cursor: pointer;
    padding: var(--space-2) 16px;
    min-height: 44px;
    border-radius: var(--radius-md);
    font-size: var(--font-sm); font-weight: 600;
    transition: background var(--transition), color var(--transition), border-color var(--transition);
  }
  /* inactivo: solo borde y texto, fondo transparente */
  .filter-role-btn.badge-role-hc { background: transparent; }
  .filter-role-btn.badge-role-gm { background: transparent; }
  /* activo: relleno sólido */
  .filter-role-btn.badge-role-hc[aria-pressed="true"] { background: rgba(var(--accent-rgb), 0.25); border-color: rgba(var(--accent-rgb), 0.6); }
  .filter-role-btn.badge-role-gm[aria-pressed="true"] { background: rgba(255,107,53,0.25); border-color: rgba(255,107,53,0.6); }

  .filter-label {
    font-family: 'Inter', sans-serif;
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--text-muted);
  }

  .filter-input, .filter-select {
    background: var(--surface);
    border: 1px solid var(--border);
    color: var(--text);
    padding: var(--space-2) 14px;
    border-radius: var(--radius-md);
    font-family: inherit;
    font-size: var(--font-sm);
    outline: none;
    transition: border-color var(--transition);
    min-height: 44px;
  }

  /* Foco visible para navegación por teclado */
  .filter-input:focus-visible, .filter-select:focus-visible,
  .btn-reset:focus-visible, .tab:focus-visible, .mobile-tab:focus-visible,
  .lang-btn:focus-visible, .theme-toggle:focus-visible,
  button:focus-visible, [role="button"]:focus-visible,
  a:focus-visible,
  .clickable-player:focus-visible, .clickable-team:focus-visible,
  .teams-grid-card:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
  }

  .filter-input { min-width: 220px; }
  .filter-select { min-width: 140px; cursor: pointer; }
  .filter-input:focus, .filter-select:focus { border-color: var(--accent); }
  .filter-input::placeholder { color: var(--text-dim); }

  .btn-reset {
    background: none;
    border: 1px solid var(--border);
    color: var(--text-muted);
    padding: 8px 14px;
    border-radius: 4px;
    cursor: pointer;
    font-family: 'Inter', sans-serif;
    font-size: 10px;
    letter-spacing: 1px;
    text-transform: uppercase;
    height: 36px;
    transition: all 0.2s;
  }

  .btn-reset:hover { border-color: var(--accent); color: var(--accent); }

  .filter-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--accent);
    color: var(--accent-contrast, #fff);
    font-size: 9px;
    font-weight: 700;
    border-radius: 999px;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    margin-left: 4px;
    vertical-align: middle;
  }

  .results-count {
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    color: var(--text-muted);
    height: 36px;
    display: flex;
    align-items: center;
    margin-left: auto;
  }

  .results-count span { color: var(--accent); font-weight: 500; }

  /* TABLE */
  .table-wrap {
    overflow-x: auto;
    overflow-y: auto;
    max-height: calc(100vh - 110px);
    border: 1px solid var(--border);
    border-radius: 8px;
  }

  .table-wrap--pending { max-height: 420px; }

  table { width: 100%; border-collapse: collapse; }

  thead th {
    background: var(--surface-2);
    font-family: 'DM Mono', monospace;
    font-size: var(--font-xs);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text);
    font-weight: 600;
    padding: var(--space-2) var(--space-4);
    text-align: left;
    border-bottom: 2px solid var(--border);
    white-space: nowrap;
    cursor: pointer;
    user-select: none;
    position: sticky;
    top: 0;
    transition: color var(--transition);
  }

  thead th:hover { color: var(--text); }
  thead th.sorted { color: var(--accent); }
  thead th .sort-icon { margin-left: 4px; opacity: 0.4; font-size: 9px; }
  thead th.sorted .sort-icon { opacity: 1; }

  tbody tr {
    border-bottom: 1px solid var(--border);
    transition: background 0.15s;
  }

  tbody tr:last-child { border-bottom: none; }
  tbody tr:hover { background: var(--surface-2); }

  tbody td {
    padding: var(--space-3) var(--space-4);
    color: var(--text);
    font-size: var(--font-sm);
    white-space: nowrap;
  }

  .td-player { font-weight: 600; font-size: 14px; }
  .fa-subsection-title {
    font-family: 'DM Mono', monospace; font-size: 13px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 2px;
    color: var(--text-muted); margin-bottom: 14px;
    display: flex; align-items: center; gap: 10px;
  }
  .fa-subsection-title::after { content: ''; flex: 1; height: 1px; background: var(--border); }

  .td-money { font-family: 'Inter', sans-serif; color: var(--accent); font-size: 11px; text-align: center; width: 70px; white-space: nowrap; }
  .td-num   { text-align: center; font-size: 11px; color: var(--text-muted); font-family: 'Inter', sans-serif; width: 50px; white-space: nowrap; }
  .td-muted { color: var(--text-muted); font-size: 12px; }
  .td-notes { white-space: normal; font-size: 12px; color: var(--text-muted); line-height: 1.5; max-width: 360px; word-break: break-word; }

  /* TOAST */
  .toast {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translate(-50%, 20px);
    background: var(--surface-2);
    border: 1px solid var(--border);
    color: var(--text);
    padding: 10px 18px;
    border-radius: 6px;
    font-family: 'DM Mono', monospace;
    font-size: 12px;
    letter-spacing: 1px;
    text-transform: uppercase;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.18s, transform 0.18s;
    z-index: 1000;
    box-shadow: 0 6px 24px rgba(0,0,0,0.25);
  }
  .toast.show { opacity: 1; transform: translate(-50%, 0); }
  .toast[data-kind="ok"]  { border-color: var(--accent);  color: var(--accent); }
  .toast[data-kind="err"] { border-color: var(--gone);    color: var(--gone); }

  /* BADGES */
  .badge {
    display: inline-flex;
    align-items: center;
    padding: 2px var(--space-2);
    border-radius: var(--radius-full);
    font-family: 'DM Mono', monospace;
    font-size: var(--font-xs);
    font-weight: 500;
    letter-spacing: 0.5px;
    text-transform: uppercase;
  }

  /* Badge variantes del sistema */
  .badge-accent  { background: var(--accent-light);   color: var(--accent); }
  .badge-success { background: var(--success-light);  color: var(--success); }
  .badge-danger  { background: var(--danger-light);   color: var(--danger); }
  .badge-warning { background: var(--warning-light);  color: var(--warning); }
  .badge-neutral { background: var(--surface-2);      color: var(--text-muted); }

  .pos-text { font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 700; color: var(--text); letter-spacing: 0.5px; }
  .badge-check { background: rgba(var(--accent-rgb),0.12); color: var(--accent); border: 1px solid rgba(var(--accent-rgb),0.25); }
  .badge-pending-c { background: rgba(255,159,0,0.12); color: var(--pending); border: 1px solid rgba(255,159,0,0.25); }
  .badge-role-hc { background: rgba(var(--accent-rgb),0.08); color: var(--accent); border: 1px solid rgba(var(--accent-rgb),0.2); }
  .badge-role-gm { background: rgba(255,107,53,0.08); color: var(--accent2); border: 1px solid rgba(255,107,53,0.2); }
  .badge-team { background: var(--surface-2); color: var(--text); border: 1px solid var(--border); gap: 4px; }
  .team-inline {
    display: inline-flex; align-items: center; gap: 5px;
    color: var(--text); font-size: inherit;
    white-space: nowrap;
  }
  .team-inline.clickable-team { cursor: pointer; }
  .team-inline.clickable-team:hover { opacity: 0.75; }
  .badge-rfa  { background: rgba(255,165,0,0.12); color: #ffaa33; border: 1px solid rgba(255,165,0,0.3); }
  .badge-to   { background: rgba(29,66,138,0.2); color: #7aadff; border: 1px solid rgba(29,66,138,0.4); }
  .badge-po   { background: rgba(160,100,255,0.12); color: #b580ff; border: 1px solid rgba(160,100,255,0.3); }

  /* PICK NUMBER */
  .pick-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px; height: 34px;
    border-radius: 4px;
    font-family: 'Bebas Neue', sans-serif;
    font-size: 18px;
    background: var(--surface-2);
    border: 1px solid var(--border);
    color: var(--text-muted);
  }

  .pick-num.r1 { background: rgba(var(--accent-rgb),0.1); border-color: rgba(var(--accent-rgb),0.3); color: var(--accent); }
  .pick-num.top5 { background: rgba(var(--accent-rgb),0.2); border-color: var(--accent); color: var(--accent); }

  /* TRADES */
  .trade-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 8px;
    margin-bottom: 10px;
    overflow: hidden;
    transition: border-color 0.2s;
  }

  .trade-card:hover { border-color: rgba(var(--accent-rgb),0.3); }

  .trade-header {
    background: var(--surface-2);
    padding: 10px 18px;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .trade-header-meta {
    font-size: 12px;
    color: var(--text-muted);
  }

  .trade-idx {
    font-family: 'Inter', sans-serif;
    font-size: 10px;
    color: var(--text-muted);
    letter-spacing: 1px;
  }

  .trade-body {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .trade-side {
    padding: 16px 20px;
    border-right: 1px solid var(--border);
  }

  .trade-side:last-child { border-right: none; }

  .trade-team-label {
    display: flex; align-items: center; gap: 8px;
    font-size: 14px; font-weight: 600;
    color: var(--text);
    margin-bottom: 10px;
  }
  .trade-receives-word {
    font-size: 12px; font-weight: 400;
    color: var(--text);
  }

  .trade-receives-label {
    font-size: 11px;
    color: var(--text);
    margin-top: 4px; margin-bottom: 10px;
  }
  .trade-group--gap { margin-top: 14px; }
  .trade-receives-label .clickable-team { color: var(--text); }
  .trade-receives-label .clickable-team:hover { color: var(--accent); opacity: 1; }

  .trade-item { font-size: 14px; font-weight: 600; color: var(--text); padding: 2px 0; cursor: pointer; }
  .trade-item:hover { color: var(--accent); }

  /* PLANTILLAS */
  .plantillas-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
    gap: 16px;
  }

  .team-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    transition: border-color 0.2s;
  }

  .team-card:hover { border-color: rgba(var(--accent-rgb),0.3); }

  .team-card-header {
    background: var(--surface-2);
    padding: 10px 16px;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 10px;
  }

  .team-name {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 18px;
    letter-spacing: 1px;
  }

  .roster-block { }

  .roster-label {
    font-family: 'Inter', sans-serif;
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: 6px;
  }

  .roster-label.plantilla { color: var(--text-muted); }
  .roster-label.siguen    { color: var(--text-muted); }
  .roster-label.llegadas  { color: var(--signed); }
  .roster-label.salidas   { color: var(--gone); }
  .roster-label.fa        { color: var(--pending); }

  .roster-pos-tag {
    font-family: 'Inter', sans-serif;
    font-size: 9px;
    letter-spacing: 0.5px;
    color: var(--text);
    display: inline-block;
    min-width: 22px;
    margin-right: 4px;
  }

  .roster-player-new { color: var(--signed); }
  .roster-player-new .roster-pos-tag { color: var(--text); }

  .roster-player-resign { color: var(--resign); }
  .roster-player-resign .roster-pos-tag { color: var(--text); }

  .roster-player-tw { color: var(--accent2); }
  .roster-player-tw .roster-pos-tag { color: var(--text); }

  .badge-resign {
    font-family: 'DM Mono', monospace;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.5px;
    color: var(--resign);
    border: 1px solid var(--resign);
    background: rgba(96,165,250,0.1);
    border-radius: 3px;
    padding: 1px 5px;
    margin-left: 5px;
    vertical-align: middle;
  }

  .badge-tw {
    font-family: 'DM Mono', monospace;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.5px;
    color: var(--accent2);
    border: 1px solid rgba(255,107,53,0.4);
    background: rgba(255,107,53,0.1);
    border-radius: 3px;
    padding: 1px 5px;
    margin-left: 5px;
    vertical-align: middle;
  }

  .roster-section {
    padding: 10px 16px;
    border-bottom: 1px solid var(--border);
  }
  .roster-section:last-child { border-bottom: none; }

  .roster-section-title {
    font-family: 'Inter', sans-serif;
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: 8px;
  }
  .roster-section-title.llegadas { color: var(--signed); }
  .roster-section-title.salidas  { color: var(--gone); }
  .roster-section-title.siguen   { color: var(--text-muted); }
  .roster-section-title.trades   { color: var(--accent2); }
  .roster-section-title.coaches  { color: var(--accent); }

  .roster-3col {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px;
  }

  .roster-subcol-label {
    font-family: 'Inter', sans-serif;
    font-size: 8px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--text-dim);
    margin-bottom: 4px;
    padding-bottom: 3px;
    border-bottom: 1px solid var(--border);
  }

  .roster-player {
    font-size: 12px;
    padding: 2px 0;
    line-height: 1.5;
    color: var(--text);
  }

  .roster-siguen {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
  }

  .roster-pill {
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 3px;
    padding: 3px 9px;
    font-size: 14px;
  }

  .roster-trade-item {
    font-size: 11px;
    color: var(--text-muted);
    padding: 2px 0;
  }

  .roster-coach-row {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    padding: 2px 0;
  }

  /* STATES */
  .state-loading {
    padding: 60px 32px;
    text-align: center;
    color: var(--text-muted);
    font-family: 'DM Mono', monospace;
    font-size: 12px;
    letter-spacing: 1px;
    text-transform: uppercase;
  }

  .state-loading::before {
    content: '';
    display: block;
    width: 28px; height: 28px;
    border: 2px solid var(--border);
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin: 0 auto 14px;
  }

  @keyframes spin { to { transform: rotate(360deg); } }

  /* Skeleton loader */
  .sk {
    display: block;
    background: linear-gradient(90deg, var(--surface-2) 0%, var(--border) 50%, var(--surface-2) 100%);
    background-size: 200% 100%;
    animation: sk-shimmer 1.4s ease infinite;
    border-radius: 3px;
    height: 12px;
  }
  .sk-s { width: 35%; }
  .sk-m { width: 60%; }
  .sk-l { width: 85%; }
  .sk-f { width: 100%; }
  @keyframes sk-shimmer {
    0%   { background-position:  200% 0; }
    100% { background-position: -200% 0; }
  }
  tr.sk-row td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--border);
  }
  .sk-card {
    border: 1px solid var(--border);
    border-radius: 6px;
    margin-bottom: 12px;
    overflow: hidden;
  }
  .sk-card-head {
    padding: 10px 16px;
    border-bottom: 1px solid var(--border);
    background: var(--surface-2);
  }
  .sk-card-body {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .sk-card-side {
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
  .sk-card-side + .sk-card-side {
    border-left: 1px solid var(--border);
  }

  .btn-retry {
    margin-top: 12px;
    display: inline-block;
    background: none;
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text-muted);
    cursor: pointer;
    font-family: 'DM Mono', monospace;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 6px 12px;
    transition: border-color var(--transition), color var(--transition);
  }
  .btn-retry:hover { border-color: var(--accent); color: var(--accent); }

  .state-empty {
    padding: 48px;
    text-align: center;
    color: var(--text-dim);
    font-family: 'DM Mono', monospace;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 2px;
  }

  /* THEME TOGGLE */
  .theme-toggle {
    display: flex;
    align-items: center;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 4px;
    overflow: hidden;
    height: 32px;
    cursor: pointer;
    padding: 0 10px;
    gap: 6px;
    color: var(--text-muted);
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    letter-spacing: 1px;
    transition: border-color 0.2s, color 0.2s;
  }

  .theme-toggle:hover { border-color: var(--accent); color: var(--text); }

  .refresh-btn {
    display: flex;
    align-items: center;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 4px;
    height: 32px;
    cursor: pointer;
    padding: 0 10px;
    gap: 6px;
    color: var(--text-muted);
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    letter-spacing: 1px;
    transition: border-color 0.2s, color 0.2s;
  }
  .refresh-btn:hover { border-color: var(--accent); color: var(--text); }
  .refresh-btn:disabled { opacity: 0.5; cursor: not-allowed; }
  .refresh-btn svg { transition: transform 0.6s ease; }
  .refresh-btn.loading svg { animation: spin 0.8s linear infinite; }
  @keyframes spin { to { transform: rotate(360deg); } }

  .theme-icon { font-size: 14px; line-height: 1; }

  /* CAP / APRON */

  .badge-1st { background: rgba(255,159,0,0.12); color: var(--pending); border: 1px solid rgba(255,159,0,0.3); }
  .badge-2nd { background: rgba(255,68,85,0.12); color: var(--gone); border: 1px solid rgba(255,68,85,0.3); }

  @media (max-width: 700px) {
  }

  /* PLAYER DRAWER */
  .drawer-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,0.55);
    z-index: 200;
    opacity: 0; pointer-events: none;
    transition: opacity 0.3s ease;
  }
  .drawer-overlay.open { opacity: 1; pointer-events: all; }

  .player-drawer {
    position: fixed; top: 0; right: 0; bottom: 0;
    width: min(480px, 95vw);
    background: var(--surface);
    border-left: 1px solid var(--border);
    z-index: 201;
    transform: translateX(100%);
    transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
    display: flex; flex-direction: column;
    overflow: hidden;
  }
  .player-drawer.open { transform: translateX(0); }

  .drawer-header {
    padding: 20px 24px 16px;
    border-bottom: 1px solid var(--border);
    display: flex; align-items: flex-start; justify-content: space-between;
    flex-shrink: 0;
  }
  .drawer-player-name {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 32px; letter-spacing: 1px; line-height: 1;
    color: var(--text);
  }
  .drawer-player-type {
    font-family: 'Inter', sans-serif;
    font-size: 13px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--accent);
    margin-top: 6px;
  }
  .drawer-close {
    background: none; border: 1px solid var(--border);
    color: var(--text-muted); cursor: pointer;
    width: 32px; height: 32px; border-radius: 4px;
    font-size: 18px; line-height: 1;
    display: flex; align-items: center; justify-content: center;
    transition: all 0.2s; flex-shrink: 0;
  }
  .drawer-close:hover { border-color: var(--accent); color: var(--accent); }

  .drawer-body {
    padding: 24px; overflow-y: auto; flex: 1;
    scrollbar-width: thin;
    scrollbar-color: var(--border) transparent;
  }
  .drawer-section { margin-bottom: 28px; }
  .drawer-scouting-title {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 20px; letter-spacing: 1px;
    color: var(--text);
    margin-bottom: 10px;
  }
  .drawer-scouting-list {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: 6px;
  }
  .drawer-scouting-link {
    display: inline-block; padding: 8px 14px;
    background: var(--surface-2); border: 1px solid var(--border); border-radius: 6px;
    color: var(--accent); text-decoration: none;
    font-size: 13px; font-weight: 500;
    transition: background 0.15s ease, border-color 0.15s ease;
  }
  .drawer-scouting-link:hover { background: var(--border); border-color: var(--accent); }
  .drawer-team-links {
    margin-top: 24px; padding-top: 16px;
    border-top: 1px solid var(--border);
    display: flex; flex-wrap: wrap; gap: 8px;
  }
  .drawer-team-btn {
    background: none; border: 1px solid var(--border);
    border-radius: 6px; cursor: pointer;
    padding: 8px 14px; text-align: left;
    transition: border-color 0.15s;
    display: flex; flex-direction: column; gap: 3px;
  }
  .drawer-team-btn:hover { border-color: var(--accent); }
  .drawer-team-btn-label {
    font-family: 'DM Mono', monospace;
    font-size: 9px; text-transform: uppercase; letter-spacing: 1px;
    color: var(--text-muted);
  }
  .drawer-team-btn-name {
    display: flex; align-items: center; gap: 6px;
    font-size: 14px; font-weight: 600; color: var(--text);
  }
  .drawer-section-title {
    font-family: 'DM Mono', monospace;
    font-size: 9px; text-transform: uppercase; letter-spacing: 2px;
    color: var(--text-muted); margin-bottom: 12px;
    padding-bottom: 6px; border-bottom: 1px solid var(--border);
  }
  .drawer-row {
    display: flex; justify-content: space-between; align-items: baseline;
    padding: 7px 0; border-bottom: 1px solid var(--border); gap: 16px;
  }
  .drawer-row:last-child { border-bottom: none; }
  .drawer-label { font-size: 12px; color: var(--text); flex-shrink: 0; }
  .drawer-value { font-size: 13px; color: var(--text); font-weight: 500; text-align: right; }
  .drawer-value.money { font-family: 'Inter', sans-serif; color: var(--accent); }
  .drawer-value.notes { font-size: 12px; font-weight: 400; color: var(--text-muted); text-align: right; line-height: 1.5; max-width: 260px; }
  .drawer-empty { font-family: 'DM Mono', monospace; font-size: 11px; color: var(--text-dim); text-align: center; padding: 16px 0; text-transform: uppercase; }

  /* TEAM VIEW */
  #section-team  { display: none; animation: fadeIn 0.3s ease; }
  #section-team.active  { display: block; }
  #section-teams { display: none; animation: fadeIn 0.3s ease; }
  #section-teams.active { display: block; }

  .teams-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 12px;
    padding: 24px 32px;
  }

  .teams-grid-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 16px 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
    text-align: center;
  }

  .teams-grid-card:hover {
    border-color: rgba(var(--accent-rgb),0.4);
    background: var(--surface-2);
  }

  .teams-grid-name {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 15px;
    letter-spacing: 0.5px;
    line-height: 1.2;
    color: var(--text);
  }

  .team-view-back {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: 'Inter', sans-serif; font-size: 11px;
    text-transform: uppercase; letter-spacing: 1.5px;
    color: var(--text-muted); cursor: pointer;
    background: none; border: none;
    padding: 0; margin-bottom: 28px; transition: color 0.2s;
  }
  .team-view-back:hover { color: var(--accent); }

  .team-view-header {
    margin-bottom: 36px; padding-bottom: 24px;
    border-bottom: 1px solid var(--border);
    display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  }
  .team-view-identity {
    display: flex; flex-direction: row; align-items: center; gap: 16px;
  }
  .team-view-identity .tv-team-logo { flex-shrink: 0; }
  .team-view-name {
    font-family: 'Bebas Neue', sans-serif;
    font-size: clamp(40px, 7vw, 72px);
    letter-spacing: 3px; line-height: 1; color: var(--text);
  }
  .team-view-meta {
    font-family: 'Inter', sans-serif;
    font-size: 11px; color: var(--text-muted); text-align: right;
    display: flex; flex-direction: column; gap: 4px;
  }
  .tv-meta-new { color: var(--signed); font-weight: 500; }
  .tv-meta-fired { color: var(--danger); margin-left: 2px; }
  .tv-coach-fired { color: var(--danger); }
  [data-theme="dark"] .tv-card-header .tv-label { color: var(--text); }
  [data-theme="dark"] .tv-meta-role { color: var(--text); }

  .team-view-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px; margin-bottom: 32px;
  }
  .tv-card { background: var(--surface); border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
  .tv-card-header {
    background: var(--surface-2); padding: 10px 16px; border-bottom: 1px solid var(--border);
    font-family: 'Inter', sans-serif; font-size: 10px; text-transform: uppercase; letter-spacing: 1.5px;
    display: flex; align-items: center; justify-content: space-between;
  }
  .tv-card-header .tv-label { color: var(--text-muted); }
  .tv-card-header .tv-count { color: var(--accent); }
  .tv-card-body { padding: 4px 0; }
  .tv-row {
    padding: 9px 16px; border-bottom: 1px solid var(--border);
    display: flex; align-items: center; justify-content: space-between; gap: 12px;
    min-height: 44px; box-sizing: border-box;
  }
  .tv-row:last-child { border-bottom: none; }
  .tv-row-main { flex: 1; min-width: 0; display: flex; flex-wrap: wrap; align-items: center; gap: 2px 8px; }
  .tv-row-name { font-size: 13px; font-weight: 500; color: var(--text); cursor: pointer; white-space: nowrap; }
  .tv-row-name:hover { color: var(--accent); text-decoration: underline; }
  .tv-row-detail { font-size: 11px; color: var(--text-muted); font-family: 'Inter', sans-serif; white-space: nowrap; }
  .tv-row-money { font-size: 12px; color: var(--accent); font-family: 'Inter', sans-serif; }
  .tv-row-pick {
    font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 600;
    color: var(--text-muted); min-width: 32px; text-align: left; flex-shrink: 0;
    letter-spacing: 0.5px;
  }
  .tv-row .roster-pos-tag {
    font-size: 11px; font-weight: 600; color: var(--text);
    min-width: 32px; margin-right: 6px;
  }
  .tv-row-pick.undrafted { color: var(--text); }
  .tv-row.tv-row-tw .tv-row-name { color: var(--text-muted); }
  .tv-empty { padding: 16px; font-size: 12px; color: var(--text-dim); font-family: 'Inter', sans-serif; }

  .tv-color-legend {
    display: flex; flex-wrap: wrap; gap: 18px;
    margin-top: 8px; padding: 12px 0;
    font-family: 'DM Mono', monospace; font-size: 10px;
    text-transform: uppercase; letter-spacing: 1px;
    color: var(--text-muted);
  }
  .tv-color-legend span { display: inline-flex; align-items: center; gap: 8px; }
  .tv-color-legend i {
    width: 10px; height: 10px; border-radius: 2px;
    display: inline-block; flex-shrink: 0;
  }
  .tv-section-title {
    font-family: 'DM Mono', monospace; font-size: 13px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 2px;
    color: var(--text-muted); margin-bottom: 14px; margin-top: 8px;
    display: flex; align-items: center; gap: 10px;
  }
  .tv-section-title::after { content: ''; flex: 1; height: 1px; background: var(--border); }
  .tv-section-count {
    font-size: 11px; font-weight: 400; font-family: 'Inter', sans-serif;
    color: var(--text-dim); letter-spacing: 0; margin-left: -4px;
  }

  .tv-video-link {
    display: flex; align-items: center; gap: 12px;
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 8px; padding: 10px 14px;
    text-decoration: none; color: var(--text);
    transition: border-color 0.2s;
  }
  .tv-video-link:hover { border-color: rgba(var(--accent-rgb), 0.4); }
  .tv-video-thumb {
    width: 80px; height: 45px; object-fit: cover;
    border-radius: 4px; flex-shrink: 0;
  }
  .tv-video-info {
    flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px;
  }
  .tv-video-title-row {
    display: flex; align-items: center; gap: 6px;
  }
  .tv-video-play {
    font-size: 14px; color: var(--accent); flex-shrink: 0;
  }
  .tv-video-title {
    font-size: 13px; font-weight: 500; color: var(--text);
    overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  }
  .tv-video-channel {
    font-size: 11px; color: var(--text-muted);
  }
  .tv-article-icon {
    width: 80px; height: 45px; border-radius: 4px; flex-shrink: 0;
    background: var(--surface-2); display: flex; align-items: center; justify-content: center;
    font-size: 20px;
  }
  .tv-article-title {
    font-size: 13px; font-weight: 500; color: var(--text);
    overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  }
  .tv-article-author { font-size: 11px; color: var(--text-muted); }
  .tv-article-arrow { font-size: 15px; color: var(--text-muted); flex-shrink: 0; }

  .clickable-player { cursor: pointer; transition: color 0.15s; }
  .clickable-player:hover { color: var(--accent); text-decoration: underline; }
  .clickable-team { cursor: pointer; transition: opacity 0.15s; }
  .clickable-team:hover { opacity: 0.75; }

  @media (max-width: 640px) {
    .team-view-grid { grid-template-columns: 1fr; }
    .player-drawer { width: 100vw; }
  }
  *:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
  }

  ::-webkit-scrollbar { width: 6px; height: 6px; }
  ::-webkit-scrollbar-track { background: var(--bg); }
  ::-webkit-scrollbar-thumb { background: var(--border); border-radius: var(--radius-full); }
  ::-webkit-scrollbar-thumb:hover { background: var(--text-muted); }

  /* FOOTER */
  .ag-footer {
    margin-top: 64px;
    background: var(--surface);
    border-top: 1px solid var(--border);
    padding: 32px 24px;
    display: grid;
    grid-template-columns: 1.5fr 2fr 1.5fr 1.5fr;
    gap: 32px 32px;
    align-items: start;
    font-size: 0.875rem;
    color: var(--text-muted);
  }

  .ag-footer-brand strong {
    display: block;
    font-size: 0.8rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text);
    margin-bottom: 0.25rem;
  }

  .ag-footer-brand span {
    text-transform: uppercase;
    letter-spacing: 0.08em;
  }

  .ag-footer-col-title {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text);
    margin-bottom: 12px;
  }

  .ag-footer-projects,
  .ag-footer-pubs {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
  }

  .ag-footer-projects a,
  .ag-footer-pubs a {
    color: var(--accent);
    text-decoration: none;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.06em;
  }

  .ag-footer-projects a:hover,
  .ag-footer-pubs a:hover {
    text-decoration: underline;
  }

  .ag-footer-meta {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.75rem;
  }

  .ag-footer-toggle {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: none;
    border: none;
    border-bottom: 1px solid var(--border);
    padding: 0 0 12px 0;
    margin-bottom: 4px;
    cursor: pointer;
    width: 100%;
    color: var(--text-muted);
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
  }
  .ag-footer-toggle:hover { color: var(--text); }
  .ag-footer-toggle-icon {
    transition: transform 0.25s ease;
    flex-shrink: 0;
  }
  .ag-footer-toggle[aria-expanded="false"] .ag-footer-toggle-icon {
    transform: rotate(180deg);
  }

  .ag-footer-body {
    display: contents;
    overflow: hidden;
  }
  .ag-footer-body.collapsed {
    display: none;
  }

  @media (max-width: 700px) {
    .ag-footer {
      grid-template-columns: 1fr;
      gap: 1.5rem;
      padding-bottom: calc(32px + 58px + env(safe-area-inset-bottom, 0px));
    }
  }

  /* HOME */
  #section-home {
    display: none;
    min-height: calc(100vh - 56px);
    padding: 0;
    flex-direction: column;
  }

  #section-home.active { display: flex; }

  /* ── HOME MASTHEAD ── */
  .home-masthead {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    padding: 48px 48px 32px;
    border-bottom: 1px solid var(--border);
    gap: 24px;
    flex-wrap: wrap;
  }

  .home-masthead-left { flex: 1; min-width: 200px; }

  .home-season-tag {
    font-family: 'DM Mono', monospace;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--text-muted);
    margin-bottom: 10px;
  }

  .home-masthead-title {
    font-family: 'Bebas Neue', sans-serif;
    font-size: clamp(40px, 6vw, 72px);
    letter-spacing: 3px;
    line-height: 0.95;
    color: var(--text);
    white-space: nowrap;
  }

  .home-masthead-title em {
    color: var(--accent);
    font-style: normal;
  }

  /* AG-HERO — título principal con italic-mix */
  .ag-hero {
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.03em;
  }
  .ag-hero em {
    font-style: italic;
    font-weight: 400;
    color: var(--text-muted);
  }

  .ag-data-badge {
    display: inline-block;
    margin-top: 12px;
    font-family: 'DM Mono', monospace;
    font-size: 10px;
    letter-spacing: 0.5px;
    color: var(--text-muted);
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 3px 8px;
  }

  .home-masthead-right {
    text-align: right;
    flex-shrink: 0;
  }

  .home-total-num {
    font-family: 'Bebas Neue', sans-serif;
    font-size: clamp(56px, 8vw, 96px);
    color: var(--accent);
    line-height: 1;
    letter-spacing: 2px;
    display: block;
  }

  .home-total-label {
    font-family: 'DM Mono', monospace;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--text-muted);
  }

  /* ── HOME ROWS ── */
  .home-rows { display: flex; flex-direction: column; flex: 1; }

  .home-sources {
    padding: 20px 48px 8px;
    display: flex;
    flex-direction: column;
    gap: 4px;
  }

  .home-sources p {
    font-family: 'DM Mono', monospace;
    font-size: 10px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin: 0;
    opacity: 0.6;
  }

  .home-row {
    display: flex;
    align-items: center;
    gap: 0;
    border: none;
    border-bottom: 1px solid var(--border);
    background: none;
    cursor: pointer;
    text-align: left;
    padding: 0 48px;
    min-height: 100px;
    position: relative;
    overflow: hidden;
    transition: background 0.25s ease;
    flex: 1;
  }

  .home-row::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--accent);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
    z-index: 0;
  }

  .home-row:hover::before { transform: scaleX(1); }
  .home-row:last-child { border-bottom: none; }

  .home-row-ordinal {
    font-family: 'Bebas Neue', sans-serif;
    font-size: clamp(64px, 9vw, 110px);
    color: var(--border);
    line-height: 1;
    letter-spacing: 2px;
    min-width: clamp(80px, 10vw, 130px);
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    transition: color 0.25s;
    user-select: none;
  }

  .home-row:hover .home-row-ordinal { color: rgba(0,0,0,0.12); }

  .home-row-body {
    flex: 1;
    padding: 0 32px;
    position: relative;
    z-index: 1;
  }

  .home-row-title {
    font-family: 'Bebas Neue', sans-serif;
    font-size: clamp(28px, 4vw, 44px);
    letter-spacing: 2px;
    color: var(--text);
    line-height: 1;
    transition: color 0.25s;
  }

  .home-row:hover .home-row-title { color: var(--accent-contrast); }

  .home-row-desc {
    font-family: inherit;
    font-size: 13px;
    color: var(--text-muted);
    font-weight: 300;
    margin-top: 4px;
    transition: color 0.25s;
  }

  .home-row:hover .home-row-desc { color: var(--accent-contrast); opacity: 0.8; }

  .home-row-right {
    display: flex;
    align-items: center;
    gap: 24px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
  }

  .home-row-stat {
    font-family: 'Bebas Neue', sans-serif;
    font-size: clamp(28px, 4vw, 42px);
    color: var(--accent);
    letter-spacing: 1px;
    line-height: 1;
    transition: color 0.25s;
    min-width: 80px;
    text-align: right;
  }

  .home-row:hover .home-row-stat { color: var(--accent-contrast); }

  .home-row-arrow {
    font-size: 20px;
    color: var(--text-dim);
    transition: color 0.25s, transform 0.25s;
  }

  .home-row:hover .home-row-arrow {
    color: var(--accent-contrast);
    transform: translate(4px, -2px);
  }

  .home-row:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: -2px;
    z-index: 1;
  }

  .home-row:active::before { transform: scaleX(1); }

  html:not([data-theme="dark"]) .home-row:hover .home-row-ordinal { color: rgba(255,255,255,0.2); }

  /* Ocultar nav cuando estamos en home */
  body.on-home nav:not(.mobile-nav) { display: none; }

  /* Botón volver al home en el logo */
  .logo { cursor: pointer; }

  /* MOBILE BOTTOM NAV */
  .mobile-nav { display: none; }

  @media (max-width: 768px) {
    nav:not(.ag-footer-projects):not(.ag-footer-pubs):not(.mobile-nav) { display: none; }
    .team-view-meta { text-align: left; }
    .legend-row--team { flex-direction: column; align-items: flex-end; gap: 8px; }

    header { position: relative; top: auto; }
    main {
      padding: 20px 16px calc(58px + env(safe-area-inset-bottom, 0px) + 20px);
      max-width: 100%;
    }
    .table-wrap { max-height: none; }

    .mobile-nav {
      display: flex;
      position: fixed;
      bottom: 0; left: 0; right: 0;
      top: auto;
      background: var(--surface);
      border-top: 1px solid var(--border);
      height: calc(58px + env(safe-area-inset-bottom, 0px));
      padding-bottom: env(safe-area-inset-bottom, 0);
      z-index: 200;
      -webkit-transform: translate3d(0, 0, 0);
      transform: translate3d(0, 0, 0);
    }

    .mobile-tab {
      flex: 1;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 4px;
      background: none;
      border: none;
      cursor: pointer;
      color: var(--text-muted);
      transition: color 0.2s;
      padding: 0;
      position: relative;
    }

    /* Indicador activo: línea en la parte superior */
    .mobile-tab::before {
      content: '';
      position: absolute;
      top: 0; left: 20%; right: 20%;
      height: 2px;
      background: transparent;
      border-radius: 0 0 2px 2px;
      transition: background 0.2s;
    }
    .mobile-tab.active::before { background: var(--accent); }
    .mobile-tab.active { color: var(--accent); }

    .mobile-tab-icon {
      position: relative;
      display: flex; align-items: center; justify-content: center;
      width: 24px; height: 24px;
    }

    .mobile-tab-label {
      font-family: 'Inter', sans-serif;
      font-size: 8px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.5px;
      line-height: 1;
    }

    /* Siempre visible en móvil, incluso en home */
    body.on-home .mobile-nav { display: flex; }

  }

  @media (max-width: 900px) {
    .home-masthead { padding: 32px 24px 24px; }
    .home-row { padding: 0 24px; min-height: 80px; }
    .home-row-ordinal { font-size: 56px; min-width: 70px; }
    .home-row-body { padding: 0 16px; }
    .home-row-stat { font-size: 28px; min-width: 60px; }
  }

  @media (max-width: 768px) {
    header { padding: 0 12px; height: 48px; }
    thead th { top: 0; }
    main { padding: 20px 16px 20px; }
    .section-title { font-size: 28px; }
    .trade-body { grid-template-columns: repeat(2, 1fr) !important; }
    .trade-side { border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 12px 14px; }
    .trade-side:nth-child(2n) { border-right: none; }
    .trade-side:last-child { border-bottom: none; }
    .trade-side:nth-last-child(2):nth-child(odd) { border-bottom: none; }
    .trade-team-label { font-size: 9px; margin-bottom: 6px; }
    .trade-item { font-size: 13px; }
    .trade-header { padding: 8px 14px; }
    .trade-card { margin-bottom: 8px; }
    .logo-title { font-size: 17px; letter-spacing: 1px; }
    .logo-year  { font-size: 17px; }
    .header-meta { display: none; }
    .header-right { gap: 8px; }
    .lang-toggle { height: 28px; }
    .lang-btn { font-size: 10px; padding: 0 8px; }
    .theme-toggle { height: 28px; padding: 0 8px; font-size: 10px; }
    .refresh-btn { height: 28px; padding: 0 8px; }
    .home-masthead { padding: 24px 16px 20px; }
    .home-row { padding: 0 16px; min-height: 72px; }
    .home-row-ordinal { font-size: 44px; min-width: 56px; }
    .home-row-body { padding: 0 12px; }
    .home-row-stat { font-size: 24px; min-width: 48px; }
    .home-row-arrow { display: block; font-size: 16px; color: var(--text-muted); }
    .teams-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; padding: 16px; }
    .teams-grid-card { padding: 10px 6px; gap: 6px; }
    .teams-grid-name { font-size: 11px; letter-spacing: 0; }

    /* Responsive tables */
    .table-wrap { -webkit-overflow-scrolling: touch; }
    table { min-width: 540px; }
    th, td { white-space: nowrap; }
    td.td-notes { white-space: normal; min-width: 120px; }
    .filters { flex-wrap: wrap; gap: 8px; }
    .filter-group { flex: 1 1 140px; }
    .filter-input, .filter-select { width: 100%; }
    .section-header { margin-bottom: 16px; }
  }

  /* Helper classes (replacing inline styles in markup) */
  .legend-row { display: flex; gap: 20px; margin-top: 10px; flex-wrap: wrap; align-items: center; }
  .legend-item { display: inline-flex; align-items: center; gap: 6px; }
  .legend-text { font-size: 11px; color: var(--text-muted); }
  .fa-subsection-title--pending { margin-top: 40px; }
  .filters--compact { margin-bottom: 16px; }
  .badge-toggle-group { display: flex; gap: 4px; }
  .badge-toggle { cursor: pointer; opacity: 0.4; border: none; padding: 3px 8px; }
  .badge-toggle[aria-pressed="true"] { opacity: 1; }
  .th-center { text-align: center; }
  .th-w-32 { width: 32px; }
  .th-w-48 { width: 48px; }
  .th-w-160 { width: 160px; }
  .th-w-200 { width: 200px; }
  .section-header--undrafted { margin-top: 48px; display: flex; align-items: center; justify-content: space-between; }
  .section-title--small { font-size: 24px; }
  .tv-team-logo { height: 64px; display: flex; align-items: center; }

  /* Sortable header keyboard focus */
  thead th[role="button"] { cursor: pointer; }
  thead th[role="button"]:focus-visible { outline: 2px solid var(--accent); outline-offset: -2px; }
  thead th[aria-sort="ascending"] .sort-icon::after { content: ""; }
  thead th[aria-sort="ascending"] .sort-icon,
  thead th[aria-sort="descending"] .sort-icon { color: var(--accent); }

  /* Logo as button reset */
  button.logo { background: none; border: 0; padding: 0; cursor: pointer; color: inherit; font: inherit; }
