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

body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    min-height: 100vh;
    padding: 0;
    margin: 0;
    color: #333;
    overflow-x: auto;
}

/* Layout principal con 3 columnas */
.main-layout {
    display: flex;
    min-height: 100vh;
    max-width: 100%;
    margin: 0 auto;
    gap: 20px;
    padding: 20px;
}

/* Banners laterales */
.sidebar-content {
    display: block;
    width: 160px;
    min-width: 160px;
    position: sticky;
    top: 20px;
    height: fit-content;
    max-height: calc(100vh - 40px);
    overflow-y: auto;
}

.banner-placeholder {
    background: white;
    border-radius: 10px;
    padding: 10px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    position: sticky;
    top: 0;
}

.banner-placeholder p {
    font-size: 0.75em;
    color: #999;
    text-align: center;
    margin-bottom: 8px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.banner-content {
    width: 100%;
    min-height: 600px;
    border-radius: 8px;
    overflow: hidden;
}

/* Contenido principal */
.main-content {
    flex: 1;
    min-width: 0; /* Permite que se comprima */
    max-width: 100%;
    overflow-x: hidden; /* Evita que el contenido se salga */
}

.container {
    max-width: 100%;
    width: 100%;
    margin: 0 auto;
    background: white;
    border-radius: 20px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    overflow: visible;
    box-sizing: border-box;
}

header {
    background: linear-gradient(135deg, #1e3c72 0%, #2a5298 100%);
    color: white;
    padding: 30px;
    text-align: center;
}

header > div {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

.auth-status {
    margin-top: 10px;
}

.usuario-logueado {
    display: flex;
    align-items: center;
    gap: 15px;
    flex-wrap: wrap;
    justify-content: center;
}

.usuario-nombre {
    font-weight: 600;
    font-size: 1em;
    background: rgba(255, 255, 255, 0.2);
    padding: 8px 15px;
    border-radius: 20px;
}

.menu-usuario-container {
    position: relative;
}

.btn-menu-usuario {
    padding: 8px 12px;
    border: 2px solid white;
    border-radius: 20px;
    background: transparent;
    color: white;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
    font-size: 1.2em;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
}

.btn-menu-usuario:hover {
    background: white;
    color: #1e3c72;
    transform: translateY(-2px);
}

.menu-usuario {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background: white;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    min-width: 220px;
    max-width: 280px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.3s ease;
    z-index: 1000;
    overflow: hidden;
}

.menu-usuario.menu-usuario-abierto {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.menu-item {
    width: 100%;
    padding: 10px 16px;
    border: none;
    background: transparent;
    color: #333;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    text-align: left;
    font-size: 0.9em;
    display: flex;
    align-items: center;
    gap: 8px;
}

.menu-item:hover {
    background: #f0f0f0;
    color: #1e3c72;
}

.menu-item-danger {
    color: #dc3545;
}

.menu-item-danger:hover {
    background: #fee;
    color: #c82333;
}

.menu-separador {
    height: 1px;
    background: #e0e0e0;
    margin: 4px 0;
}

.menu-item-toggle {
    width: 100%;
    padding: 10px 16px;
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    transition: all 0.2s;
    border: none;
    background: transparent;
    font-size: 0.9em;
    font-weight: 600;
    color: #333;
}

.menu-item-toggle:hover {
    background: #f0f0f0;
}

.menu-item-toggle input[type="checkbox"] {
    cursor: pointer;
    width: 18px;
    height: 18px;
}

.menu-item-submenu {
    padding: 10px 16px;
}

.menu-item-label {
    font-size: 0.9em;
    font-weight: 600;
    color: #333;
    display: block;
    margin-bottom: 8px;
}

.menu-item-idiomas {
    display: flex;
    gap: 8px;
    flex-direction: column;
}

.menu-item-idioma {
    padding: 6px 12px;
    border: 1px solid #ddd;
    border-radius: 4px;
    background: white;
    color: #666;
    font-size: 0.85em;
    cursor: pointer;
    transition: all 0.2s;
    text-align: center;
}

.menu-item-idioma:hover {
    border-color: #1e3c72;
    color: #1e3c72;
}

.menu-item-idioma.activo {
    background: #1e3c72;
    color: white;
    border-color: #1e3c72;
}

/* Skeleton screens */
.skeleton-grupo {
    animation: skeleton-loading 1.5s ease-in-out infinite;
}

.skeleton-text {
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: skeleton-shimmer 1.5s infinite;
    border-radius: 4px;
}

.skeleton-table td {
    padding: 8px 4px;
}

.skeleton-partido {
    padding: 8px;
    margin-bottom: 6px;
    background: #f9f9f9;
    border-radius: 6px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: center;
}

@keyframes skeleton-shimmer {
    0% {
        background-position: -200% 0;
    }
    100% {
        background-position: 200% 0;
    }
}

@keyframes skeleton-loading {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.7;
    }
}

.btn-login, .btn-registro {
    padding: 8px 16px;
    border: 2px solid white;
    border-radius: 20px;
    background: transparent;
    color: white;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
    font-size: 0.9em;
}

.btn-login:hover, .btn-registro:hover {
    background: white;
    color: #1e3c72;
    transform: translateY(-2px);
}

.usuario-no-logueado {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: center;
}

.btn-registro {
    background: rgba(255, 255, 255, 0.2);
}

.btn-registro:hover {
    background: white;
    color: #1e3c72;
}

header h1 {
    font-size: 2.5em;
    margin-bottom: 10px;
}

.subtitle {
    font-size: 1.1em;
    opacity: 0.9;
}

.tabs {
    display: flex;
    background: #f5f5f5;
    border-bottom: 2px solid #ddd;
    overflow-x: auto;
}

.tab-btn {
    flex: 1;
    padding: 15px 20px;
    border: none;
    background: transparent;
    cursor: pointer;
    font-size: 1em;
    font-weight: 600;
    color: #666;
    transition: all 0.3s;
    border-bottom: 3px solid transparent;
}

.tab-btn:hover {
    background: #e0e0e0;
    color: #333;
}

.tab-btn.active {
    color: #1e3c72;
    border-bottom-color: #1e3c72;
    background: white;
}

.tab-content {
    display: none;
    padding: 30px;
}

.tab-content.active {
    display: block;
}

#bracket-completo.tab-content,
#eliminatorias.tab-content {
    padding: 15px 10px;
    overflow: visible;
    background: linear-gradient(to bottom right, #eff6ff, #dbeafe);
}

#bracket-completo.tab-content h2 {
    text-align: center;
    color: #1e40af;
    margin-bottom: 20px;
    font-size: 1.8em;
    font-weight: 700;
}

#grupos-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 15px;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.grupo {
    background: #f9f9f9;
    border-radius: 12px;
    padding: 15px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    border: 2px solid #e0e0e0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    overflow: visible;
}

.grupo h3 {
    color: #1e3c72;
    margin-bottom: 12px;
    font-size: 1.3em;
    text-align: center;
    padding-bottom: 8px;
    border-bottom: 2px solid #1e3c72;
    font-weight: 700;
}

.tabla-posiciones {
    width: 100%;
    margin-bottom: 15px;
    border-collapse: collapse;
    font-size: 0.85em;
    table-layout: fixed;
    overflow: visible;
}

.tabla-posiciones th {
    background: #1e3c72;
    color: white;
    padding: 8px 4px;
    text-align: center;
    font-size: 0.85em;
    font-weight: 600;
}

.tabla-posiciones th:nth-child(2) {
    width: 35%;
    min-width: 150px;
}

.tabla-posiciones td {
    padding: 8px 5px;
    border-bottom: 1px solid #ddd;
    text-align: center;
    font-size: 0.85em;
}

.tabla-posiciones tr:hover {
    background: #f0f0f0;
}

.tabla-posiciones tr:hover .playoff-select {
    z-index: 20;
}

.pos-1, .pos-2 {
    background: #d4edda !important;
    font-weight: bold;
}

.pos-3 {
    background: #fff3cd !important;
}

.partidos {
    margin-top: 15px;
}

.partidos h4 {
    margin-bottom: 8px;
    color: #666;
    font-size: 1em;
    font-weight: 600;
}

.partido {
    display: flex;
    flex-direction: column;
    padding: 8px;
    margin-bottom: 6px;
    background: white;
    border-radius: 6px;
    border: 1px solid #ddd;
    position: relative;
    gap: 4px;
}

.partido-fecha-horario {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 3px;
    border-bottom: 1px solid #f0f0f0;
    font-size: 0.7em;
    margin-bottom: 2px;
}

.fecha-partido {
    color: #666;
    font-weight: 600;
}

.horario-partido {
    color: #1e3c72;
    font-weight: 700;
    background: #e3f2fd;
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 0.75em;
}

.partido-equipos-resultado {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.equipo {
    flex: 1;
    font-weight: 600;
    text-align: center;
    font-size: 0.85em;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.equipo-local {
    text-align: right;
}

.equipo-visitante {
    text-align: left;
}

.partido .resultado-input {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    gap: 2px;
}

.playoff-select {
    width: 100%;
    padding: 6px 28px 6px 10px;
    border: 1.5px solid #cbd5e1;
    border-radius: 6px;
    font-size: 0.85em;
    font-weight: 600;
    background: white;
    color: #1e3c72;
    cursor: pointer;
    text-align: left;
    transition: all 0.2s ease;
    position: relative;
    z-index: 1;
    pointer-events: auto;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231e3c72' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 12px;
    line-height: 1.4;
}

.playoff-select:hover {
    border-color: #1e3c72;
    background-color: #f8fafc;
    box-shadow: 0 1px 3px rgba(30, 60, 114, 0.1);
}

.playoff-select:focus {
    outline: none;
    border-color: #1e3c72;
    box-shadow: 0 0 0 3px rgba(30, 60, 114, 0.1);
    background-color: white;
}

.playoff-select option {
    padding: 10px 12px;
    font-weight: 600;
    font-size: 0.9em;
    color: #1e3c72;
    background: white;
    line-height: 1.5;
}

.tabla-posiciones .playoff-select {
    width: 95%;
    max-width: 95%;
    margin: 0 auto;
    display: block;
    position: relative;
    z-index: 1;
    pointer-events: auto;
    box-sizing: border-box;
    min-height: 32px;
}

.tabla-posiciones .playoff-select:focus,
.tabla-posiciones .playoff-select:active {
    z-index: 1;
    position: relative;
}

.tabla-posiciones td {
    padding: 8px 5px;
    border-bottom: 1px solid #ddd;
    text-align: center;
    font-size: 0.85em;
    position: relative;
    overflow: hidden;
}

.tabla-posiciones td:has(.playoff-select) {
    text-align: center;
}

.tabla-posiciones td:has(.playoff-select) {
    padding: 8px 6px;
    text-align: center;
    min-width: 150px;
    overflow: hidden;
    z-index: 1;
    max-width: 100%;
}

.resultado-input {
    display: flex;
    align-items: center;
    gap: 3px;
}

.resultado-input input {
    width: 35px;
    padding: 4px;
    text-align: center;
    border: 1.5px solid #ddd;
    border-radius: 4px;
    font-size: 0.85em;
    font-weight: bold;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.resultado-input input.input-invalido {
    border-color: #dc3545;
    box-shadow: 0 0 0 2px rgba(220, 53, 69, 0.25);
    background-color: #fff5f5;
}

.resultado-input input:focus.input-invalido {
    border-color: #dc3545;
    box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.35);
}

.resultado-input input:focus {
    outline: none;
    border-color: #1e3c72;
}

/* Estilos para partidos ya jugados (bloqueados) */
.partido-ya-jugado .resultado-input input,
.bracket-match.partido-ya-jugado .bracket-resultado input {
    background-color: #f5f5f5 !important;
    color: #666 !important;
    cursor: not-allowed !important;
    opacity: 0.7;
    border-color: #ccc !important;
}

.partido-ya-jugado {
    opacity: 0.85;
    position: relative;
}

.partido-ya-jugado::after {
    content: '✓';
    position: absolute;
    top: 5px;
    right: 5px;
    color: #28a745;
    font-weight: bold;
    font-size: 0.9em;
    z-index: 10;
}

.separador {
    font-weight: bold;
    color: #666;
    margin: 0 4px;
    font-size: 0.9em;
}

.eliminatoria-container {
    overflow: visible;
    padding: 15px;
    margin-top: 20px;
    width: 100%;
    background: linear-gradient(to bottom right, #eff6ff, #dbeafe);
    min-height: 600px;
    display: flex;
    justify-content: center;
    align-items: flex-start;
}

.eliminatoria-container::-webkit-scrollbar {
    height: 8px;
}

.eliminatoria-container::-webkit-scrollbar-track {
    background: #e0e7ff;
    border-radius: 10px;
}

.eliminatoria-container::-webkit-scrollbar-thumb {
    background: #3b82f6;
    border-radius: 10px;
}

.bracket {
    display: grid;
    grid-template-columns: repeat(9, minmax(110px, 1fr));
    grid-template-rows: 35px repeat(18, 38px);
    gap: 3px 5px;
    padding: 8px;
    position: relative;
    width: 100%;
    max-width: 100%;
    align-items: start;
    justify-items: center;
    background: linear-gradient(135deg, #e0e7ff 0%, #ddd6fe 100%);
    border-radius: 12px;
    height: fit-content;
    box-sizing: border-box;
}

.bracket-column-title {
    text-align: center;
    font-size: 0.65em;
    font-weight: 700;
    color: #1e40af;
    padding: 3px 2px;
    background: rgba(255, 255, 255, 0.95);
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.2px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
    border: 1px solid rgba(59, 130, 246, 0.2);
}

.bracket-match-wrapper {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    height: 100%;
    padding: 2px 0;
    overflow: visible;
}

.bracket-match {
    background: white;
    border: 1px solid #e5e7eb;
    border-radius: 5px;
    padding: 1px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
    width: 100%;
    min-width: 120px;
    max-width: 100%;
    display: flex;
    flex-direction: column;
    gap: 1px;
    box-sizing: border-box;
    overflow: hidden;
}

.bracket-match-header {
    font-size: 0.7em;
    color: #6b7280;
    padding: 2px 4px;
    margin-bottom: 2px;
    text-align: center;
}

.bracket-team {
    width: 100%;
    padding: 2px;
    border-radius: 3px;
    transition: all 0.15s;
    min-height: 34px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border: 1px solid transparent;
    margin-bottom: 1px;
    background: white;
    flex-shrink: 0;
    box-sizing: border-box;
    overflow: hidden;
}

.bracket-team:last-child {
    margin-bottom: 0;
}

.bracket-team:hover {
    background: #f3f4f6;
}

.bracket-team:hover .bracket-resultado input {
    border-color: #9ca3af;
}

.bracket-team.ganador {
    background: #dcfce7;
    border: 2px solid #22c55e;
    font-weight: 600;
}

.bracket-team-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 1px;
    padding: 0 4px;
}

.bracket-team-nombre {
    font-weight: 500;
    font-size: 0.75em;
    color: #1f2937;
    line-height: 1.2;
}

.bracket-team-posicion {
    font-size: 0.65em;
    color: #6b7280;
    font-weight: 400;
    line-height: 1;
}

.bracket-team.ganador .bracket-team-nombre {
    color: #15803d;
}

.bracket-team.por-definir {
    opacity: 0.5;
}

.bracket-team.por-definir .bracket-team-nombre {
    color: #9ca3af;
    font-style: italic;
}

.bracket-resultado {
    display: flex;
    align-items: center;
    padding: 0 3px;
    pointer-events: auto;
}

.bracket-resultado input {
    width: 30px;
    padding: 2px 1px;
    text-align: center;
    border: 1px solid #d1d5db;
    border-radius: 3px;
    font-size: 0.75em;
    font-weight: 600;
    background: white;
    cursor: text;
    pointer-events: auto;
}

.bracket-resultado input:focus {
    outline: none;
    border-color: #3b82f6;
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}

.bracket-team.ganador .bracket-resultado input {
    border-color: #22c55e;
}

.bracket-separador {
    font-weight: bold;
    color: #666;
    margin: 0 3px;
}

.partido-eliminatoria {
    background: #f9f9f9;
    border-radius: 15px;
    padding: 20px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    border: 2px solid #e0e0e0;
}

.partido-eliminatoria h4 {
    color: #1e3c72;
    margin-bottom: 15px;
    text-align: center;
    font-size: 1.2em;
}

.equipo-eliminatoria {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px;
    margin-bottom: 10px;
    background: white;
    border-radius: 8px;
    border: 1px solid #ddd;
}

.equipo-eliminatoria.ganador {
    background: #d4edda;
    font-weight: bold;
    border-color: #28a745;
}

.equipo-nombre {
    flex: 1;
    font-weight: 600;
}

.resultado-eliminatoria {
    display: flex;
    gap: 5px;
    align-items: center;
}

.resultado-eliminatoria input {
    width: 50px;
    padding: 8px;
    text-align: center;
    border: 2px solid #ddd;
    border-radius: 5px;
    font-size: 1em;
    font-weight: bold;
}

.resultado-eliminatoria input:focus {
    outline: none;
    border-color: #1e3c72;
}

.actions {
    padding: 20px 30px;
    background: #f5f5f5;
    display: flex;
    gap: 15px;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

.actions-left {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
}

.actions-right {
    display: flex;
    gap: 15px;
    align-items: center;
    flex-wrap: wrap;
}

.btn-secondary {
    padding: 12px 24px;
    background: #6c757d;
    color: white;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    font-size: 1em;
    font-weight: 600;
    transition: all 0.3s;
}

.btn-secondary:hover {
    background: #5a6268;
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.btn-primary-api {
    padding: 12px 24px;
    background: #28a745;
    color: white;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    font-size: 1em;
    font-weight: 600;
    transition: all 0.3s;
    display: flex;
    align-items: center;
    gap: 8px;
}

.btn-primary-api:hover {
    background: #218838;
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(40, 167, 69, 0.3);
}

.btn-primary-api:disabled {
    background: #6c757d;
    cursor: not-allowed;
    transform: none;
}

.toggle-auto-update {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    user-select: none;
    font-weight: 500;
    color: #333;
}

.toggle-auto-update input[type="checkbox"] {
    width: 20px;
    height: 20px;
    cursor: pointer;
    accent-color: #28a745;
}

.toggle-auto-update span {
    font-size: 0.95em;
}

/* Media queries ajustadas para considerar los banners */
@media (min-width: 1600px) {
    /* Con banners visibles, ajustar a 3 columnas máximo */
    #grupos-container {
        grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
        max-width: 100%;
    }
}

@media (min-width: 1400px) and (max-width: 1599px) {
    #grupos-container {
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    }
}

@media (min-width: 1024px) and (max-width: 1399px) {
    #grupos-container {
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    }
}

@media (max-width: 768px) {
    header h1 {
        font-size: 1.3em;
    }
    
    #grupos-container {
        grid-template-columns: 1fr;
    }
    
    .tab-btn {
        font-size: 0.85em;
        padding: 12px 8px;
        min-width: 80px;
    }
    
    .eliminatoria-container {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        padding: 10px 5px;
    }
    
    .bracket {
        min-width: 800px;
        gap: 10px 5px;
    }
}

/* Estilos para el Torneo */
.enviar-predicciones-container {
    text-align: center;
    margin-top: 30px;
    padding: 20px;
}

.btn-enviar-predicciones {
    padding: 15px 40px;
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    color: white;
    border: none;
    border-radius: 12px;
    font-size: 1.2em;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}

.btn-enviar-predicciones:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(16, 185, 129, 0.4);
}

.btn-enviar-predicciones:active {
    transform: translateY(0);
}

.torneo-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-top: 20px;
}

