/* Barra superior capitanas */
.header--con-utility {
    padding-top: 0 !important;
}

.header-utility-bar {
    background: #f4f6f5;
    border-bottom: 1px solid rgba(27, 94, 58, 0.12);
}

.header-utility-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0.4rem 1rem;
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

.header-auth-links {
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.header-auth-link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.75rem;
    color: #1b5e3a !important;
    text-decoration: none !important;
    font-family: var(--font-heading, 'Montserrat', sans-serif);
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    border-radius: 4px;
    transition: color 0.2s ease, background 0.2s ease;
}

.header-auth-link i {
    font-size: 0.85rem;
    opacity: 0.85;
}

.header-utility-bar .header-auth-link:hover {
    color: #2e8b57 !important;
    background: rgba(46, 139, 87, 0.1) !important;
}

.header-auth-link--register {
    color: #fff !important;
    background: linear-gradient(135deg, #ff6b35 0%, #e55a2b 100%) !important;
    box-shadow: 0 1px 4px rgba(255, 107, 53, 0.25);
}

.header-utility-bar .header-auth-link--register:hover {
    color: #fff !important;
    background: linear-gradient(135deg, #ff7d4d 0%, #ff6b35 100%) !important;
}

/*
 * Anti-flash: el CSS global pone background:transparent en :focus del header
 * y eso deja ver el blanco del body al navegar. Forzamos verde siempre.
 */
.header,
.header:focus,
.header:focus-within,
.header:active {
    background: linear-gradient(135deg, #2e8b57 0%, #1b5e3a 100%) !important;
}

.header .header-container:focus,
.header .header-container:focus-within,
.header .header-container:active,
.header .nav-menu li:focus,
.header .nav-menu li:active {
    background: transparent !important;
}

.header > .nav-link:focus,
.header .nav-menu .nav-link:focus,
.header .nav-menu .nav-link:active,
.header .nav-menu .nav-link:focus-visible {
    background: transparent !important;
    color: #fff !important;
    box-shadow: none !important;
    outline: none !important;
}

/* Submenú interno — no usa .nav-link del header */
.internal-navigation .internal-nav-link {
    color: #fff !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 1rem !important;
    padding: 8px 16px !important;
    border-radius: 6px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

.internal-navigation .internal-nav-link:hover {
    background: rgba(255, 255, 255, 0.2) !important;
    color: #fff !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2) !important;
}

.footer-bottom a {
    color: var(--tennis-green-light, #90ee90);
    text-decoration: underline;
}

.footer-bottom a:hover {
    color: #fff;
}

@media (max-width: 768px) {
    .header-utility-inner {
        justify-content: center;
        padding: 0.45rem 0.75rem;
    }

    .header-auth-links {
        width: 100%;
        justify-content: center;
        flex-wrap: wrap;
        gap: 0.5rem;
    }
}
