/* ============================================
   EDUPREPS ACADEMY - "DAYBREAK CLARITY" DESIGN SYSTEM
   A refined, high-end educational marketplace aesthetic
   ============================================ */

/* ----------------------------------------
   FONT IMPORTS
   Using Satoshi for display (modern geometric sans)
   and General Sans for body (clean, readable)
   ---------------------------------------- */
@font-face {
    font-family: 'Satoshi';
    src: url('https://api.fontshare.com/v2/css?f[]=satoshi@700,800,900&display=swap');
    font-weight: 700 900;
    font-display: swap;
}

@import url('https://api.fontshare.com/v2/css?f[]=satoshi@300,400,500,700,900&display=swap');
@import url('https://api.fontshare.com/v2/css?f[]=general-sans@400,500,600&display=swap');

/* ----------------------------------------
   CSS VARIABLES & DESIGN TOKENS
   ---------------------------------------- */
:root {
    /* Primary Palette - Daybreak Clarity */
    --porcelain: #FEFEFE;
    --soft-mist: #F8FAFC;
    --morning-fog: #F1F5F9;
    --focus-blue: #2563EB;
    --focus-blue-deep: #1D4ED8;
    --focus-blue-glow: #3B82F6;
    --focus-blue-pale: #DBEAFE;
    --focus-blue-whisper: #EFF6FF;
    --sunrise-orange: #F97316;
    --sunrise-orange-deep: #EA580C;
    --sunrise-orange-glow: #FB923C;
    --sunrise-orange-pale: #FFEDD5;
    --sunrise-orange-whisper: #FFF7ED;

    /* Neutral Palette - Slate Tones */
    --slate-50: #F8FAFC;
    --slate-100: #F1F5F9;
    --slate-200: #E2E8F0;
    --slate-300: #CBD5E1;
    --slate-400: #94A3B8;
    --slate-500: #64748B;
    --slate-600: #475569;
    --slate-700: #334155;
    --slate-800: #1E293B;
    --slate-900: #0F172A;
    --slate-950: #020617;

    /* Semantic Colors */
    --success: #10B981;
    --success-pale: #D1FAE5;
    --warning: #F59E0B;
    --warning-pale: #FEF3C7;
    --error: #EF4444;
    --error-pale: #FEE2E2;

    /* Typography */
    --font-display: 'Satoshi', -apple-system, BlinkMacSystemFont, sans-serif;
    --font-body: 'General Sans', -apple-system, BlinkMacSystemFont, sans-serif;

    /* Spacing Scale */
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-8: 2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;
    --space-20: 5rem;
    --space-24: 6rem;
    --space-32: 8rem;

    /* Border Radius - Soft, rounded aesthetic */
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 24px;
    --radius-2xl: 32px;
    --radius-3xl: 40px;
    --radius-full: 9999px;

    /* Shadows - Soft, diffused */
    --shadow-xs: 0 1px 2px rgba(15, 23, 42, 0.04);
    --shadow-sm: 0 2px 4px rgba(15, 23, 42, 0.04), 0 1px 2px rgba(15, 23, 42, 0.03);
    --shadow-md: 0 4px 8px rgba(15, 23, 42, 0.04), 0 2px 4px rgba(15, 23, 42, 0.03);
    --shadow-lg: 0 8px 24px rgba(15, 23, 42, 0.06), 0 4px 8px rgba(15, 23, 42, 0.04);
    --shadow-xl: 0 16px 48px rgba(15, 23, 42, 0.08), 0 8px 16px rgba(15, 23, 42, 0.04);
    --shadow-2xl: 0 24px 64px rgba(15, 23, 42, 0.12), 0 12px 24px rgba(15, 23, 42, 0.06);
    --shadow-glow-blue: 0 0 40px rgba(37, 99, 235, 0.15);
    --shadow-glow-orange: 0 0 40px rgba(249, 115, 22, 0.15);
    --shadow-float: 0 20px 60px -15px rgba(15, 23, 42, 0.15);
    --shadow-card: 0 4px 24px rgba(15, 23, 42, 0.06);
    --shadow-card-hover: 0 12px 40px rgba(15, 23, 42, 0.1);

    /* Transitions */
    --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);
    --ease-in-out-quart: cubic-bezier(0.76, 0, 0.24, 1);
    --duration-fast: 150ms;
    --duration-base: 250ms;
    --duration-slow: 400ms;
    --duration-slower: 600ms;

    /* Z-Index Scale */
    --z-dropdown: 100;
    --z-sticky: 200;
    --z-fixed: 300;
    --z-modal-backdrop: 400;
    --z-modal: 500;
    --z-popover: 600;
    --z-tooltip: 700;
}

/* ----------------------------------------
   BASE STYLES
   ---------------------------------------- */
*, *::before, *::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

body.academy-theme {
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.6;
    color: var(--slate-800);
    background: var(--porcelain);
    overflow-x: hidden;
}

/* Selection */
::selection {
    background: var(--focus-blue-pale);
    color: var(--focus-blue-deep);
}

/* Focus States */
:focus-visible {
    outline: 2px solid var(--focus-blue);
    outline-offset: 3px;
}

/* Scrollbar */
::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

::-webkit-scrollbar-track {
    background: var(--soft-mist);
}

::-webkit-scrollbar-thumb {
    background: var(--slate-300);
    border-radius: 5px;
    border: 2px solid var(--soft-mist);
}

::-webkit-scrollbar-thumb:hover {
    background: var(--slate-400);
}

/* ----------------------------------------
   TYPOGRAPHY
   ---------------------------------------- */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-display);
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.02em;
    color: var(--slate-900);
}

.display-xl {
    font-size: clamp(3rem, 6vw, 5rem);
    font-weight: 800;
    letter-spacing: -0.03em;
}

.display-lg {
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 800;
    letter-spacing: -0.025em;
}

.display-md {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700;
}

.heading-lg {
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 700;
}

.heading-md {
    font-size: 1.25rem;
    font-weight: 600;
}

.heading-sm {
    font-size: 1rem;
    font-weight: 600;
}

.body-lg {
    font-size: 1.125rem;
    line-height: 1.7;
}

.body-md {
    font-size: 1rem;
    line-height: 1.6;
}

.body-sm {
    font-size: 0.875rem;
    line-height: 1.5;
}

.caption {
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

/* Text Colors */
.text-muted { color: var(--slate-500); }
.text-subtle { color: var(--slate-600); }
.text-default { color: var(--slate-800); }
.text-emphasis { color: var(--slate-900); }
.text-blue { color: var(--focus-blue); }
.text-orange { color: var(--sunrise-orange); }

/* Gradient Text */
.text-gradient {
    background: linear-gradient(135deg, var(--focus-blue) 0%, #8B5CF6 50%, var(--sunrise-orange) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.text-gradient-blue {
    background: linear-gradient(135deg, var(--focus-blue) 0%, #3B82F6 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ----------------------------------------
   FLOATING NAV - "THE TOOL BELT"
   ---------------------------------------- */
.academy-nav {
    position: fixed;
    top: var(--space-4);
    left: 50%;
    transform: translateX(-50%);
    z-index: var(--z-fixed);
    width: calc(100% - var(--space-8));
    max-width: 1280px;
    animation: navSlideDown 0.8s var(--ease-out-expo) forwards;
}

@keyframes navSlideDown {
    from {
        opacity: 0;
        transform: translateX(-50%) translateY(-20px);
    }
    to {
        opacity: 1;
        transform: translateX(-50%) translateY(0);
    }
}

.academy-nav-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-6);
    padding: var(--space-3) var(--space-4) var(--space-3) var(--space-6);
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid rgba(255, 255, 255, 0.8);
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-lg), 0 0 0 1px rgba(0, 0, 0, 0.02);
}

.academy-nav-logo {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    text-decoration: none;
    color: var(--slate-900);
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1.25rem;
    letter-spacing: -0.02em;
}

.academy-nav-logo svg {
    width: 36px;
    height: 36px;
    flex-shrink: 0;
}

.academy-nav-links {
    display: flex;
    align-items: center;
    gap: var(--space-1);
}

.academy-nav-link {
    padding: var(--space-2) var(--space-4);
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--slate-600);
    text-decoration: none;
    border-radius: var(--radius-full);
    transition: all var(--duration-fast) var(--ease-out-quart);
}

.academy-nav-link:hover {
    color: var(--slate-900);
    background: var(--slate-100);
}

.academy-nav-link.active {
    color: var(--focus-blue);
    background: var(--focus-blue-whisper);
}

.academy-nav-actions {
    display: flex;
    align-items: center;
    gap: var(--space-4);
}

/* Language Selector */
.academy-lang-selector {
    position: relative;
}

.academy-locale-btn {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.5rem 0.75rem;
    background: transparent;
    border: 1px solid var(--silver);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--slate);
    cursor: pointer;
    transition: all var(--duration-fast);
}

.academy-locale-btn:hover {
    background: var(--porcelain);
    border-color: var(--slate-300);
}

.academy-locale-dropdown {
    position: absolute;
    top: calc(100% + 0.5rem);
    right: 0;
    min-width: 10rem;
    background: white;
    border: 1px solid var(--silver);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-0.5rem);
    transition: all var(--duration-fast);
    z-index: 100;
}

.academy-locale-dropdown.open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.academy-locale-option {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.625rem 1rem;
    background: transparent;
    border: none;
    font-family: var(--font-body);
    font-size: 0.875rem;
    color: var(--slate);
    cursor: pointer;
    transition: background var(--duration-fast);
}

.academy-locale-option:hover {
    background: var(--porcelain);
}

.academy-locale-option.selected {
    color: var(--focus-blue);
    font-weight: 500;
}

/* (flame-counter removed, replaced by currency selector using .academy-lang-selector) */

.academy-nav-login {
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--slate-600);
    text-decoration: none;
    transition: color var(--duration-fast);
}

.academy-nav-login:hover {
    color: var(--slate-900);
}

/* Cart Button */
.academy-cart-btn {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: var(--slate-50);
    border-radius: var(--radius-full);
    color: var(--slate-600);
    text-decoration: none;
    transition: all var(--duration-fast) var(--ease-out-quart);
    border: 1px solid var(--slate-200);
}

.academy-cart-btn:hover {
    background: var(--focus-blue-whisper);
    color: var(--focus-blue);
    border-color: var(--focus-blue-pale);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.15);
}

.academy-cart-btn:active {
    transform: translateY(0);
}

.academy-cart-icon {
    width: 20px;
    height: 20px;
    stroke-width: 2;
    transition: transform var(--duration-fast) var(--ease-out-quart);
}

.academy-cart-btn:hover .academy-cart-icon {
    transform: scale(1.05);
}

/* Cart bounce animation when item added */
.academy-cart-icon.animate-bounce {
    animation: cartBounce 0.6s var(--ease-out-expo);
}

@keyframes cartBounce {
    0%, 100% { transform: scale(1) translateY(0); }
    30% { transform: scale(1.2) translateY(-2px); }
    50% { transform: scale(0.95) translateY(1px); }
    70% { transform: scale(1.05) translateY(-1px); }
}

.academy-cart-count {
    position: absolute;
    top: -4px;
    right: -4px;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    background: var(--sunrise-orange);
    color: white;
    font-family: var(--font-body);
    font-size: 0.65rem;
    font-weight: 700;
    border-radius: var(--radius-full);
    box-shadow: 0 2px 6px rgba(249, 115, 22, 0.4);
    animation: cartCountPop 0.3s var(--ease-out-expo);
}

@keyframes cartCountPop {
    0% { transform: scale(0); }
    50% { transform: scale(1.2); }
    100% { transform: scale(1); }
}

/* Mobile Cart Button - hidden by default, shown in mobile view */
.academy-cart-btn--mobile {
    display: none;
}

@media (max-width: 1024px) {
    .academy-cart-btn:not(.academy-cart-btn--mobile) {
        display: none;
    }

    .academy-cart-btn--mobile {
        display: none;
    }
}

/* Mobile Nav Toggle */
.academy-nav-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: var(--radius-md);
    color: var(--slate-700);
    cursor: pointer;
    transition: background var(--duration-fast);
}

.academy-nav-toggle:hover {
    background: var(--slate-100);
}

@media (max-width: 1024px) {
    .academy-nav-links,
    .academy-lang-selector,
    .academy-nav-login,
    .academy-nav-actions > .btn {
        display: none;
    }

    .academy-nav-toggle {
        display: flex;
    }

    /* Fix: Solid opaque background on mobile to prevent content bleeding through */
    .academy-nav-inner {
        background: #ffffff !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        box-shadow: var(--shadow-lg), 0 0 0 1px rgba(0, 0, 0, 0.02);
    }
}

/* Mobile Menu */
.academy-mobile-menu {
    position: fixed !important;
    inset: 88px 16px 16px 16px !important; /* top right bottom left */
    width: calc(100% - 32px) !important;
    height: calc(100vh - 104px) !important;
    height: calc(100dvh - 104px) !important; /* Dynamic viewport height for mobile */
    background: #ffffff !important;
    border-radius: 32px;
    padding: 24px;
    box-shadow: 0 24px 64px rgba(15, 23, 42, 0.2), 0 12px 24px rgba(15, 23, 42, 0.1);
    z-index: 9999 !important;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-20px);
    transition: all 250ms cubic-bezier(0.16, 1, 0.3, 1);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    pointer-events: none;
}

.academy-mobile-menu.open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
}

.academy-mobile-menu a {
    display: block;
    padding: var(--space-3) var(--space-4);
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 500;
    color: var(--slate-700);
    text-decoration: none;
    border-radius: var(--radius-lg);
    transition: all var(--duration-fast);
}

.academy-mobile-menu a:hover {
    background: var(--slate-100);
    color: var(--slate-900);
}

/* Mobile menu extras row (cart, lang, flame) */
.academy-mobile-extras {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    flex-wrap: wrap;
}

.academy-mobile-extras .academy-lang-selector,
.academy-mobile-extras .academy-cart-btn {
    display: flex;
}

.academy-mobile-extras .academy-lang-selector .academy-locale-dropdown {
    right: auto;
    left: 0;
}

/* ----------------------------------------
   BUTTONS
   ---------------------------------------- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-6);
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 600;
    text-decoration: none;
    border: none;
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: all var(--duration-base) var(--ease-out-quart);
    position: relative;
    overflow: hidden;
}

.btn::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255,255,255,0.15) 0%, transparent 50%);
    opacity: 0;
    transition: opacity var(--duration-fast);
}

.btn:hover::before {
    opacity: 1;
}

.btn-primary {
    color: var(--porcelain);
    background: var(--focus-blue);
    box-shadow: 0 4px 14px -3px rgba(37, 99, 235, 0.5), inset 0 1px 0 rgba(255,255,255,0.1);
}

.btn-primary:hover {
    background: var(--focus-blue-deep);
    box-shadow: 0 8px 24px -4px rgba(37, 99, 235, 0.6), inset 0 1px 0 rgba(255,255,255,0.15);
    transform: translateY(-2px);
}

.btn-primary:active {
    transform: translateY(0);
    box-shadow: 0 2px 8px -2px rgba(37, 99, 235, 0.5);
}

.btn-secondary {
    color: var(--slate-700);
    background: var(--porcelain);
    border: 2px solid var(--slate-200);
    box-shadow: var(--shadow-sm);
}

.btn-secondary:hover {
    border-color: var(--slate-300);
    background: var(--soft-mist);
    box-shadow: var(--shadow-md);
}

.btn-outline {
    color: var(--focus-blue);
    background: transparent;
    border: 2px solid var(--focus-blue);
}

.btn-outline:hover {
    color: var(--porcelain);
    background: var(--focus-blue);
}

.btn-orange {
    color: var(--porcelain);
    background: var(--sunrise-orange);
    box-shadow: 0 4px 14px -3px rgba(249, 115, 22, 0.5), inset 0 1px 0 rgba(255,255,255,0.1);
}

.btn-orange:hover {
    background: var(--sunrise-orange-deep);
    box-shadow: 0 8px 24px -4px rgba(249, 115, 22, 0.6);
    transform: translateY(-2px);
}

.btn-ghost {
    color: var(--slate-600);
    background: transparent;
}

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

.btn-sm {
    padding: var(--space-2) var(--space-4);
    font-size: 0.85rem;
}

.btn-lg {
    padding: var(--space-4) var(--space-8);
    font-size: 1rem;
}

.btn-xl {
    padding: var(--space-5) var(--space-10);
    font-size: 1.1rem;
}

/* ----------------------------------------
   CARDS - SOFT ROUNDED STYLE
   ---------------------------------------- */
.card {
    background: var(--porcelain);
    border-radius: var(--radius-2xl);
    border: 1px solid rgba(0, 0, 0, 0.04);
    box-shadow: var(--shadow-card);
    transition: all var(--duration-slow) var(--ease-out-quart);
}

.card:hover {
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-4px);
}

.card-flat {
    background: var(--porcelain);
    border-radius: var(--radius-2xl);
    border: 2px solid var(--slate-200);
    transition: all var(--duration-base) var(--ease-out-quart);
}