.torneo-columna {
    background: #f9f9f9;
    border-radius: 12px;
    padding: 20px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.torneo-columna h3 {
    color: #1e3c72;
    margin-bottom: 20px;
    font-size: 1.5em;
    border-bottom: 3px solid #1e3c72;
    padding-bottom: 10px;
}

.mis-torneos-lista {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.sin-torneos, .sin-datos {
    text-align: center;
    color: #666;
    padding: 30px;
    font-style: italic;
    background: white;
    border-radius: 8px;
}

.torneo-item {
    background: white;
    border-radius: 8px;
    padding: 15px;
    border: 2px solid #e0e0e0;
    transition: all 0.3s;
}

.torneo-item:hover {
    border-color: #1e3c72;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.torneo-item-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.torneo-nombre-clickeable {
    color: #1e3c72;
    margin: 0;
    font-size: 1.6em;
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: all 0.2s;
    user-select: none;
}

.torneo-nombre-clickeable:hover {
    color: #2a5298;
    transform: translateX(2px);
}

.torneo-nombre-texto {
    flex: 1;
}

.torneo-toggle-icon {
    font-size: 0.7em;
    transition: transform 0.3s;
    color: #1e3c72;
}

.torneo-item.expandido .torneo-toggle-icon {
    transform: rotate(0deg);
}

.torneo-item:not(.expandido) .torneo-toggle-icon {
    transform: rotate(-90deg);
}

.torneo-item-content {
    display: block;
    animation: slideDown 0.3s ease-out;
}

@keyframes slideDown {
    from {
        opacity: 0;
        max-height: 0;
    }
    to {
        opacity: 1;
        max-height: 1000px;
    }
}

.torneo-item-header h4 {
    color: #1e3c72;
    margin: 0;
    font-size: 1.2em;
}

.badge-creador {
    background: #10b981;
    color: white;
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 0.8em;
    font-weight: 600;
}

.torneo-item-info {
    margin-bottom: 15px;
    color: #666;
    font-size: 0.9em;
}

.torneo-item-info p {
    margin: 5px 0;
}

.codigo-torneo {
    font-family: 'Courier New', monospace;
    font-weight: 700;
    color: #1e3c72;
    font-size: 1.1em;
    background: #f0f4ff;
    padding: 2px 8px;
    border-radius: 4px;
}

.torneo-item-acciones {
    margin-bottom: 15px;
    padding: 10px 0;
    border-bottom: 1px solid #e0e0e0;
}

.btn-ver-predicciones {
    padding: 10px 20px;
    background: #1e3c72;
    color: white;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    font-size: 0.95em;
    font-weight: 600;
    transition: all 0.3s;
    display: flex;
    align-items: center;
    gap: 8px;
}

.btn-ver-predicciones:hover {
    background: #2a5298;
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(30, 60, 114, 0.3);
}

.torneo-item-participantes {
    background: #f9f9f9;
    padding: 10px;
    border-radius: 6px;
    margin-top: 15px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.torneo-item-participantes h5 {
    margin: 0 0 10px 0;
    color: #1e3c72;
    font-size: 0.9em;
}

.tabla-clasificacion-torneo {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.8em;
    margin-top: 5px;
    background: white;
    border-radius: 6px;
    overflow: visible;
    table-layout: fixed;
    min-width: 500px;
}

.tabla-clasificacion-torneo thead {
    background: #1e3c72;
    color: white;
}

.tabla-clasificacion-torneo th {
    padding: 8px 6px;
    text-align: left;
    font-weight: 600;
    font-size: 0.8em;
    white-space: nowrap;
}

.tabla-clasificacion-torneo th:first-child {
    text-align: center;
    width: 50px;
}

.tabla-clasificacion-torneo th:nth-child(2) {
    width: 35%;
    min-width: 120px;
}

.tabla-clasificacion-torneo th:nth-child(3) {
    text-align: center;
    width: 60px;
}

.tabla-clasificacion-torneo th:nth-child(4),
.tabla-clasificacion-torneo th:nth-child(5),
.tabla-clasificacion-torneo th:nth-child(6) {
    text-align: center;
    width: 80px;
}

.tabla-clasificacion-torneo td {
    padding: 8px 6px;
    border-bottom: 1px solid #e0e0e0;
    font-size: 0.8em;
    background: white;
}

.tabla-clasificacion-torneo td:first-child {
    text-align: center;
    font-weight: 600;
    color: #1e3c72;
}

.tabla-clasificacion-torneo td:nth-child(2) {
    max-width: 150px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.tabla-clasificacion-torneo td:nth-child(n+3) {
    text-align: center;
}

.tabla-clasificacion-torneo tbody tr:hover {
    background: #f0f4ff;
}

.tabla-clasificacion-torneo .mi-fila-torneo {
    background: #e0f2fe !important;
    font-weight: 600;
}

.tabla-clasificacion-torneo .mi-nombre {
    color: #1e3c72;
    font-weight: 700;
}

.torneo-item-participantes ol {
    margin: 0;
    padding-left: 20px;
}

.torneo-item-participantes li {
    margin: 5px 0;
    font-size: 0.9em;
}

.torneo-item-participantes .mas-participantes {
    color: #666;
    font-style: italic;
}

.tabla-global {
    background: white;
    border-radius: 8px;
    overflow: hidden;
}

.tabla-global-table {
    width: 100%;
    border-collapse: collapse;
}

.tabla-global-table thead {
    background: #1e3c72;
    color: white;
}

.tabla-global-table th {
    padding: 12px;
    text-align: left;
    font-weight: 600;
}

.tabla-global-table td {
    padding: 10px 12px;
    border-bottom: 1px solid #e0e0e0;
}

.tabla-global-table tbody tr:hover {
    background: #f0f4ff;
}

.tabla-global-table thead tr:hover {
    background: #1e3c72;
}

.tabla-global-table .mi-fila {
    background: #e0f2fe !important;
    font-weight: 600;
}

.tabla-global-table .pos-1 {
    background: linear-gradient(135deg, #ffd700 0%, #ffed4e 100%) !important;
}

.tabla-global-table .pos-2 {
    background: linear-gradient(135deg, #c0c0c0 0%, #e8e8e8 100%) !important;
}

.tabla-global-table .pos-3 {
    background: linear-gradient(135deg, #cd7f32 0%, #e6a057 100%) !important;
}

@media (max-width: 1024px) {
    .torneo-layout {
        grid-template-columns: 1fr;
    }
}

.torneo-section h3 {
    color: #1e3c72;
    margin-bottom: 15px;
    font-size: 1.3em;
    border-bottom: 2px solid #1e3c72;
    padding-bottom: 8px;
}

.admin-controls {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.btn-admin {
    padding: 12px 20px;
    background: #1e3c72;
    color: white;
    border: none;
    border-radius: 8px;
    font-size: 1em;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
}

.btn-admin:hover {
    background: #2a5298;
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.btn-admin.active {
    background: #10b981;
}

.admin-info {
    color: #10b981;
    font-weight: 600;
    font-size: 0.9em;
    margin-top: 5px;
}

.agregar-participante {
    display: flex;
    gap: 10px;
    margin-bottom: 20px;
}

.agregar-participante input {
    flex: 1;
    padding: 10px 15px;
    border: 2px solid #ddd;
    border-radius: 8px;
    font-size: 1em;
}

.agregar-participante input:focus {
    outline: none;
    border-color: #1e3c72;
}

.btn-primary {
    padding: 10px 20px;
    background: #1e3c72;
    color: white;
    border: none;
    border-radius: 8px;
    font-size: 1em;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
}

.btn-primary:hover {
    background: #2a5298;
    transform: translateY(-2px);
}

.participantes-lista {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.sin-participantes {
    text-align: center;
    color: #666;
    padding: 20px;
    font-style: italic;
}

.participante-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 15px;
    background: white;
    border-radius: 8px;
    border: 2px solid #e0e0e0;
    transition: all 0.3s;
}

.participante-item:hover {
    border-color: #1e3c72;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.participante-info {
    display: flex;
    align-items: center;
    gap: 15px;
    flex: 1;
}

.participante-posicion {
    font-weight: 700;
    color: #1e3c72;
    min-width: 30px;
    font-size: 1.1em;
}

.participante-nombre {
    font-weight: 600;
    font-size: 1em;
    flex: 1;
}

.participante-puntos {
    font-weight: 700;
    color: #10b981;
    font-size: 1.1em;
}

.btn-eliminar {
    padding: 6px 12px;
    background: #ef4444;
    color: white;
    border: none;
    border-radius: 6px;
    font-size: 0.9em;
    cursor: pointer;
    transition: all 0.3s;
}

.btn-eliminar:hover {
    background: #dc2626;
    transform: scale(1.05);
}

.leaderboard {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.leaderboard-item {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 15px;
    background: white;
    border-radius: 8px;
    border: 2px solid #e0e0e0;
    transition: all 0.3s;
}

.leaderboard-item.pos-1 {
    background: linear-gradient(135deg, #ffd700 0%, #ffed4e 100%);
    border-color: #ffd700;
    font-weight: 700;
    box-shadow: 0 4px 12px rgba(255, 215, 0, 0.3);
}

.leaderboard-item.pos-2 {
    background: linear-gradient(135deg, #c0c0c0 0%, #e8e8e8 100%);
    border-color: #c0c0c0;
    font-weight: 700;
    box-shadow: 0 4px 12px rgba(192, 192, 192, 0.3);
}

.leaderboard-item.pos-3 {
    background: linear-gradient(135deg, #cd7f32 0%, #e6a057 100%);
    border-color: #cd7f32;
    font-weight: 700;
    box-shadow: 0 4px 12px rgba(205, 127, 50, 0.3);
}

.leaderboard-pos {
    font-weight: 700;
    font-size: 1.2em;
    min-width: 40px;
    text-align: center;
}

.leaderboard-nombre {
    flex: 1;
    font-weight: 600;
    font-size: 1.1em;
}

.leaderboard-puntos {
    font-weight: 700;
    font-size: 1.2em;
    color: #1e3c72;
}

.resultado-real {
    position: relative;
    border: 2px solid #10b981 !important;
    background: #f0fdf4 !important;
}

.resultado-real-badge {
    position: absolute;
    top: -10px;
    right: 10px;
    background: #10b981;
    color: white;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 0.7em;
    font-weight: 700;
    z-index: 5;
}

/* Selector de participante en grupos */
.selector-participante {
    background: #f0f4ff;
    padding: 15px;
    border-radius: 8px;
    margin-bottom: 20px;
    border: 2px solid #1e3c72;
}

.selector-participante label {
    display: block;
    margin-bottom: 8px;
    font-weight: 600;
    color: #1e3c72;
}

.selector-participante select {
    width: 100%;
    padding: 10px;
    border: 2px solid #1e3c72;
    border-radius: 6px;
    font-size: 1em;
    font-weight: 600;
    background: white;
    cursor: pointer;
}

/* Estilos para Modal Personalizado */
.modal-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(4px);
    z-index: 10000;
    align-items: center;
    justify-content: center;
    animation: fadeIn 0.2s ease-out;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

.modal-container {
    background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    width: 90%;
    max-width: 500px;
    max-height: 90vh;
    overflow: hidden;
    animation: slideUp 0.3s ease-out;
    border: 2px solid #1e3c72;
}

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

.modal-header {
    background: linear-gradient(135deg, #1e3c72 0%, #2a5298 100%);
    color: white;
    padding: 20px 25px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 3px solid rgba(255, 255, 255, 0.2);
}

.modal-header h3 {
    margin: 0;
    font-size: 1.4em;
    font-weight: 700;
}

.modal-close {
    background: transparent;
    border: none;
    color: white;
    font-size: 2em;
    cursor: pointer;
    padding: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: all 0.2s;
    line-height: 1;
}

.modal-close:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: rotate(90deg);
}

.modal-body {
    padding: 25px;
}

.modal-body p {
    margin: 0 0 20px 0;
    color: #333;
    font-size: 1.1em;
    line-height: 1.6;
    white-space: pre-line;
}

.modal-input-wrapper {
    display: flex;
    align-items: center;
    position: relative;
    width: 100%;
    margin-top: 15px;
}

.modal-input {
    width: 100%;
    padding: 12px 45px 12px 15px;
    border: 2px solid #ddd;
    border-radius: 8px;
    font-size: 1em;
    font-weight: 500;
    transition: all 0.3s;
    box-sizing: border-box;
    font-family: inherit;
    background: white;
    pointer-events: auto !important;
    opacity: 1 !important;
}

.modal-input:focus {
    outline: none;
    border-color: #1e3c72;
    box-shadow: 0 0 0 3px rgba(30, 60, 114, 0.1);
}

.modal-input:disabled {
    background: #f5f5f5;
    cursor: not-allowed;
}

.modal-toggle-password {
    position: absolute;
    right: 10px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2em;
    transition: transform 0.2s;
    z-index: 10;
}

.modal-toggle-password:hover {
    transform: scale(1.1);
}

.modal-toggle-password:active {
    transform: scale(0.95);
}

.eye-icon {
    user-select: none;
    pointer-events: none;
}

/* Responsive: Ocultar banners progresivamente según el ancho de pantalla */

/* Ocultar la barra izquierda entre 698px y 900px (solo barra derecha visible) */
@media (min-width: 698px) and (max-width: 900px) {
    .sidebar-content.sidebar-left {
        display: none !important;
        width: 0 !important;
        min-width: 0 !important;
    }
}

/* En móvil (< 698px), asegurar que no haya publicidad (ambas ocultas) */
@media (max-width: 697px) {
    .sidebar-content {
        display: none !important;
        width: 0 !important;
        min-width: 0 !important;
    }
    
    .main-layout {
        padding: 5px;
        gap: 0;
    }
    
    .main-content {
        width: 100%;
    }
}

/* Ajustes para tablets */
@media (min-width: 768px) and (max-width: 1200px) {
    .main-layout {
        gap: 15px;
        padding: 15px;
    }
}

/* Ajustes para móviles */
@media (max-width: 767px) {
    body {
        padding: 0;
        font-size: 14px;
    }
    
    .main-layout {
        padding: 5px;
        gap: 0;
    }
    
    .container {
        border-radius: 10px;
        margin: 5px;
    }
    
    /* Header móvil */
    header {
        padding: 15px 10px;
    }
    
    header h1 {
        font-size: 1.3em !important;
        margin-bottom: 5px;
    }
    
    .subtitle {
        font-size: 0.85em;
        margin-bottom: 10px;
    }
    
    .auth-status {
        width: 100%;
        margin-top: 10px;
    }
    
    .usuario-logueado,
    .usuario-no-logueado {
        flex-direction: row;
        width: 100%;
        gap: 8px;
        justify-content: space-between;
        align-items: center;
    }
    
    .btn-login,
    .btn-registro {
        width: 100%;
        font-size: 0.85em;
        padding: 8px 12px;
    }
    
    .usuario-nombre {
        font-size: 0.9em;
        padding: 0;
        background: transparent;
        border-radius: 0;
        text-align: left;
        flex: 1;
    }
    
    .menu-usuario-container {
        position: relative;
    }
    
    .btn-menu-usuario {
        width: 36px;
        height: 36px;
        font-size: 1em;
        padding: 0;
    }
    
    .menu-usuario {
        right: 0;
        min-width: 160px;
    }
    
    .menu-item {
        font-size: 0.85em;
        padding: 10px 14px;
    }
    
    /* Tabs móvil */
    .tabs {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    
    .tab-btn {
        font-size: 0.85em;
        padding: 12px 8px;
        min-width: 80px;
        white-space: nowrap;
    }
    
    .tab-content {
        padding: 15px 10px;
    }
    
    /* Grupos móvil */
    #grupos-container {
        grid-template-columns: 1fr !important;
        gap: 10px;
    }
    
    .grupo {
        padding: 12px;
    }
    
    .grupo h3 {
        font-size: 1.4em;
        margin-bottom: 10px;
    }
    
    .tabla-posiciones {
        font-size: 0.9em;
    }
    
    .tabla-posiciones th,
    .tabla-posiciones td {
        padding: 8px 4px;
        font-size: 0.9em;
    }
    
    .partido {
        padding: 8px;
        margin-bottom: 5px;
        flex-wrap: wrap;
    }
    
    .equipo {
        font-size: 0.85em;
        min-width: 80px;
    }
    
    .resultado-input input {
        width: 35px;
        padding: 5px;
        font-size: 0.9em;
    }
    
    /* Bracket móvil - Diseño vertical apilado */
    .eliminatoria-container {
        padding: 10px;
        overflow-x: visible;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        justify-content: flex-start;
        align-items: flex-start;
    }
    
    .bracket {
        display: grid !important;
        grid-template-columns: 1fr 1fr 1fr 1fr 1fr !important;
        grid-auto-rows: min-content !important;
        width: 100% !important;
        min-width: 100% !important;
        max-width: 100% !important;
        gap: 36px 8px !important;
        padding: 10px !important;
        align-items: start !important;
        justify-items: stretch !important;
        background: transparent !important;
        overflow: visible !important;
    }
    
    /* Asegurar que todos los elementos del bracket sean visibles en móvil */
    .bracket > * {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
    }
    
    /* Ocultar títulos duplicados, mostrar solo uno por ronda */
    .bracket-column-title {
        display: none !important;
        grid-area: unset !important;
    }
    
    /* Mostrar solo los títulos de dieciseisavos y octavos en móvil - alineados a la misma altura */
    /* SOBRESCRIBIR el grid-area inline del JavaScript */
    .bracket-column-title[data-ronda="dieciseisavos"][data-col="1"] {
        display: block !important;
        grid-area: 1 / 1 / 2 / 2 !important;
        font-size: 1em;
        font-weight: 700;
        color: #1e40af;
        padding: 12px 0 8px 0;
        margin: 0 0 10px 0;
        text-align: left;
        border-bottom: 2px solid #1e40af;
        width: 100%;
        background: transparent;
        box-shadow: none;
        border-top: none;
        border-left: none;
        border-right: none;
        border-radius: 0;
        position: relative;
        align-self: start !important;
    }
    
    .bracket-column-title[data-ronda="octavos"][data-col="2"] {
        display: block !important;
        grid-area: 1 / 2 / 2 / 3 !important;
        font-size: 1em;
        font-weight: 700;
        color: #1e40af;
        padding: 12px 0 8px 0;
        margin: 0 0 10px 0;
        text-align: left;
        border-bottom: 2px solid #1e40af;
        width: 100%;
        background: transparent;
        box-shadow: none;
        border-top: none;
        border-left: none;
        border-right: none;
        border-radius: 0;
        position: relative;
        align-self: start !important;
    }
    
    /* Mostrar título de cuartos en la tercera columna */
    .bracket-column-title[data-ronda="cuartos"][data-col="3"] {
        display: block !important;
        grid-area: 1 / 3 / 2 / 4 !important;
        font-size: 1em;
        font-weight: 700;
        color: #1e40af;
        padding: 12px 0 8px 0;
        margin: 0 0 10px 0;
        text-align: left;
        border-bottom: 2px solid #1e40af;
        width: 100%;
        background: transparent;
        box-shadow: none;
        border-top: none;
        border-left: none;
        border-right: none;
        border-radius: 0;
        position: relative;
        align-self: start !important;
    }
    
    /* Mostrar título de semifinales en la cuarta columna */
    .bracket-column-title[data-ronda="semifinales"][data-col="4"] {
        display: block !important;
        grid-area: 1 / 4 / 2 / 5 !important;
        font-size: 1em;
        font-weight: 700;
        color: #1e40af;
        padding: 12px 0 8px 0;
        margin: 0 0 10px 0;
        text-align: left;
        border-bottom: 2px solid #1e40af;
        width: 100%;
        background: transparent;
        box-shadow: none;
        border-top: none;
        border-left: none;
        border-right: none;
        border-radius: 0;
        position: relative;
        align-self: start !important;
    }
    
    /* Mostrar título de final en la quinta columna */
    .bracket-column-title[data-ronda="final"][data-col="5"] {
        display: block !important;
        grid-area: 1 / 5 / 2 / 6 !important;
        font-size: 1em;
        font-weight: 700;
        color: #1e40af;
        padding: 12px 0 8px 0;
        margin: 0 0 10px 0;
        text-align: left;
        border-bottom: 2px solid #1e40af;
        width: 100%;
        background: transparent;
        box-shadow: none;
        border-top: none;
        border-left: none;
        border-right: none;
        border-radius: 0;
        position: relative;
        align-self: start !important;
    }
    
    /* Reorganizar partidos verticalmente usando data attributes */
    .bracket-match-wrapper {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        /* SOBRESCRIBIR completamente el gridArea inline del JavaScript en móvil */
        /* Usar grid-row-start, grid-row-end, grid-column-start, grid-column-end en lugar de grid-area */
        grid-area: unset !important;
        grid-row-start: auto !important;
        grid-row-end: auto !important;
        grid-column-start: auto !important;
        grid-column-end: auto !important;
        position: relative !important;
        /* Asegurar que todos los partidos sean visibles */
        visibility: visible !important;
        opacity: 1 !important;
        height: auto !important;
        min-height: auto !important;
        max-height: none !important;
        overflow: visible !important;
        /* Resetear cualquier estilo que pueda ocultar elementos */
        clip: unset !important;
        clip-path: unset !important;
        padding: 0 !important;
        /* Asegurar que cada wrapper tenga su propio espacio en el grid */
        box-sizing: border-box !important;
    }
    
    /* Agrupar partidos por ronda usando grid-column */
    /* Dieciseisavos: todos en columna 1, ordenados por índice (0-15) */
    .bracket-match-wrapper[data-fase="dieciseisavos"] {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        /* Forzar que cada partido ocupe solo una fila */
        grid-row: auto !important;
    }
    
    /* Ordenar dieciseisavos por índice usando grid-row */
    /* Cada partido ocupa su propia fila única en la columna 1 - sin solapamiento */
    /* IMPORTANTE: Sobrescribir el gridArea inline del JavaScript que usa span 2 */
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="0"] { 
        grid-column: 1 !important;
        grid-row: 2 !important;
        grid-row-end: 3 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="1"] { 
        grid-column: 1 !important;
        grid-row: 3 !important;
        grid-row-end: 4 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="2"] { 
        grid-column: 1 !important;
        grid-row: 4 !important;
        grid-row-end: 5 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="3"] { 
        grid-column: 1 !important;
        grid-row: 5 !important;
        grid-row-end: 6 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="4"] { 
        grid-column: 1 !important;
        grid-row: 6 !important;
        grid-row-end: 7 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="5"] { 
        grid-column: 1 !important;
        grid-row: 7 !important;
        grid-row-end: 8 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="6"] { 
        grid-column: 1 !important;
        grid-row: 8 !important;
        grid-row-end: 9 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="7"] { 
        grid-column: 1 !important;
        grid-row: 9 !important;
        grid-row-end: 10 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="8"] { 
        grid-column: 1 !important;
        grid-row: 10 !important;
        grid-row-end: 11 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="9"] { 
        grid-column: 1 !important;
        grid-row: 11 !important;
        grid-row-end: 12 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="10"] { 
        grid-column: 1 !important;
        grid-row: 12 !important;
        grid-row-end: 13 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="11"] { 
        grid-column: 1 !important;
        grid-row: 13 !important;
        grid-row-end: 14 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="12"] { 
        grid-column: 1 !important;
        grid-row: 14 !important;
        grid-row-end: 15 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="13"] { 
        grid-column: 1 !important;
        grid-row: 15 !important;
        grid-row-end: 16 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="14"] { 
        grid-column: 1 !important;
        grid-row: 16 !important;
        grid-row-end: 17 !important;
    }
    .bracket-match-wrapper[data-fase="dieciseisavos"][data-index="15"] { 
        grid-column: 1 !important;
        grid-row: 17 !important;
        grid-row-end: 18 !important;
    }
    
    /* Octavos: todos en columna 2, posicionados entre los partidos de dieciseisavos correspondientes */
    .bracket-match-wrapper[data-fase="octavos"] {
        grid-column: 2 / span 1 !important;
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        /* Ajustar el gap solo entre partidos de octavos - puedes cambiar este valor */
        margin-bottom: 10px !important;
    }
    
    /* Ordenar octavos: cada uno centrado entre dos partidos de dieciseisavos */
    /* Octavos 0: entre dieciseisavos 0 (fila 2) y 1 (fila 3) → fila 3, centrado */
    .bracket-match-wrapper[data-fase="octavos"][data-index="0"] { 
        grid-row: 3 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    /* Octavos 1: entre dieciseisavos 2 (fila 4) y 3 (fila 5) → fila 5 */
    .bracket-match-wrapper[data-fase="octavos"][data-index="1"] { 
        grid-row: 5 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    /* Octavos 2: entre dieciseisavos 4 (fila 6) y 5 (fila 7) → fila 7 */
    .bracket-match-wrapper[data-fase="octavos"][data-index="2"] { 
        grid-row: 7 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    /* Octavos 3: entre dieciseisavos 6 (fila 8) y 7 (fila 9) → fila 9 */
    .bracket-match-wrapper[data-fase="octavos"][data-index="3"] { 
        grid-row: 9 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    /* Octavos 4: entre dieciseisavos 8 (fila 10) y 9 (fila 11) → fila 11 */
    .bracket-match-wrapper[data-fase="octavos"][data-index="4"] { 
        grid-row: 11 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    /* Octavos 5: entre dieciseisavos 10 (fila 12) y 11 (fila 13) → fila 13 */
    .bracket-match-wrapper[data-fase="octavos"][data-index="5"] { 
        grid-row: 13 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    /* Octavos 6: entre dieciseisavos 12 (fila 14) y 13 (fila 15) → fila 15 */
    .bracket-match-wrapper[data-fase="octavos"][data-index="6"] { 
        grid-row: 15 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    /* Octavos 7: entre dieciseisavos 14 (fila 16) y 15 (fila 17) → fila 17 */
    .bracket-match-wrapper[data-fase="octavos"][data-index="7"] { 
        grid-row: 17 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    
    /* Mostrar cuartos en la tercera columna */
    .bracket-match-wrapper[data-fase="cuartos"] {
        grid-column: 3 / span 1 !important;
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        margin-bottom: 10px !important;
    }
    
    /* Cuartos: todos en columna 3, posicionados entre los partidos de octavos correspondientes */
    /* Cuartos 0: entre octavos 0 (fila 3) y octavos 1 (fila 5) → fila 4 */
    .bracket-match-wrapper[data-fase="cuartos"][data-index="0"] { 
        grid-row: 4 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    /* Cuartos 1: entre octavos 2 (fila 7) y octavos 3 (fila 9) → fila 8 */
    .bracket-match-wrapper[data-fase="cuartos"][data-index="1"] { 
        grid-row: 8 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    /* Cuartos 2: entre octavos 4 (fila 11) y octavos 5 (fila 13) → fila 12 */
    .bracket-match-wrapper[data-fase="cuartos"][data-index="2"] { 
        grid-row: 12 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    /* Cuartos 3: entre octavos 6 (fila 15) y octavos 7 (fila 17) → fila 16 */
    .bracket-match-wrapper[data-fase="cuartos"][data-index="3"] { 
        grid-row: 16 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    
    /* Mostrar semis en la cuarta columna */
    .bracket-match-wrapper[data-fase="semis"] {
        grid-column: 4 / span 1 !important;
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        margin-bottom: 10px !important;
    }
    
    /* Semis: todos en columna 4, posicionados entre los partidos de cuartos correspondientes */
    /* Semis 0: entre cuartos 0 (fila 4) y cuartos 1 (fila 8) → fila 6 */
    .bracket-match-wrapper[data-fase="semis"][data-index="0"] { 
        grid-row: 6 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    /* Semis 1: entre cuartos 2 (fila 12) y cuartos 3 (fila 16) → fila 14 */
    .bracket-match-wrapper[data-fase="semis"][data-index="1"] { 
        grid-row: 14 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    
    /* Mostrar final en la quinta columna */
    .bracket-match-wrapper[data-fase="final"] {
        grid-column: 5 / span 1 !important;
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        margin-bottom: 10px !important;
    }
    
    /* Final: en columna 5, posicionado entre los dos partidos de semis (fila 6 y 14) → fila 10 */
    .bracket-match-wrapper[data-fase="final"][data-index="0"] { 
        grid-row: 10 !important;
        align-self: center !important;
        margin-top: -20px !important;
    }
    
    /* Ordenar títulos de columna para que aparezcan antes de sus partidos */
    /* En móvil: dieciseisavos en columna 1, octavos en columna 2 */
    .bracket-column-title[data-ronda="dieciseisavos"][data-col="1"] {
        grid-column: 1 / span 1 !important;
        grid-row: 1 !important;
    }
    
    
    .bracket-match {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        padding: 3px 4px !important;
        margin: 0 !important;
        /* Asegurar que cada partido tenga su propio espacio */
        box-sizing: border-box !important;
        height: auto !important;
        min-height: fit-content !important;
        /* Mantener el estilo de bracket: fondo blanco, bordes, sombra */
        background: white !important;
        border: 1px solid #e5e7eb !important;
        border-radius: 4px !important;
        box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08) !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 0 !important;
    }
    
    .bracket-team {
        min-height: 28px;
        padding: 3px 3px;
        width: 100%;
        /* Mantener estilo de bracket */
        background: white !important;
        border: 1px solid transparent !important;
        border-radius: 2px !important;
        margin-bottom: 0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 3px;
    }
    
    .bracket-team:last-child {
        margin-bottom: 0 !important;
    }
    
    .bracket-team:hover {
        background: #f3f4f6 !important;
    }
    
    .bracket-team.ganador {
        background: #dcfce7 !important;
        border: 1.5px solid #22c55e !important;
        font-weight: 600 !important;
    }
    
    .bracket-team-info {
        flex: 1;
        display: flex;
        flex-direction: column;
        gap: 0;
        padding: 0 1px;
        min-width: 0; /* Permite que el texto se trunque si es necesario */
    }
    
    .bracket-team-nombre {
        font-size: 0.75em;
        font-weight: 500;
        color: #1f2937;
        line-height: 1.1;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    
    .bracket-team-posicion {
        font-size: 0.6em;
        color: #6b7280;
        font-weight: 400;
        line-height: 1;
        margin-top: 0;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    
    .bracket-team.ganador .bracket-team-nombre {
        color: #15803d !important;
    }
    
    .bracket-resultado {
        flex-shrink: 0;
        margin-left: auto;
        display: flex;
        align-items: center;
        padding: 0 1px;
    }
    
    .bracket-resultado input {
        width: 32px;
        font-size: 0.7em;
        padding: 2px 1px;
        min-height: 24px;
        text-align: center;
        border: 1px solid #d1d5db;
        border-radius: 2px;
        font-weight: 600;
        background: white;
    }
    
    .bracket-resultado input:focus {
        outline: none;
        border-color: #3b82f6;
        box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
    }
    
    .bracket-team.ganador .bracket-resultado input {
        border-color: #22c55e;
    }
    
    /* Reducir espacio entre rondas */
    .bracket-column-title[data-ronda="dieciseisavos"][data-col="1"],
    .bracket-column-title[data-ronda="octavos"][data-col="2"],
    .bracket-column-title[data-ronda="cuartos"][data-col="3"],
    .bracket-column-title[data-ronda="semifinales"][data-col="4"],
    .bracket-column-title[data-ronda="final"][data-col="5"] {
        margin: 0 0 8px 0;
        padding: 10px 0 6px 0;
        font-size: 0.95em;
    }
    
    .bracket-column-title[data-ronda="dieciseisavos"][data-col="1"] {
        margin-top: 0;
    }
    
    /* Torneo móvil */
    .torneo-layout {
        grid-template-columns: 1fr !important;
        gap: 15px;
    }
    
    .torneo-item {
        padding: 12px;
    }
    
    .torneo-item-header h4 {
        font-size: 1.2em;
    }
    
    .tabla-clasificacion-torneo,
    .tabla-global {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        max-width: 100%;
    }
    
    .tabla-global-table {
        font-size: 0.8em;
        width: 100%;
        min-width: 100%;
        display: table;
        border-collapse: collapse;
    }
    
    .tabla-clasificacion-torneo {
        display: table;
        width: 100%;
    }
    
    .tabla-clasificacion-torneo thead,
    .tabla-clasificacion-torneo tbody {
        display: table-row-group;
    }
    
    .tabla-clasificacion-torneo tr {
        display: table-row;
    }
    
    .tabla-clasificacion-torneo th,
    .tabla-clasificacion-torneo td {
        display: table-cell;
    }
    
    .tabla-global-table thead,
    .tabla-global-table tbody {
        display: table-header-group;
    }
    
    .tabla-global-table tbody {
        display: table-row-group;
    }
    
    .tabla-clasificacion-torneo th,
    .tabla-clasificacion-torneo td {
        padding: 8px 6px;
        font-size: 0.75em;
        white-space: nowrap;
    }
    
    .tabla-global-table th {
        padding: 10px 8px;
        font-size: 0.85em;
        text-align: left;
        white-space: nowrap;
    }
    
    .tabla-global-table td {
        padding: 8px;
        font-size: 0.8em;
        white-space: nowrap;
    }
    
    /* Hacer las columnas más compactas en móvil */
    .tabla-global-table th:nth-child(1),
    .tabla-global-table td:nth-child(1) {
        width: 15%;
        min-width: 50px;
    }
    
    .tabla-global-table th:nth-child(2),
    .tabla-global-table td:nth-child(2) {
        width: 40%;
        min-width: 100px;
    }
    
    .tabla-global-table th:nth-child(3),
    .tabla-global-table td:nth-child(3) {
        width: 25%;
        min-width: 80px;
    }
    
    .tabla-global-table th:nth-child(4),
    .tabla-global-table td:nth-child(4) {
        width: 20%;
        min-width: 60px;
    }
    
    /* Botones móvil */
    .actions {
        padding: 15px 10px;
        flex-direction: column;
        gap: 10px;
    }
    
    .actions-left,
    .actions-right {
        width: 100%;
        flex-direction: column;
    }
    
    .btn-secondary,
    .btn-primary-api {
        width: 100%;
        padding: 10px 16px;
        font-size: 0.9em;
    }
    
    .btn-enviar-predicciones {
        width: 100%;
        padding: 12px 20px;
        font-size: 1em;
    }
    
    .btn-ver-predicciones {
        width: 100%;
        padding: 10px 16px;
        font-size: 0.9em;
    }
    
    /* Modales móvil */
    .modal-container {
        width: 95%;
        max-width: 95%;
        margin: 10px;
    }
    
    .modal-header {
        padding: 15px;
    }
    
    .modal-header h3 {
        font-size: 1.2em;
    }
    
    .modal-body {
        padding: 15px;
    }
    
    .modal-body p {
        font-size: 1em;
    }
    
    .modal-footer {
        padding: 15px;
        flex-direction: column;
        gap: 10px;
    }
    
    .modal-btn {
        width: 100%;
    }
    
    .modal-predicciones {
        width: 100%;
        max-width: 100%;
        max-height: 95vh;
        margin: 0;
        border-radius: 10px;
    }
    
    .modal-predicciones-header {
        padding: 15px;
    }
    
    .modal-predicciones-header h2 {
        font-size: 1.2em;
    }
    
    .modal-predicciones-body {
        padding: 15px 10px;
    }
    
    .predicciones-container-solo-lectura {
        grid-template-columns: 1fr;
        gap: 15px;
    }
    
    /* Playoff select móvil */
    .playoff-select {
        min-width: 120px;
        max-width: 120px;
        font-size: 0.8em;
        padding: 6px 8px;
    }
    
    /* Títulos y textos móvil */
    .torneo-section h3 {
        font-size: 1.1em;
    }
    
    .torneo-columna h3 {
        font-size: 1.1em;
    }
    
    .eliminatoria-container h2 {
        font-size: 1.3em;
    }
    
    /* Mejoras de espaciado */
    .grupo h3 {
        font-size: 1.1em;
        margin-bottom: 8px;
    }
    
    .partido {
        gap: 5px;
    }
    
    /* Inputs más grandes en móvil para mejor usabilidad */
    .modal-input {
        font-size: 16px; /* Previene zoom en iOS */
        padding: 12px;
    }
    
    /* Mejorar visibilidad de botones en móvil */
    .btn-enviar-predicciones,
    .btn-ver-predicciones,
    .btn-secondary,
    .btn-primary-api {
        min-height: 44px; /* Tamaño mínimo táctil recomendado */
    }
}

/* Estilos para modal de predicciones solo lectura */
.modal-predicciones-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(4px);
    z-index: 10001;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    overflow-y: auto;
}

.modal-predicciones {
    background: white;
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    width: 100%;
    max-width: 1400px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    animation: slideUp 0.3s ease-out;
}

.modal-predicciones-header {
    background: linear-gradient(135deg, #1e3c72 0%, #2a5298 100%);
    color: white;
    padding: 20px 25px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-radius: 16px 16px 0 0;
}

.modal-predicciones-header h2 {
    margin: 0;
    font-size: 1.5em;
}

.modal-predicciones-cerrar {
    background: transparent;
    border: none;
    color: white;
    font-size: 2em;
    cursor: pointer;
    padding: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: all 0.2s;
}

.modal-predicciones-cerrar:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: rotate(90deg);
}

.modal-predicciones-body {
    padding: 25px;
    overflow-y: auto;
    flex: 1;
}

.modal-predicciones-info {
    background: #f0f4ff;
    padding: 12px 15px;
    border-radius: 8px;
    margin-bottom: 20px;
    color: #1e3c72;
    font-size: 0.95em;
    border-left: 4px solid #1e3c72;
}

.predicciones-container-solo-lectura {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 20px;
}

.grupo-solo-lectura {
    background: #f9f9f9;
    border-radius: 12px;
    padding: 15px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    border: 2px solid #e0e0e0;
}

.grupo-solo-lectura h3 {
    color: #1e3c72;
    margin-bottom: 12px;
    font-size: 1.2em;
    text-align: center;
    padding-bottom: 8px;
    border-bottom: 2px solid #1e3c72;
}

.tabla-solo-lectura {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.85em;
    margin-bottom: 15px;
    background: white;
}

.tabla-solo-lectura th {
    background: #1e3c72;
    color: white;
    padding: 8px 4px;
    text-align: center;
    font-size: 0.85em;
    font-weight: 600;
}

.tabla-solo-lectura td {
    padding: 8px 5px;
    border-bottom: 1px solid #ddd;
    text-align: center;
    font-size: 0.85em;
    background: #fafafa;
    color: #666;
}

.partidos-solo-lectura h4 {
    margin-bottom: 10px;
    color: #666;
    font-size: 1em;
    font-weight: 600;
}

.partido-solo-lectura {
    display: flex;
    flex-direction: column;
    padding: 8px;
    margin-bottom: 8px;
    background: white;
    border-radius: 6px;
    border: 1.5px solid #e0e0e0;
    gap: 6px;
}

.partido-solo-lectura.puntos-exacto {
    border-color: #28a745;
    background: #f0fff4;
    border-width: 2px;
}

.partido-solo-lectura.puntos-acertado {
    border-color: #ffc107;
    background: #fffef0;
    border-width: 2px;
}

.partido-solo-lectura.puntos-error {
    border-color: #dc3545;
    background: #fff5f5;
    border-width: 2px;
}

.partido-comparacion-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2px;
}

.partido-solo-lectura .equipo-nombre {
    font-weight: 600;
    text-align: left;
    color: #333;
    font-size: 0.85em;
    line-height: 1.2;
}

.equipos-nombres {
    font-weight: 600;
    text-align: left;
    color: #333;
    font-size: 0.85em;
    line-height: 1.2;
    flex: 1;
}

.puntos-badge {
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 0.7em;
    font-weight: bold;
    color: white;
    white-space: nowrap;
}

.puntos-badge.puntos-exacto {
    background: #28a745;
}

.puntos-badge.puntos-acertado {
    background: #ffc107;
    color: #333;
}

.puntos-badge.puntos-error {
    background: #dc3545;
}

.resultado-comparacion {
    display: flex;
    flex-direction: row;
    gap: 12px;
    width: 100%;
    align-items: center;
}

.resultado-prediccion,
.resultado-real {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex: 1;
}

.resultado-label {
    font-size: 0.65em;
    color: #666;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    margin-bottom: 2px;
}

.resultado-pendiente {
    color: #999;
    font-style: italic;
    font-size: 0.7em;
}

.resultado-input-solo-lectura {
    display: flex;
    align-items: center;
    gap: 2px;
    margin: 0;
}

.input-solo-lectura {
    width: 32px !important;
    padding: 3px 4px !important;
    text-align: center;
    border: 1.5px solid #ccc;
    border-radius: 3px;
    font-size: 0.8em !important;
    font-weight: bold;
    background: #e0e0e0;
    color: #666;
    cursor: not-allowed;
    pointer-events: none;
}

.input-prediccion {
    background: #e3f2fd !important;
    border-color: #2196f3 !important;
    color: #1976d2 !important;
    border-width: 1.5px !important;
}

.input-real {
    background: #f5f5f5 !important;
    border-color: #9e9e9e !important;
    color: #424242 !important;
    font-weight: bold;
    border-width: 1.5px !important;
}

.resultado-real {
    border: none !important;
    background: transparent !important;
    padding: 0 !important;
}

.partido-solo-lectura .separador {
    font-weight: bold;
    color: #999;
    margin: 0 3px;
    font-size: 0.8em;
}

.resultado-input-solo-lectura {
    display: flex;
    align-items: center;
    gap: 3px;
    margin: 0 10px;
}

.input-solo-lectura {
    width: 40px;
    padding: 6px;
    text-align: center;
    border: 2px solid #ccc;
    border-radius: 4px;
    font-size: 0.95em;
    font-weight: bold;
    background: #e0e0e0;
    color: #666;
    cursor: not-allowed;
    pointer-events: none;
}

.input-solo-lectura:focus {
    outline: none;
    border-color: #999;
}

.partido-solo-lectura .separador {
    font-weight: bold;
    color: #999;
    margin: 0 5px;
}

.modal-footer {
    padding: 20px 25px;
    background: #f8fafc;
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    border-top: 1px solid #e0e0e0;
}

.modal-btn {
    padding: 12px 24px;
    border: none;
    border-radius: 8px;
    font-size: 1em;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
    min-width: 100px;
}

.modal-btn-primary {
    background: linear-gradient(135deg, #1e3c72 0%, #2a5298 100%);
    color: white;
    box-shadow: 0 4px 12px rgba(30, 60, 114, 0.3);
}

.modal-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(30, 60, 114, 0.4);
}

.modal-btn-primary:active {
    transform: translateY(0);
}

.modal-btn-secondary {
    background: #e0e0e0;
    color: #333;
}

.modal-btn-secondary:hover {
    background: #d0d0d0;
    transform: translateY(-2px);
}

.modal-btn-secondary:active {
    transform: translateY(0);
}

/* Botón de reglas del torneo */
.btn-reglas-torneo {
    padding: 10px 20px;
    background: linear-gradient(135deg, #1e3c72 0%, #2a5298 100%);
    color: white;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    font-size: 0.95em;
    font-weight: 600;
    transition: all 0.3s ease;
    box-shadow: 0 2px 8px rgba(30, 60, 114, 0.2);
}

.btn-reglas-torneo:hover {
    background: linear-gradient(135deg, #2a5298 0%, #3d6bb8 100%);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(30, 60, 114, 0.3);
}

.btn-reglas-torneo:active {
    transform: translateY(0);
    box-shadow: 0 2px 6px rgba(30, 60, 114, 0.2);
}

@media (max-width: 768px) {
    .btn-reglas-torneo {
        padding: 8px 16px;
        font-size: 0.9em;
        width: 100%;
    }
}

