* {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        html {
            scroll-behavior: smooth;
            scroll-padding-top: 80px;
            width: 100%;
            max-width: 100%;
            overflow-x: hidden;
        }

        body {
            background-color: #080b1f;
            color: #e2e8f0;
            width: 100%;
            max-width: 100%;
            overflow-x: hidden;
            cursor: default;
            font-family: 'Inter', sans-serif;
            text-rendering: optimizeLegibility;
            -webkit-font-smoothing: antialiased;
            font-feature-settings: 'liga' 1, 'kern' 1, 'ss01' 1;
        }

        .skip-link {
            position: fixed;
            top: 16px;
            left: 16px;
            z-index: 100000;
            padding: 10px 14px;
            border-radius: 999px;
            border: 1px solid rgba(212, 160, 23, 0.55);
            background: rgba(8, 11, 31, 0.96);
            color: #fff;
            font-size: 0.82rem;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            transform: translateY(-150%);
            transition: transform 0.22s ease;
        }

        .skip-link:focus-visible {
            transform: translateY(0);
            outline: 2px solid #f0c42a;
            outline-offset: 2px;
        }

        body.show-click-guide,
        body.show-click-guide * {
            cursor: none !important;
        }


        :root {
            --radius-sm: 12px;
            --radius-md: 16px;
            --radius-lg: 22px;
            --blur-sm: 12px;
            --blur-md: 20px;
            --shadow-card: 0 8px 28px rgba(0, 0, 0, 0.35);
            --shadow-card-hover: 0 18px 40px rgba(0, 0, 0, 0.42);
            --shadow-glow: 0 0 32px rgba(212, 160, 23, 0.28);
            --border-glass: 1px solid rgba(255, 255, 255, 0.1);
            --dur-fast: 0.24s;
            --dur-base: 0.42s;
            --ease-standard: cubic-bezier(0.22, 1, 0.36, 1);
            --ease-soft: cubic-bezier(0.4, 0, 0.2, 1);
            --font-h1: clamp(2.1rem, 6.4vw, 6.2rem);
            --font-h2: clamp(1.7rem, 4vw, 3.9rem);
            --font-lead: clamp(1.05rem, 1.8vw, 1.42rem);
            --font-body: clamp(0.96rem, 1.1vw, 1.06rem);
            --space-1: 4px; --space-2: 8px; --space-3: 12px; --space-4: 16px;
            --space-5: 24px; --space-6: 32px; --space-7: 48px; --space-8: 64px;
            --ease-expo: cubic-bezier(0.16, 1, 0.3, 1);
            --dur-quick: 180ms;
            --dur-slow: 700ms;
        }

        h1,.hero-title{font-size:var(--font-h1);letter-spacing:.012em;line-height:.95;}
        h2{font-size:var(--font-h2);letter-spacing:.01em;line-height:1.03;}
        h2,h3,.section-title{
            font-family:'Cormorant Garamond',serif;
            font-weight:600;
            letter-spacing:.03em;
            text-wrap:balance;
        }
        p{font-size:var(--font-body);line-height:1.72;text-wrap:pretty;}


        /* GPU compositing hints for animated UI */
        .glass-card,
        .media-card,
        .hero-btn,
        .timeline-content,
        .timeline-dot,
        .live-bg,
        .gallery-modal img,
        .gallery-modal-nav,
        #particles-canvas,
        #aurora-canvas,
        #topography-overlay {
            will-change: transform, opacity;
            transform: translateZ(0);
            backface-visibility: hidden;
        }

        /* Custom Scrollbar */
        ::-webkit-scrollbar {
            width: 10px;
        }
        ::-webkit-scrollbar-track {
            background: #080b1f;
        }
        ::-webkit-scrollbar-thumb {
            background: linear-gradient(180deg, #d4a017, #1a2458);
            border-radius: 5px;
        }
        ::-webkit-scrollbar-thumb:hover {
            background: linear-gradient(180deg, #f0c42a, #27367a);
        }

        /* Selection */
        ::selection {
            background: rgba(212, 160, 23, 0.3);
            color: #fff;
        }

        /* Utilities */
        .parallax-wrapper {
            position: relative;
            overflow: hidden;
        }

        .hero-overlay {
            background: linear-gradient(to bottom, rgba(8, 11, 31, 0.2) 0%, rgba(8, 11, 31, 0.65) 50%, rgba(8, 11, 31, 1) 100%);
        }

        .glass-card {
            position: relative;
            isolation: isolate;
            overflow: hidden;
            background: rgba(255, 255, 255, 0.02);
            backdrop-filter: blur(var(--blur-md));
            border: 1px solid rgba(173, 250, 255, 0.15);
            border-radius: 0;
            clip-path: polygon(15px 0, 100% 0, 100% calc(100% - 15px), calc(100% - 15px) 100%, 0 100%, 0 15px);
            box-shadow: var(--shadow-card);
            transition: transform var(--dur-base) var(--ease-standard), border-color var(--dur-base) var(--ease-standard), background var(--dur-base) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard);
            transform-style: preserve-3d;
            --pointer-x: 50%;
            --pointer-y: 50%;
            --light-opacity: 0;
        }

        .glass-card::before {
            content: '';
            position: absolute;
            inset: -160% -60%;
            background: linear-gradient(45deg, transparent 35%, rgba(255, 255, 255, 0.28) 50%, transparent 66%);
            transform: translateX(-140%) rotate(6deg);
            animation: glass-glare 6s ease-in-out infinite;
            pointer-events: none;
            z-index: 2;
            mix-blend-mode: screen;
        }

        .glass-card::after {
            content: '';
            position: absolute;
            inset: 0;
            border-radius: inherit;
            background:
                radial-gradient(180px circle at var(--pointer-x) var(--pointer-y), rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.05) 30%, rgba(255, 255, 255, 0) 65%),
                radial-gradient(110px circle at calc(var(--pointer-x) + 10%) calc(var(--pointer-y) - 12%), rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0) 74%);
            opacity: var(--light-opacity);
            transition: opacity 0.28s ease;
            pointer-events: none;
            z-index: 1;
            mix-blend-mode: screen;
        }

        .glass-card .metallic-border {
            position: absolute;
            inset: 0;
            border-radius: 0;
            clip-path: polygon(15px 0, 100% 0, 100% calc(100% - 15px), calc(100% - 15px) 100%, 0 100%, 0 15px);
            pointer-events: none;
            z-index: 4;
            border: 1px solid transparent;
            background:
                linear-gradient(135deg, rgba(255, 255, 255, 0.55), rgba(255, 255, 255, 0) 28%) border-box,
                linear-gradient(120deg, rgba(128, 95, 20, 0.72) 0%, rgba(255, 243, 184, 0.95) 20%, rgba(212, 160, 23, 0.96) 46%, rgba(255, 218, 107, 0.95) 72%, rgba(117, 84, 14, 0.82) 100%) border-box;
            -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
            -webkit-mask-composite: xor;
            mask-composite: exclude;
            opacity: 0.7;
            filter: saturate(1.05);
            transition: opacity 0.34s ease, filter 0.34s ease;
        }

        .glass-card > * {
            position: relative;
            z-index: 3;
        }

        .glass-card:hover {
            background: rgba(255, 255, 255, 0.055);
            border-color: rgba(212, 160, 23, 0.5);
            transform: translateY(-5px);
            box-shadow: 0 0 30px rgba(212, 160, 23, 0.15), var(--shadow-card-hover);
            --light-opacity: 0.62;
        }

        .glass-card:hover .metallic-border {
            opacity: 0.98;
            filter: saturate(1.2) brightness(1.08);
        }

        .glass-card:focus-within {
            border-color: rgba(212, 160, 23, 0.58);
            box-shadow: 0 0 0 3px rgba(212, 160, 23, 0.2), var(--shadow-card-hover);
        }


        #candidateForm input,
        #candidateForm textarea {
            min-height: 52px;
            line-height: 1.45;
        }

        #candidateForm textarea {
            min-height: 120px;
        }

        #candidateForm label {
            letter-spacing: 0.02em;
        }

        .mobile-quick-actions {
            position: fixed;
            left: 50%;
            bottom: 16px;
            transform: translateX(-50%);
            width: min(92vw, 380px);
            padding: 10px;
            border-radius: 999px;
            border: 1px solid rgba(255, 255, 255, 0.14);
            background: rgba(8, 11, 31, 0.85);
            backdrop-filter: blur(14px);
            display: none;
            grid-template-columns: 1fr 1fr;
            gap: 8px;
            z-index: 60;
            box-shadow: 0 12px 28px rgba(0, 0, 0, 0.45);
        }

        .mobile-quick-actions a {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            padding: 11px 10px;
            border-radius: 999px;
            color: #f8fafc;
            font-size: 0.77rem;
            font-weight: 700;
            letter-spacing: 0.06em;
            text-transform: uppercase;
            text-decoration: none;
            border: 1px solid rgba(255, 255, 255, 0.1);
            transition: background-color var(--dur-fast) var(--ease-standard), color var(--dur-fast) var(--ease-standard), border-color var(--dur-fast) var(--ease-standard);
        }

        .mobile-quick-actions a:first-child {
            background: rgba(26, 36, 88, 0.85);
        }

        .mobile-quick-actions a:last-child {
            background: linear-gradient(135deg, rgba(212, 160, 23, 0.94), rgba(240, 196, 42, 0.94));
            color: #080b1f;
            border-color: rgba(212, 160, 23, 0.8);
        }

        .mobile-quick-actions a:hover {
            border-color: rgba(212, 160, 23, 0.55);
        }

        @media (max-width: 767px) {
            .mobile-quick-actions {
                display: grid;
            }

            footer {
                padding-bottom: 118px !important;
            }
        }

        .gradient-text {
            background: linear-gradient(135deg, #d4a017 0%, #f0c42a 50%, #d4a017 100%);
            background-clip: text;
            -webkit-background-clip: text;
            color: transparent;
            background-size: 200% auto;
            animation: gradient-shift 3s ease infinite;
        }

        @keyframes gradient-shift {
            0%, 100% { background-position: 0% 50%; }
            50% { background-position: 100% 50%; }
        }

        .section-padding {
            padding-top: 140px;
            padding-bottom: 140px;
        }

        .section-title {
            position: relative;
            display: inline-block;
        }

        .section-title::after {
            content: '';
            position: absolute;
            bottom: -15px;
            left: 0;
            width: 80px;
            height: 3px;
            background: linear-gradient(90deg, #d4a017, transparent);
        }

        /* Loader */
        #loader {
            position: fixed;
            inset: 0;
            background: linear-gradient(135deg, #080b1f 0%, #111a46 100%);
            z-index: 99999;
            display: flex;
            justify-content: center;
            align-items: center;
            flex-direction: column;
            transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.8s;
        }
        #loader.hidden {
            opacity: 0;
            visibility: hidden;
            pointer-events: none;
        }
        .loader-bar {
            width: 0%;
            height: 3px;
            background: linear-gradient(90deg, #d4a017, #f0c42a);
            margin-top: 24px;
            border-radius: 2px;
            box-shadow: 0 0 20px rgba(212, 160, 23, 0.5);
        }
        .loader-emblem {
            width: 108px;
            height: 108px;
            object-fit: contain;
            margin-bottom: 32px;
            animation: pulse-slow 3s infinite;
            filter: drop-shadow(0 0 30px rgba(212, 160, 23, 0.4));
        }

        /* Navigation */
        .nav-scrolled {
            background: rgba(8, 11, 31, 0.95);
            backdrop-filter: blur(20px);
            box-shadow: 0 4px 30px rgba(0, 0, 0, 0.3);
            padding-top: 10px !important;
            padding-bottom: 10px !important;
        }

        .nav-scrolled .nav-link {
            padding-top: 10px !important;
            padding-bottom: 10px !important;
        }

        .nav-scrolled img {
            width: 42px;
            height: 42px;
        }

        .nav-hidden {
            transform: translateY(-110%);
        }

        .nav-link {
            position: relative;
            transition: all 0.3s ease;
        }

        .nav-link::after {
            content: '';
            position: absolute;
            bottom: -5px;
            left: 0;
            width: 0;
            height: 2px;
            background: linear-gradient(90deg, #d4a017, #f0c42a);
            transition: width 0.3s ease;
        }

        .nav-link:hover::after {
            width: 100%;
        }

        .nav-link.active {
            color: #d4a017;
        }

        /* Hero */
        .hero-title {
            text-shadow: 0 0 40px rgba(212, 160, 23, 0.3);
        }

        .hero-title.is-scrambling,
        .section-title.is-scrambling {
            color: rgba(206, 246, 255, 0.95);
            text-shadow: 0 0 14px rgba(103, 237, 255, 0.62), 0 0 36px rgba(62, 189, 255, 0.36);
            filter: saturate(1.08);
        }


        .hero-btn {
            position: relative;
            overflow: hidden;
            transition: transform var(--dur-base) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard), filter var(--dur-fast) var(--ease-soft);
            will-change: transform;
            --press-depth: 0px;
        }

        .hero-btn::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 100%;
            background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
            transition: left 0.6s ease;
        }

        .hero-btn:hover::before {
            left: 100%;
        }

        .hero-btn:hover {
            transform: translateY(-3px);
            box-shadow: 0 10px 40px rgba(212, 160, 23, 0.4);
        }

        .hero-btn.is-pressed {
            transform: translateY(1px) scale(0.985) !important;
            box-shadow: 0 5px 14px rgba(0, 0, 0, 0.32), inset 0 2px 10px rgba(0, 0, 0, 0.25);
            filter: saturate(1.08);
        }

        .hero-btn:hover,
        .hero-btn:focus-visible,
        .media-card:hover,
        .media-card:focus-visible {
            animation: rgb-glitch 0.28s steps(2, end) 1;
        }
        .media-card .rgb-ghost {
            content: '';
            position: absolute;
            inset: -1px;
            pointer-events: none;
            opacity: 0;
            transition: opacity 0.24s ease;
            z-index: 2;
            background: linear-gradient(120deg, rgba(255, 0, 92, 0.18), rgba(255, 0, 92, 0) 42%), linear-gradient(300deg, rgba(0, 187, 255, 0.2), rgba(0, 187, 255, 0) 46%);
            mix-blend-mode: screen;
            transform: translate3d(0, 0, 0);
        }


        .media-card:hover .rgb-ghost,
        .media-card:focus-visible .rgb-ghost {
            opacity: 0.92;
            animation: rgb-shift 0.38s steps(2, end) 1;
        }

        /* Timeline */
        .timeline-dot {
            transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        }

        .timeline-item:hover .timeline-dot {
            transform: scale(1.5);
            box-shadow: 0 0 30px rgba(212, 160, 23, 0.6);
        }

        .timeline-content {
            transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        }

        .timeline-item:hover .timeline-content {
            transform: translateX(10px);
        }

        /* Stats */
        .stat-card {
            position: relative;
            overflow: hidden;
        }

        .stat-card::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 3px;
            background: linear-gradient(90deg, #d4a017, #f0c42a);
            transform: scaleX(0);
            transform-origin: left;
            transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        }

        .stat-card:hover::before {
            transform: scaleX(1);
        }


        @keyframes levitate {
            0%, 100% { transform: translateY(0); }
            50% { transform: translateY(-10px); }
        }

        .stat-card,
        #tasks .glass-card {
            animation: levitate 7s ease-in-out infinite;
        }

        #tasks .glass-card:nth-child(2n),
        .stat-card:nth-child(2n) {
            animation-delay: -2.4s;
        }

        #tasks .glass-card:nth-child(3n),
        .stat-card:nth-child(3n) {
            animation-delay: -4.8s;
        }

        /* Media Gallery */
        .media-grid {
            display: grid;
            grid-template-columns: repeat(12, minmax(0, 1fr));
            gap: 20px;
        }

        .media-card {
            grid-column: span 4;
            position: relative;
            overflow: hidden;
            border-radius: 0;
            clip-path: polygon(14px 0, 100% 0, 100% calc(100% - 14px), calc(100% - 14px) 100%, 0 100%, 0 14px);
            border: 1px solid rgba(255,255,255,0.12);
            aspect-ratio: 16 / 9;
            min-height: 280px;
            background: rgba(255,255,255,0.03);
            transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
        }

        .media-card.wide { grid-column: span 6; aspect-ratio: 16 / 9; }

        .media-card img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            transition: transform 0.55s ease;
        }

        .media-card::after {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(to top, rgba(3, 5, 4, 0.99) 0%, rgba(3, 5, 4, 0.94) 36%, rgba(3, 5, 4, 0.72) 58%, rgba(4, 8, 6, 0.44) 76%, rgba(5, 9, 7, 0.18) 90%, rgba(5, 9, 7, 0) 100%);
            transition: background 0.4s ease;
        }

        .media-card::before {
            content: '';
            position: absolute;
            top: 10px;
            left: 10px;
            width: 20px;
            height: 20px;
            border-style: solid;
            border-color: rgba(212, 160, 23, 0.8);
            border-width: 2px 0 0 2px;
            z-index: 3;
            pointer-events: none;
            transition: all 0.3s ease;
        }

        .media-card .target-bracket {
            content: '';
            position: absolute;
            bottom: 10px;
            right: 10px;
            width: 20px;
            height: 20px;
            border-style: solid;
            border-color: rgba(212, 160, 23, 0.8);
            border-width: 0 2px 2px 0;
            z-index: 3;
            pointer-events: none;
            transition: all 0.3s ease;
        }

        .media-card:hover {
            transform: translateY(-6px);
            border-color: rgba(212,160,23,0.45);
            box-shadow: 0 16px 42px rgba(0,0,0,0.35);
        }

        .media-card:hover img { transform: scale(1.1); }

        .media-card:hover::after {
            background: linear-gradient(to top, rgba(3, 5, 4, 0.96) 0%, rgba(3, 5, 4, 0.86) 38%, rgba(3, 5, 4, 0.56) 62%, rgba(4, 8, 6, 0.3) 80%, rgba(5, 9, 7, 0.1) 92%, rgba(5, 9, 7, 0) 100%);
        }

        .media-card:hover::before {
            top: 5px;
            left: 5px;
            width: 30px;
            height: 30px;
        }

        .media-card:hover .target-bracket {
            bottom: 5px;
            right: 5px;
            width: 30px;
            height: 30px;
        }

        .media-meta {
            position: absolute;
            left: 18px;
            right: 18px;
            bottom: 16px;
            z-index: 2;
            font-size: clamp(0.8rem, 1.2vw, 0.95rem);
            display: flex;
            flex-direction: column;
            justify-content: flex-end;
            gap: 4px;
            overflow: hidden;
            text-shadow: 0 4px 16px rgba(0, 0, 0, 0.82), 0 2px 4px rgba(0, 0, 0, 0.7);
        }

        .media-meta p {
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }

        /* FAQ */
        .faq-grid { display: grid; gap: 14px; }

        .faq-item {
            border: 1px solid rgba(255,255,255,0.12);
            border-radius: var(--radius-md);
            background: rgba(255,255,255,0.03);
            overflow: hidden;
            transition: border-color 0.25s ease, background 0.25s ease;
        }

        .faq-item.active,
        .faq-item:hover { border-color: rgba(212,160,23,0.45); background: rgba(255,255,255,0.05); }

        .faq-question {
            width: 100%;
            text-align: left;
            padding: var(--space-4) var(--space-5);
            color: #f8fafc;
            background: transparent;
            border: 0;
            font-weight: 600;
            display: flex;
            justify-content: space-between;
            gap: 20px;
            cursor: pointer;
        }

        .faq-answer {
            max-height: 0;
            overflow: hidden;
            opacity: 0;
            transition: max-height 0.45s ease, opacity 0.4s ease;
        }

        .faq-item.active .faq-answer {
            opacity: 1;
        }

        .faq-answer-content {
            padding: 0 var(--space-5) var(--space-4);
            color: #cbd5e1;
            line-height: 1.65;
            font-size: 15px;
        }

        .faq-answer-content ul { padding-left: 18px; }

        .faq-answer-content li { margin-bottom: 6px; }

        .faq-question i {
            transition: transform 0.35s ease, color 0.35s ease;
            transform-origin: center;
        }

        .faq-item.active .faq-question i {
            transform: rotate(45deg);
            color: #fca5a5;
        }

        .media-shell {
            position: relative;
            margin-top: 12px;
        }

        .media-scroller {
            display: grid;
            grid-auto-flow: column;
            grid-auto-columns: minmax(320px, 85vw);
            gap: 20px;
            overflow-x: auto;
            scroll-snap-type: x mandatory;
            padding: 8px 6px 22px;
            scrollbar-width: none;
            -webkit-overflow-scrolling: touch;
            cursor: grab;
        }

        .media-scroller:active { cursor: grabbing; }
        .media-scroller::-webkit-scrollbar { display: none; }
        .media-scroller .media-card { scroll-snap-align: start; grid-column: auto; min-height: 320px; aspect-ratio: 16 / 9; width: 100%; min-width: 0; }

        .gallery-nav {
            position: absolute;
            top: 50%;
            transform: translateY(-50%);
            width: 44px;
            height: 44px;
            border-radius: 999px;
            border: 1px solid rgba(255,255,255,0.2);
            background: rgba(13, 20, 17, 0.72);
            color: #fff;
            z-index: 3;
            display: grid;
            place-items: center;
        }

        .gallery-prev { left: -12px; }
        .gallery-next { right: -12px; }

        .gallery-modal {
            position: fixed;
            inset: 0;
            background: rgba(6, 10, 8, 0.92);
            backdrop-filter: blur(var(--blur-sm));
            display: flex;
            align-items: center;
            justify-content: center;
            opacity: 0;
            pointer-events: none;
            transition: opacity .35s ease;
            z-index: 110;
            padding: 24px;
        }

        .gallery-modal.active {
            opacity: 1;
            pointer-events: auto;
        }

        #lightbox figure {
            max-width: min(1000px, 94vw);
            margin: 0;
            width: 100%;
            display: flex;
            flex-direction: column;
            gap: 14px;
        }

        #lightbox .lightbox-description {
            margin: 0;
            padding: 14px 18px;
            border-radius: 14px;
            background: linear-gradient(180deg, rgba(8, 11, 10, 0.45) 0%, rgba(8, 11, 10, 0.82) 100%);
            border: 1px solid rgba(255,255,255,0.16);
            color: #e2e8f0;
            font-size: clamp(0.9rem, 1.3vw, 1rem);
            line-height: 1.6;
            text-shadow: 0 2px 10px rgba(0,0,0,0.6);
        }

        .gallery-modal figure {
            max-width: min(1000px, 94vw);
            margin: 0;
        }

        .gallery-modal img {
            width: 100%;
            max-height: 76vh;
            object-fit: contain;
            border-radius: 18px;
            border: 1px solid rgba(255, 255, 255, 0.18);
            box-shadow: 0 18px 48px rgba(0, 0, 0, 0.45);
        }

        .gallery-modal .modal-caption {
            margin-top: 12px;
            color: #cbd5e1;
        }

        .gallery-close {
            position: absolute;
            top: 18px;
            right: 18px;
            width: 44px;
            height: 44px;
            border-radius: 999px;
            border: 1px solid rgba(255,255,255,0.28);
            background: rgba(0,0,0,0.38);
            color: white;
        }

        .sound-toggle {
            position: fixed;
            right: 24px;
            bottom: 96px;
            z-index: 1000;
            border: 1px solid rgba(255, 255, 255, 0.25);
            background: rgba(8, 11, 31, 0.88);
            color: #f8fafc;
            border-radius: 999px;
            padding: 10px 14px;
            font-size: 12px;
            letter-spacing: .08em;
            text-transform: uppercase;
        }


        /* Particles */
        #particles-canvas {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            z-index: 10;
            pointer-events: none;
            opacity: 0.8;
        }

        /* Mobile Menu */
        .mobile-menu {
            transform: translateX(100%);
            transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        }

        .mobile-menu.active {
            transform: translateX(0);
        }

        /* Scroll Progress */
        .scroll-progress {
            position: fixed;
            top: 0;
            left: 0;
            width: 0%;
            height: 3px;
            background: linear-gradient(90deg, #d4a017, #f0c42a);
            z-index: 10000;
            transition: width 0.1s ease;
        }

        .premium-icon-orb {
            background: rgba(255, 255, 255, 0.03) !important;
            border: 1px solid rgba(255, 255, 255, 0.1);
            backdrop-filter: blur(var(--blur-sm));
            box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5), inset 0 2px 15px rgba(212, 160, 23, 0.15);
            animation: float 3.8s ease-in-out infinite;
        }

        .premium-icon-orb i {
            color: #d4a017 !important;
            filter: drop-shadow(0px 0px 12px rgba(212, 160, 23, 0.8));
        }

        @keyframes float {
            0%, 100% { transform: translateY(0); }
            50% { transform: translateY(-8px); }
        }

        .loader-rings {
            position: absolute;
            width: 220px;
            height: 220px;
            pointer-events: none;
            filter: drop-shadow(0 0 24px rgba(212, 160, 23, 0.35));
        }

        .loader-rings span {
            position: absolute;
            inset: 0;
            border-radius: 999px;
            border: 1px solid rgba(212, 160, 23, 0.28);
            animation: loader-spin 7s linear infinite;
        }

        .loader-rings span:nth-child(2) {
            inset: 18px;
            border-color: rgba(0, 87, 184, 0.4);
            animation-direction: reverse;
            animation-duration: 9s;
        }

        .loader-rings span:nth-child(3) {
            inset: 36px;
            border-style: dashed;
            border-color: rgba(240, 196, 42, 0.45);
            animation-duration: 5s;
        }

        .loader-status {
            letter-spacing: 0.35em;
            text-transform: uppercase;
            color: rgba(255, 255, 255, 0.7);
            font-size: 10px;
            margin-top: 12px;
        }

        @keyframes loader-spin {
            from { transform: rotate(0deg); }
            to { transform: rotate(360deg); }
        }

        #loaderParticles {
            position: absolute;
            inset: 0;
            width: 100%;
            height: 100%;
            opacity: 0.45;
            pointer-events: none;
        }


        .timeline-item:nth-child(odd) .timeline-content {
            transform-origin: right center;
        }

        .timeline-item:nth-child(even) .timeline-content {
            transform-origin: left center;
        }

        @media (min-width: 768px) {
            .timeline-item {
                display: flex;
                width: 100%;
                padding-left: 0;
            }

            .timeline-item:nth-child(odd) {
                justify-content: flex-start;
            }

            .timeline-item:nth-child(even) {
                justify-content: flex-end;
            }

            .timeline-item .timeline-content {
                width: min(100%, calc(50% - 1.75rem));
            }

            .timeline-item:nth-child(odd) .timeline-content {
                margin-right: auto !important;
                margin-left: 0 !important;
            }

            .timeline-item:nth-child(even) .timeline-content {
                margin-left: auto !important;
                margin-right: 0 !important;
            }
        }

        .timeline-content .glass-card {
            position: relative;
            overflow: hidden;
        }

        .timeline-content .glass-card::before {
            content: '';
            position: absolute;
            top: -120%;
            left: -30%;
            width: 60%;
            height: 320%;
            transform: rotate(15deg);
            background: linear-gradient(180deg, transparent, rgba(255,255,255,0.08), transparent);
            transition: transform 0.7s ease;
        }

        .timeline-item:hover .glass-card::before {
            transform: translateX(260%) rotate(15deg);
        }

        .live-bg {
            position: absolute;
            border-radius: 999px;
            filter: blur(50px);
            opacity: 0.35;
            animation: drift 12s ease-in-out infinite;
            pointer-events: none;
        }

        .live-bg.alt {
            animation-delay: -4s;
            animation-duration: 16s;
        }

        @keyframes drift {
            0%, 100% { transform: translate3d(0,0,0) scale(1); }
            50% { transform: translate3d(24px,-18px,0) scale(1.08); }
        }

        .scroll-sheen {
            position: relative;
            overflow: hidden;
        }

        .scroll-sheen::after {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(120deg, transparent 20%, rgba(212,160,23,0.08) 50%, transparent 80%);
            transform: translateX(-120%);
            transition: transform 0.9s ease;
            pointer-events: none;
        }

        .scroll-sheen.is-visible::after {
            transform: translateX(120%);
        }

        /* Responsive */
        @media (max-width: 768px) {
            .section-padding {
                padding-top: 100px;
                padding-bottom: 100px;
            }
            
            .hero-title {
                font-size: 2.5rem !important;
            }
            
            .timeline-container {
                margin-left: 0 !important;
            }
            
            .timeline-item {
                padding-left: 40px !important;
            }
        }

        /* Loading animations */
        .fade-in-up {
            opacity: 0;
            transform: translateY(30px);
        }

        .fade-in-up.visible {
            opacity: 1;
            transform: translateY(0);
            transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
        }

        .timeline-content,
        .timeline-dot,
        .live-bg {
            will-change: transform, opacity;
            transform: translateZ(0);
            backface-visibility: hidden;
        }



        .hero-btn::after {
            content: '';
            position: absolute;
            inset: -1px;
            border-radius: inherit;
            border: 1px solid rgba(173, 250, 255, 0.45);
            clip-path: polygon(12px 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%, 0 12px);
            background: radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(240, 196, 42, 0.34), transparent 58%);
            opacity: 0;
            transition: opacity var(--dur-fast) var(--ease-soft);
            pointer-events: none;
            mix-blend-mode: screen;
        }

        .hero-btn:hover::after,
        .hero-btn:focus-visible::after { opacity: 1; }

        .reveal-up,
        .reveal-scale,
        .reveal-fade,
        .fade-in-up {
            opacity: 0;
        }

        .reveal-up { transform: translate3d(0, 28px, 0); }
        .reveal-scale { transform: scale(0.96) translate3d(0, 14px, 0); }
        .reveal-fade { transform: none; }

        .mobile-menu-overlay {
            position: fixed;
            inset: 0;
            background: rgba(0, 0, 0, 0.55);
            backdrop-filter: blur(3px);
            opacity: 0;
            pointer-events: none;
            transition: opacity var(--dur-base) var(--ease-standard);
            z-index: 45;
        }

        .mobile-menu-overlay.active {
            opacity: 1;
            pointer-events: auto;
        }

        .mobile-menu {
            z-index: 50;
        }

        .nav-link.active::after {
            width: 100%;
        }

        .grain-overlay {
            position: fixed;
            inset: 0;
            z-index: 9999;
            pointer-events: none;
            opacity: 0.12;
            background-image:
                linear-gradient(rgba(18, 16, 16, 0) 50%, rgba(0, 0, 0, 0.11) 50%),
                linear-gradient(90deg, rgba(255, 0, 0, 0.03), rgba(0, 255, 170, 0.01), rgba(0, 120, 255, 0.03)),
                linear-gradient(rgba(123, 245, 255, 0.03) 1px, transparent 1px),
                linear-gradient(90deg, rgba(123, 245, 255, 0.03) 1px, transparent 1px);
            background-size: 100% 4px, 3px 100%, 26px 26px, 26px 26px;
            mix-blend-mode: screen;
        }
        nav, .scroll-progress {
            position: relative;
            z-index: 10;
        }

        header,
        section,
        footer {
            display: block;
            position: relative;
            z-index: auto;
        }

        section + section {
            --divider-line-opacity: 0.42;
            --divider-flare-opacity: 0;
        }

        section + section::before,
        section + section::after {
            content: '';
            position: absolute;
            left: clamp(20px, 6vw, 72px);
            right: clamp(20px, 6vw, 72px);
            top: 0;
            pointer-events: none;
            z-index: 12;
        }

        section + section::before {
            height: 1px;
            opacity: var(--divider-line-opacity);
            background:
                linear-gradient(90deg, rgba(255,255,255,0), rgba(180, 196, 220, 0.58) 8%, rgba(240, 196, 42, 0.65) 50%, rgba(180, 196, 220, 0.58) 92%, rgba(255,255,255,0)),
                linear-gradient(120deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.78) 46%, rgba(255,255,255,0) 54%);
            background-size: 100% 100%, 220px 100%;
            background-repeat: no-repeat;
            animation: divider-shimmer 7.5s linear infinite;
            box-shadow: 0 0 12px rgba(225, 233, 255, 0.16), 0 0 20px rgba(212, 160, 23, 0.14);
        }

        section + section::after {
            height: 16px;
            opacity: calc(var(--divider-line-opacity) * 0.45 + var(--divider-flare-opacity));
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='18' viewBox='0 0 180 18'%3E%3Cg fill='%23ffffff' fill-opacity='0.16'%3E%3Ccircle cx='13' cy='8' r='0.8'/%3E%3Ccircle cx='58' cy='3' r='0.7'/%3E%3Ccircle cx='92' cy='10' r='0.9'/%3E%3Ccircle cx='143' cy='5' r='0.7'/%3E%3Ccircle cx='172' cy='12' r='0.8'/%3E%3C/g%3E%3C/svg%3E");
            background-size: 180px 18px;
            mix-blend-mode: screen;
            transform: translateY(-8px);
            filter: blur(0.15px);
        }

        section.divider-hit {
            --divider-line-opacity: 0.95;
            --divider-flare-opacity: 0.8;
        }

        .parallax-content-layer {
            transform: translate3d(0, var(--content-layer-shift, 0px), 0);
            will-change: transform;
        }

        @keyframes divider-shimmer {
            0% { background-position: 0% 0, -220px 0; }
            100% { background-position: 0% 0, calc(100% + 220px) 0; }
        }

        #aurora-canvas {
            position: fixed;
            inset: 0;
            width: 100%;
            height: 100%;
            z-index: 0;
            pointer-events: none;
            opacity: 0.3;
            mix-blend-mode: screen;
            filter: blur(2px) saturate(110%);
        }

        #topography-overlay {
            position: fixed;
            inset: 0;
            z-index: 1;
            pointer-events: none;
            opacity: 0.2;
            background-image:
                radial-gradient(circle at 24% 22%, rgba(110, 232, 255, 0.16) 0, rgba(110, 232, 255, 0) 42%),
                radial-gradient(circle at 78% 66%, rgba(212, 160, 23, 0.14) 0, rgba(212, 160, 23, 0) 44%),
                repeating-radial-gradient(circle at 70% 52%, rgba(164, 203, 255, 0.12) 0 1px, transparent 1px 28px),
                repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.05) 0 1px, transparent 1px 56px),
                repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.04) 0 1px, transparent 1px 56px);
            background-size: 100% 100%, 100% 100%, 140% 140%, 100% 100%, 100% 100%;
            mix-blend-mode: screen;
            filter: saturate(115%) blur(0.2px);
            transform: translate3d(0, 0, 0) scale(1.08);
            animation: topoDrift 26s linear infinite;
        }

        #topography-overlay::before,
        #topography-overlay::after {
            content: '';
            position: absolute;
            inset: 0;
            pointer-events: none;
            mix-blend-mode: screen;
        }

        #topography-overlay::before {
            background:
                radial-gradient(circle at 68% 50%, rgba(155, 221, 255, 0.14) 0 1px, transparent 1px 6px) 0 0 / 130px 130px,
                radial-gradient(circle at 21% 77%, rgba(121, 251, 199, 0.14) 0 1px, transparent 1px 7px) 0 0 / 180px 180px;
            opacity: 0.42;
            animation: radarSweep 8.8s linear infinite;
        }

        #topography-overlay::after {
            background: linear-gradient(118deg, rgba(255, 255, 255, 0) 18%, rgba(146, 230, 255, 0.16) 49%, rgba(255, 255, 255, 0) 78%);
            transform: translateX(-130%);
            opacity: 0.35;
            animation: radarScanline 12s ease-in-out infinite;
        }

        #loader.loader-finale .loader-emblem {
            transform: scale(1.06);
            filter: drop-shadow(0 0 44px rgba(240, 196, 42, 0.7));
        }

        #loader.loader-finale .loader-rings { opacity: 0.85; transform: scale(1.08); }


        .click-guide {
            position: fixed;
            top: 0;
            left: 0;
            width: 58px;
            height: 58px;
            z-index: 110;
            pointer-events: none;
            opacity: 0;
            transform: translate3d(-999px, -999px, 0);
            transition: opacity 260ms ease;
            will-change: transform, opacity;
        }

        .click-guide-label {
            position: absolute;
            top: 14px;
            left: 44px;
            font-family: 'Montserrat', sans-serif;
            font-size: 0.58rem;
            font-weight: 600;
            letter-spacing: 0.2em;
            text-transform: uppercase;
            color: rgba(173, 250, 255, 0.95);
            text-shadow: 0 0 12px rgba(103, 237, 255, 0.4);
            white-space: nowrap;
            opacity: 0.92;
        }

        .click-guide.active {
            opacity: 1;
        }

        .click-guide-wave,
        .click-guide-wave::before,
        .click-guide-wave::after {
            position: absolute;
            inset: 17px;
            border-radius: 50%;
            border: 1px solid rgba(103, 237, 255, 0.48);
            box-shadow: 0 0 16px rgba(103, 237, 255, 0.25);
            content: '';
            animation: click-wave 1.95s ease-out infinite;
            transform-origin: 50% 20%;
        }

        .click-guide-wave::before {
            animation-delay: 0.5s;
        }

        .click-guide-wave::after {
            animation-delay: 1s;
        }

        .click-guide-hand {
            position: absolute;
            inset: 0;
            filter: drop-shadow(0 0 6px rgba(105, 241, 255, 0.42));
            animation: hand-invite 1.3s ease-in-out infinite;
        }

        .click-guide-hand path {
            fill: rgba(130, 249, 255, 0.06);
            stroke: rgba(152, 246, 255, 0.94);
            stroke-width: 1.75;
            stroke-linecap: round;
            stroke-linejoin: round;
        }

        .click-guide-hand .index-detail {
            fill: none;
            stroke-width: 1.35;
            opacity: 0.92;
        }

        .click-guide-hand .palm-detail {
            fill: none;
            stroke-width: 1.1;
            opacity: 0.6;
        }

        .click-guide-hand .click-burst {
            stroke: rgba(173, 250, 255, 0.95);
            fill: none;
            stroke-width: 1.6;
            transform-origin: 40px 7px;
            animation: click-burst 1.3s ease-in-out infinite;
        }

        @keyframes click-wave {
            0% {
                transform: scale(0.18);
                opacity: 0.62;
            }
            78% {
                opacity: 0.15;
            }
            100% {
                transform: scale(1.45);
                opacity: 0;
            }
        }

        @keyframes hand-invite {
            0%, 100% {
                transform: translateY(0) scale(0.98);
            }
            32% {
                transform: translateY(4px) scale(1.02);
            }
            58% {
                transform: translateY(-1px) scale(0.99);
            }
        }

        @keyframes click-burst {
            0%, 100% {
                opacity: 0;
                transform: scale(0.65);
            }
            27% {
                opacity: 1;
                transform: scale(1);
            }
            52% {
                opacity: 0;
                transform: scale(1.2);
            }
        }

        @keyframes rgb-glitch {
            0% { transform: translate3d(0, 0, 0); filter: none; }
            28% { transform: translate3d(-1px, 1px, 0); filter: drop-shadow(2px 0 rgba(255, 0, 92, 0.5)) drop-shadow(-2px 0 rgba(0, 187, 255, 0.5)); }
            52% { transform: translate3d(1px, -1px, 0); filter: drop-shadow(-2px 0 rgba(255, 0, 92, 0.45)) drop-shadow(2px 0 rgba(0, 187, 255, 0.45)); }
            100% { transform: translate3d(0, 0, 0); filter: none; }
        }

        @keyframes rgb-shift {
            0% { transform: translate3d(0, 0, 0); }
            40% { transform: translate3d(2px, -1px, 0); }
            65% { transform: translate3d(-1px, 1px, 0); }
            100% { transform: translate3d(0, 0, 0); }
        }

        @keyframes topoDrift {
            0% { transform: translate3d(0, 0, 0) scale(1.08); background-position: 0 0, 0 0, 0 0, 0 0, 0 0; }
            50% { transform: translate3d(-1.4%, -1.1%, 0) scale(1.095); background-position: 0 0, 0 0, -24px -14px, -30px -22px, -18px -24px; }
            100% { transform: translate3d(-2.6%, -2.2%, 0) scale(1.11); background-position: 0 0, 0 0, -48px -30px, -60px -44px, -40px -46px; }
        }

        @keyframes radarSweep {
            0%, 100% { transform: rotate(0deg); opacity: 0.22; }
            50% { transform: rotate(2.4deg); opacity: 0.46; }
        }

        @keyframes radarScanline {
            0% { transform: translateX(-130%); opacity: 0; }
            26% { opacity: 0.22; }
            52% { transform: translateX(130%); opacity: 0.5; }
            100% { transform: translateX(130%); opacity: 0; }
        }

        @media (prefers-reduced-motion: reduce) {
            .click-guide-wave,
            .click-guide-wave::before,
            .click-guide-wave::after,
            .click-guide-hand,
            .click-guide-hand .click-burst {
                animation: none;
            }
        }

        .fullscreen-hint {
            position: fixed;
            top: 18px;
            left: 50%;
            transform: translate(-50%, -18px);
            padding: 10px 18px;
            border-radius: 999px;
            border: 1px solid rgba(255, 255, 255, 0.2);
            background: linear-gradient(135deg, rgba(11, 19, 14, 0.9), rgba(22, 39, 30, 0.78));
            box-shadow: 0 16px 36px rgba(0, 0, 0, 0.35), 0 0 24px rgba(212, 160, 23, 0.2);
            color: rgba(229, 236, 240, 0.92);
            font-family: 'Montserrat', sans-serif;
            font-size: 0.72rem;
            letter-spacing: 0.08em;
            text-transform: uppercase;
            backdrop-filter: blur(10px);
            opacity: 0;
            pointer-events: none;
            transition: opacity 420ms var(--ease-standard), transform 420ms var(--ease-standard);
            z-index: 120;
        }

        .fullscreen-hint.active {
            opacity: 1;
            transform: translate(-50%, 0);
        }

        .gallery-progress {
            width: min(420px, 92%);
            height: 3px;
            margin-top: 10px;
            border-radius: 999px;
            background: rgba(255, 255, 255, 0.12);
            overflow: hidden;
        }

        .gallery-progress > span {
            display: block;
            width: 0;
            height: 100%;
            background: linear-gradient(90deg, #d4a017, #f0c42a);
            transition: width .2s ease;
        }

        .gallery-modal-nav {
            position: absolute;
            top: 50%;
            transform: translateY(-50%);
            width: 46px;
            height: 46px;
            border-radius: 999px;
            border: 1px solid rgba(255, 255, 255, 0.3);
            background: rgba(5, 10, 8, 0.5);
            color: #fff;
            display: grid;
            place-items: center;
        }
        .gallery-modal-prev { left: 22px; }
        .gallery-modal-next { right: 22px; }


        @keyframes glass-glare {
            0%, 72%, 100% { transform: translateX(-145%) rotate(6deg); opacity: 0; }
            78% { opacity: 0.85; }
            92% { transform: translateX(145%) rotate(6deg); opacity: 0.2; }
        }

        .fas.text-ngu-accent {
            filter: drop-shadow(0 0 8px rgba(212, 160, 23, 0.6));
        }

        .hero-btn,
        .cta-glow {
            position: relative;
            overflow: hidden;
        }

        .cta-glow::before {
            content: '';
            position: absolute;
            inset: -24%;
            background: radial-gradient(circle, rgba(212, 160, 23, 0.38) 0%, rgba(212, 160, 23, 0) 72%);
            z-index: -1;
            filter: blur(10px);
            animation: cta-pulse 2.8s ease-in-out infinite;
            pointer-events: none;
        }

        @keyframes cta-pulse {
            0%, 100% { opacity: 0.45; transform: scale(0.95); }
            50% { opacity: 0.95; transform: scale(1.1); }
        }

        .facebook-embed-shell {
            width: min(100%, 500px);
            margin: 0 auto;
            height: clamp(520px, 70vh, 760px);
            overflow: hidden;
            border-radius: 24px;
            display: flex;
            justify-content: center;
            align-items: center;
            background: rgba(0,0,0,0.2);
            box-shadow: inset 0 0 26px rgba(255, 255, 255, 0.12), inset 0 0 38px rgba(212, 160, 23, 0.14);
        }

        .facebook-embed-shell iframe {
            width: 100%;
            max-width: 500px;
            height: 100%;
            border: 0;
            display: block;
            background: transparent;
            margin: 0 auto;
        }

        .icon-glow i {
            filter: drop-shadow(0 0 10px rgba(212,160,23,0.8));
        }

        #vacancies a[href="#contact"]:hover {
            transform: scale(1.05);
        }

        @media (prefers-reduced-transparency: reduce), (update: slow) {
            :root {
                --blur-sm: 0px;
                --blur-md: 0px;
                --shadow-card: 0 6px 16px rgba(0, 0, 0, 0.25);
                --shadow-card-hover: 0 10px 24px rgba(0, 0, 0, 0.3);
            }

            .glass-card,
            .mobile-menu,
            .gallery-modal,
            .nav-scrolled,
            .mobile-quick-actions,
            .mobile-menu-overlay,
            .premium-icon-orb,
            .fullscreen-hint {
                backdrop-filter: none !important;
                box-shadow: none !important;
            }

            .glass-card::before,
            .cta-glow::before,
            .scroll-sheen::after,
            section + section::before {
                animation: none !important;
            }

            .grain-overlay,
            #aurora-canvas,
            #topography-overlay {
                opacity: 0 !important;
            }
        }

        @media (max-width: 480px) and (max-height: 900px) {
            .glass-card,
            .premium-icon-orb,
            .facebook-embed-shell,
            .gallery-modal img {
                box-shadow: none;
            }

            .mobile-menu-overlay,
            .mobile-quick-actions,
            .fullscreen-hint {
                backdrop-filter: none;
            }
        }


        #gallery,
        #facebook,
        #faq,
        #vacancies {
            content-visibility: auto;
            contain-intrinsic-size: 1px 900px;
        }

        .faq-question:focus-visible,
        a:focus-visible,
        button:focus-visible,
        input:focus-visible,
        textarea:focus-visible {
            outline: 2px solid rgba(240, 196, 42, 0.95);
            outline-offset: 3px;
            box-shadow: 0 0 0 5px rgba(212, 160, 23, 0.2);
            border-radius: 10px;
        }

        @media (prefers-reduced-motion: reduce) {
            html { scroll-behavior: auto; }
            *, *::before, *::after {
                animation-duration: 0.01ms !important;
                animation-iteration-count: 1 !important;
                transition-duration: 0.01ms !important;
                scroll-behavior: auto !important;
            }
            #topography-overlay,
            #topography-overlay::before,
            #topography-overlay::after {
                animation: none !important;
            }
            .hero-btn:hover,
            .media-card:hover,
            .glass-card:hover,
            .timeline-item:hover .timeline-content,
            .timeline-item:hover .timeline-dot {
                transform: none !important;
                box-shadow: var(--shadow-card) !important;
            }
        }




        @media (min-width: 1024px) {
            .media-scroller { grid-auto-columns: minmax(400px, 1fr); }
        }

        @media (max-width: 1024px) {
            .media-card,
            .media-card.wide { grid-column: span 6; }
        }

        @media (max-width: 700px) {
            .media-grid { grid-template-columns: repeat(1, minmax(0, 1fr)); }
            .media-card,
            .media-card.wide { grid-column: span 1; min-height: 220px; aspect-ratio: 4 / 5; }
            .gallery-nav { display: none; }
            .media-scroller {
                display: flex;
                gap: 14px;
                overflow-x: auto;
                padding: 6px 2px 18px;
                scroll-snap-type: x mandatory;
                scroll-padding-left: 2px;
            }
            .media-scroller .media-card,
            .media-scroller .media-card.wide {
                flex: 0 0 82vw;
                max-width: 82vw;
                min-width: 82vw;
                margin: 0;
            }
            .media-meta {
                left: 12px;
                right: 12px;
                bottom: 12px;
                font-size: 0.82rem;
                gap: 2px;
            }
            .media-meta p {
                white-space: normal;
                display: -webkit-box;
                -webkit-line-clamp: 2;
                -webkit-box-orient: vertical;
                line-clamp: 2;
            }
            .sound-toggle { right: 16px; bottom: 84px; }
        }


.access-block-screen {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 24px;
    background: radial-gradient(circle at top, #1a2458, #080b1f 60%);
    color: #f8fafc;
}

.access-block-screen h1 {
    font-size: clamp(2rem, 7vw, 3.4rem);
    margin-bottom: 16px;
}

.access-block-screen p {
    max-width: 620px;
    margin-bottom: 10px;
}

.access-block-screen .access-block-reason {
    font-size: 0.9rem;
    color: #94a3b8;
}

@media (max-width: 768px) {
    .glass-card,
    .media-card {
        backdrop-filter: blur(8px);
    }

    .glass-card::before,
    .glass-card::after,
    .media-card::before,
    .media-card::after {
        animation: none !important;
    }
}