.card-flat:hover {
    border-color: var(--slate-300);
    box-shadow: var(--shadow-md);
}

.card-interactive {
    cursor: pointer;
}

.card-interactive:hover {
    border-color: var(--focus-blue);
}

/* ----------------------------------------
   HERO SECTION - "THE PROMISE"
   ---------------------------------------- */
.hero-section {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    padding: calc(var(--space-32) + var(--space-8)) var(--space-8) var(--space-16);
    background: var(--porcelain);
    overflow: hidden;
}

/* Subtle gradient orb background */
.hero-section::before {
    content: '';
    position: absolute;
    top: -30%;
    right: -20%;
    width: 80%;
    height: 120%;
    background: radial-gradient(ellipse at center, var(--focus-blue-whisper) 0%, transparent 60%);
    opacity: 0.8;
    pointer-events: none;
    animation: heroOrbFloat 20s ease-in-out infinite;
}

.hero-section::after {
    content: '';
    position: absolute;
    bottom: -20%;
    left: -10%;
    width: 50%;
    height: 80%;
    background: radial-gradient(ellipse at center, var(--sunrise-orange-whisper) 0%, transparent 60%);
    opacity: 0.5;
    pointer-events: none;
    animation: heroOrbFloat 25s ease-in-out infinite reverse;
}

@keyframes heroOrbFloat {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50% { transform: translate(30px, -20px) scale(1.05); }
}

.hero-container {
    position: relative;
    z-index: 1;
    max-width: 1400px;
    margin: 0 auto;
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-16);
    align-items: center;
}

@media (max-width: 1024px) {
    .hero-container {
        grid-template-columns: 1fr;
        text-align: center;
        gap: var(--space-12);
    }
}

.hero-content {
    animation: heroContentReveal 1s var(--ease-out-expo) forwards;
    animation-delay: 0.2s;
    opacity: 0;
}

@keyframes heroContentReveal {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.hero-content h1 {
    font-size: clamp(2.75rem, 5.5vw, 4.25rem);
    font-weight: 800;
    line-height: 1.05;
    color: var(--slate-900);
    margin-bottom: var(--space-6);
}

.hero-content h1 em {
    font-style: normal;
    color: var(--focus-blue);
}

.hero-content .hero-subtitle {
    font-size: clamp(1.1rem, 2vw, 1.35rem);
    color: var(--slate-600);
    margin-bottom: var(--space-10);
    max-width: 540px;
    line-height: 1.7;
}

@media (max-width: 1024px) {
    .hero-content .hero-subtitle {
        margin-left: auto;
        margin-right: auto;
    }
}

/* Hero Search */
.hero-search {
    display: flex;
    gap: 0;
    background: var(--porcelain);
    border-radius: var(--radius-full);
    padding: var(--space-2);
    box-shadow: var(--shadow-xl), 0 0 0 1px var(--slate-200);
    max-width: 580px;
    transition: all var(--duration-base) var(--ease-out-quart);
}

.hero-search:focus-within {
    box-shadow: var(--shadow-xl), 0 0 0 3px var(--focus-blue-pale);
}

.hero-search input {
    flex: 1;
    padding: var(--space-4) var(--space-6);
    font-family: var(--font-body);
    font-size: 1rem;
    color: var(--slate-800);
    background: transparent;
    border: none;
    outline: none;
}

.hero-search input::placeholder {
    color: var(--slate-400);
}

.hero-search button {
    padding: var(--space-4) var(--space-8);
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--porcelain);
    background: var(--focus-blue);
    border: none;
    border-radius: var(--radius-full);
    cursor: pointer;
    white-space: nowrap;
    transition: all var(--duration-fast) var(--ease-out-quart);
}

.hero-search button:hover {
    background: var(--focus-blue-deep);
}

@media (max-width: 640px) {
    .hero-search {
        flex-direction: column;
        border-radius: var(--radius-2xl);
        padding: var(--space-3);
        margin: 0 auto;
    }

    .hero-search input {
        text-align: center;
        font-size: 0.875rem; /* Fix: Smaller font to prevent placeholder truncation */
    }

    .hero-search input::placeholder {
        font-size: 0.8rem; /* Fix: Ensure placeholder fits on mobile */
    }

    .hero-search button {
        width: 100%;
    }
}

/* Social Proof */
.hero-social-proof {
    margin-top: var(--space-12);
    padding-top: var(--space-8);
    border-top: 1px solid var(--slate-200);
    animation: heroContentReveal 1s var(--ease-out-expo) forwards;
    animation-delay: 0.5s;
    opacity: 0;
}

.hero-social-proof p {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--slate-500);
    margin-bottom: var(--space-4);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.hero-logos {
    display: flex;
    align-items: center;
    gap: var(--space-8);
    flex-wrap: wrap;
}

@media (max-width: 1024px) {
    .hero-logos {
        justify-content: center;
    }
}

.hero-logos img {
    height: 24px;
    width: auto;
    opacity: 0.4;
    filter: grayscale(100%);
    transition: all var(--duration-base);
}

.hero-logos img:hover {
    opacity: 0.8;
    filter: grayscale(0%);
}

/* Hero Visual */
.hero-visual {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    animation: heroVisualReveal 1.2s var(--ease-out-expo) forwards;
    animation-delay: 0.4s;
    opacity: 0;
}

@keyframes heroVisualReveal {
    from {
        opacity: 0;
        transform: translateY(40px) scale(0.95);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.hero-visual-inner {
    position: relative;
    width: 100%;
    max-width: 520px;
    aspect-ratio: 1;
}

@media (max-width: 1024px) {
    .hero-visual-inner {
        max-width: 400px;
    }
}

/* Floating Cards in Hero */
.hero-float-card {
    position: absolute;
    background: var(--porcelain);
    border-radius: var(--radius-2xl);
    padding: var(--space-5);
    box-shadow: var(--shadow-xl);
    border: 1px solid rgba(255, 255, 255, 0.8);
}

.hero-float-card:nth-child(1) {
    top: 5%;
    left: -5%;
    animation: floatCard1 8s ease-in-out infinite;
}

.hero-float-card:nth-child(2) {
    top: 25%;
    right: -10%;
    animation: floatCard2 10s ease-in-out infinite;
}

.hero-float-card:nth-child(3) {
    bottom: 10%;
    left: 5%;
    animation: floatCard3 9s ease-in-out infinite;
}

.hero-float-card:nth-child(4) {
    bottom: 30%;
    right: 0%;
    animation: floatCard1 11s ease-in-out infinite reverse;
}

@keyframes floatCard1 {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50% { transform: translateY(-15px) rotate(2deg); }
}

@keyframes floatCard2 {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50% { transform: translateY(-20px) rotate(-2deg); }
}

@keyframes floatCard3 {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50% { transform: translateY(-12px) rotate(1deg); }
}

/* Fix: Mobile floating cards - prevent text truncation */
@media (max-width: 640px) {
    .hero-float-card {
        padding: var(--space-3);
        font-size: 0.75rem;
        min-width: max-content; /* Prevent text wrapping/truncation */
        white-space: nowrap;
    }

    .hero-float-card:nth-child(1) {
        left: 2%; /* Keep cards visible on screen */
    }

    .hero-float-card:nth-child(2) {
        right: 2%;
    }
}

/* ----------------------------------------
   SECTION STYLES
   ---------------------------------------- */
.section {
    padding: var(--space-24) var(--space-8);
}

.section-sm {
    padding: var(--space-16) var(--space-8);
}

.section-lg {
    padding: var(--space-32) var(--space-8);
}

.section-white {
    background: var(--porcelain);
}

.section-mist {
    background: var(--soft-mist);
}

.section-slate {
    background: var(--slate-900);
    color: var(--slate-100);
}

.section-header {
    text-align: center;
    max-width: 720px;
    margin: 0 auto var(--space-16);
}

.section-header h2 {
    margin-bottom: var(--space-4);
}

.section-header p {
    font-size: 1.125rem;
    color: var(--slate-600);
}

.section-cta {
    text-align: center;
    margin-top: var(--space-12);
}

/* ----------------------------------------
   WHO WE ARE - "THE ANTI-ANXIETY ENGINE"
   ---------------------------------------- */
.who-we-are-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-8);
    max-width: 1200px;
    margin: 0 auto;
}

@media (max-width: 900px) {
    .who-we-are-grid {
        grid-template-columns: 1fr;
        max-width: 480px;
    }
}

.who-we-are-card {
    text-align: center;
    padding: var(--space-10) var(--space-8);
    background: var(--porcelain);
    border-radius: var(--radius-2xl);
    border: 1px solid var(--slate-200);
    transition: all var(--duration-slow) var(--ease-out-quart);
}

.who-we-are-card:hover {
    border-color: var(--focus-blue-pale);
    box-shadow: var(--shadow-lg), var(--shadow-glow-blue);
    transform: translateY(-4px);
}

.who-we-are-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto var(--space-6);
    background: linear-gradient(135deg, var(--focus-blue-whisper) 0%, var(--focus-blue-pale) 100%);
    border-radius: var(--radius-2xl);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform var(--duration-base) var(--ease-out-quart);
}

.who-we-are-card:hover .who-we-are-icon {
    transform: scale(1.05) rotate(-3deg);
}

.who-we-are-icon svg {
    width: 36px;
    height: 36px;
    color: var(--focus-blue);
}

.who-we-are-card h3 {
    font-size: 1.35rem;
    margin-bottom: var(--space-3);
}

.who-we-are-card p {
    color: var(--slate-600);
    line-height: 1.7;
}

/* ----------------------------------------
   HOW WE WORK - "THE MOMENTUM LOOP"
   ---------------------------------------- */
.momentum-loop {
    max-width: 1100px;
    margin: 0 auto;
    position: relative;
}

.momentum-steps {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-8);
    position: relative;
}

@media (max-width: 900px) {
    .momentum-steps {
        grid-template-columns: 1fr;
        max-width: 400px;
        margin: 0 auto;
    }
}

/* The Blue Line */
.momentum-line {
    position: absolute;
    top: 70px;
    left: calc(16.66% + 24px);
    right: calc(16.66% + 24px);
    height: 3px;
    background: linear-gradient(90deg, var(--focus-blue) 0%, var(--focus-blue-glow) 50%, var(--focus-blue) 100%);
    border-radius: 2px;
    z-index: 0;
}

.momentum-line::before {
    content: '';
    position: absolute;
    inset: -4px;
    background: inherit;
    filter: blur(8px);
    opacity: 0.4;
}

@media (max-width: 900px) {
    .momentum-line {
        display: none;
    }
}

.momentum-step {
    position: relative;
    z-index: 1;
    text-align: center;
}

.momentum-step-number {
    width: 56px;
    height: 56px;
    margin: 0 auto var(--space-6);
    background: var(--focus-blue);
    color: var(--porcelain);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    box-shadow: 0 8px 24px -4px rgba(37, 99, 235, 0.4);
    position: relative;
}

.momentum-step-number::before {
    content: '';
    position: absolute;
    inset: -4px;
    border-radius: 50%;
    background: var(--focus-blue);
    opacity: 0.2;
    animation: stepPulse 3s ease-in-out infinite;
}

@keyframes stepPulse {
    0%, 100% { transform: scale(1); opacity: 0.2; }
    50% { transform: scale(1.15); opacity: 0; }
}

.momentum-step-visual {
    width: 140px;
    height: 140px;
    margin: 0 auto var(--space-6);
    background: var(--soft-mist);
    border-radius: var(--radius-2xl);
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid var(--slate-200);
    transition: all var(--duration-base) var(--ease-out-quart);
}

.momentum-step:hover .momentum-step-visual {
    border-color: var(--focus-blue-pale);
    box-shadow: var(--shadow-lg);
}

.momentum-step-visual svg {
    width: 56px;
    height: 56px;
    color: var(--focus-blue);
}

.momentum-step h3 {
    font-size: 1.25rem;
    margin-bottom: var(--space-2);
}

.momentum-step p {
    color: var(--slate-600);
    font-size: 0.95rem;
    line-height: 1.6;
}

/* ----------------------------------------
   PROGRAMS - "CHOOSE YOUR OPERATING SYSTEM"
   ---------------------------------------- */
.programs-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-8);
    max-width: 1200px;
    margin: 0 auto;
}

@media (max-width: 1024px) {
    .programs-grid {
        grid-template-columns: 1fr;
        max-width: 440px;
    }
}

.program-card {
    background: var(--porcelain);
    border-radius: var(--radius-2xl);
    padding: var(--space-10) var(--space-8);
    text-align: center;
    border: 2px solid var(--slate-200);
    transition: all var(--duration-slow) var(--ease-out-quart);
    position: relative;
}

.program-card:hover {
    border-color: var(--focus-blue);
    box-shadow: var(--shadow-xl);
    transform: translateY(-6px);
}

.program-card.featured {
    border-color: var(--focus-blue);
    box-shadow: var(--shadow-xl), var(--shadow-glow-blue);
}

.program-card.featured::before {
    content: 'POPULAR';
    position: absolute;
    top: -14px;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(135deg, var(--sunrise-orange) 0%, var(--sunrise-orange-glow) 100%);
    color: var(--porcelain);
    font-family: var(--font-body);
    font-size: 0.7rem;
    font-weight: 700;
    padding: var(--space-1) var(--space-4);
    border-radius: var(--radius-full);
    letter-spacing: 0.08em;
    box-shadow: 0 4px 12px -2px rgba(249, 115, 22, 0.4);
}

.program-card-icon {
    width: 72px;
    height: 72px;
    margin: 0 auto var(--space-6);
    background: linear-gradient(135deg, var(--focus-blue-whisper) 0%, var(--focus-blue-pale) 100%);
    border-radius: var(--radius-xl);
    display: flex;
    align-items: center;
    justify-content: center;
}

.program-card-icon svg {
    width: 32px;
    height: 32px;
    color: var(--focus-blue);
}

.program-card-title {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--slate-900);
    margin-bottom: var(--space-2);
}

.program-card-subtitle {
    font-size: 0.9rem;
    color: var(--slate-500);
    margin-bottom: var(--space-6);
}

.program-card-description {
    font-size: 0.95rem;
    color: var(--slate-600);
    margin-bottom: var(--space-8);
    line-height: 1.7;
}

.program-card-features {
    text-align: left;
    margin-bottom: var(--space-8);
    list-style: none;
    padding: 0;
}

.program-card-features li {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    padding: var(--space-2) 0;
    font-size: 0.9rem;
    color: var(--slate-700);
}

.program-card-features li svg {
    width: 20px;
    height: 20px;
    color: var(--success);
    flex-shrink: 0;
    margin-top: 2px;
}

/* ----------------------------------------
   COURSES - "A LA CARTE MASTERY"
   ---------------------------------------- */
.courses-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--space-8);
    max-width: 1400px;
    margin: 0 auto;
}

.course-card {
    background: var(--porcelain);
    border-radius: var(--radius-2xl);
    overflow: hidden;
    box-shadow: var(--shadow-card);
    border: 1px solid rgba(0, 0, 0, 0.04);
    transition: all var(--duration-slow) var(--ease-out-quart);
}

.course-card:hover {
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-6px);
}

.course-card-image {
    position: relative;
    aspect-ratio: 16/9;
    background: linear-gradient(135deg, var(--slate-200) 0%, var(--slate-300) 100%);
    overflow: hidden;
}

.course-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--duration-slow) var(--ease-out-quart);
}

.course-card:hover .course-card-image img {
    transform: scale(1.08);
}

.course-card-preview {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.6);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity var(--duration-base) var(--ease-out-quart);
}

.course-card:hover .course-card-preview {
    opacity: 1;
}

.course-card-preview button {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-6);
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--porcelain);
    background: var(--focus-blue);
    border: none;
    border-radius: var(--radius-full);
    cursor: pointer;
    transform: translateY(10px);
    transition: all var(--duration-base) var(--ease-out-quart);
}

.course-card:hover .course-card-preview button {
    transform: translateY(0);
}

.course-card-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: rgba(255, 255, 255, 0.3);
}

.course-card-progress-bar {
    height: 100%;
    background: var(--focus-blue);
    border-radius: 0 2px 2px 0;
    transition: width var(--duration-slow);
}

.course-card-body {
    padding: var(--space-6);
}

.course-card-meta {
    display: flex;
    gap: var(--space-4);
    margin-bottom: var(--space-3);
}

.course-card-meta span {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--slate-500);
    display: flex;
    align-items: center;
    gap: var(--space-1);
}

.course-card-title {
    font-family: var(--font-display);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--slate-900);
    margin-bottom: var(--space-2);
    line-height: 1.4;
}

.course-card-description {
    font-size: 0.9rem;
    color: var(--slate-600);
    margin-bottom: var(--space-4);
    line-height: 1.6;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.course-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: var(--space-4);
    border-top: 1px solid var(--slate-100);
}

.course-card-add {
    padding: var(--space-2) var(--space-4);
    font-family: var(--font-body);
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--focus-blue);
    background: var(--focus-blue-whisper);
    border: none;
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: all var(--duration-fast) var(--ease-out-quart);
}

