/* ============================================
   TEAM GOZALBO - SHARED STYLES
   Reutilizable entre versiones dark y light
   ============================================ */

html { scroll-behavior: smooth; }
body { font-family: 'Inter', sans-serif; }
.font-heading { font-family: 'Oswald', sans-serif; }

/* ---- Accent line ---- */
.accent-line {
    width: 60px;
    height: 3px;
    background: linear-gradient(90deg, #fd0142, #ff5c87);
    border-radius: 2px;
}

/* ---- Mountain silhouette (hero) ---- */
.mountain-layer {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    line-height: 0;
}

/* ---- Team card hover ---- */
.team-card {
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94), box-shadow 0.4s ease;
}
.team-card:hover {
    transform: translateY(-8px);
}
.team-card:hover .team-img {
    transform: scale(1.08);
}
.team-card:hover .team-overlay {
    opacity: 1;
}
.team-img {
    transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ---- Partner logos ---- */
.partner-card {
    transition: all 0.3s ease;
}
.partner-card img {
    transition: filter 0.4s ease;
}

/* ---- Scroll reveal animations ---- */
.reveal {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94),
                transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.reveal.active {
    opacity: 1;
    transform: translateY(0);
}
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }
.reveal-delay-5 { transition-delay: 0.5s; }

/* ---- Position badges (race results) ---- */
.position-gold   { background: linear-gradient(135deg, #f59e0b, #d97706); }
.position-silver  { background: linear-gradient(135deg, #94a3b8, #64748b); }
.position-bronze  { background: linear-gradient(135deg, #b45309, #92400e); }

/* ---- Focus visible (accesibilidad) ---- */
a:focus-visible, button:focus-visible {
    outline: 2px solid #fd0142;
    outline-offset: 2px;
    border-radius: 4px;
}

/* ---- Subtle grain texture overlay ---- */
.grain::after {
    content: '';
    position: absolute;
    inset: 0;
    opacity: 0.03;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
    pointer-events: none;
}
