/* RETOGOL — Hoja de estilos principal
   Paleta: navy (#0f1d3a) + verde vibrante (#22c55e) + dorado (#f5b700)
*/

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html, body { height: 100%; }
body {
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}
img, picture, video, canvas, svg { display: block; max-width: 100%; }
input, button, textarea, select { font: inherit; color: inherit; }
button { cursor: pointer; background: none; border: none; }
a { color: inherit; }

:root {
    --color-navy-900: #0f1d3a;
    --color-navy-800: #15264a;
    --color-navy-700: #1f3666;
    --color-navy-600: #2c4a85;
    --color-navy-100: #e8edf5;
    --color-navy-50:  #f4f6fa;

    --color-green-900: #15803d;
    --color-green-800: #16a34a;
    --color-green-700: #22c55e;
    --color-green-600: #4ade80;
    --color-green-100: #dcfce7;
    --color-green-50:  #f0fdf4;

    --color-gold:      #f5b700;
    --color-gold-dark: #c89400;
    --color-cream:     #fffaf0;

    --color-red:       #dc2626;
    --color-red-bg:    #fee2e2;

    --color-ink:       #0f1d3a;
    --color-ink-soft:  #4a5876;
    --color-line:      #d8dee8;
    --color-bg:        #f7f9fc;
    --color-white:     #ffffff;

    --font-display: 'Bebas Neue', 'Oswald', system-ui, sans-serif;
    --font-body:    'Manrope', 'Segoe UI', system-ui, sans-serif;

    --text-xs:   14px;
    --text-sm:   16px;
    --text-base: 18px;
    --text-lg:   20px;
    --text-xl:   24px;
    --text-2xl:  32px;
    --text-3xl:  44px;
    --text-4xl:  64px;
    --text-5xl:  88px;

    --space-1: 4px;
    --space-2: 8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-5: 24px;
    --space-6: 32px;
    --space-7: 48px;
    --space-8: 64px;
    --space-9: 96px;

    --radius-sm: 6px;
    --radius:    12px;
    --radius-lg: 20px;
    --radius-xl: 28px;

    --shadow-sm:  0 2px 4px rgba(15, 29, 58, 0.06);
    --shadow:     0 4px 16px rgba(15, 29, 58, 0.10);
    --shadow-lg:  0 16px 40px rgba(15, 29, 58, 0.14);
    --shadow-card: 0 8px 24px rgba(15, 29, 58, 0.10), 0 2px 4px rgba(15, 29, 58, 0.06);

    --transition: 200ms cubic-bezier(0.4, 0, 0.2, 1);
}

body {
    font-family: var(--font-body);
    font-size: var(--text-base);
    color: var(--color-ink);
    background: var(--color-bg);
    background-image:
        radial-gradient(circle at 20% 0%, rgba(34, 197, 94, 0.04) 0%, transparent 50%),
        radial-gradient(circle at 80% 100%, rgba(245, 183, 0, 0.04) 0%, transparent 50%);
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
}

h1, h2, h3, h4 {
    font-family: var(--font-display);
    font-weight: 400;
    letter-spacing: 0.02em;
    color: var(--color-navy-900);
    line-height: 1.05;
}
h1 { font-size: var(--text-4xl); }
h2 { font-size: var(--text-3xl); }
h3 { font-size: var(--text-2xl); }
h4 { font-size: var(--text-xl); font-family: var(--font-body); font-weight: 700; letter-spacing: 0; }

a { color: var(--color-green-800); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--color-green-900); }

.container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--space-5);
}
.container-narrow { max-width: 720px; }
main { flex: 1; padding: var(--space-6) 0; }