.course-card-add:hover {
    color: var(--porcelain);
    background: var(--focus-blue);
}

/* ----------------------------------------
   MENTORS - "YOUR PERSONAL BOARD OF ADVISORS"
   ---------------------------------------- */
.mentors-section {
    background: var(--porcelain);
}

.mentor-match-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-3);
    margin: 0 auto var(--space-12);
    padding: var(--space-4) var(--space-8);
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 600;
    color: var(--porcelain);
    background: linear-gradient(135deg, var(--focus-blue) 0%, #7C3AED 100%);
    border: none;
    border-radius: var(--radius-full);
    cursor: pointer;
    box-shadow: 0 8px 32px -8px rgba(37, 99, 235, 0.5);
    transition: all var(--duration-base) var(--ease-out-quart);
}

.mentor-match-btn:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 40px -8px rgba(37, 99, 235, 0.6);
}

.mentors-carousel {
    display: flex;
    gap: var(--space-6);
    overflow-x: auto;
    padding: var(--space-4) var(--space-2);
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.mentors-carousel::-webkit-scrollbar {
    display: none;
}

.mentor-card {
    flex: 0 0 340px;
    background: var(--soft-mist);
    border-radius: var(--radius-2xl);
    padding: var(--space-8);
    scroll-snap-align: start;
    transition: all var(--duration-slow) var(--ease-out-quart);
    border: 1px solid transparent;
}

.mentor-card:hover {
    background: var(--porcelain);
    box-shadow: var(--shadow-xl);
    border-color: var(--slate-200);
}

.mentor-card-header {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    margin-bottom: var(--space-6);
}

.mentor-avatar {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--slate-300) 0%, var(--slate-400) 100%);
    overflow: hidden;
    flex-shrink: 0;
}

.mentor-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mentor-info h3 {
    font-family: var(--font-display);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--slate-900);
    margin-bottom: var(--space-1);
}

.mentor-info p {
    font-size: 0.85rem;
    color: var(--slate-500);
}

.mentor-offerings {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.mentor-offering {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-3) var(--space-4);
    background: var(--porcelain);
    border-radius: var(--radius-lg);
    border: 1px solid var(--slate-200);
}

.mentor-offering span {
    font-size: 0.9rem;
    color: var(--slate-700);
}

.mentor-offering button {
    padding: var(--space-1) var(--space-3);
    font-family: var(--font-body);
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--focus-blue);
    background: transparent;
    border: 1.5px solid var(--focus-blue);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--duration-fast);
}

.mentor-offering button:hover {
    color: var(--porcelain);
    background: var(--focus-blue);
}

/* ----------------------------------------
   FEATURES - "THE TOOLKIT" (Bento Grid)
   ---------------------------------------- */
.bento-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: auto auto;
    gap: var(--space-6);
    max-width: 1200px;
    margin: 0 auto;
}

@media (max-width: 1024px) {
    .bento-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .bento-grid {
        grid-template-columns: 1fr;
    }
}

.bento-item {
    background: var(--porcelain);
    border-radius: var(--radius-2xl);
    padding: var(--space-8);
    border: 1px solid rgba(0, 0, 0, 0.04);
    box-shadow: var(--shadow-card);
    transition: all var(--duration-slow) var(--ease-out-quart);
    overflow: hidden;
    position: relative;
}

.bento-item:hover {
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-4px);
}

.bento-item.large {
    grid-column: span 2;
}

.bento-item.tall {
    grid-row: span 2;
}

.bento-icon {
    width: 52px;
    height: 52px;
    margin-bottom: var(--space-5);
    background: linear-gradient(135deg, var(--focus-blue-whisper) 0%, var(--focus-blue-pale) 100%);
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
}

.bento-icon svg {
    width: 24px;
    height: 24px;
    color: var(--focus-blue);
}

.bento-item h3 {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--slate-900);
    margin-bottom: var(--space-2);
}

.bento-item p {
    font-size: 0.9rem;
    color: var(--slate-600);
    line-height: 1.6;
}

/* Bento Widget Animations */
.bento-widget {
    margin-top: var(--space-6);
    padding: var(--space-4);
    background: var(--soft-mist);
    border-radius: var(--radius-lg);
}

.bento-flashcard {
    perspective: 1000px;
}

.bento-flashcard-inner {
    width: 100%;
    height: 90px;
    position: relative;
    transform-style: preserve-3d;
    transition: transform 0.8s var(--ease-out-expo);
}

.bento-item:hover .bento-flashcard-inner {
    transform: rotateY(180deg);
}

.bento-flashcard-front,
.bento-flashcard-back {
    position: absolute;
    inset: 0;
    backface-visibility: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-4);
    background: var(--porcelain);
    border-radius: var(--radius-lg);
    border: 1px solid var(--slate-200);
    font-family: var(--font-body);
    font-size: 0.9rem;
    color: var(--slate-700);
    text-align: center;
}

.bento-flashcard-back {
    transform: rotateY(180deg);
    background: var(--focus-blue);
    color: var(--porcelain);
    border: none;
}

.bento-timer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-4);
}

.bento-timer-display {
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--slate-900);
    letter-spacing: -0.02em;
}

.bento-streak {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-3);
}

.bento-streak-flame {
    font-size: 2.5rem;
    animation: flamePulse 2s ease-in-out infinite;
}

.bento-streak-count {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 800;
    color: var(--sunrise-orange);
}

/* ----------------------------------------
   GUARANTEE - "THE ACADEMY GUARANTEE"
   ---------------------------------------- */
.guarantee-section {
    background: linear-gradient(135deg, var(--focus-blue) 0%, var(--focus-blue-deep) 100%);
    position: relative;
    overflow: hidden;
}

.guarantee-section::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -20%;
    width: 60%;
    height: 200%;
    background: radial-gradient(ellipse at center, rgba(255,255,255,0.1) 0%, transparent 60%);
    pointer-events: none;
}

.guarantee-card {
    max-width: 800px;
    margin: 0 auto;
    background: var(--porcelain);
    border-radius: var(--radius-3xl);
    padding: var(--space-12) var(--space-10);
    text-align: center;
    position: relative;
    box-shadow: var(--shadow-2xl);
}

.guarantee-badge {
    position: absolute;
    top: -28px;
    left: 50%;
    transform: translateX(-50%);
    width: 56px;
    height: 56px;
    background: linear-gradient(135deg, var(--success) 0%, #059669 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 24px -4px rgba(16, 185, 129, 0.5);
}

.guarantee-badge svg {
    width: 28px;
    height: 28px;
    color: var(--porcelain);
}

.guarantee-card h2 {
    font-family: var(--font-display);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: 700;
    color: var(--slate-900);
    margin-bottom: var(--space-4);
    margin-top: var(--space-4);
}

.guarantee-card > p {
    font-size: 1.125rem;
    color: var(--slate-600);
    margin-bottom: var(--space-2);
    line-height: 1.7;
}

.guarantee-card .subtext {
    font-size: 0.95rem;
    color: var(--slate-500);
    font-style: italic;
    margin-bottom: var(--space-8);
}

/* ----------------------------------------
   FOOTER - "THE CAMPUS MAP"
   ---------------------------------------- */
.academy-footer {
    background: var(--slate-950);
    color: var(--slate-400);
    padding: var(--space-16) var(--space-8) var(--space-8);
    padding-bottom: 100px; /* Account for sticky CTA bar on mobile */
}

@media (min-width: 1024px) {
    .academy-footer {
        padding-bottom: var(--space-8); /* Reset for desktop */
    }
}

.footer-container {
    max-width: 1200px;
    margin: 0 auto;
}

.footer-grid {
    display: grid;
    grid-template-columns: 2fr repeat(3, 1fr);
    gap: var(--space-12);
    margin-bottom: var(--space-12);
}

@media (max-width: 900px) {
    .footer-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .footer-grid {
        grid-template-columns: 1fr;
    }
}

.footer-brand {
    max-width: 300px;
}

.footer-brand h3 {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--porcelain);
    margin-bottom: var(--space-4);
}

.footer-brand p {
    font-size: 0.9rem;
    line-height: 1.7;
}

.footer-column h4 {
    font-family: var(--font-body);
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--slate-300);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: var(--space-5);
}

.footer-column ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-column li {
    margin-bottom: var(--space-3);
}

.footer-column a {
    font-size: 0.9rem;
    color: var(--slate-400);
    text-decoration: none;
    transition: color var(--duration-fast);
}

.footer-column a:hover {
    color: var(--porcelain);
}

.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: var(--space-8);
    border-top: 1px solid var(--slate-800);
}

@media (max-width: 600px) {
    .footer-bottom {
        flex-direction: column;
        gap: var(--space-4);
        text-align: center;
    }
}

.footer-bottom p {
    font-size: 0.85rem;
    color: var(--slate-500);
}

.footer-social {
    display: flex;
    gap: var(--space-3);
}

.footer-social a {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--slate-800);
    border-radius: 50%;
    color: var(--slate-400);
    transition: all var(--duration-fast) var(--ease-out-quart);
}

.footer-social a:hover {
    background: var(--focus-blue);
    color: var(--porcelain);
    transform: translateY(-2px);
}

/* Sticky CTA Bar */
.sticky-cta {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--porcelain);
    padding: var(--space-4) var(--space-6);
    box-shadow: 0 -8px 32px rgba(15, 23, 42, 0.1);
    z-index: var(--z-sticky);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-6);
    transform: translateY(100%);
    transition: transform var(--duration-slow) var(--ease-out-expo);
}

.sticky-cta.visible {
    transform: translateY(0);
}

.sticky-cta p {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 600;
    color: var(--slate-700);
}

@media (max-width: 640px) {
    .sticky-cta {
        flex-direction: column;
        gap: var(--space-3);
        padding: var(--space-4);
    }

    .sticky-cta p {
        font-size: 0.9rem;
    }
}

/* ----------------------------------------
   ANIMATIONS & UTILITIES
   ---------------------------------------- */
.fade-in {
    animation: fadeIn var(--duration-slow) var(--ease-out-expo) forwards;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.slide-up {
    animation: slideUp var(--duration-slow) var(--ease-out-expo) forwards;
}

@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.stagger-1 { animation-delay: 0.1s; }
.stagger-2 { animation-delay: 0.2s; }
.stagger-3 { animation-delay: 0.3s; }
.stagger-4 { animation-delay: 0.4s; }
.stagger-5 { animation-delay: 0.5s; }

/* Container */
.container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 var(--space-8);
}

.container-sm {
    max-width: 960px;
}

.container-lg {
    max-width: 1600px;
}

/* Spacing Utilities */
.mt-0 { margin-top: 0; }
.mt-4 { margin-top: var(--space-4); }
.mt-8 { margin-top: var(--space-8); }
.mt-12 { margin-top: var(--space-12); }
.mt-16 { margin-top: var(--space-16); }

.mb-0 { margin-bottom: 0; }
.mb-4 { margin-bottom: var(--space-4); }
.mb-8 { margin-bottom: var(--space-8); }
.mb-12 { margin-bottom: var(--space-12); }
.mb-16 { margin-bottom: var(--space-16); }

/* Display Utilities */
.hidden { display: none; }
.block { display: block; }
.flex { display: flex; }
.grid { display: grid; }
.inline-flex { display: inline-flex; }

.items-center { align-items: center; }
.items-start { align-items: flex-start; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }

.gap-2 { gap: var(--space-2); }
.gap-4 { gap: var(--space-4); }
.gap-6 { gap: var(--space-6); }
.gap-8 { gap: var(--space-8); }

.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

.mb-12 { margin-bottom: var(--space-12); }

/* Width Utilities */
.w-full { width: 100%; }
.max-w-sm { max-width: 24rem; }
.max-w-md { max-width: 28rem; }
.max-w-lg { max-width: 32rem; }
.max-w-xl { max-width: 36rem; }

/* Skeleton Loader */
.skeleton {
    background: linear-gradient(
        90deg,
        var(--slate-100) 25%,
        var(--slate-200) 50%,
        var(--slate-100) 75%
    );
    background-size: 200% 100%;
    animation: skeletonShimmer 1.5s infinite;
    border-radius: var(--radius-md);
}

@keyframes skeletonShimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Page Transition */
.page-transition {
    animation: pageTransition 0.4s var(--ease-out-expo) forwards;
}

@keyframes pageTransition {
    from {
        opacity: 0;
        transform: translateY(12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ============================================
   STOREFRONT ARCHITECTURE - "DEPARTMENT STORE FOR THE MIND"
   4 Storefronts: Programs, Mentors, Classes, Library
   ============================================ */

/* ----------------------------------------
   STOREFRONT SECTION - Base Styles
   ---------------------------------------- */
.storefront {
    padding: var(--space-20) var(--space-8);
    position: relative;
}

.storefront-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: var(--space-12);
    padding-bottom: var(--space-6);
    border-bottom: 2px solid var(--slate-200);
}

.storefront-header h2 {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 2.75rem);
    font-weight: 800;
    color: var(--slate-900);
    margin: 0;
}

.storefront-header .storefront-subtitle {
    font-size: 1rem;
    color: var(--slate-500);
    margin-top: var(--space-2);
}

.storefront-header .browse-all {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--focus-blue);
    text-decoration: none;
    padding: var(--space-2) var(--space-4);
    border-radius: var(--radius-full);
    transition: all var(--duration-fast) var(--ease-out-quart);
}

.storefront-header .browse-all:hover {
    background: var(--focus-blue-whisper);
}

.storefront-header .browse-all svg {
    width: 20px;
    height: 20px;
    transition: transform var(--duration-fast);
}

.storefront-header .browse-all:hover svg {
    transform: translateX(4px);
}

@media (max-width: 768px) {
    .storefront-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-4);
    }
}

/* ----------------------------------------
   BILLBOARD - Featured Spotlight per Storefront
   ---------------------------------------- */
.billboard {
    background: linear-gradient(135deg, var(--soft-mist) 0%, var(--porcelain) 100%);
    border-radius: var(--radius-3xl);
    padding: var(--space-12);
    margin-bottom: var(--space-10);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-10);
    align-items: center;
    border: 1px solid var(--slate-200);
    position: relative;
    overflow: hidden;
}

.billboard::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 60%;
    height: 200%;
    background: radial-gradient(ellipse at center, var(--focus-blue-whisper) 0%, transparent 60%);
    opacity: 0.6;
    pointer-events: none;
}

.billboard-content {
    position: relative;
    z-index: 1;
}

.billboard-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-4);
    background: var(--sunrise-orange);
    color: var(--porcelain);
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    border-radius: var(--radius-full);
    margin-bottom: var(--space-4);
}

.billboard h3 {
    font-family: var(--font-display);
    font-size: clamp(1.75rem, 3.5vw, 2.25rem);
    font-weight: 700;
    color: var(--slate-900);
    margin-bottom: var(--space-4);
    line-height: 1.2;
}

.billboard p {
    font-size: 1.1rem;
    color: var(--slate-600);
    line-height: 1.7;
    margin-bottom: var(--space-6);
}

.billboard-visual {
    position: relative;
    z-index: 1;
    display: flex;
    justify-content: center;
    align-items: center;
}

.billboard-visual img {
    width: 100%;
    max-width: 400px;
    border-radius: var(--radius-2xl);
    box-shadow: var(--shadow-xl);
}

@media (max-width: 900px) {
    .billboard {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .billboard-visual {
        order: -1;
    }
}

/* ----------------------------------------
   AISLE - Horizontal Scroll Container
   ---------------------------------------- */
.aisle {
    display: flex;
    gap: var(--space-6);
    overflow-x: auto;
    padding: var(--space-4) var(--space-2);
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    margin: 0 calc(var(--space-8) * -1);
    padding-left: var(--space-8);
    padding-right: var(--space-8);
}

.aisle::-webkit-scrollbar {
    display: none;
}

.aisle > * {
    scroll-snap-align: start;
    flex-shrink: 0;
}

/* Aisle Navigation Buttons */
.aisle-wrapper {
    position: relative;
}

.aisle-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 48px;
    height: 48px;
    background: var(--porcelain);
    border: 2px solid var(--slate-200);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 10;
    box-shadow: var(--shadow-lg);
    transition: all var(--duration-fast) var(--ease-out-quart);
    color: var(--slate-700);
}

.aisle-nav:hover {
    background: var(--focus-blue);
    border-color: var(--focus-blue);
    color: var(--porcelain);
}

.aisle-nav.prev {
    left: var(--space-2);
}

.aisle-nav.next {
    right: var(--space-2);
}

@media (max-width: 768px) {
    .aisle-nav {
        display: none;
    }

    /* Fix: Show partial card at edge to indicate scrollability */
    .aisle {
        padding-right: var(--space-16); /* Extra space to show peek of next card */
        scroll-padding-left: var(--space-4);
    }

    .aisle > * {
        min-width: 280px;
        max-width: 85vw; /* Cards don't exceed viewport */
    }
}

/* ----------------------------------------
   SHELF - Grid Layout
   ---------------------------------------- */
