    :root {
      /* ── LIGHT MODE (por defecto) ── */
      --bg: #f0f2f7;
      --bg2: #e6e9f2;
      --bg3: #dde1ee;
      --panel: #ffffff;
      --panel2: #f5f7fc;
      --border: #c8cfe0;
      --gold: #d4920a;
      --gold2: #b87a00;
      --red: #d0303c;
      --green: #1a9e40;
      --blue: #2878d6;
      --text: #1a2340;
      --text2: #4a5a7a;
      --text3: #8899bb;
      --win: #d6f0df;
      --win-border: #1a9e40;
      --shadow: 0 2px 8px #0001;
    }

    html.dark {
      /* ── DARK MODE ── */
      --bg: #0a0e1a;
      --bg2: #0f1525;
      --bg3: #151d35;
      --panel: #1a2340;
      --panel2: #1f2a4a;
      --border: #2a3a60;
      --gold: #f0b429;
      --gold2: #ffd166;
      --red: #e63946;
      --green: #2dc653;
      --blue: #4895ef;
      --text: #e8eaf0;
      --text2: #8899bb;
      --text3: #4a5a7a;
      --win: #1a3a2a;
      --win-border: #2dc653;
      --shadow: 0 2px 8px #0004;
    }

    * { margin: 0; padding: 0; box-sizing: border-box; }

    body {
      background: var(--bg);
      color: var(--text);
      font-family: 'Barlow', sans-serif;
      min-height: 100vh;
      overflow-x: hidden;
    }

    /* ===================== LOGIN ===================== */
    #login-screen {
      min-height: 100vh;
      display: flex;
      align-items: center;
      justify-content: center;
      background:
        radial-gradient(ellipse 80% 60% at 50% 0%, #1a3a6a22 0%, transparent 70%),
        radial-gradient(ellipse 40% 40% at 80% 80%, var(--gold) 0%, transparent 80%),
        var(--bg);
      position: relative;
      overflow: hidden;
    }

    #login-screen::before {
      content: '⚽';
      position: absolute;
      font-size: 400px;
      opacity: 0.025;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%) rotate(-20deg);
      pointer-events: none;
    }

    .login-box {
      background: var(--panel);
      border: 1px solid var(--border);
      border-radius: 16px;
      padding: 48px 44px;
      width: 380px;
      position: relative;
      box-shadow: 0 20px 60px #00000022, 0 0 0 1px #ffffff60 inset;
    }

    .login-logo {
      text-align: center;
      margin-bottom: 32px;
    }

    .login-logo .trophy {
      font-size: 48px;
      display: block;
      margin-bottom: 8px;
    }

    .login-logo h1 {
      font-family: 'Bebas Neue', cursive;
      font-size: 38px;
      letter-spacing: 4px;
      color: var(--gold);
      line-height: 1;
    }

    .login-logo .subtitle {
      font-family: 'Barlow', sans-serif;
      font-size: 13px;
      letter-spacing: 6px;
      color: var(--text2);
      text-transform: uppercase;
      margin-top: 4px;
    }

    .login-box label {
      display: block;
      font-family: 'Barlow', sans-serif;
      font-size: 11px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--text2);
      margin-bottom: 6px;
    }

    .login-box input {
      width: 100%;
      background: var(--bg2);
      border: 1px solid var(--border);
      border-radius: 8px;
      padding: 12px 16px;
      color: var(--text);
      font-family: 'Barlow', sans-serif;
      font-size: 16px;
      margin-bottom: 20px;
      transition: border-color .2s;
      outline: none;
    }

    .login-box input:focus {
      border-color: var(--gold);
    }

    .btn-login {
      width: 100%;
      background: var(--gold);
      color: #0a0e1a;
      border: none;
      border-radius: 8px;
      padding: 14px;
      font-family: 'Bebas Neue', cursive;
      font-size: 20px;
      letter-spacing: 3px;
      cursor: pointer;
      transition: background .2s, transform .1s;
    }

    .btn-login:hover { background: var(--gold2); }
    .btn-login:active { transform: scale(.98); }

    .login-error {
      background: #e6394622;
      border: 1px solid #e6394644;
      border-radius: 8px;
      padding: 10px 14px;
      font-size: 14px;
      color: #ff6b76;
      margin-top: 14px;
      display: none;
    }

    /* ===================== APP ===================== */
    #app-screen { display: none; }

    .topbar {
      background: var(--bg2);
      border-bottom: 1px solid var(--border);
      padding: 0 24px;
      height: 56px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      position: sticky;
      top: 0;
      z-index: 100;
    }

    .topbar-left {
      display: flex;
      align-items: center;
      gap: 16px;
    }

    .topbar-title {
      font-family: 'Bebas Neue', cursive;
      font-size: 26px;
      letter-spacing: 3px;
      color: var(--gold);
    }

    .topbar-subtitle {
      font-family: 'Barlow', sans-serif;
      font-size: 12px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--text2);
    }

    .topbar-right {
      display: flex;
      align-items: center;
      gap: 16px;
    }

    .deadline-badge {
      background: var(--bg3);
      border: 1px solid var(--border);
      border-radius: 6px;
      padding: 5px 12px;
      font-family: 'Barlow', sans-serif;
      font-size: 12px;
      letter-spacing: 1px;
      color: var(--text2);
    }

    .deadline-badge.expired {
      background: #e6394618;
      border-color: #e6394644;
      color: var(--red);
    }

    .deadline-badge.urgent {
      background: #f0b42918;
      border-color: #f0b42944;
      color: var(--gold);
    }

    .user-chip {
      display: flex;
      align-items: center;
      gap: 8px;
      background: var(--panel);
      border: 1px solid var(--border);
      border-radius: 24px;
      padding: 4px 14px 4px 8px;
      font-size: 14px;
    }

    .user-avatar {
      width: 28px;
      height: 28px;
      background: var(--gold);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-family: 'Bebas Neue', cursive;
      font-size: 15px;
      color: #0a0e1a;
    }

    .btn-logout {
      background: none;
      border: none;
      color: var(--text2);
      font-size: 18px;
      cursor: pointer;
      padding: 4px 8px;
      border-radius: 4px;
      transition: color .2s;
    }
    .btn-logout:hover { color: var(--red); }

    /* ===================== TABS ===================== */
    .tabs-bar {
      background: var(--bg2);
      border-bottom: 1px solid var(--border);
      display: flex;
      padding: 0 24px;
      gap: 4px;
    }

    .tab-btn {
      background: none;
      border: none;
      border-bottom: 2px solid transparent;
      padding: 12px 18px;
      font-family: 'Barlow', sans-serif;
      font-size: 14px;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: var(--text2);
      cursor: pointer;
      transition: color .2s, border-color .2s;
    }

    .tab-btn.active {
      color: var(--gold);
      border-bottom-color: var(--gold);
    }

    .tab-btn:hover:not(.active) { color: var(--text); }

    /* ===================== BRACKET ===================== */
    .bracket-container {
      padding: 24px 16px;
      overflow-x: auto;
    }

    .bracket-wrapper {
      display: flex;
      align-items: flex-start;
      gap: 0;
      min-width: 1400px;
      position: relative;
    }

    /* Column layout */
    .bracket-col {
      display: flex;
      flex-direction: column;
      gap: 0;
    }

    .col-header {
      font-family: 'Barlow', sans-serif;
      font-size: 10px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--text2);
      text-align: center;
      padding: 0 8px 10px;
      white-space: nowrap;
    }

    /* Team slot */
    .team-slot {
      background: var(--panel);
      border: 1px solid var(--border);
      border-radius: 6px;
      padding: 6px 10px;
      cursor: pointer;
      transition: all .15s;
      display: flex;
      align-items: center;
      gap: 6px;
      min-height: 34px;
      position: relative;
      white-space: nowrap;
    }

    .team-slot:hover:not(.locked):not(.empty-slot) {
      border-color: var(--gold);
      background: var(--panel2);
      z-index: 2;
    }

    .team-slot.winner {
      background: var(--win);
      border-color: var(--win-border);
    }

    .team-slot.champion {
      background: linear-gradient(135deg, #2a1f00, #3a2800);
      border-color: var(--gold);
      box-shadow: 0 0 20px #f0b42933;
    }

    .team-slot.empty-slot {
      cursor: default;
      opacity: .5;
    }

    .team-slot.locked {
      cursor: default;
    }

    .team-flag { font-size: 16px; }

    .team-name {
      font-family: 'Barlow', sans-serif;
      font-size: 12px;
      letter-spacing: .5px;
    }

    .team-slot.winner .team-name { color: var(--green); }
    .team-slot.champion .team-name { color: var(--gold); }
    .team-slot.empty-slot .team-name { color: var(--text2); }

    /* Texto descriptivo en slots vacíos ("2A", "G(P74)", "3 (C/D/F)") */
    .slot-hint {
      color: var(--text2) !important;
      font-size: 11px !important;
      font-style: italic;
      letter-spacing: .3px;
    }

    /* Botón ✕ para borrar selección dentro de un slot */
    .slot-clear-btn {
      display: none;
      align-items: center;
      justify-content: center;
      margin-left: auto;
      flex-shrink: 0;
      width: 16px;
      height: 16px;
      padding: 0;
      background: none;
      border: none;
      border-radius: 3px;
      color: var(--text2);
      font-size: 11px;
      line-height: 1;
      cursor: pointer;
      transition: color .12s, background .12s;
    }
    .team-slot:hover .slot-clear-btn {
      display: flex;
    }
    .slot-clear-btn:hover {
      color: var(--red);
      background: color-mix(in srgb, var(--red) 15%, transparent);
    }

    /* Match block */
    .match-block {
      display: flex;
      flex-direction: column;
      position: relative;
    }

    .match-block .team-slot:first-child {
      border-radius: 6px 6px;
      border-bottom: 1px dashed var(--border);
    }

    .match-block .team-slot:last-child {
      border-radius: 6px 6px;
      border-top: none;
    }

    /* Group section */
    .group-section {
      margin-bottom: 8px;
    }

    .group-label {
      font-family: 'Barlow', sans-serif;
      font-size: 9px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--text2);
      padding: 3px 8px;
    }

    /* Connector lines drawn via SVG overlay */
    .connectors-svg {
      position: absolute;
      top: 0;
      left: 0;
      pointer-events: none;
    }

    /* ===================== VIEW MODE ===================== */
    .view-panel {
      padding: 24px;
    }

    .users-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
      gap: 12px;
      margin-bottom: 24px;
    }

    .user-card {
      background: var(--panel);
      border: 1px solid var(--border);
      border-radius: 10px;
      padding: 14px 16px;
      cursor: pointer;
      transition: all .15s;
    }

    .user-card:hover { border-color: var(--gold); }
    .user-card.active { border-color: var(--gold); background: var(--panel2); }

    .user-card-name {
      font-family: 'Barlow', sans-serif;
      font-size: 18px;
      font-weight: 700;
      letter-spacing: 1px;
    }

    .user-card-status {
      font-size: 12px;
      color: var(--text2);
      margin-top: 3px;
    }

    .user-card.has-data .user-card-status { color: var(--green); }

    /* ===================== MODALS / DROPDOWNS ===================== */
    .dropdown-overlay {
      position: fixed;
      inset: 0;
      z-index: 200;
      display: none;
    }

    .dropdown-overlay.active { display: block; }

    .team-picker {
      position: fixed;
      background: var(--panel2);
      border: 1px solid var(--border);
      border-radius: 10px;
      padding: 8px;
      z-index: 300;
      box-shadow: 0 20px 50px #000a;
      min-width: 200px;
      display: none;
      max-height: 300px;
      overflow-y: auto;
    }

    .team-picker.active { display: block; }

    .picker-item {
      padding: 8px 12px;
      border-radius: 6px;
      cursor: pointer;
      display: flex;
      align-items: center;
      gap: 8px;
      font-family: 'Barlow', sans-serif;
      font-size: 15px;
      transition: background .1s;
    }

    .picker-item:hover { background: var(--panel); }
    .picker-item.selected { color: var(--gold); }

    /* Opción borrar en el picker */
    .picker-item.picker-clear {
      color: var(--red);
      border-bottom: 1px solid var(--border);
      border-radius: 6px 6px 0 0;
      margin-bottom: 2px;
    }
    .picker-item.picker-clear:hover { background: var(--panel); }
    .picker-item.picker-clear .team-flag {
      font-size: 13px;
      font-style: normal;
      opacity: .8;
    }

    /* ===================== TOAST ===================== */
    .toast {
      position: fixed;
      bottom: 24px;
      left: 50%;
      transform: translateX(-50%) translateY(80px);
      background: var(--panel2);
      border: 1px solid var(--border);
      border-radius: 8px;
      padding: 12px 24px;
      font-family: 'Barlow', sans-serif;
      font-size: 15px;
      letter-spacing: 1px;
      z-index: 999;
      transition: transform .3s ease;
      pointer-events: none;
    }

    .toast.show { transform: translateX(-50%) translateY(0); }
    .toast.success { border-color: var(--green); color: var(--green); }
    .toast.error { border-color: var(--red); color: #ff6b76; }

    /* ===================== RESPONSIVE ===================== */
    @media (max-width: 768px) {
      .topbar-subtitle { display: none; }
      .deadline-badge { display: none; }
    }

    /* ===================== SCROLLBAR ===================== */
    ::-webkit-scrollbar { width: 6px; height: 6px; }
    ::-webkit-scrollbar-track { background: var(--bg); }
    ::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
    ::-webkit-scrollbar-thumb:hover { background: var(--text2); }

    .save-bar {
      position: sticky;
      bottom: 0;
      background: var(--bg2);
      border-top: 1px solid var(--border);
      padding: 12px 24px;
      display: flex;
      justify-content: flex-end;
      gap: 12px;
    }

    .btn-save {
      background: var(--gold);
      color: #0a0e1a;
      border: none;
      border-radius: 8px;
      padding: 10px 28px;
      font-family: 'Bebas Neue', cursive;
      font-size: 18px;
      letter-spacing: 2px;
      cursor: pointer;
      transition: background .2s;
    }
    .btn-save:hover { background: var(--gold2); }
    .btn-save:disabled {
      opacity: .4;
      cursor: not-allowed;
    }

    .btn-reset {
      background: none;
      border: 1px solid var(--border);
      color: var(--text2);
      border-radius: 8px;
      padding: 10px 20px;
      font-family: 'Barlow', sans-serif;
      font-size: 14px;
      letter-spacing: 2px;
      text-transform: uppercase;
      cursor: pointer;
      transition: border-color .2s, color .2s;
    }
    .btn-reset:hover { border-color: var(--red); color: var(--red); }

    .champion-display {
      text-align: center;
      padding: 20px 8px 8px;
    }

    .champion-trophy { font-size: 28px; }
    .champion-label {
      font-family: 'Bebas Neue', cursive;
      font-size: 11px;
      letter-spacing: 4px;
      color: var(--gold);
      display: block;
      margin-top: 2px;
    }
    .champion-name {
      font-family: 'Barlow', sans-serif;
      font-size: 14px;
      font-weight: 700;
      color: var(--gold2);
    }

    .view-readonly-notice {
      background: #4895ef18;
      border: 1px solid #4895ef44;
      border-radius: 8px;
      padding: 10px 16px;
      font-size: 13px;
      color: var(--blue);
      margin-bottom: 16px;
      font-family: 'Barlow', sans-serif;
      letter-spacing: 1px;
    }

    .empty-bracket-msg {
      text-align: center;
      padding: 60px 20px;
      color: var(--text2);
      font-family: 'Barlow', sans-serif;
      font-size: 16px;
      letter-spacing: 2px;
    }
    .btn-theme {
      background: none;
      border: 1px solid var(--border);
      border-radius: 6px;
      color: var(--text2);
      font-size: 16px;
      cursor: pointer;
      padding: 4px 9px;
      transition: border-color .2s, color .2s;
      line-height: 1;
    }
    .btn-theme:hover { border-color: var(--gold); color: var(--gold); }

    /* ── Group reference panel ── */
    .group-ref {
      background: var(--bg3);
      border: 1px solid var(--border);
      border-radius: 6px 6px 0 0;
      border-bottom: none;
      padding: 4px 8px 3px;
    }

    .group-ref-title {
      font-family: 'Barlow', sans-serif;
      font-size: 11px;
      font-weight: bold;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: var(--text2);
      margin-bottom: 2px;
    }

    .group-ref-team {
      display: flex;
      align-items: center;
      gap: 5px;
      font-family: 'Barlow', sans-serif;
      font-size: 11px;
      color: var(--text2);
      padding: 1px 0;
      white-space: nowrap;
    }

    .group-ref-team .rf { font-size: 12px; }

    /* Slots de clasificados debajo del panel de referencia */
    .group-section { margin-bottom: 10px; }
    .group-section .team-slot { border-radius: 0; border-top: none; }
    .group-section .team-slot:first-of-type { border-top: 1px solid var(--border); }
    .group-section .team-slot:last-of-type  { border-radius: 0 0 6px 6px; }

    /* ============================================================
       MOBILE RESPONSIVE — fases secuenciales en vertical
       ============================================================ */

    /* Fase nav (solo móvil) */
    .phase-nav {
      display: none;
    }

    @media (max-width: 900px) {

      /* Topbar compacta */
      .topbar {
        padding: 0 12px;
        height: 50px;
      }
      .topbar-subtitle { display: none; }
      .deadline-badge  { display: none; }
      .topbar-title    { font-size: 20px; letter-spacing: 2px; }

      /* Tabs */
      .tabs-bar { padding: 0 12px; }
      .tab-btn  { padding: 10px 14px; font-size: 13px; }

      /* Ocultar árbol horizontal */
      .bracket-container { display: none; }

      /* Mostrar vista de fases */
      .phase-view { display: block; }

      /* Barra de navegación de fases */
      .phase-nav {
        display: flex;
        overflow-x: auto;
        background: var(--bg2);
        border-bottom: 1px solid var(--border);
        padding: 0 4px;
        gap: 2px;
        scrollbar-width: none;
        -webkit-overflow-scrolling: touch;
      }
      .phase-nav::-webkit-scrollbar { display: none; }

      .phase-nav-btn {
        background: none;
        border: none;
        border-bottom: 2px solid transparent;
        padding: 10px 12px;
        font-family: 'Barlow', sans-serif;
        font-size: 12px;
        letter-spacing: 1.5px;
        text-transform: uppercase;
        color: var(--text2);
        cursor: pointer;
        white-space: nowrap;
        transition: color .15s, border-color .15s;
        flex-shrink: 0;
      }
      .phase-nav-btn.active {
        color: var(--gold);
        border-bottom-color: var(--gold);
      }

      /* Contenido de fase */
      .phase-content {
        padding: 16px 12px 100px;
      }

      /* Grid de grupos */
      .mobile-groups-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 10px;
      }

      .mobile-group-card {
        background: var(--panel);
        border: 1px solid var(--border);
        border-radius: 10px;
        overflow: hidden;
      }

      .mobile-group-header {
        background: var(--bg3);
        padding: 6px 10px;
        font-family: 'Barlow', sans-serif;
        font-size: 11px;
        letter-spacing: 3px;
        text-transform: uppercase;
        color: var(--text2);
        border-bottom: 1px solid var(--border);
      }

      .mobile-group-ref {
        padding: 6px 10px;
        border-bottom: 1px solid var(--border);
      }

      .mobile-group-ref-team {
        display: flex;
        align-items: center;
        gap: 5px;
        font-family: 'Barlow', sans-serif;
        font-size: 11px;
        color: var(--text2);
        padding: 1px 0;
      }

      .mobile-group-classified {
        padding: 6px 10px;
      }

      .mobile-group-classified-label {
        font-family: 'Barlow', sans-serif;
        font-size: 9px;
        letter-spacing: 2px;
        text-transform: uppercase;
        color: var(--text2);
        margin-bottom: 4px;
      }

      /* Indicador de posición (1º / 2º / 3º) a la derecha del slot */
      .mobile-pos-badge {
        font-family: 'Barlow', sans-serif;
        font-size: 9px;
        font-weight: 700;
        letter-spacing: 1px;
        color: var(--text2);
        margin-left: auto;
        padding-left: 4px;
        flex-shrink: 0;
        white-space: nowrap;
      }

      /* Slot táctil en móvil */
      .mobile-team-slot {
        display: flex;
        align-items: center;
        gap: 7px;
        background: var(--bg2);
        border: 1px solid var(--border);
        border-radius: 6px;
        padding: 7px 10px;
        margin-bottom: 4px;
        cursor: pointer;
        transition: border-color .15s, background .15s;
        min-height: 36px;
        -webkit-tap-highlight-color: transparent;
      }
      .mobile-team-slot:active { background: var(--panel2); }
      .mobile-team-slot.locked { cursor: default; }
      .mobile-team-slot.winner {
        background: var(--win);
        border-color: var(--win-border);
      }
      .mobile-team-slot.empty-slot { opacity: .55; }
      /* En móvil el ✕ siempre visible (sin hover) */
      .mobile-team-slot .slot-clear-btn { display: flex; }
      /* Terceros de R32 en vista móvil usan team-slot, también muestran X siempre */
      .phase-content .team-slot .slot-clear-btn { display: flex; }

      .mobile-team-slot .team-flag { font-size: 17px; }
      .mobile-team-slot .team-name {
        font-family: 'Barlow', sans-serif;
        font-size: 12px;
        color: var(--text);
        flex: 1;
      }
      .mobile-team-slot.winner .team-name { color: var(--green); }
      .mobile-team-slot.empty-slot .team-name { color: var(--text2); font-weight: 400; }

      /* Partidos en fases eliminatorias */
      .mobile-matches-list {
        display: flex;
        flex-direction: column;
        gap: 10px;
      }

      .mobile-match-card {
        background: var(--panel);
        border: 1px solid var(--border);
        border-radius: 10px;
        overflow: hidden;
      }

      .mobile-match-label {
        background: var(--bg3);
        padding: 5px 12px;
        font-family: 'Barlow', sans-serif;
        font-size: 10px;
        letter-spacing: 2px;
        text-transform: uppercase;
        color: var(--text2);
        border-bottom: 1px solid var(--border);
      }

      .mobile-match-slots {
        padding: 8px 10px;
        display: flex;
        flex-direction: column;
        gap: 0;
      }

      .mobile-match-vs {
        text-align: center;
        font-family: 'Bebas Neue', cursive;
        font-size: 11px;
        letter-spacing: 2px;
        color: var(--text2);
        padding: 2px 0;
      }

      /* Campeón móvil */
      .mobile-champion-card {
        background: linear-gradient(135deg, var(--panel), var(--panel2));
        border: 2px solid var(--gold);
        border-radius: 14px;
        padding: 24px 16px;
        text-align: center;
        box-shadow: 0 0 30px color-mix(in srgb, var(--gold) 20%, transparent);
      }

      .mobile-champion-trophy { font-size: 48px; margin-bottom: 8px; }

      .mobile-champion-title {
        font-family: 'Bebas Neue', cursive;
        font-size: 14px;
        letter-spacing: 5px;
        color: var(--gold);
        display: block;
        margin-bottom: 8px;
      }

      .mobile-champion-name {
        font-family: 'Barlow', sans-serif;
        font-size: 22px;
        font-weight: 700;
        color: var(--text);
      }

      .mobile-champion-empty {
        opacity: .35;
      }

      /* Save bar móvil */
      .save-bar {
        padding: 10px 12px;
      }
      .btn-save { font-size: 16px; padding: 10px 20px; flex: 1; }
      .btn-reset { padding: 10px 14px; font-size: 13px; }

      /* View panel */
      .view-panel { padding: 12px; }
      .users-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
      .user-card { padding: 10px 12px; }
      .user-card-name { font-size: 15px; }
    }

    @media (max-width: 900px) {
      /* Desktop bracket hidden, phase view shown */
      .phase-view-wrapper { display: block !important; }
    }


    /* ============================================================
       GUAPURA TAB
       ============================================================ */

    .guapura-panel {
      padding: 20px 24px 80px;
      max-width: 1100px;
      margin: 0 auto;
    }

    .guapura-intro {
      display: flex;
      align-items: center;
      gap: 14px;
      background: var(--panel);
      border: 1px solid var(--border);
      border-radius: 10px;
      padding: 14px 18px;
      margin-bottom: 20px;
      font-family: 'Barlow', sans-serif;
      font-size: 15px;
      color: var(--text2);
    }
    .guapura-intro-icon { font-size: 28px; flex-shrink: 0; }
    .guapura-intro strong { color: var(--text); }

    /* ── Ranking top 10 ── */
    .guapura-ranking-section {
      background: var(--panel);
      border: 1px solid var(--border);
      border-radius: 10px;
      overflow: hidden;
      margin-bottom: 20px;
    }

    .guapura-ranking-title {
      font-family: 'Bebas Neue', cursive;
      font-size: 16px;
      letter-spacing: 3px;
      color: var(--gold);
      padding: 12px 16px 10px;
      border-bottom: 1px solid var(--border);
      background: var(--bg2);
    }

    .guapura-ranking-list { padding: 4px 0; }

    .guapura-ranking-row {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 8px 16px;
      cursor: pointer;
      transition: background .12s;
      border-bottom: 1px solid var(--border);
    }
    .guapura-ranking-row:last-child { border-bottom: none; }
    .guapura-ranking-row:hover { background: var(--panel2); }
    .guapura-ranking-row.active { background: color-mix(in srgb, var(--gold) 8%, var(--panel)); }

    .guapura-ranking-pos {
      font-family: 'Bebas Neue', cursive;
      font-size: 18px;
      min-width: 28px;
      text-align: center;
      color: var(--text2);
      flex-shrink: 0;
    }

    .guapura-ranking-team {
      display: flex;
      align-items: center;
      gap: 8px;
      flex: 1;
      min-width: 0;
    }
    .guapura-ranking-flag { font-size: 18px; flex-shrink: 0; }
    .guapura-ranking-name {
      font-family: 'Barlow', sans-serif;
      font-size: 15px;
      font-weight: 600;
      color: var(--text);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .guapura-ranking-right {
      display: flex;
      flex-direction: column;
      align-items: flex-end;
      flex-shrink: 0;
    }
    .guapura-ranking-avg {
      font-family: 'Bebas Neue', cursive;
      font-size: 20px;
      color: var(--gold);
      line-height: 1;
    }
    .guapura-ranking-count {
      font-family: 'Barlow', sans-serif;
      font-size: 11px;
      color: var(--text2);
      letter-spacing: .5px;
      margin-top: 1px;
    }

    /* Grid de dos columnas (desktop) */
    /* Grid alfabético de equipos */
    .guapura-alpha-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
      gap: 2px;
      margin-bottom: 20px;
    }

    .guapura-team-chip {
      display: flex;
      align-items: center;
      gap: 6px;
      background: var(--panel);
      border: 1px solid var(--border);
      border-radius: 10px;
      padding: 5px 12px 5px 8px;
      cursor: pointer;
      font-family: 'Barlow', sans-serif;
      font-size: 13px;
      color: var(--text2);
      transition: border-color .15s, background .15s, color .15s;
      white-space: nowrap;
    }
    .guapura-team-chip:hover { border-color: var(--gold); color: var(--text); }
    .guapura-team-chip.active {
      border-color: var(--gold);
      background: var(--panel2);
      color: var(--text);
    }
    .guapura-team-chip .chip-name { font-weight: 500; }
    .guapura-team-chip .chip-score {
      font-family: 'Bebas Neue', cursive;
      font-size: 13px;
      color: var(--gold);
      margin-left: 2px;
    }

    /* ── Panel del equipo ── */
    #guapura-team-panel {
      margin-top: 24px;
      /*border-top: 1px solid var(--border);*/
      /*padding-top: 20px;*/
    }

    .guapura-team-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 12px 16px;
      background: var(--bg2);
      border: 1px solid var(--border);
      border-radius: 10px 10px 0 0;
      border-bottom: none;
    }

    .guapura-team-name {
      font-family: 'Barlow', sans-serif;
      font-size: 22px;
      font-weight: 700;
      letter-spacing: 1px;
    }

    .guapura-team-count {
      font-family: 'Barlow', sans-serif;
      font-size: 14px;
      letter-spacing: 1px;
    }

    .guapura-search-btn {
      background: var(--bg3);
      border: 1px solid var(--border);
      border-radius: 6px;
      padding: 6px 12px;
      font-family: 'Barlow', sans-serif;
      font-size: 13px;
      color: var(--text2);
      cursor: pointer;
      transition: border-color .15s, color .15s;
      white-space: nowrap;
      flex-shrink: 0;
    }
    .guapura-search-btn:hover   { border-color: var(--blue); color: var(--blue); }
    .guapura-search-btn.loading { opacity: .6; cursor: wait; }

    /* Tabla (grid) de fotos */
    .guapura-photos-table {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(105px, 1fr));
      gap: 10px;
      padding: 16px;
      background: var(--panel);
      border: 1px solid var(--border);
	  border-top: none;
	  border-radius: 0 0 10px 10px;
      min-height: 80px;
    }

    .guapura-photo-card {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 5px;
	  border: 1px solid var(--border);
	  border-radius: 10px;
    }

    .guapura-photo-card img {
      width: 100%;
      aspect-ratio: 1;
      object-fit: cover;
      border-radius: 10px 10px 0 0;
      border: 1px solid var(--border);
      background: var(--bg3);
    }

    .guapura-photo-name {
      font-family: 'Barlow', sans-serif;
      font-size: 11px;
	  font-weight: bold;
      color: var(--text2);
      text-align: center;
      line-height: 1.2;
    }

    .guapura-photo-data {
      font-family: 'Barlow', sans-serif;
      font-size: 11px;
      color: var(--text2);
      text-align: center;
      line-height: 1.2;
	  margin-bottom: 5px;
    }

    .guapura-empty-photos {
      grid-column: 1/-1;
      text-align: center;
      padding: 24px 12px;
      color: var(--text2);
      font-family: 'Barlow', sans-serif;
      font-size: 14px;
      letter-spacing: 1px;
    }

    /* Slider de guapura */
    .guapura-score-section {
      border: 1px solid var(--border);
      /*border-top: none;*/
      /*border-radius: 0 0 10px 10px;*/
      padding: 14px 16px;
      background: var(--bg2);
    }

    .guapura-score-label {
      font-family: 'Barlow', sans-serif;
      font-size: 12px;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: var(--text2);
      margin-bottom: 10px;
    }

    .guapura-slider-row {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .guapura-slider {
      flex: 1;
      -webkit-appearance: none;
      appearance: none;
      height: 6px;
      border-radius: 3px;
      background: var(--border);
      outline: none;
      cursor: pointer;
    }
    .guapura-slider::-webkit-slider-thumb {
      -webkit-appearance: none;
      width: 22px;
      height: 22px;
      border-radius: 50%;
      background: var(--gold);
      cursor: pointer;
      border: 2px solid var(--bg);
      box-shadow: 0 2px 6px #0004;
    }
    .guapura-slider::-moz-range-thumb {
      width: 22px;
      height: 22px;
      border-radius: 50%;
      background: var(--gold);
      cursor: pointer;
      border: 2px solid var(--bg);
    }

    .guapura-score-value {
      font-family: 'Bebas Neue', cursive;
      font-size: 36px;
      color: var(--gold);
      min-width: 36px;
      text-align: center;
      line-height: 1;
    }

    .guapura-score-stars {
      font-size: 15px;
      letter-spacing: 1px;
      margin-top: 6px;
    }

    .guapura-pick-msg {
      text-align: center;
      padding: 48px 20px;
      color: var(--text2);
      font-family: 'Barlow', sans-serif;
      font-size: 16px;
      letter-spacing: 2px;
    }

    @media (max-width: 900px) {
      .guapura-panel { padding: 12px 10px 80px; }
      .guapura-photos-table { grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); gap: 8px; padding: 10px; }
    }