.site-header {
    background: var(--color-white);
    border-bottom: 4px solid var(--color-green-700);
    box-shadow: var(--shadow-sm);
    position: sticky;
    top: 0;
    z-index: 50;
}
.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-5);
    min-height: 80px;
    padding: var(--space-3) var(--space-5);
    max-width: 1200px;
    margin: 0 auto;
}
.brand {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    text-decoration: none;
    color: var(--color-navy-900);
}
.brand__logo {
    height: 56px;
    width: auto;
    flex-shrink: 0;
}
.brand__name {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    line-height: 1;
    color: var(--color-navy-900);
    letter-spacing: 0.04em;
}
.brand__name .accent { color: var(--color-green-700); }
.brand__tag {
    display: block;
    font-size: var(--text-xs);
    color: var(--color-ink-soft);
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-top: 2px;
}

.nav { display: flex; align-items: center; gap: var(--space-2); }
.nav__link {
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius);
    font-weight: 600;
    font-size: var(--text-sm);
    transition: background var(--transition), color var(--transition);
    color: var(--color-navy-900);
}
.nav__link:hover { background: var(--color-green-100); color: var(--color-navy-900); }
.nav__link.is-active { background: var(--color-navy-900); color: var(--color-white); }

.nav-toggle {
    display: none;
    width: 48px;
    height: 48px;
    border-radius: var(--radius);
    color: var(--color-navy-900);
    align-items: center;
    justify-content: center;
}
.nav-toggle:hover { background: var(--color-green-100); }

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    min-height: 56px;
    padding: 0 var(--space-6);
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: var(--text-base);
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    transition: transform var(--transition), box-shadow var(--transition), background var(--transition);
    cursor: pointer;
    white-space: nowrap;
    text-align: center;
    border: 2px solid transparent;
}
.btn:active { transform: translateY(1px); }

.btn--primary {
    background: var(--color-green-700);
    color: var(--color-white);
    box-shadow: 0 4px 0 var(--color-green-900), var(--shadow);
}
.btn--primary:hover {
    background: var(--color-green-800);
    box-shadow: 0 6px 0 var(--color-green-900), var(--shadow-lg);
    transform: translateY(-1px);
    color: var(--color-white);
}

.btn--navy {
    background: var(--color-navy-900);
    color: var(--color-white);
    box-shadow: 0 4px 0 #050d1f, var(--shadow);
}
.btn--navy:hover {
    background: var(--color-navy-800);
    box-shadow: 0 6px 0 #050d1f, var(--shadow-lg);
    transform: translateY(-1px);
    color: var(--color-white);
}

.btn--gold {
    background: var(--color-gold);
    color: var(--color-navy-900);
    box-shadow: 0 4px 0 var(--color-gold-dark), var(--shadow);
}
.btn--gold:hover {
    background: #ffc91a;
    box-shadow: 0 6px 0 var(--color-gold-dark), var(--shadow-lg);
    transform: translateY(-1px);
    color: var(--color-navy-900);
}

.btn--outline {
    background: var(--color-white);
    color: var(--color-navy-900);
    border-color: var(--color-navy-900);
}
.btn--outline:hover { background: var(--color-navy-100); }

.btn--ghost {
    background: transparent;
    color: var(--color-navy-900);
}
.btn--ghost:hover { background: var(--color-green-100); }

.btn--block { width: 100%; }
.btn--lg { min-height: 64px; font-size: var(--text-lg); padding: 0 var(--space-7); }

.form-group { margin-bottom: var(--space-5); }
.form-label {
    display: block;
    font-weight: 700;
    margin-bottom: var(--space-2);
    color: var(--color-navy-900);
    font-size: var(--text-base);
}
.form-help {
    display: block;
    margin-top: var(--space-2);
    font-size: var(--text-sm);
    color: var(--color-ink-soft);
}
.form-input {
    width: 100%;
    min-height: 56px;
    padding: 0 var(--space-4);
    border: 2px solid var(--color-line);
    border-radius: var(--radius);
    background: var(--color-white);
    font-size: var(--text-base);
    color: var(--color-ink);
    transition: border-color var(--transition), box-shadow var(--transition);
}
.form-input:focus {
    outline: none;
    border-color: var(--color-green-700);
    box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.18);
}
.form-input.has-error {
    border-color: var(--color-red);
    background: var(--color-red-bg);
}
.form-error {
    display: block;
    margin-top: var(--space-2);
    color: var(--color-red);
    font-size: var(--text-sm);
    font-weight: 600;
}