.shelf {
    display: grid;
    gap: var(--space-6);
}

.shelf-3 {
    grid-template-columns: repeat(3, 1fr);
}

.shelf-4 {
    grid-template-columns: repeat(4, 1fr);
}

.shelf-auto {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

@media (max-width: 1024px) {
    .shelf-3,
    .shelf-4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .shelf-3,
    .shelf-4 {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   THE ROADMAP CARD - Programs Storefront
   Journey-focused, horizontal timeline aesthetic
   ============================================ */
.roadmap-card {
    background: var(--porcelain);
    border-radius: var(--radius-2xl);
    padding: var(--space-8);
    border: 2px solid var(--slate-200);
    transition: all var(--duration-slow) var(--ease-out-quart);
    position: relative;
    overflow: hidden;
    min-width: 360px;
}

.roadmap-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--focus-blue) 0%, var(--focus-blue-glow) 100%);
    opacity: 0;
    transition: opacity var(--duration-base);
}

.roadmap-card:hover {
    border-color: var(--focus-blue);
    box-shadow: var(--shadow-xl), var(--shadow-glow-blue);
    transform: translateY(-4px);
}

.roadmap-card:hover::before {
    opacity: 1;
}

.roadmap-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: var(--space-6);
}

.roadmap-meta {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.roadmap-icon {
    width: 56px;
    height: 56px;
    background: linear-gradient(135deg, var(--focus-blue-whisper) 0%, var(--focus-blue-pale) 100%);
    border-radius: var(--radius-xl);
    display: flex;
    align-items: center;
    justify-content: center;
}

.roadmap-icon svg {
    width: 28px;
    height: 28px;
    color: var(--focus-blue);
}

.roadmap-type {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--slate-500);
}

.roadmap-duration {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    background: var(--soft-mist);
    border-radius: var(--radius-full);
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--slate-600);
}

.roadmap-title {
    font-family: var(--font-display);
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--slate-900);
    margin-bottom: var(--space-3);
    line-height: 1.3;
}

.roadmap-description {
    font-size: 0.95rem;
    color: var(--slate-600);
    line-height: 1.6;
    margin-bottom: var(--space-6);
}

/* The Journey Timeline */
.roadmap-journey {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-4) 0;
    margin-bottom: var(--space-6);
    position: relative;
}

.roadmap-journey::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 24px;
    right: 24px;
    height: 2px;
    background: var(--slate-200);
    transform: translateY(-50%);
    z-index: 0;
}

.roadmap-milestone {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2);
    position: relative;
    z-index: 1;
}

.roadmap-milestone-dot {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--slate-300);
    border: 3px solid var(--porcelain);
    box-shadow: 0 0 0 2px var(--slate-200);
}

.roadmap-milestone.active .roadmap-milestone-dot {
    background: var(--focus-blue);
    box-shadow: 0 0 0 2px var(--focus-blue-pale);
}

.roadmap-milestone.completed .roadmap-milestone-dot {
    background: var(--success);
    box-shadow: 0 0 0 2px var(--success-pale);
}

.roadmap-milestone-label {
    font-size: 0.7rem;
    font-weight: 500;
    color: var(--slate-500);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.roadmap-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: var(--space-4);
    border-top: 1px solid var(--slate-100);
}

.roadmap-stats {
    display: flex;
    gap: var(--space-6);
}

.roadmap-stat {
    display: flex;
    flex-direction: column;
}

.roadmap-stat-value {
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--slate-900);
}

.roadmap-stat-label {
    font-size: 0.75rem;
    color: var(--slate-500);
}

/* ============================================
   THE AUTHORITY CARD - Mentors Storefront
   Tall vertical portrait, expertise-focused
   ============================================ */
.authority-card {
    background: var(--porcelain);
    border-radius: var(--radius-2xl);
    overflow: hidden;
    box-shadow: var(--shadow-card);
    transition: all var(--duration-slow) var(--ease-out-quart);
    min-width: 280px;
    width: 320px;
    max-width: 320px;
    display: flex;
    flex-direction: column;
}

.authority-card:hover {
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-6px);
}

.authority-portrait {
    position: relative;
    aspect-ratio: 3/4;
    background: linear-gradient(135deg, var(--slate-200) 0%, var(--slate-300) 100%);
    overflow: hidden;
}

.authority-portrait img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--duration-slow) var(--ease-out-quart);
}

.authority-card:hover .authority-portrait img {
    transform: scale(1.05);
}

.authority-badge {
    position: absolute;
    top: var(--space-4);
    left: var(--space-4);
    display: flex;
    gap: var(--space-2);
}

.authority-badge span {
    padding: var(--space-1) var(--space-3);
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(8px);
    border-radius: var(--radius-full);
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--slate-700);
}

.authority-badge .verified {
    background: var(--focus-blue);
    color: var(--porcelain);
}

.authority-rating {
    position: absolute;
    bottom: var(--space-4);
    right: var(--space-4);
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(8px);
    border-radius: var(--radius-full);
}

.authority-rating svg {
    width: 16px;
    height: 16px;
    color: #F59E0B;
    fill: #F59E0B;
}

.authority-rating span {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--slate-900);
}

.authority-content {
    padding: var(--space-6);
    flex: 1;
    display: flex;
    flex-direction: column;
}

.authority-name {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--slate-900);
    margin-bottom: var(--space-1);
}

.authority-title {
    font-size: 0.9rem;
    color: var(--slate-500);
    margin-bottom: var(--space-4);
}

.authority-expertise {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-bottom: var(--space-4);
}

.authority-expertise span {
    padding: var(--space-1) var(--space-3);
    background: var(--soft-mist);
    border-radius: var(--radius-full);
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--slate-600);
}

.authority-services {
    margin-top: auto;
    padding-top: var(--space-4);
    border-top: 1px solid var(--slate-100);
}

.authority-services-title {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--slate-400);
    margin-bottom: var(--space-3);
}

.authority-service {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-2) 0;
}

.authority-service span {
    font-size: 0.9rem;
    color: var(--slate-700);
}

.authority-service-price {
    font-weight: 600;
    color: var(--slate-900);
}

/* Authority card text overflow handling */
.authority-content {
    overflow: hidden;
    min-width: 0;
}

.authority-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}

.authority-title {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    max-width: 100%;
}

.authority-expertise span {
    max-width: 100px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: inline-block;
}

@media (max-width: 768px) {
    .authority-card {
        min-width: 220px;
        max-width: 260px;
    }
    .authority-content {
        padding: var(--space-4);
    }
    .authority-name {
        font-size: 1.05rem;
    }
    .authority-title {
        font-size: 0.8rem;
    }
    .authority-expertise span {
        max-width: 80px;
        font-size: 0.7rem;
    }
    .authority-service span {
        font-size: 0.8rem;
    }
}

/* ============================================
   THE POSTER CARD - Classes Storefront
   Bold, movie-poster aesthetic with cinematic feel
   ============================================ */
.poster-card {
    background: var(--slate-900);
    border-radius: var(--radius-2xl);
    overflow: hidden;
    position: relative;
    min-width: 300px;
    aspect-ratio: 3/4;
    cursor: pointer;
    transition: all var(--duration-slow) var(--ease-out-quart);
}

.poster-card:hover {
    transform: scale(1.02) translateY(-4px);
    box-shadow: 0 24px 64px -16px rgba(0, 0, 0, 0.4);
}

.poster-image {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.poster-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--duration-slow) var(--ease-out-quart);
}

.poster-card:hover .poster-image img {
    transform: scale(1.08);
}

.poster-gradient {
    position: absolute;
    inset: 0;
    /* Fix: Strong dark gradient for white text readability */
    background: linear-gradient(180deg,
        rgba(0, 0, 0, 0) 0%,
        rgba(0, 0, 0, 0.4) 20%,
        rgba(0, 0, 0, 0.8) 50%,
        rgba(0, 0, 0, 0.95) 100%
    );
    z-index: 1;
}

.poster-content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--space-8);
    z-index: 2;
}

.poster-category {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-1) var(--space-3);
    background: var(--focus-blue);
    color: var(--porcelain);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    border-radius: var(--radius-full);
    margin-bottom: var(--space-4);
}

.poster-title {
    font-family: var(--font-display);
    font-size: clamp(1.25rem, 3vw, 1.5rem);
    font-weight: 700;
    color: #ffffff;
    margin-bottom: var(--space-2);
    line-height: 1.2;
}

.poster-instructor {
    font-size: 0.9rem;
    color: #ffffff;
    margin-bottom: var(--space-4);
}

.poster-meta {
    display: flex;
    align-items: center;
    gap: var(--space-6);
}

.poster-meta-item {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: 0.85rem;
    color: #ffffff;
}

.poster-meta-item svg {
    width: 16px;
    height: 16px;
    opacity: 0.7;
}

.poster-play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0.9);
    width: 72px;
    height: 72px;
    background: rgba(255, 255, 255, 0.95);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: all var(--duration-base) var(--ease-out-quart);
    z-index: 3;
}

.poster-card:hover .poster-play {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
}

.poster-play svg {
    width: 28px;
    height: 28px;
    color: var(--slate-900);
    margin-left: 4px;
}

.poster-price {
    position: absolute;
    top: var(--space-4);
    right: var(--space-4);
    padding: var(--space-2) var(--space-4);
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(8px);
    border-radius: var(--radius-full);
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
    color: var(--slate-900);
    z-index: 2;
}

/* ============================================
   THE WIDGET CARD - Library Storefront
   Compact, utility-focused, tool-like
   ============================================ */
.widget-card {
    background: var(--porcelain);
    border-radius: var(--radius-xl);
    padding: var(--space-5);
    border: 1px solid var(--slate-200);
    transition: all var(--duration-base) var(--ease-out-quart);
    display: flex;
    align-items: flex-start;
    gap: var(--space-4);
    min-width: 280px;
}

.widget-card:hover {
    border-color: var(--focus-blue-pale);
    box-shadow: var(--shadow-md), var(--shadow-glow-blue);
    transform: translateY(-2px);
}

.widget-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.widget-icon.blue {
    background: linear-gradient(135deg, var(--focus-blue-whisper) 0%, var(--focus-blue-pale) 100%);
    color: var(--focus-blue);
}

.widget-icon.orange {
    background: linear-gradient(135deg, var(--sunrise-orange-whisper) 0%, var(--sunrise-orange-pale) 100%);
    color: var(--sunrise-orange);
}

.widget-icon.green {
    background: linear-gradient(135deg, #D1FAE5 0%, #A7F3D0 100%);
    color: #059669;
}

.widget-icon.purple {
    background: linear-gradient(135deg, #EDE9FE 0%, #DDD6FE 100%);
    color: #7C3AED;
}

.widget-icon svg {
    width: 24px;
    height: 24px;
}

.widget-content {
    flex: 1;
    min-width: 0;
}

.widget-title {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 600;
    color: var(--slate-900);
    margin-bottom: var(--space-1);
}

.widget-description {
    font-size: 0.85rem;
    color: var(--slate-500);
    line-height: 1.5;
}

.widget-meta {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    margin-top: var(--space-3);
}

.widget-meta span {
    font-size: 0.75rem;
    color: var(--slate-400);
    display: flex;
    align-items: center;
    gap: var(--space-1);
}

.widget-action {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--soft-mist);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--slate-400);
    flex-shrink: 0;
    transition: all var(--duration-fast);
}

.widget-card:hover .widget-action {
    background: var(--focus-blue);
    color: var(--porcelain);
}

/* ============================================
   SIGNATURE PROGRAMS - Film Strip Layout
   ============================================ */
.signature-programs {
    background: var(--slate-950);
    padding: var(--space-20) 0;
    overflow: hidden;
    position: relative;
}

.signature-programs::before,
.signature-programs::after {
    content: '';
    position: absolute;
    top: 0;
    width: 120px;
    height: 100%;
    z-index: 10;
    pointer-events: none;
}

.signature-programs::before {
    left: 0;
    background: linear-gradient(90deg, var(--slate-950) 0%, transparent 100%);
}

.signature-programs::after {
    right: 0;
    background: linear-gradient(-90deg, var(--slate-950) 0%, transparent 100%);
}

.signature-header {
    text-align: center;
    margin-bottom: var(--space-12);
    padding: 0 var(--space-8);
}

.signature-header h2 {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 2.75rem);
    font-weight: 800;
    color: var(--porcelain);
    margin-bottom: var(--space-4);
}

.signature-header p {
    font-size: 1.125rem;
    color: var(--slate-400);
    max-width: 600px;
    margin: 0 auto;
}

.film-strip {
    display: flex;
    gap: var(--space-6);
    padding: var(--space-4) var(--space-8);
    animation: filmScroll 60s linear infinite;
}

.film-strip:hover {
    animation-play-state: paused;
}

@keyframes filmScroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

.film-frame {
    flex-shrink: 0;
    width: 400px;
    background: var(--slate-800);
    border-radius: var(--radius-2xl);
    overflow: hidden;
    transition: all var(--duration-base) var(--ease-out-quart);
}

.film-frame:hover {
    transform: scale(1.02);
    box-shadow: 0 24px 64px -16px rgba(0, 0, 0, 0.5);
}

.film-frame-image {
    aspect-ratio: 16/9;
    background: var(--slate-700);
    position: relative;
    overflow: hidden;
}

.film-frame-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.film-frame-content {
    padding: var(--space-6);
}

.film-frame-mentor {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    margin-bottom: var(--space-4);
}

.film-frame-mentor img {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
}

.film-frame-mentor span {
    font-size: 0.9rem;
    color: var(--slate-400);
}

.film-frame h3 {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--porcelain);
    margin-bottom: var(--space-2);
}

.film-frame p {
    font-size: 0.9rem;
    color: var(--slate-400);
    line-height: 1.6;
}

/* Signature Programs mobile responsive */
@media (max-width: 768px) {
    .film-strip {
        animation: none;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        padding: var(--space-4);
    }
    .film-strip::-webkit-scrollbar {
        display: none;
    }
    .film-frame {
        width: 280px;
        scroll-snap-align: start;
    }
    .film-frame-content {
        padding: var(--space-4);
        overflow: hidden;
    }
    .film-frame h3 {
        font-size: 1.1rem;
        overflow: hidden;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
    }
    .film-frame p {
        overflow: hidden;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 3;
    }
    .film-frame-mentor {
        overflow: hidden;
    }
    .film-frame-mentor span {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        max-width: 180px;
        display: inline-block;
    }
    .signature-programs::before,
    .signature-programs::after {
        width: 40px;
    }
}

@media (max-width: 480px) {
    .film-frame {
        width: 260px;
    }
    .film-frame h3 {
        font-size: 1rem;
    }
    .film-frame p {
        font-size: 0.85rem;
    }
    .signature-programs::before,
    .signature-programs::after {
        width: 20px;
    }
}

/* ============================================
   THE FACULTY - Master-Detail Grid
   ============================================ */
.faculty-section {
    background: var(--soft-mist);
    padding: var(--space-20) var(--space-8);
}

.faculty-tabs {
    display: flex;
    justify-content: center;
    gap: var(--space-2);
    margin-bottom: var(--space-12);
    flex-wrap: wrap;
}

.faculty-tab {
    padding: var(--space-3) var(--space-6);
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--slate-600);
    background: var(--porcelain);
    border: 2px solid transparent;
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: all var(--duration-fast) var(--ease-out-quart);
}

.faculty-tab:hover {
    border-color: var(--slate-300);
}

.faculty-tab.active {
    background: var(--focus-blue);
    color: var(--porcelain);
    border-color: var(--focus-blue);
}

.faculty-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--space-6);
    max-width: 1400px;
    margin: 0 auto;
}

/* ============================================
   HOW MENTORSHIP WORKS - Process Section
   ============================================ */
.mentorship-process {
    background: var(--porcelain);
    padding: var(--space-20) var(--space-8);
}

.process-steps {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-8);
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
}

.process-steps::before {
    content: '';
    position: absolute;
    top: 48px;
    left: calc(12.5% + 32px);
    right: calc(12.5% + 32px);
    height: 2px;
    background: linear-gradient(90deg, var(--focus-blue) 0%, var(--focus-blue-glow) 50%, var(--focus-blue) 100%);
}

@media (max-width: 900px) {
    .process-steps {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }

    .process-steps::before {
        display: none;
    }
}

.process-step {
    text-align: center;
    position: relative;
    z-index: 1;
}

.process-step-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto var(--space-6);
    background: var(--focus-blue);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--porcelain);
    box-shadow: 0 8px 24px -6px rgba(37, 99, 235, 0.4);
    position: relative;
}

.process-step-icon::before {
    content: '';
    position: absolute;
    inset: -4px;
    border-radius: 50%;
    background: var(--focus-blue);
    opacity: 0.2;
}

.process-step-icon svg {
    width: 28px;
    height: 28px;
}

.process-step h3 {
    font-family: var(--font-display);
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--slate-900);
    margin-bottom: var(--space-2);
}

