/* GACS homepage — cinematic expedition */

.gacs-home-root {
    --gacs-bg: var(--gacs-navy, #071226);
    --gacs-bg-elevated: var(--gacs-navy-elevated, #0b1120);
    --gacs-line: rgba(255, 255, 255, 0.09);
    --gacs-accent: var(--gacs-gold, #d4a017);
}

.gacs-card {
    border: 1px solid var(--gacs-line);
    background: rgba(255, 255, 255, 0.02);
    border-radius: var(--gacs-radius, 2px);
    transition: border-color 0.35s ease;
}

.gacs-card-media img {
    transition: transform 1.1s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Hero eyebrow */
.gacs-hero-eyebrow {
    font-family: var(--gacs-sans, 'Manrope', system-ui, sans-serif);
    font-size: clamp(0.625rem, 0.55rem + 0.35vw, 0.75rem);
    font-weight: 600;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    line-height: 1.5;
}

.gacs-hero-eyebrow__brand {
    color: var(--gacs-gold-light, #e0b84c);
}

.gacs-hero-eyebrow__sep {
    color: rgba(255, 255, 255, 0.4);
    letter-spacing: 0.12em;
}

.gacs-hero-eyebrow__year {
    color: var(--gacs-orange, #d97706);
    font-weight: 700;
    letter-spacing: 0.28em;
}

.gacs-live-pulse {
    position: relative;
    padding-left: 1rem;
}

.gacs-live-pulse::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    width: 0.4rem;
    height: 0.4rem;
    margin-top: -0.2rem;
    border-radius: 9999px;
    background: var(--gacs-orange, #d97706);
}

@media (prefers-reduced-motion: no-preference) {
    .gacs-live-pulse.gacs-hero-eyebrow::before {
        animation: gacsHeroLivePulse 2.8s ease-out infinite;
    }
}

@keyframes gacsHeroLivePulse {
    0%,
    100% {
        opacity: 1;
    }
    50% {
        opacity: 0.55;
    }
}

.gacs-marquee-wrap:hover .gacs-marquee {
    animation-play-state: paused;
}

.gacs-countdown-digit {
    font-variant-numeric: tabular-nums;
    font-feature-settings: 'tnum';
}

.gacs-hero-enter {
    opacity: 0;
    transform: translateY(10px);
}

@media (prefers-reduced-motion: no-preference) {
    .gacs-hero-enter.gacs-in {
        animation: gacsHeroIn 0.85s cubic-bezier(0.22, 1, 0.36, 1) forwards;
    }
    .gacs-hero-enter.gacs-in-delay-1 { animation-delay: 0.08s; }
    .gacs-hero-enter.gacs-in-delay-2 { animation-delay: 0.16s; }
    .gacs-hero-enter.gacs-in-delay-3 { animation-delay: 0.24s; }
}

@keyframes gacsHeroIn {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .gacs-hero-enter,
    .gacs-hero-media {
        opacity: 1 !important;
        transform: none !important;
        animation: none !important;
    }
}