.alert {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    padding: var(--space-4) var(--space-5);
    border-radius: var(--radius);
    border-left: 6px solid;
    margin-bottom: var(--space-5);
    font-weight: 500;
}
.alert__icon {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    color: var(--color-white);
}
.alert--success { background: var(--color-green-100); border-left-color: var(--color-green-700); color: var(--color-green-900); }
.alert--success .alert__icon { background: var(--color-green-700); }
.alert--error   { background: var(--color-red-bg); border-left-color: var(--color-red); color: #6b0411; }
.alert--error .alert__icon { background: var(--color-red); }
.alert--info    { background: #fff8e1; border-left-color: var(--color-gold); color: #5b4500; }
.alert--info .alert__icon { background: var(--color-gold); color: var(--color-navy-900); }

.card {
    background: var(--color-white);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    box-shadow: var(--shadow-card);
    border: 1px solid var(--color-line);
}
.card__title {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    color: var(--color-navy-900);
    margin-bottom: var(--space-3);
}
.card__lead {
    color: var(--color-ink-soft);
    margin-bottom: var(--space-5);
}

.site-footer {
    background: var(--color-navy-900);
    color: rgba(255,255,255,0.85);
    padding: var(--space-7) 0 var(--space-6);
    margin-top: var(--space-9);
    text-align: center;
    font-size: var(--text-sm);
}
.site-footer a { color: var(--color-green-700); font-weight: 600; }

.text-center { text-align: center; }
.mt-2 { margin-top: var(--space-2); }
.mt-3 { margin-top: var(--space-3); }
.mt-4 { margin-top: var(--space-4); }
.mt-5 { margin-top: var(--space-5); }
.mt-6 { margin-top: var(--space-6); }
.mb-3 { margin-bottom: var(--space-3); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-5 { margin-bottom: var(--space-5); }
.mb-6 { margin-bottom: var(--space-6); }

.sr-only {
    position: absolute; width: 1px; height: 1px; padding: 0;
    margin: -1px; overflow: hidden; clip: rect(0,0,0,0);
    white-space: nowrap; border: 0;
}

@media (max-width: 767px) {
    h1 { font-size: 44px; }
    h2 { font-size: 32px; }
    h3 { font-size: 24px; }

    .brand__logo { height: 44px; }
    .brand__tag { display: none; }
    .brand__name { font-size: var(--text-xl); }

    .nav-toggle { display: inline-flex; }
    .nav {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: var(--color-white);
        flex-direction: column;
        align-items: stretch;
        padding: var(--space-3);
        border-top: 2px solid var(--color-line);
        box-shadow: var(--shadow);
        gap: var(--space-1);
    }
    .nav.is-open { display: flex; }
    .nav__link { padding: var(--space-4); font-size: var(--text-base); }

    .container { padding: 0 var(--space-4); }
    main { padding: var(--space-4) 0; }
    .card { padding: var(--space-5); }
}

/* ── Mobile responsive fixes ──────────────────────────────────────────────── */
@media (max-width: 600px) {

    /* Ocultar columnas secundarias en tablas */
    .mobile-hide { display: none !important; }

    /* Nombres cortos de equipos */
    .team-name-full { display: none !important; }
    .team-name-short { display: inline !important; }

    /* Tabla de resultados admin — ajustar padding */
    .pred-card {
        padding: 12px !important;
    }

    /* Historial jugador — tabla más compacta */
    table td, table th {
        padding: 8px 10px !important;
        font-size: 13px !important;
    }

    /* Pronósticos — inputs más grandes en mobile */
    .pred-score-input {
        width: 56px !important;
        height: 56px !important;
        font-size: 24px !important;
    }

    /* Selector de torneo — full width en mobile */
    .tournament-tabs {
        display: flex;
        flex-direction: column;
        gap: 6px;
        width: 100%;
    }
    .tournament-tabs a {
        text-align: center;
    }
}