.process-step p {
    font-size: 0.9rem;
    color: var(--slate-600);
    line-height: 1.6;
}

/* ============================================
   SUCCESS STORIES - Testimonials
   ============================================ */
.success-stories {
    background: linear-gradient(135deg, var(--focus-blue) 0%, var(--focus-blue-deep) 100%);
    padding: var(--space-20) var(--space-8);
    position: relative;
    overflow: hidden;
}

.success-stories::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 80%;
    height: 200%;
    background: radial-gradient(ellipse at center, rgba(255,255,255,0.1) 0%, transparent 60%);
    pointer-events: none;
}

.stories-header {
    text-align: center;
    margin-bottom: var(--space-12);
    position: relative;
    z-index: 1;
}

.stories-header h2 {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 2.75rem);
    font-weight: 800;
    color: var(--porcelain);
    margin-bottom: var(--space-4);
}

.stories-header p {
    font-size: 1.125rem;
    color: rgba(255, 255, 255, 0.8);
}

.story-card {
    background: var(--porcelain);
    border-radius: var(--radius-2xl);
    padding: var(--space-8);
    max-width: 600px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.story-quote {
    font-family: var(--font-body);
    font-size: 1.125rem;
    color: var(--slate-700);
    line-height: 1.8;
    margin-bottom: var(--space-6);
    font-style: italic;
    position: relative;
    padding-left: var(--space-6);
}

.story-quote::before {
    content: '"';
    position: absolute;
    left: 0;
    top: -8px;
    font-family: var(--font-display);
    font-size: 3rem;
    color: var(--focus-blue-pale);
    line-height: 1;
}

.story-author {
    display: flex;
    align-items: center;
    gap: var(--space-4);
}

.story-author img {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    object-fit: cover;
}

.story-author-info h4 {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 600;
    color: var(--slate-900);
    margin-bottom: var(--space-1);
}

.story-author-info p {
    font-size: 0.85rem;
    color: var(--slate-500);
}

.story-mentor {
    margin-top: var(--space-6);
    padding-top: var(--space-6);
    border-top: 1px solid var(--slate-200);
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.story-mentor span {
    font-size: 0.85rem;
    color: var(--slate-500);
}

.story-mentor a {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--focus-blue);
    text-decoration: none;
}

.story-mentor a:hover {
    text-decoration: underline;
}

/* ============================================
   MOBILE RESPONSIVENESS IMPROVEMENTS
   ============================================ */

@media (max-width: 768px) {
  .storefront { padding: 48px 20px; }
  .signature-programs { padding: 48px 0; }
  .mentorship-process { padding: 48px 20px; }
  .guarantee-section .storefront,
  .guarantee-section { padding: 48px 20px; }

  .storefront-header {
    margin-bottom: 20px;
    padding-bottom: 14px;
    border-bottom-width: 1px;
    gap: 6px;
  }
  .storefront-header h2 { font-size: 1.65rem; line-height: 1.2; }
  .storefront-subtitle { font-size: 0.875rem; line-height: 1.5; margin: 0; }
  .browse-all { font-size: 0.82rem; margin-top: 4px; }

  .billboard {
    padding: 28px 24px;
    margin-bottom: 20px;
    border-radius: 24px;
    gap: 20px;
    grid-template-columns: 1fr;
  }
  .billboard-content h2 { font-size: 1.4rem; line-height: 1.25; }
  .billboard-content p { font-size: 0.875rem; }
  .billboard-badge { font-size: 0.7rem; padding: 4px 12px; }
  .billboard-visual { max-height: 200px; border-radius: 16px; }
  .billboard-visual img { border-radius: 16px; }

  .aisle {
    gap: 14px;
    padding: 10px 20px;
    margin: 0 -20px;
    scroll-padding-left: 20px;
  }

  .roadmap-card {
    min-width: 280px;
    max-width: 300px;
    padding: 22px;
    border-radius: 20px;
  }
  .roadmap-header { margin-bottom: 12px; }
  .roadmap-title { font-size: 1.05rem; line-height: 1.3; }
  .roadmap-description { font-size: 0.82rem; line-height: 1.5; }
  .roadmap-footer { margin-top: 14px; }
  .roadmap-meta { gap: 6px; }
  .roadmap-icon { width: 40px; height: 40px; }
  .roadmap-duration, .roadmap-type { font-size: 0.72rem; padding: 3px 8px; }

  .authority-card {
    min-width: 250px;
    max-width: 280px;
    border-radius: 20px;
    overflow: hidden;
  }
  .authority-portrait { height: 160px; }
  .authority-content { padding: 14px 16px 8px; }
  .authority-name { font-size: 1rem; }
  .authority-title { font-size: 0.78rem; line-height: 1.4; }
  .authority-expertise { gap: 4px; margin: 8px 0; }
  .authority-expertise span { font-size: 0.68rem; padding: 2px 8px; max-width: 90px; }
  .authority-services { padding: 10px 16px 14px; }
  .authority-service { padding: 6px 0; }
  .authority-service span { font-size: 0.78rem; }
  .authority-badge { font-size: 0.65rem; }
  .authority-rating { font-size: 0.78rem; }

  .poster-card {
    min-width: 260px;
    max-width: 280px;
    border-radius: 20px;
    height: 360px;
  }
  .poster-card h3 { font-size: 1.1rem; }
  .poster-meta { font-size: 0.78rem; }
  .poster-price { font-size: 0.85rem; }
  .poster-badge { font-size: 0.65rem; }

  .signature-programs .container { padding: 0 20px; }
  .signature-programs h2 { font-size: 1.65rem; margin-bottom: 8px; }
  .signature-programs p { font-size: 0.875rem; }
  .film-strip { gap: 14px; padding: 16px 20px; }
  .film-frame { min-width: 280px; border-radius: 16px; }
  .film-frame h3 { font-size: 1.05rem; }
  .film-frame p { font-size: 0.8rem; line-height: 1.5; }

  .mentorship-process h2 { font-size: 1.65rem; }
  .process-steps { gap: 28px; padding: 0 8px; }
  .process-step h3 { font-size: 1.1rem; }
  .process-step p { font-size: 0.82rem; line-height: 1.6; }
  .process-icon, .process-step-icon { width: 56px; height: 56px; margin-bottom: 12px; }

  #library .storefront-header { text-align: center; align-items: center; }
  #library .storefront-subtitle { text-align: center; }

  .guarantee-card { padding: 32px 24px; border-radius: 24px; }
  .guarantee-card h2 { font-size: 1.4rem; line-height: 1.3; }
  .guarantee-card p { font-size: 0.85rem; line-height: 1.6; }

  .section-header h2 { font-size: 1.65rem; }
  .section-header p { font-size: 0.875rem; }

  .mentor-match-btn { padding: 12px 24px; font-size: 0.85rem; border-radius: 50px; }
  .text-center.mb-12 { margin-bottom: 16px !important; }
  .aisle-wrapper { margin-top: 0; }
  footer { padding: 40px 20px 24px; }
}

@media (max-width: 480px) {
  .storefront { padding: 36px 16px; }
  .signature-programs { padding: 36px 0; }
  .mentorship-process { padding: 36px 16px; }
  .storefront-header { margin-bottom: 16px; padding-bottom: 12px; }
  .storefront-header h2 { font-size: 1.45rem; }

  .aisle { gap: 12px; padding: 10px 16px; margin: 0 -16px; scroll-padding-left: 16px; }

  .roadmap-card { min-width: 260px; max-width: 280px; padding: 18px; border-radius: 16px; }
  .roadmap-title { font-size: 1rem; }

  .authority-card { min-width: 230px; max-width: 260px; border-radius: 16px; }
  .authority-portrait { height: 140px; }

  .poster-card { min-width: 240px; max-width: 260px; border-radius: 16px; height: 340px; }

  .billboard { padding: 22px 18px; border-radius: 18px; gap: 16px; margin-bottom: 16px; }
  .billboard-content h2 { font-size: 1.25rem; }

  .film-frame { min-width: 260px; border-radius: 14px; }
  .signature-programs h2 { font-size: 1.45rem; }
  .signature-programs .container { padding: 0 16px; }
  .film-strip { padding: 12px 16px; }

  .guarantee-card { padding: 28px 18px; border-radius: 18px; }
  .process-steps { gap: 24px; padding: 0; }
}

/* ============================================
   PATHWAYS GALLERY - Programs Index Page
   ============================================ */

.pathways-gallery {
    min-height: 100vh;
    background: var(--porcelain);
}

/* ----------------------------------------
   Hero Section
   ---------------------------------------- */
.pathways-hero {
    padding: calc(var(--space-32) + var(--space-8)) var(--space-8) var(--space-16);
    background: linear-gradient(180deg, var(--soft-mist) 0%, var(--porcelain) 100%);
    position: relative;
    overflow: hidden;
}

.pathways-hero::before {
    content: '';
    position: absolute;
    top: -30%;
    right: -15%;
    width: 60%;
    height: 140%;
    background: radial-gradient(ellipse at center, var(--focus-blue-whisper) 0%, transparent 60%);
    opacity: 0.7;
    pointer-events: none;
}

.pathways-hero-inner {
    max-width: 1400px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-16);
    align-items: center;
    position: relative;
    z-index: 1;
}

@media (max-width: 1024px) {
    .pathways-hero-inner {
        grid-template-columns: 1fr;
        text-align: center;
    }
}

.pathways-hero-content {
    animation: fadeInUp 0.8s var(--ease-out-expo) forwards;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.pathways-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-4);
    background: var(--focus-blue-whisper);
    border: 1px solid var(--focus-blue-pale);
    border-radius: var(--radius-full);
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--focus-blue);
    margin-bottom: var(--space-6);
}

.pathways-eyebrow svg {
    width: 18px;
    height: 18px;
}

.pathways-hero-content h1 {
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 800;
    color: var(--slate-900);
    margin-bottom: var(--space-6);
    line-height: 1.1;
}

.pathways-hero-content h1 em {
    font-style: normal;
    background: linear-gradient(135deg, var(--focus-blue) 0%, #8B5CF6 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.pathways-subtitle {
    font-size: 1.15rem;
    color: var(--slate-600);
    line-height: 1.7;
    margin-bottom: var(--space-8);
    max-width: 540px;
}

@media (max-width: 1024px) {
    .pathways-subtitle {
        margin-left: auto;
        margin-right: auto;
    }
}

/* Search Bar */
.pathways-search {
    margin-bottom: var(--space-10);
}

.pathways-search-inner {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-2);
    background: var(--porcelain);
    border: 2px solid var(--slate-200);
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-lg);
    max-width: 580px;
    transition: all var(--duration-base) var(--ease-out-quart);
}

.pathways-search-inner:focus-within {
    border-color: var(--focus-blue);
    box-shadow: var(--shadow-lg), 0 0 0 4px var(--focus-blue-whisper);
}

.pathways-search-inner svg {
    width: 22px;
    height: 22px;
    color: var(--slate-400);
    margin-left: var(--space-4);
    flex-shrink: 0;
}

.pathways-search-inner input {
    flex: 1;
    padding: var(--space-3) var(--space-2);
    font-family: var(--font-body);
    font-size: 1rem;
    color: var(--slate-800);
    background: transparent;
    border: none;
    outline: none;
    min-width: 0;
}

.pathways-search-inner input::placeholder {
    color: var(--slate-400);
}

@media (max-width: 640px) {
    .pathways-search-inner {
        flex-direction: column;
        border-radius: var(--radius-2xl);
        padding: var(--space-3);
    }

    .pathways-search-inner svg {
        display: none;
    }

    .pathways-search-inner input {
        width: 100%;
        text-align: center;
    }

    .pathways-search-inner .btn {
        width: 100%;
    }
}

/* Stats */
.pathways-stats {
    display: flex;
    align-items: center;
    gap: var(--space-6);
}

@media (max-width: 1024px) {
    .pathways-stats {
        justify-content: center;
    }
}

.pathways-stats .stat {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.pathways-stats .stat-value {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--slate-900);
}

.pathways-stats .stat-label {
    font-size: 0.85rem;
    color: var(--slate-500);
}

.pathways-stats .stat-divider {
    width: 1px;
    height: 40px;
    background: var(--slate-200);
}

/* Hero Visual */
.pathways-hero-visual {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 400px;
}

@media (max-width: 1024px) {
    .pathways-hero-visual {
        display: none;
    }
}

.journey-cards-float {
    position: relative;
    width: 100%;
    height: 400px;
}

.journey-float-card {
    position: absolute;
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-4) var(--space-5);
    background: var(--porcelain);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    border: 1px solid rgba(255, 255, 255, 0.8);
}

.journey-float-card span {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--slate-800);
}

.journey-float-icon {
    width: 44px;
    height: 44px;
    background: linear-gradient(135deg, var(--focus-blue-whisper) 0%, var(--focus-blue-pale) 100%);
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
}

.journey-float-icon svg {
    width: 22px;
    height: 22px;
    color: var(--focus-blue);
}

.journey-float-icon.orange {
    background: linear-gradient(135deg, var(--sunrise-orange-whisper) 0%, var(--sunrise-orange-pale) 100%);
}

.journey-float-icon.orange svg {
    color: var(--sunrise-orange);
}

.journey-float-icon.success {
    background: linear-gradient(135deg, var(--success-pale) 0%, #A7F3D0 100%);
}

.journey-float-icon.success svg {
    color: var(--success);
}

.journey-float-1 {
    top: 10%;
    left: 5%;
    animation: floatCard1 8s ease-in-out infinite;
}

.journey-float-2 {
    top: 40%;
    right: 10%;
    animation: floatCard2 10s ease-in-out infinite;
}

.journey-float-3 {
    bottom: 10%;
    left: 15%;
    animation: floatCard3 9s ease-in-out infinite;
}

@keyframes floatCard1 {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50% { transform: translateY(-20px) rotate(2deg); }
}

@keyframes floatCard2 {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50% { transform: translateY(-15px) rotate(-2deg); }
}

@keyframes floatCard3 {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50% { transform: translateY(-18px) rotate(1deg); }
}

/* ----------------------------------------
   Content Section
   ---------------------------------------- */
.pathways-content {
    padding: var(--space-16) var(--space-8);
}

.pathways-container {
    max-width: 1400px;
    margin: 0 auto;
}

.pathways-layout {
    display: grid;
    gap: var(--space-10);
}

.pathways-layout.with-sidebar {
    grid-template-columns: 280px 1fr;
}

@media (max-width: 1024px) {
    .pathways-layout.with-sidebar {
        grid-template-columns: 1fr;
    }
}

/* ----------------------------------------
   Sidebar Filters
   ---------------------------------------- */
.pathways-sidebar {
    position: relative;
}

.mobile-filter-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    width: 100%;
    padding: var(--space-4);
    background: var(--porcelain);
    border: 2px solid var(--slate-200);
    border-radius: var(--radius-xl);
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--slate-700);
    cursor: pointer;
    margin-bottom: var(--space-4);
}

.mobile-filter-toggle svg {
    width: 20px;
    height: 20px;
}

@media (max-width: 1024px) {
    .mobile-filter-toggle {
        display: flex;
    }

    .filter-panel {
        display: none;
    }

    .filter-panel.open {
        display: block;
    }
}

.filter-panel {
    background: var(--porcelain);
    border-radius: var(--radius-2xl);
    border: 2px solid var(--slate-200);
    padding: var(--space-6);
    position: sticky;
    top: 100px;
}

.filter-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-6);
    padding-bottom: var(--space-4);
    border-bottom: 1px solid var(--slate-200);
}

.filter-panel-header h3 {
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--slate-900);
    margin: 0;
}

.clear-filters {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--focus-blue);
    text-decoration: none;
}

.clear-filters:hover {
    text-decoration: underline;
}

.filter-group {
    border-bottom: 1px solid var(--slate-100);
    padding-bottom: var(--space-4);
    margin-bottom: var(--space-4);
}

.filter-group:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.filter-group-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: var(--space-2) 0;
    background: transparent;
    border: none;
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--slate-700);
    cursor: pointer;
}

.filter-group-header svg {
    width: 16px;
    height: 16px;
    color: var(--slate-400);
    transition: transform var(--duration-fast);
}

.filter-group-header svg.rotate-180 {
    transform: rotate(180deg);
}

.filter-group-content {
    padding-top: var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.filter-option {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-2);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: background var(--duration-fast);
}

.filter-option:hover {
    background: var(--soft-mist);
}

.filter-option input {
    display: none;
}

.filter-radio {
    width: 18px;
    height: 18px;
    border: 2px solid var(--slate-300);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all var(--duration-fast);
}

.filter-option input:checked + .filter-radio {
    border-color: var(--focus-blue);
    background: var(--focus-blue);
}

.filter-option input:checked + .filter-radio::after {
    content: '';
    width: 6px;
    height: 6px;
    background: var(--porcelain);
    border-radius: 50%;
}

.filter-label {
    font-size: 0.9rem;
    color: var(--slate-600);
}

.filter-option input:checked ~ .filter-label {
    color: var(--slate-900);
    font-weight: 500;
}

