/* Global Styles */
html {
    scroll-behavior: smooth;
    scroll-padding-top: 5rem; /* Adjust based on your navbar height */
}

/* For Safari and older browsers */
@media screen and (prefers-reduced-motion: no-preference) {
    html {
        scroll-behavior: smooth;
    }
}

/* Navigation background */
.nav-bg-image {
    background-image: url('../images/Background/Whistler-Sky-Sports_Sky-Background.png');
    background-size: cover;
    background-position: center bottom 10%;
    background-repeat: no-repeat;
    will-change: transform;
    contain: layout;
    background-color: #5c8da4; /* Fallback color */
    
    /* Add a smooth transition to prevent jarring effect when image loads */
    transition: background-image 0.3s ease-in;
}

/* Class added when the background image has loaded */
.bg-loaded {
    opacity: 1;
}

/* Header logo background */
.header-logo-bg {
    background-image: url('https://www.hellobc.com/content/uploads/2022/10/147484_PowerPoint-2000px-2000x1000.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    position: relative;
}

/* Animations */
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.animate-fadeIn {
    animation: fadeIn 1.5s ease-out forwards;
}

/* Font Styles */
body {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'Roboto Slab', serif;
}

.heading-primary {
    font-family: 'Roboto Slab', serif;
    font-weight: 700;
}

.heading-secondary {
    font-family: 'Roboto Slab', serif;
    font-weight: 600;
}

.heading-tertiary {
    font-family: 'Roboto Slab', serif;
    font-weight: 500;
}

/* Custom scrollbar styles */
::-webkit-scrollbar {
    width: 10px;
}

::-webkit-scrollbar-track {
    background: #f1f1f1;
}

::-webkit-scrollbar-thumb {
    background: #0F1B2A;
    border-radius: 5px;
}

::-webkit-scrollbar-thumb:hover {
    background: #12161c;
}

/* Smooth scroll for anchor links */
a[href^="#"] {
    scroll-margin-top: 5rem;
}

/* Prevent horizontal scroll */
body {
    overflow-x: hidden;
    width: 100%;
}

/* Smooth transitions */
* {
    transition: all 0.3s ease-in-out;
} 

/* --- Premium Hero / CTA Enhancements --- */
.header-logo-bg {
    /* subtle dark overlay for legibility */
    position: relative;
    overflow: hidden;
}
.header-logo-bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(3,7,18,0.2) 0%, rgba(3,7,18,0.4) 60%, rgba(3,7,18,0.6) 100%);
    pointer-events: none;
    mix-blend-mode: multiply;
}

/* Logo treatment */
.header-logo-bg img[itemprop="logo"] {
    filter: drop-shadow(0 10px 30px rgba(47, 54, 76, 0.45));
    transform-origin: center;
}

/* Hero heading polish */
header .welcome-text {
    text-shadow: 0 6px 24px rgba(2,6,23,0.35);
    letter-spacing: 0.02em;
}
header p[itemprop="description"] {
    color: rgba(0,0,0,0.8);
    text-shadow: 0 4px 18px rgba(2,6,23,0.18);
}

/* Book Now CTA - premium button */
header a[aria-label="Book Now"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    padding: 0.7rem 1.35rem;
    border-radius: 9999px;
    background: linear-gradient(90deg, #ff5420 0%, #ff2200 55%);
    color: #fff !important;
    box-shadow: 0 12px 30px rgba(20, 40, 80, 0.15), inset 0 -2px 8px rgba(255,255,255,0.06);
    transform: translateZ(0);
    will-change: transform, box-shadow;
}

header a[aria-label="Book Now"] svg { opacity: 0.95; }

header a[aria-label="Book Now"]:hover,
header a[aria-label="Book Now"]:focus {
    transform: translateY(-4px);
    box-shadow: 0 18px 40px rgba(20, 40, 80, 0.22), inset 0 -2px 8px rgba(255,255,255,0.08);
}

/* subtle shine animation */
header a[aria-label="Book Now"]::after {
    content: '';
    position: absolute;
    top: -40%;
    left: -30%;
    width: 60%;
    height: 140%;
    background: linear-gradient(120deg, rgba(255,255,255,0.25), rgba(255,255,255,0.06), rgba(255,255,255,0));
    transform: rotate(25deg) translateX(-100%);
    transition: transform 0.7s ease-in-out;
}
header a[aria-label="Book Now"]:hover::after { transform: rotate(25deg) translateX(20%); }

/* Glass card for tagline */
.modern-tagline {
    background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.03));
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 10px 40px rgba(2,6,23,0.18);
}

/* Smaller screens: keep CTA visible and comfortable */
@media (max-width: 767px) {
    header a[aria-label="Book Now"] { padding: 0.6rem 1rem; font-size: 0.95rem; }
}