/* ----------------------------------------
   Results Header
   ---------------------------------------- */
.results-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--space-4);
    margin-bottom: var(--space-8);
    padding-bottom: var(--space-6);
    border-bottom: 2px solid var(--slate-200);
}

.results-count {
    display: flex;
    align-items: baseline;
    gap: var(--space-2);
    flex-wrap: wrap;
}

.results-count .count-number {
    font-family: var(--font-display);
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--slate-900);
}

.results-count .count-label {
    font-size: 1rem;
    color: var(--slate-500);
}

.results-count .search-term {
    font-size: 0.95rem;
    color: var(--focus-blue);
    font-weight: 500;
}

.sort-form {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.sort-label {
    font-size: 0.9rem;
    color: var(--slate-500);
}

.sort-select {
    padding: var(--space-2) var(--space-4);
    font-family: var(--font-body);
    font-size: 0.9rem;
    color: var(--slate-700);
    background: var(--porcelain);
    border: 2px solid var(--slate-200);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: border-color var(--duration-fast);
}

.sort-select:focus {
    outline: none;
    border-color: var(--focus-blue);
}

/* ----------------------------------------
   Programs Grid (Programs Index page)
   ---------------------------------------- */
.pathways-gallery .programs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: var(--space-6);
}

@media (max-width: 768px) {
    .pathways-gallery .programs-grid {
        grid-template-columns: 1fr;
    }
}

/* ----------------------------------------
   Roadmap Card - Enhanced (Programs Index)
   Scoped under .pathways-gallery to avoid
   conflicting with storefront aisle cards
   ---------------------------------------- */
.pathways-gallery .roadmap-card {
    display: flex;
    flex-direction: column;
    background: var(--porcelain);
    border-radius: var(--radius-2xl);
    border: 2px solid var(--slate-200);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: all var(--duration-slow) var(--ease-out-quart);
    position: relative;
    padding: 0;
    min-width: 0;
}

.pathways-gallery .roadmap-card::before {
    display: none;
}

.pathways-gallery .roadmap-card:hover {
    border-color: var(--focus-blue);
    box-shadow: var(--shadow-xl), 0 0 0 4px var(--focus-blue-whisper);
    transform: translateY(-6px);
}

.roadmap-card-top {
    position: absolute;
    top: var(--space-4);
    left: var(--space-4);
    z-index: 2;
}

.roadmap-badge {
    display: inline-flex;
    padding: var(--space-1) var(--space-3);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    border-radius: var(--radius-full);
}

.roadmap-badge.discount {
    background: var(--sunrise-orange);
    color: var(--porcelain);
}

.roadmap-badge.free {
    background: var(--success);
    color: var(--porcelain);
}

.roadmap-badge.level {
    background: var(--slate-800);
    color: var(--porcelain);
}

.roadmap-badge.level-beginner {
    background: var(--success);
}

.roadmap-badge.level-intermediate {
    background: var(--warning);
    color: var(--slate-900);
}

.roadmap-badge.level-advanced {
    background: var(--error);
}

.roadmap-visual {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
}

.roadmap-visual img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--duration-slow) var(--ease-out-quart);
}

.pathways-gallery .roadmap-card:hover .roadmap-visual img {
    transform: scale(1.05);
}

.pathways-gallery .roadmap-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: var(--space-6);
}

.roadmap-categories {
    display: flex;
    gap: var(--space-2);
    flex-wrap: wrap;
    margin-bottom: var(--space-3);
}

.category-tag {
    padding: var(--space-1) var(--space-3);
    background: var(--focus-blue-whisper);
    color: var(--focus-blue);
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: var(--radius-full);
}

.pathways-gallery .roadmap-title {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--slate-900);
    margin-bottom: var(--space-2);
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.pathways-gallery .roadmap-description {
    font-size: 0.9rem;
    color: var(--slate-600);
    line-height: 1.6;
    margin-bottom: var(--space-4);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Journey Mini Timeline */
.roadmap-journey-mini {
    display: flex;
    align-items: center;
    padding: var(--space-4) 0;
    margin-bottom: var(--space-4);
}

.journey-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-1);
    flex-shrink: 0;
}

.step-dot {
    width: 12px;
    height: 12px;
    background: var(--slate-200);
    border-radius: 50%;
    border: 2px solid var(--porcelain);
    box-shadow: 0 0 0 2px var(--slate-200);
}

.journey-step.completed .step-dot {
    background: var(--focus-blue);
    box-shadow: 0 0 0 2px var(--focus-blue);
}

.step-label {
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--slate-400);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.journey-step.completed .step-label {
    color: var(--focus-blue);
}

.journey-line {
    flex: 1;
    height: 2px;
    background: var(--slate-200);
    margin: 0 var(--space-2);
    margin-top: calc(-1 * var(--space-5));
}

/* Stats */
.pathways-gallery .roadmap-stats {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    margin-top: auto;
}

.stat-item {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    font-size: 0.85rem;
    color: var(--slate-500);
}

.stat-item svg {
    width: 16px;
    height: 16px;
}

.stat-item.rating {
    color: var(--warning);
}

.stat-item.rating svg {
    width: 14px;
    height: 14px;
}

/* Footer */
.pathways-gallery .roadmap-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-4) var(--space-6);
    background: var(--soft-mist);
    border-top: 1px solid var(--slate-200);
}

.roadmap-price {
    display: flex;
    align-items: baseline;
    gap: var(--space-2);
}

.price-current {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--slate-900);
}

.price-current.free {
    color: var(--success);
}

.price-original {
    font-size: 0.9rem;
    color: var(--slate-400);
    text-decoration: line-through;
}

.roadmap-cta {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--focus-blue);
}

.roadmap-cta svg {
    width: 18px;
    height: 18px;
    transition: transform var(--duration-fast);
}

.pathways-gallery .roadmap-card:hover .roadmap-cta svg {
    transform: translateX(4px);
}

/* ----------------------------------------
   Empty State
   ---------------------------------------- */
.empty-state {
    text-align: center;
    padding: var(--space-20) var(--space-8);
}

.empty-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto var(--space-6);
    background: var(--soft-mist);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.empty-icon svg {
    width: 40px;
    height: 40px;
    color: var(--slate-400);
}

.empty-state h3 {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--slate-900);
    margin-bottom: var(--space-3);
}

.empty-state p {
    color: var(--slate-600);
    margin-bottom: var(--space-6);
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
}

/* ----------------------------------------
   Pagination
   ---------------------------------------- */
.pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    margin-top: var(--space-12);
}

.page-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-5);
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--slate-600);
    background: var(--porcelain);
    border: 2px solid var(--slate-200);
    border-radius: var(--radius-lg);
    text-decoration: none;
    transition: all var(--duration-fast) var(--ease-out-quart);
}

.page-btn:hover:not(.disabled) {
    border-color: var(--focus-blue);
    color: var(--focus-blue);
}

.page-btn.disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.page-btn svg {
    width: 16px;
    height: 16px;
}

.page-numbers {
    display: flex;
    align-items: center;
    gap: var(--space-1);
}

.page-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--slate-600);
    background: var(--porcelain);
    border: 2px solid transparent;
    border-radius: var(--radius-md);
    text-decoration: none;
    transition: all var(--duration-fast);
}

.page-num:hover:not(.active) {
    background: var(--soft-mist);
}

.page-num.active {
    background: var(--focus-blue);
    color: var(--porcelain);
    font-weight: 600;
}

.page-ellipsis {
    padding: 0 var(--space-2);
    color: var(--slate-400);
}

@media (max-width: 640px) {
    .pagination {
        flex-wrap: wrap;
    }

    .page-numbers {
        order: -1;
        width: 100%;
        justify-content: center;
        margin-bottom: var(--space-3);
    }
}

/* ============================================
   PROGRAMS INDEX - Mobile UI Fixes
   ============================================ */

/* ===== FIX 1: Cards fill available width on mobile ===== */
@media (max-width: 768px) {
  .pathways-gallery .roadmap-card {
    min-width: 0px !important;
    max-width: none !important;
    width: 100% !important;
    padding: 0px !important;
    border-radius: 20px !important;
  }
}
@media (max-width: 480px) {
  .pathways-gallery .roadmap-card {
    border-radius: 16px !important;
  }
}

/* ===== FIX 2: Sticky CTA bar — compact single row ===== */
@media (max-width: 768px) {
  .sticky-cta {
    flex-direction: row !important;
    gap: 12px !important;
    padding: 10px 16px !important;
    align-items: center !important;
    justify-content: center !important;
  }
  .sticky-cta p {
    white-space: nowrap;
    font-size: 0.85rem !important;
    margin: 0px !important;
  }
  .sticky-cta a.btn {
    white-space: nowrap;
    padding: 8px 20px !important;
    font-size: 0.85rem !important;
  }
}
@media (max-width: 380px) {
  .sticky-cta {
    flex-direction: column !important;
    padding: 8px 12px !important;
    gap: 6px !important;
  }
  .sticky-cta p {
    font-size: 0.8rem !important;
  }
}

/* ===== FIX 3: Price text no-wrap in card footer ===== */
@media (max-width: 768px) {
  .pathways-gallery .roadmap-footer {
    padding: 12px 16px !important;
  }
  .pathways-gallery .price-current {
    font-size: 1rem !important;
    white-space: nowrap !important;
  }
  .pathways-gallery .roadmap-cta {
    font-size: 0.85rem !important;
    white-space: nowrap !important;
  }
}

/* ===== FIX 4: Hero top padding reduced ===== */
@media (max-width: 768px) {
  .pathways-hero {
    padding: 100px 20px 40px !important;
  }
}
@media (max-width: 480px) {
  .pathways-hero {
    padding: 88px 14px 28px !important;
  }
}

/* ===== FIX 5: Content section + gallery bottom padding ===== */
@media (max-width: 768px) {
  .pathways-content {
    padding: 28px 16px !important;
  }
  .pathways-gallery {
    padding-bottom: 80px !important;
  }
}
@media (max-width: 480px) {
  .pathways-content {
    padding: 20px 12px !important;
  }
}

/* ===== FIX 6: Card body / visual sizing ===== */
@media (max-width: 768px) {
  .pathways-gallery .roadmap-visual {
    aspect-ratio: 16 / 9;
    max-height: 180px;
  }
  .pathways-gallery .roadmap-body {
    padding: 16px !important;
  }
  .pathways-gallery .roadmap-title {
    font-size: 1.1rem !important;
  }
  .pathways-gallery .roadmap-description {
    font-size: 0.88rem !important;
  }
}
@media (max-width: 480px) {
  .pathways-gallery .roadmap-visual {
    max-height: 140px;
  }
  .pathways-gallery .roadmap-body {
    padding: 12px 14px 8px !important;
  }
  .pathways-gallery .roadmap-title {
    font-size: 1rem !important;
  }
}

/* ===== FIX 7: Results header stacking ===== */
@media (max-width: 640px) {
  .results-header {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 10px !important;
  }
}

/* ===== FIX 8: Hero text sizing ===== */
@media (max-width: 768px) {
  .pathways-hero-content h1,
  .pathways-hero-content .display-lg {
    font-size: 2rem !important;
    line-height: 1.15 !important;
  }
  .pathways-subtitle {
    font-size: 0.9rem !important;
    line-height: 1.55 !important;
    max-width: 360px !important;
  }
  .pathways-eyebrow {
    font-size: 0.75rem !important;
    padding: 6px 14px !important;
  }
  .pathways-stats {
    gap: 20px !important;
  }
  .pathways-stats .stat-value {
    font-size: 1.35rem !important;
  }
  .pathways-stats .stat-label {
    font-size: 0.7rem !important;
  }
}
@media (max-width: 480px) {
  .pathways-hero-content h1,
  .pathways-hero-content .display-lg {
    font-size: 1.7rem !important;
  }
  .pathways-subtitle {
    font-size: 0.82rem !important;
  }
  .pathways-stats {
    gap: 14px !important;
    flex-wrap: wrap !important;
  }
  .pathways-stats .stat-value {
    font-size: 1.2rem !important;
  }
}

/* ===== FIX 9: Journey timeline mini + stat items ===== */
@media (max-width: 768px) {
  .pathways-gallery .roadmap-journey-mini {
    padding: 10px 0px 6px !important;
    margin-bottom: 6px !important;
  }
  .pathways-gallery .journey-step .step-label {
    font-size: 0.6rem !important;
  }
  .pathways-gallery .journey-step .step-dot {
    width: 18px !important;
    height: 18px !important;
  }
  .pathways-gallery .roadmap-stats {
    gap: 10px !important;
  }
  .pathways-gallery .stat-item {
    font-size: 0.78rem !important;
  }
}

/* ===== FIX 10: Pagination ===== */
@media (max-width: 480px) {
  .pagination {
    flex-wrap: wrap !important;
    gap: 8px !important;
  }
  .page-btn {
    padding: 8px 14px !important;
    font-size: 0.85rem !important;
  }
}

/* ============================================
   SCREENING ROOM - Courses Index Page
   ============================================ */

.screening-room {
    min-height: 100vh;
    background: var(--porcelain);
}

/* Hero */
.screening-hero {
    padding: calc(var(--space-32) + var(--space-8)) var(--space-8) var(--space-16);
    background: linear-gradient(180deg, var(--sunrise-orange-whisper) 0%, var(--porcelain) 100%);
    position: relative;
    overflow: hidden;
}

.screening-hero::before {
    content: '';
    position: absolute;
    top: -30%;
    right: -15%;
    width: 60%;
    height: 140%;
    background: radial-gradient(ellipse at center, rgba(249, 115, 22, 0.1) 0%, transparent 60%);
    pointer-events: none;
}

.screening-hero-inner {
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
    position: relative;
    z-index: 1;
}

.screening-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-4);
    background: var(--sunrise-orange-whisper);
    border: 1px solid var(--sunrise-orange-pale);
    border-radius: var(--radius-full);
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--sunrise-orange);
    margin-bottom: var(--space-6);
}
.screening-eyebrow svg { width: 18px; height: 18px; }

.screening-hero-content h1 {
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 800;
    color: var(--slate-900);
    margin-bottom: var(--space-6);
    line-height: 1.1;
}
.screening-hero-content h1 em {
    font-style: normal;
    background: linear-gradient(135deg, var(--sunrise-orange) 0%, #ea580c 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.screening-subtitle {
    font-size: 1.15rem;
    color: var(--slate-600);
    line-height: 1.7;
    margin-bottom: var(--space-8);
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

/* Search */
.screening-search-inner {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-2);
    background: var(--porcelain);
    border: 2px solid var(--slate-200);
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-lg);
    max-width: 580px;
    margin: 0 auto;
    transition: all var(--duration-base) var(--ease-out-quart);
}
.screening-search-inner:focus-within {
    border-color: var(--sunrise-orange);
    box-shadow: var(--shadow-lg), 0 0 0 4px var(--sunrise-orange-whisper);
}
.screening-search-inner svg { width: 22px; height: 22px; color: var(--slate-400); margin-left: var(--space-4); flex-shrink: 0; }
.screening-search-inner input {
    flex: 1;
    padding: var(--space-3) var(--space-2);
    font-family: var(--font-body);
    font-size: 1rem;
    color: var(--slate-800);
    background: transparent;
    border: none;
    outline: none;
    min-width: 0;
}
.screening-search-inner input::placeholder { color: var(--slate-400); }

@media (max-width: 640px) {
    .screening-search-inner { flex-direction: column; border-radius: var(--radius-2xl); padding: var(--space-3); }
    .screening-search-inner svg { display: none; }
    .screening-search-inner input { width: 100%; text-align: center; }
    .screening-search-inner .btn { width: 100%; }
}

/* Content Layout */
.screening-content { padding: var(--space-16) var(--space-8); }
.screening-container { max-width: 1400px; margin: 0 auto; }
.screening-layout { display: grid; gap: var(--space-10); }
.screening-layout.with-sidebar { grid-template-columns: 280px 1fr; }

@media (max-width: 1024px) {
    .screening-layout.with-sidebar { grid-template-columns: 1fr; }
}

/* Sidebar */
.screening-sidebar { position: relative; }

/* Courses Grid */
.screening-room .courses-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--space-6);
}

/* Poster Card (Courses Index) */
.screening-room .poster-card {
    display: flex;
    flex-direction: column;
    background: var(--porcelain);
    border-radius: var(--radius-2xl);
    border: 2px solid var(--slate-200);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: all var(--duration-slow) var(--ease-out-quart);
    min-width: 0;
}
.screening-room .poster-card:hover {
    border-color: var(--sunrise-orange);
    box-shadow: var(--shadow-xl), 0 0 0 4px var(--sunrise-orange-whisper);
    transform: translateY(-4px);
}

.screening-room .poster-visual { position: relative; aspect-ratio: 16/9; overflow: hidden; }
.screening-room .poster-visual img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--duration-slow) var(--ease-out-quart); }
.screening-room .poster-card:hover .poster-visual img { transform: scale(1.05); }

.poster-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity var(--duration-base);
}
.screening-room .poster-card:hover .poster-overlay { opacity: 1; }

.play-icon {
    width: 56px;
    height: 56px;
    background: var(--porcelain);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-xl);
}
.play-icon svg { width: 24px; height: 24px; color: var(--sunrise-orange); margin-left: 4px; }

.poster-badges { position: absolute; top: var(--space-3); left: var(--space-3); display: flex; flex-wrap: wrap; gap: var(--space-2); }
.poster-badges .badge { padding: var(--space-1) var(--space-2); font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; border-radius: var(--radius-sm); }
.poster-badges .badge.level { background: var(--slate-800); color: var(--porcelain); }
.poster-badges .badge.level-beginner { background: var(--success); }
.poster-badges .badge.level-intermediate { background: var(--warning); color: var(--slate-900); }
.poster-badges .badge.level-advanced { background: var(--error); }
.poster-badges .badge.bestseller { background: var(--sunrise-orange); color: var(--porcelain); }
.poster-badges .badge.new { background: var(--focus-blue); color: var(--porcelain); }

.screening-room .poster-content { flex: 1; padding: var(--space-5); display: flex; flex-direction: column; }
.screening-room .poster-category { display: inline-block; font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--focus-blue); background: color-mix(in srgb, var(--focus-blue) 10%, transparent); padding: 2px 8px; border-radius: var(--radius-sm); margin-bottom: var(--space-2); }
.screening-room .poster-title { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; color: var(--slate-900); margin-bottom: var(--space-1); line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.screening-room .poster-description { font-size: 0.85rem; color: var(--slate-600); margin-bottom: var(--space-2); line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.screening-room .poster-instructor { font-size: 0.85rem; color: var(--slate-500); margin-bottom: var(--space-3); }

.screening-room .poster-meta { margin-bottom: var(--space-3); }
.meta-rating { display: flex; align-items: center; gap: var(--space-1); font-size: 0.9rem; font-weight: 600; color: var(--slate-800); }
.meta-rating svg { width: 16px; height: 16px; color: #fbbf24; }
.meta-rating .students { font-weight: 400; color: var(--slate-500); }

.poster-stats { display: flex; gap: var(--space-4); margin-top: auto; }
.poster-stats .stat { display: flex; align-items: center; gap: var(--space-1); font-size: 0.8rem; color: var(--slate-500); }
.poster-stats .stat svg { width: 14px; height: 14px; }

.poster-footer { padding: var(--space-4) var(--space-5); background: var(--soft-mist); border-top: 1px solid var(--slate-200); }
.screening-room .poster-price { display: flex; align-items: baseline; gap: var(--space-2); }
.screening-room .price-current { font-family: var(--font-display); font-size: 1.15rem; font-weight: 700; color: var(--slate-900); }
.screening-room .price-current.free { color: var(--success); }

/* ============================================
   COURSES INDEX - Mobile Responsive
   ============================================ */

@media (max-width: 768px) {
    /* Hero */
    .screening-hero {
        padding: 100px 20px 40px;
    }
    .screening-hero-content h1 {
        font-size: 2rem;
    }
    .screening-subtitle {
        font-size: 0.9rem;
        line-height: 1.55;
    }
    .screening-eyebrow {
        font-size: 0.75rem;
        padding: 6px 14px;
    }

    /* Content */
    .screening-content {
        padding: 28px 16px;
    }
    .screening-room {
        padding-bottom: 80px;
    }

    /* Grid: single column */
    .screening-room .courses-grid {
        grid-template-columns: 1fr;
    }

    /* Cards full width */
    .screening-room .poster-card {
        max-width: none;
        width: 100%;
        min-width: 0;
    }

    /* Card visual sizing */
    .screening-room .poster-visual {
        max-height: 200px;
    }
    .poster-content {
        padding: 16px;
    }
    .poster-title {
        font-size: 1rem;
    }
    .poster-instructor {
        font-size: 0.8rem;
        margin-bottom: var(--space-2);
    }
    .poster-stats .stat {
        font-size: 0.75rem;
    }
    .poster-footer {
        padding: 12px 16px;
    }
    .screening-room .price-current {
        font-size: 1rem;
        white-space: nowrap;
    }

    /* Results header stack */
    .screening-room .results-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }
}

@media (max-width: 480px) {
    .screening-hero {
        padding: 88px 14px 28px;
    }
    .screening-hero-content h1 {
        font-size: 1.7rem;
    }
    .screening-subtitle {
        font-size: 0.82rem;
    }
    .screening-content {
        padding: 20px 12px;
    }
    .screening-room .poster-visual {
        max-height: 160px;
    }
    .poster-content {
        padding: 12px;
    }
    .poster-title {
        font-size: 0.95rem;
    }
    .poster-footer {
        padding: 10px 12px;
    }
    .play-icon {
        width: 44px;
        height: 44px;
    }
    .play-icon svg {
        width: 20px;
        height: 20px;
    }
}

/* ============================================
   FEATURE PRESENTATION — Course Details
   ============================================ */

.feature-presentation { min-height: 100vh; background: var(--porcelain); }

/* Hero */
.presentation-hero { position: relative; padding: calc(var(--space-16) + var(--space-4)) var(--space-8) var(--space-6); overflow: hidden; }
.presentation-hero-bg { position: absolute; inset: 0; background: linear-gradient(135deg, var(--focus-blue) 0%, #1a2744 60%, #2a1f3d 100%); }
.presentation-hero-bg::after { content: ''; position: absolute; inset: 0; background-image: radial-gradient(circle at 20% 80%, rgba(249, 115, 22, 0.08) 0%, transparent 50%), radial-gradient(circle at 80% 20%, rgba(59, 130, 246, 0.1) 0%, transparent 50%); }

.presentation-hero-inner { position: relative; z-index: 1; max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1fr 360px; gap: var(--space-8); align-items: start; }

.presentation-content { color: var(--porcelain); }
.presentation-breadcrumb { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-3); font-size: 0.85rem; }
.presentation-breadcrumb a { color: rgba(255, 255, 255, 0.6); text-decoration: none; transition: color var(--duration-fast); }
.presentation-breadcrumb a:hover { color: var(--porcelain); }
.presentation-breadcrumb svg { width: 14px; height: 14px; color: rgba(255, 255, 255, 0.4); }
.presentation-breadcrumb span { color: rgba(255, 255, 255, 0.8); }

.presentation-badges { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-2); }
.presentation-badges .badge { padding: 2px var(--space-2); font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; border-radius: var(--radius-full); }
.presentation-badges .badge.category { background: rgba(249, 115, 22, 0.25); color: #fbbf24; }
.presentation-badges .badge.level { background: rgba(16, 185, 129, 0.25); color: #6ee7b7; }
.presentation-badges .badge.level-intermediate { background: rgba(245, 158, 11, 0.25); color: #fcd34d; }
.presentation-badges .badge.level-advanced { background: rgba(239, 68, 68, 0.25); color: #fca5a5; }

.presentation-title { font-family: var(--font-display); font-size: clamp(1.5rem, 3.5vw, 2rem); font-weight: 800; line-height: 1.2; margin-bottom: var(--space-2); color: var(--porcelain); }
.presentation-subtitle { font-size: 0.95rem; color: rgba(255, 255, 255, 0.75); line-height: 1.6; margin-bottom: var(--space-3); max-width: 600px; }

.presentation-meta { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-3); margin-bottom: var(--space-3); }
.meta-item { display: flex; align-items: center; gap: 6px; font-size: 0.85rem; color: rgba(255, 255, 255, 0.75); }
.meta-item svg { width: 16px; height: 16px; color: rgba(255, 255, 255, 0.5); }
.meta-item.rating .stars { display: flex; gap: 2px; }
.meta-item.rating .stars svg { width: 14px; height: 14px; color: rgba(255, 255, 255, 0.3); }
.meta-item.rating .stars svg.filled { color: #fbbf24; }
.meta-divider { width: 3px; height: 3px; background: rgba(255, 255, 255, 0.3); border-radius: 50%; }

.presentation-updated, .presentation-instructor { display: flex; align-items: center; gap: var(--space-2); font-size: 0.8rem; color: rgba(255, 255, 255, 0.5); margin-bottom: 2px; }
.presentation-updated svg { width: 14px; height: 14px; }

/* Media Card */
.presentation-media-card { background: var(--porcelain); border-radius: var(--radius-xl); overflow: hidden; box-shadow: 0 20px 40px -12px rgba(0, 0, 0, 0.35); }
.media-wrapper { position: relative; aspect-ratio: 16/9; background: var(--slate-900); }
.media-wrapper img { width: 100%; height: 100%; object-fit: cover; }
.play-overlay { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-2); background: rgba(0, 0, 0, 0.4); cursor: pointer; transition: background var(--duration-fast); }
.play-overlay:hover { background: rgba(0, 0, 0, 0.5); }
.play-btn { width: 52px; height: 52px; background: var(--porcelain); border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-xl); }
.play-btn svg { width: 20px; height: 20px; color: var(--sunrise-orange); margin-left: 3px; }
.play-overlay span { color: var(--porcelain); font-weight: 600; font-size: 0.8rem; }

.pricing-card { padding: var(--space-4) var(--space-5); }
.pricing-card .price-row { display: flex; align-items: baseline; gap: var(--space-3); margin-bottom: var(--space-4); }
.pricing-card .price-current { font-family: var(--font-display); font-size: 1.75rem; font-weight: 700; color: var(--slate-900); }
.pricing-card .price-original { font-size: 1rem; color: var(--slate-400); text-decoration: line-through; }
.cta-actions { display: flex; flex-direction: column; gap: var(--space-2); }
.cta-actions .btn-lg { width: 100%; justify-content: center; }
.cta-actions form { width: 100%; }
.cta-actions form button { width: 100%; }
.coppa-note { font-size: 0.85rem; color: var(--slate-500); text-align: center; }

.quick-features { display: flex; flex-direction: column; gap: var(--space-3); padding-top: var(--space-4); border-top: 1px solid var(--slate-200); }
.quick-features .feature { display: flex; align-items: center; gap: var(--space-3); font-size: 0.85rem; color: var(--slate-600); }
.quick-features .feature svg { width: 18px; height: 18px; color: var(--success); }

/* Tabs */
.presentation-tabs { position: sticky; top: 72px; z-index: var(--z-sticky); background: var(--porcelain); border-bottom: 2px solid var(--slate-200); }
.presentation-tabs-inner { max-width: 1200px; margin: 0 auto; padding: 0 var(--space-8); display: flex; gap: var(--space-1); overflow-x: auto; -webkit-overflow-scrolling: touch; }
.tab-btn { padding: var(--space-4) var(--space-6); font-family: var(--font-body); font-size: 0.95rem; font-weight: 500; color: var(--slate-500); background: transparent; border: none; border-bottom: 3px solid transparent; margin-bottom: -2px; cursor: pointer; transition: all var(--duration-fast); white-space: nowrap; }
.tab-btn:hover { color: var(--slate-700); }
.tab-btn.active { color: var(--focus-blue); border-bottom-color: var(--focus-blue); }

/* Content */
.presentation-content { padding: var(--space-16) var(--space-8); }
.presentation-content-inner { max-width: 1200px; margin: 0 auto; }
.tab-panel { animation: presentationFadeIn 0.3s ease-out; }
@keyframes presentationFadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

/* Overview */
.overview-grid { display: grid; grid-template-columns: 1fr 320px; gap: var(--space-12); }
.overview-main { display: flex; flex-direction: column; gap: var(--space-10); }
.content-block { padding-bottom: var(--space-8); border-bottom: 1px solid var(--slate-200); }
.content-block:last-child { border-bottom: none; }
.block-title { font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; color: var(--slate-900); margin-bottom: var(--space-6); }
.prose-content { color: var(--slate-700); line-height: 1.8; }
.prose-content p { margin-bottom: var(--space-4); }

.outcomes-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-4); }
.outcome-item { display: flex; align-items: flex-start; gap: var(--space-3); padding: var(--space-4); background: var(--soft-mist); border-radius: var(--radius-lg); }
.outcome-item svg { width: 20px; height: 20px; color: var(--success); flex-shrink: 0; margin-top: 2px; }
.outcome-item span { color: var(--slate-700); line-height: 1.5; }

.prereq-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-3); }
.prereq-list li { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-4); background: var(--sunrise-orange-whisper); border-radius: var(--radius-md); color: var(--slate-700); }
.prereq-list li::before { content: ''; width: 8px; height: 8px; background: var(--sunrise-orange); border-radius: 50%; flex-shrink: 0; }

/* Course Includes Sidebar */
.course-includes-card { background: var(--porcelain); border: 2px solid var(--slate-200); border-radius: var(--radius-2xl); padding: var(--space-6); position: sticky; top: 140px; }
.course-includes-card h3 { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; color: var(--slate-900); margin-bottom: var(--space-6); }
.includes-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-4); }
.includes-list li { display: flex; align-items: center; gap: var(--space-3); font-size: 0.9rem; color: var(--slate-700); }
.includes-list li svg { width: 20px; height: 20px; color: var(--focus-blue); flex-shrink: 0; }

/* Curriculum */
.curriculum-header { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--space-4); margin-bottom: var(--space-8); }
.curriculum-stats { display: flex; align-items: center; gap: var(--space-3); font-size: 0.9rem; color: var(--slate-500); }
.curriculum-stats .dot { width: 4px; height: 4px; background: var(--slate-300); border-radius: 50%; }

.sections-list { display: flex; flex-direction: column; gap: var(--space-4); }
.section-item { background: var(--porcelain); border: 2px solid var(--slate-200); border-radius: var(--radius-xl); overflow: hidden; transition: border-color var(--duration-fast); }
.section-item:hover { border-color: var(--slate-300); }
.section-header { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: var(--space-5) var(--space-6); background: transparent; border: none; cursor: pointer; text-align: left; }
.section-info { display: flex; align-items: center; gap: var(--space-4); }
.section-number { width: 40px; height: 40px; background: color-mix(in srgb, var(--focus-blue) 10%, transparent); color: var(--focus-blue); border-radius: var(--radius-lg); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 1rem; flex-shrink: 0; }
.section-title { font-family: var(--font-display); font-size: 1.1rem; font-weight: 600; color: var(--slate-900); margin: 0; }
.section-meta { font-size: 0.85rem; color: var(--slate-500); margin-top: var(--space-1); }
.expand-icon { width: 24px; height: 24px; color: var(--slate-400); transition: transform var(--duration-fast); }
.expand-icon.rotated { transform: rotate(180deg); }
.section-content { padding: 0 var(--space-6) var(--space-6); }
.lessons-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-2); }
.lesson-item { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-4); background: var(--soft-mist); border-radius: var(--radius-md); }
.lesson-item svg { width: 18px; height: 18px; color: var(--slate-400); flex-shrink: 0; }
.lesson-item span { font-size: 0.9rem; color: var(--slate-700); }

/* Instructor */
.instructors-list { display: flex; flex-direction: column; gap: var(--space-8); }
.instructor-profile { display: flex; gap: var(--space-6); }
.instructor-avatar { width: 120px; height: 120px; border-radius: var(--radius-xl); overflow: hidden; flex-shrink: 0; }
.instructor-avatar img { width: 100%; height: 100%; object-fit: cover; }
.instructor-info h3 { font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; color: var(--slate-900); margin-bottom: var(--space-2); }
.instructor-title { font-size: 1rem; color: var(--focus-blue); margin-bottom: var(--space-4); }
.instructor-bio { color: var(--slate-700); line-height: 1.8; }

/* Reviews */
.reviews-header { margin-bottom: var(--space-8); }
.reviews-summary { display: flex; align-items: center; gap: var(--space-4); }
.rating-number { font-family: var(--font-display); font-size: 3rem; font-weight: 700; color: var(--slate-900); }
.rating-stars { display: flex; gap: 4px; }
.rating-stars svg { width: 24px; height: 24px; color: var(--slate-300); }
.rating-stars svg.filled { color: #fbbf24; }
.review-count { color: var(--slate-500); }
.reviews-list { display: flex; flex-direction: column; gap: var(--space-4); }
.review-card { padding: var(--space-6); background: var(--porcelain); border: 2px solid var(--slate-200); border-radius: var(--radius-xl); }
.review-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-4); }
.reviewer-info { display: flex; align-items: center; gap: var(--space-3); }
.reviewer-avatar { width: 48px; height: 48px; background: color-mix(in srgb, var(--focus-blue) 15%, transparent); color: var(--focus-blue); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 1.1rem; overflow: hidden; }
.reviewer-avatar img { width: 100%; height: 100%; object-fit: cover; }
.reviewer-name { display: block; font-weight: 600; color: var(--slate-900); }
.review-date { font-size: 0.85rem; color: var(--slate-500); }
.review-rating { display: flex; gap: 2px; }
.review-rating svg { width: 16px; height: 16px; color: var(--slate-300); }
.review-rating svg.filled { color: #fbbf24; }
.review-content { color: var(--slate-700); line-height: 1.7; }

/* ---- COURSE DETAILS Mobile Responsive ---- */
@media (max-width: 1024px) {
    .presentation-hero-inner { grid-template-columns: 1fr; }
    .overview-grid { grid-template-columns: 1fr; }
    .presentation-media-card { max-width: 420px; }
}

@media (max-width: 768px) {
    .presentation-hero { padding: calc(var(--space-16) + var(--space-2)) var(--space-4) var(--space-6); }
    .presentation-title { font-size: 1.35rem; }
    .presentation-subtitle { font-size: 0.9rem; }
    .presentation-meta { gap: var(--space-2); }
    .meta-item { font-size: 0.8rem; }
    .meta-divider { display: none; }
    .presentation-meta { flex-direction: row; flex-wrap: wrap; }
    .meta-item::after { content: '·'; margin-left: var(--space-2); color: rgba(255, 255, 255, 0.3); }
    .meta-item:last-child::after { display: none; }

    .presentation-media-card { max-width: 100%; }
    .play-btn { width: 48px; height: 48px; }
    .play-btn svg { width: 18px; height: 18px; }
    .pricing-card .price-current { font-size: 1.6rem; }

    .presentation-tabs-inner { padding: 0 var(--space-4); gap: 0; }
    .tab-btn { padding: var(--space-3) var(--space-4); font-size: 0.85rem; }

    .presentation-content { padding: var(--space-8) var(--space-4); }
    .block-title { font-size: 1.25rem; }

    .outcomes-grid { grid-template-columns: 1fr; }
    .section-header { padding: var(--space-4); }
    .section-info { gap: var(--space-3); }
    .section-number { width: 32px; height: 32px; font-size: 0.85rem; }
    .section-title { font-size: 0.95rem; }
    .section-content { padding: 0 var(--space-4) var(--space-4); }

    .instructor-profile { flex-direction: column; }
    .instructor-avatar { width: 80px; height: 80px; }

    .review-header { flex-direction: column; align-items: flex-start; gap: var(--space-2); }
    .review-card { padding: var(--space-4); }
    .rating-number { font-size: 2rem; }

    .course-includes-card { position: static; }
}

@media (max-width: 480px) {
    .presentation-hero { padding: calc(var(--space-16) + var(--space-2)) var(--space-3) var(--space-4); }
    .presentation-title { font-size: 1.3rem; }
    .presentation-badges .badge { font-size: 0.65rem; padding: 2px var(--space-2); }
    .pricing-card { padding: var(--space-4); }
    .cta-actions .btn-lg { padding: var(--space-3); font-size: 0.9rem; }
    .tab-btn { padding: var(--space-2) var(--space-3); font-size: 0.8rem; }
}


/* ==============================================
   BILLBOARD — COLORFUL OVERRIDE
   ============================================== */

/* --- Base Billboard Dark Gradient --- */
.billboard {
    background: linear-gradient(135deg, #0F172A 0%, #1E1B4B 30%, #312E81 50%, #1E1B4B 70%, #0F172A 100%) !important;
    border: none !important;
    border-radius: 40px !important;
    padding: 56px !important;
    position: relative !important;
    overflow: hidden !important;
    box-shadow:
        0 0 0 1px rgba(139, 92, 246, 0.15),
        0 25px 80px -20px rgba(99, 102, 241, 0.25),
        0 0 60px -10px rgba(139, 92, 246, 0.15) !important;
    transition: box-shadow 0.5s ease !important;
}

.billboard:hover {
    box-shadow:
        0 0 0 1px rgba(168, 85, 247, 0.25),
        0 30px 100px -20px rgba(99, 102, 241, 0.35),
        0 0 80px -10px rgba(139, 92, 246, 0.25) !important;
}

/* --- Inner Border Glow (::before override) --- */
.billboard::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    top: 0 !important;
    right: 0 !important;
    width: 100% !important;
    height: 100% !important;
    border-radius: 40px !important;
    background: transparent !important;
    opacity: 1 !important;
    filter: none !important;
    pointer-events: none !important;
    z-index: 3 !important;
    border: 1.5px solid rgba(139, 92, 246, 0.25) !important;
    box-shadow: inset 0 0 60px rgba(99, 102, 241, 0.06), inset 0 1px 0 rgba(255,255,255,0.06) !important;
}

.billboard::after {
    display: none !important;
}

/* --- Animated Orb (left side via .billboard-content::before) --- */
.billboard .billboard-content::before {
    content: '';
    position: absolute;
    width: 300px;
    height: 300px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(99, 102, 241, 0.3) 0%, transparent 70%);
    top: -100px;
    left: -80px;
    filter: blur(60px);
    animation: orbDrift 8s ease-in-out infinite;
    pointer-events: none;
    z-index: -1;
}

/* --- Animated Orb (right side via .billboard-visual::before) --- */
.billboard .billboard-visual::before {
    content: '';
    position: absolute;
    width: 250px;
    height: 250px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(249, 115, 22, 0.25) 0%, transparent 70%);
    bottom: -60px;
    right: -40px;
    filter: blur(50px);
    animation: orbDrift 10s ease-in-out infinite reverse;
    pointer-events: none;
    z-index: 0;
}

@keyframes orbDrift {
    0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.6; }
    33% { transform: translate(20px, -15px) scale(1.1); opacity: 0.8; }
    66% { transform: translate(-15px, 20px) scale(0.9); opacity: 0.5; }
}

/* --- Grid Mesh Overlay (via .billboard-content::after) --- */
.billboard .billboard-content::after {
    content: '';
    position: absolute;
    inset: -100px;
    background-image:
        linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
    z-index: -1;
}

/* --- Badge — Animated Orange Gradient + Glow --- */
.billboard-badge {
    background: linear-gradient(135deg, #F97316, #F59E0B, #F97316) !important;
    background-size: 200% auto !important;
    color: #fff !important;
    padding: 6px 16px !important;
    font-size: 0.72rem !important;
    font-weight: 800 !important;
    letter-spacing: 0.12em !important;
    border-radius: 50px !important;
    box-shadow: 0 0 20px rgba(249, 115, 22, 0.4), 0 2px 8px rgba(0,0,0,0.2) !important;
    animation: badgeShine 3s ease-in-out infinite !important;
}

@keyframes badgeShine {
    0%, 100% {
        background-position: 0% center;
        box-shadow: 0 0 15px rgba(249, 115, 22, 0.3), 0 2px 8px rgba(0,0,0,0.2);
    }
    50% {
        background-position: 200% center;
        box-shadow: 0 0 35px rgba(249, 115, 22, 0.6), 0 2px 8px rgba(0,0,0,0.2);
    }
}

/* --- Heading — White Gradient with Animated Shimmer --- */
.billboard h3 {
    color: transparent !important;
    -webkit-text-fill-color: transparent !important;
    font-size: clamp(2rem, 4vw, 2.6rem) !important;
    font-weight: 800 !important;
    line-height: 1.15 !important;
    letter-spacing: -0.02em !important;
    text-shadow: none !important;
    background: linear-gradient(
        90deg,
        #FFFFFF 0%,
        #C7D2FE 20%,
        #FFFFFF 40%,
        #E0E7FF 60%,
        #FFFFFF 80%,
        #C7D2FE 100%
    ) !important;
    background-size: 300% 100% !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    animation: headlineShine 6s ease-in-out infinite !important;
}

@keyframes headlineShine {
    0% { background-position: 300% center; }
    100% { background-position: 0% center; }
}

/* --- Description --- */
.billboard p {
    color: rgba(255, 255, 255, 0.55) !important;
    font-size: 1.1rem !important;
    line-height: 1.7 !important;
}

/* --- CTA Button — Glowing Orange with Pulse --- */
.billboard .btn-primary,
.billboard a.btn {
    background: linear-gradient(135deg, #F97316, #EA580C) !important;
    border: none !important;
    color: #fff !important;
    font-weight: 700 !important;
    font-size: 0.95rem !important;
    padding: 16px 36px !important;
    border-radius: 14px !important;
    letter-spacing: 0.04em !important;
    box-shadow: 0 0 30px rgba(249, 115, 22, 0.35), 0 4px 15px rgba(0,0,0,0.2) !important;
    transition: all 0.35s cubic-bezier(0.16, 1, 0.3, 1) !important;
    animation: btnGlow 4s ease-in-out infinite !important;
}

.billboard .btn-primary:hover,
.billboard a.btn:hover {
    transform: translateY(-3px) scale(1.03) !important;
    box-shadow: 0 0 50px rgba(249, 115, 22, 0.55), 0 8px 30px rgba(0,0,0,0.25) !important;
}

@keyframes btnGlow {
    0%, 100% {
        box-shadow: 0 0 20px rgba(249, 115, 22, 0.3), 0 4px 15px rgba(0,0,0,0.2);
    }
    50% {
        box-shadow: 0 0 40px rgba(249, 115, 22, 0.5), 0 4px 20px rgba(0,0,0,0.3);
    }
}

/* --- Image / Visual — Purple Tinted Shadow --- */
.billboard-visual {
    position: relative !important;
}

.billboard-visual img {
    border-radius: 20px !important;
    border: 1px solid rgba(139, 92, 246, 0.25) !important;
    box-shadow:
        0 20px 60px rgba(0, 0, 0, 0.4),
        0 0 30px rgba(99, 102, 241, 0.12),
        0 0 0 1px rgba(139, 92, 246, 0.1) !important;
    background: linear-gradient(135deg, #1E1B4B, #312E81) !important;
    object-fit: contain !important;
    transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.billboard:hover .billboard-visual img {
    border-color: rgba(168, 85, 247, 0.3) !important;
    transform: scale(1.02) translateY(-4px) !important;
    box-shadow:
        0 25px 80px rgba(0, 0, 0, 0.5),
        0 0 50px rgba(139, 92, 246, 0.2),
        0 0 0 1px rgba(168, 85, 247, 0.15) !important;
}

/* --- Fade-in / Slide-up Override (don't conflict with site's observer) --- */
.billboard.fade-in.slide-up {
    animation: none !important;
}

.billboard.fade-in.slide-up.visible,
.billboard.fade-in.slide-up[style*="opacity: 1"] {
    opacity: 1 !important;
    transform: translateY(0) scale(1) !important;
}

/* --- Particle Accent Lines (inside .bb-particles) --- */
.billboard .bb-particles::before {
    content: '';
    position: absolute;
    top: 0;
    left: 8%;
    right: 8%;
    height: 2px;
    z-index: 10;
    border-radius: 1px;
    background: linear-gradient(90deg,
        transparent,
        #6366F1 15%,
        #A855F7 30%,
        #F97316 50%,
        #A855F7 70%,
        #6366F1 85%,
        transparent);
    animation: accentPulse 3s ease-in-out infinite;
}

.billboard .bb-particles::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 15%;
    right: 15%;
    height: 1px;
    z-index: 10;
    border-radius: 1px;
    background: linear-gradient(90deg,
        transparent,
        rgba(99,102,241,0.4) 20%,
        rgba(168,85,247,0.5) 50%,
        rgba(99,102,241,0.4) 80%,
        transparent);
    animation: accentPulse 4s ease-in-out infinite 1.5s;
}

@keyframes accentPulse {
    0%, 100% { opacity: 0.5; transform: scaleX(0.95); }
    50% { opacity: 1; transform: scaleX(1); }
}

/* --- Particle Floating Keyframes --- */
@keyframes particleDrift1 {
    0%, 100% { transform: translate(0, 0); opacity: 0.3; }
    25% { transform: translate(15px, -25px); opacity: 0.7; }
    50% { transform: translate(-10px, -40px); opacity: 0.4; }
    75% { transform: translate(20px, -15px); opacity: 0.6; }
}

@keyframes particleDrift2 {
    0%, 100% { transform: translate(0, 0); opacity: 0.2; }
    25% { transform: translate(-20px, -10px); opacity: 0.6; }
    50% { transform: translate(10px, -30px); opacity: 0.3; }
    75% { transform: translate(-5px, -20px); opacity: 0.5; }
}

@keyframes particleDrift3 {
    0%, 100% { transform: translate(0, 0); opacity: 0.4; }
    33% { transform: translate(25px, -20px); opacity: 0.7; }
    66% { transform: translate(-10px, -35px); opacity: 0.3; }
}

@keyframes orbPulse {
    0%, 100% { transform: scale(1); opacity: 0.5; }
    50% { transform: scale(1.2); opacity: 0.8; }
}


/* ==============================================
   CTA BANNER (between Programs & Mentors)
   ============================================== */

.cta-banner-colorful {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #1D4ED8 0%, #2563EB 25%, #7C3AED 50%, #6D28D9 75%, #4F46E5 100%);
    padding: 80px 32px;
}

.cta-banner-inner {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 60px;
    position: relative;
    z-index: 2;
}

.cta-content {
    flex: 1;
    min-width: 0;
}

.cta-badge {
    display: inline-block;
    background: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    color: #fff;
    font-family: var(--font-body, sans-serif);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    padding: 6px 16px;
    border-radius: 50px;
    margin-bottom: 20px;
}

.cta-heading {
    font-family: var(--font-display, sans-serif);
    font-size: 2.8rem;
    font-weight: 800;
    color: #fff;
    line-height: 1.15;
    margin: 0 0 16px 0;
}

.cta-highlight {
    background: linear-gradient(135deg, #FB923C, #F97316, #FBBF24);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.cta-subtext {
    font-family: var(--font-body, sans-serif);
    font-size: 1.125rem;
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.7;
    margin: 0 0 28px 0;
    max-width: 520px;
}

.cta-buttons {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 28px;
    flex-wrap: wrap;
}

.cta-btn-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #F97316, #EA580C);
    color: #fff;
    font-family: var(--font-body, sans-serif);
    font-size: 1rem;
    font-weight: 700;
    padding: 14px 32px;
    border-radius: 12px;
    text-decoration: none;
    letter-spacing: 0.02em;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(249, 115, 22, 0.4);
}

.cta-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(249, 115, 22, 0.5);
    background: linear-gradient(135deg, #FB923C, #F97316);
}

.cta-btn-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    color: #fff;
    font-family: var(--font-body, sans-serif);
    font-size: 1rem;
    font-weight: 600;
    padding: 14px 24px;
    border-radius: 12px;
    text-decoration: none;
    border: 2px solid rgba(255, 255, 255, 0.3);
    transition: all 0.3s ease;
}

.cta-btn-secondary:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.5);
}

.cta-trust {
    display: flex;
    gap: 24px;
    flex-wrap: wrap;
}

.cta-trust-item {
    display: flex;
    align-items: center;
    gap: 6px;
    color: rgba(255, 255, 255, 0.8);
    font-family: var(--font-body, sans-serif);
    font-size: 0.9rem;
    font-weight: 500;
}

.cta-trust-item svg {
    color: #34D399;
    flex-shrink: 0;
}

/* Right side: floating stat cards */
.cta-visual {
    flex-shrink: 0;
    position: relative;
    width: 280px;
    height: 320px;
}

.cta-stat-card {
    position: absolute;
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.25);
    border-radius: 16px;
    padding: 20px 28px;
    text-align: center;
    animation: ctaFloat 6s ease-in-out infinite;
}

.cta-stat-number {
    font-family: var(--font-display, sans-serif);
    font-size: 2rem;
    font-weight: 800;
    color: #fff;
    line-height: 1.2;
}

.cta-stat-label {
    font-family: var(--font-body, sans-serif);
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.7);
    font-weight: 500;
    margin-top: 4px;
}

.cta-stat-1 {
    top: 0;
    left: 0;
    animation-delay: 0s;
}

.cta-stat-2 {
    top: 80px;
    right: 0;
    animation-delay: 2s;
}

.cta-stat-3 {
    bottom: 0;
    left: 30px;
    animation-delay: 4s;
}

@keyframes ctaFloat {
    0%, 100% { transform: translateY(0px); }
    50% { transform: translateY(-12px); }
}

/* Background decorations */
.cta-decoration {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
}

.cta-decoration-1 {
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(251, 146, 60, 0.3) 0%, transparent 70%);
    top: -100px;
    right: -50px;
}

.cta-decoration-2 {
    width: 200px;
    height: 200px;
    background: radial-gradient(circle, rgba(124, 58, 237, 0.4) 0%, transparent 70%);
    bottom: -80px;
    left: -60px;
}

.cta-decoration-3 {
    width: 150px;
    height: 150px;
    background: radial-gradient(circle, rgba(59, 130, 246, 0.3) 0%, transparent 70%);
    top: 50%;
    left: 40%;
    transform: translate(-50%, -50%);
}

/* --- CTA Banner Responsive --- */
@media (max-width: 768px) {
    .cta-banner-colorful {
        padding: 60px 20px;
    }
    .cta-banner-inner {
        flex-direction: column;
        gap: 40px;
        text-align: center;
    }
    .cta-heading {
        font-size: 2rem;
    }
    .cta-subtext {
        max-width: 100%;
    }
    .cta-buttons {
        justify-content: center;
    }
    .cta-trust {
        justify-content: center;
    }
    .cta-visual {
        width: 260px;
        height: 280px;
    }
}

