        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
            list-style: none;
            text-decoration: none;
        }
        :root {
            /* Light Theme Colors (Default) */
            --space-indigo: #2b2d42ff;
            --lavender-grey: #8d99aeff;
            --platinum: #edf2f4ff;
            --punch-red: #ef233cff;
            --flag-red: #d90429ff;
            --accent: #e94560;

            --space-indigo-light: rgba(43, 45, 66, 0.08);
            --lavender-grey-light: rgba(141, 153, 174, 0.15);
            --white: #ffffff;

            /* Dark Theme Colors */
            --dark-space-indigo: #1a1c2eff;
            --dark-lavender-grey: #a0a8b8ff;
            --dark-platinum: #1e2130ff;
            --dark-white: #2d3142ff;
            --dark-white-light: #3a3f54ff;

            --xs: 4px; --sm: 8px; --md: 16px; --lg: 24px; --xl: 32px; --2xl: 48px; --3xl: 64px; --4xl: 80px;

            --card-radius: 16px;
            --btn-radius: 50px;
            --input-radius: 12px;
            --capsule-radius: 50px;

            --shadow-sm: 0 2px 8px rgba(43, 45, 66, 0.08);
            --shadow-md: 0 8px 24px rgba(43, 45, 66, 0.12);
            --shadow-lg: 0 16px 40px rgba(43, 45, 66, 0.15);

            --transition-fast: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
            --transition-medium: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            --transition-slow: 0.5s cubic-bezier(0.4, 0, 0.2, 1);

            /* =========================================
               HERO BACKGROUND IMAGE SETTINGS
               =========================================

               To set your hero background images:
               1. Place your image files in the same folder as this HTML file
               2. Update the variables below with your image filenames

               Light Theme (White Background):
               --hero-bg-image-light: url('hero-background-light.jpg');

               Dark Theme (Black Background):
               --hero-bg-image-dark: url('hero-background-dark.jpg');

               If no image is set, the background will default to the solid theme color.
            */
            --hero-bg-image-light: none;
            --hero-bg-image-dark: none;
        }


        body {
            font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
            color: var(--space-indigo);
            background-color: var(--platinum);
            line-height: 1.7;
            -webkit-font-smoothing: antialiased;
        }
        h1, h2, h3, h4, h5 {
            font-family: 'Plus Jakarta Sans', sans-serif;
            font-weight: 700;
            line-height: 1.25;
            color: var(--space-indigo);
        }
        h1 { font-size: clamp(2.5rem, 5vw, 3.5rem); letter-spacing: -0.02em; }
        h2 { font-size: clamp(2rem, 4vw, 2.75rem); text-align: center; margin-bottom: var(--2xl); position: relative; }
        h3 { font-size: clamp(1.25rem, 3vw, 1.5rem); }
        h4 { font-size: 1.125rem; font-weight: 600; }
        p { color: var(--lavender-grey); font-size: 1rem; line-height: 1.75; }
        .text-center { text-align: center; }
        .text-primary { color: var(--flag-red); }
        .text-white { color: var(--white); }


        .container { max-width: 1280px; width: 92%; margin: 0 auto; padding: var(--2xl) 0; }
        .grid { display: grid; gap: var(--lg); }
        .grid-2 { grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); }
        .grid-3 { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }
        .grid-4 { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
        .flex { display: flex; align-items: center; justify-content: center; gap: var(--md); }
        .flex-col { flex-direction: column; }
        .flex-between { justify-content: space-between; }
        .flex-start { justify-content: flex-start; }
        .gap-sm { gap: var(--sm); }
        .gap-md { gap: var(--md); }
        .gap-lg { gap: var(--lg); }
        .mb-sm { margin-bottom: var(--sm); }
        .mb-md { margin-bottom: var(--md); }
        .mb-lg { margin-bottom: var(--lg); }
        .mb-xl { margin-bottom: var(--xl); }
        .mt-xl { margin-top: var(--xl); }
        .badge.highlight { background: var(--accent); }


        .modern-card {
            background: var(--white);
            border-radius: var(--card-radius);
            padding: var(--xl);
            box-shadow: var(--shadow-md);
            transition: var(--transition-medium);
            height: 100%;
            display: flex;
            flex-direction: column;
            position: relative;
            overflow: hidden;
        }
        .modern-card::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 4px;
            background: linear-gradient(90deg, var(--flag-red), var(--punch-red));
            transform: scaleX(0);
            transition: var(--transition-medium);
        }
        .modern-card:hover {
            transform: translateY(-8px);
            box-shadow: var(--shadow-lg);
        }
        .modern-card:hover::before {
            transform: scaleX(1);
        }

        .btn-primary {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            padding: 14px 32px;
            border-radius: var(--btn-radius);
            font-weight: 600;
            font-size: 1rem;
            cursor: pointer;
            border: none;
            transition: var(--transition-medium);
            gap: var(--sm);
            background: var(--flag-red);
            color: var(--white);
        }
        .btn-primary:hover {
            background: var(--punch-red);
            transform: translateY(-2px);
            box-shadow: 0 8px 20px rgba(217, 4, 41, 0.3);
        }
        .btn-primary:active {
            transform: scale(0.98);
        }

        .btn-secondary {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            padding: 14px 32px;
            border-radius: var(--btn-radius);
            font-weight: 600;
            font-size: 1rem;
            cursor: pointer;
            border: 2px solid var(--space-indigo);
            background: transparent;
            color: var(--space-indigo);
            transition: var(--transition-fast);
        }
        .btn-secondary:hover {
            background: var(--space-indigo);
            color: var(--white);
        }

        .modern-input {
            width: 100%;
            padding: 16px var(--md);
            border: 2px solid var(--lavender-grey-light);
            border-radius: var(--input-radius);
            background: var(--platinum);
            font-family: inherit;
            font-size: 1rem;
            color: var(--space-indigo);
            transition: var(--transition-fast);
        }
        .modern-input:focus {
            outline: none;
            border-color: var(--flag-red);
            background: var(--white);
            box-shadow: 0 0 0 4px rgba(217, 4, 41, 0.1);
        }
        .modern-input::placeholder {
            color: var(--lavender-grey);
        }
        textarea.modern-input {
            min-height: 140px;
            resize: none;
            line-height: 1.6;
        }

        .capsule-tag {
            display: inline-flex;
            align-items: center;
            padding: 6px 14px;
            background: var(--lavender-grey-light);
            border-radius: var(--capsule-radius);
            font-size: 0.75rem;
            font-weight: 600;
            color: var(--space-indigo);
            white-space: nowrap;
        }
        .capsule-tag.highlight { background: var(--accent); }
        
        .capsule-tag i {
            margin-right: 6px;
            font-size: 0.7rem;
        }

        /* Filter Form Styles */
        .uni-filter-section {
            background: var(--white);
            padding: var(--xl) var(--xl);
            margin-bottom: var(--xl);
            border-radius: var(--card-radius);
            box-shadow: var(--shadow-sm);
        }
        .uni-filter-form {
            display: flex;
            align-items: flex-end;
            gap: var(--lg);
            flex-wrap: wrap;
        }
        .filter-group {
            flex: 1;
            min-width: 200px;
            display: flex;
            flex-direction: column;
            gap: var(--sm);
        }
        .filter-group label {
            font-size: 0.8rem;
            font-weight: 600;
            color: var(--space-indigo);
            text-transform: uppercase;
            letter-spacing: 0.05em;
            padding-left: 4px;
        }
        .filter-select {
            width: 100%;
            padding: 14px var(--md);
            border: 2px solid var(--lavender-grey-light);
            border-radius: var(--input-radius);
            background: var(--platinum);
            font-family: inherit;
            font-size: 0.95rem;
            color: var(--space-indigo);
            cursor: pointer;
            transition: var(--transition-fast);
            appearance: none;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238d99ae' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
            background-repeat: no-repeat;
            background-position: right 16px center;
        }
        .filter-select:focus {
            outline: none;
            border-color: var(--flag-red);
            background-color: var(--white);
            box-shadow: 0 0 0 4px rgba(217, 4, 41, 0.1);
        }
        .filter-btn {
            padding: 14px 36px;
            white-space: nowrap;
            min-width: 150px;
            margin-top: auto;
        }
        .filter-results-count {
            font-size: 0.875rem;
            color: var(--lavender-grey);
            margin-top: var(--lg);
            text-align: center;
            width: 100%;
            padding-top: var(--md);
            border-top: 1px solid var(--lavender-grey-light);
        }

        /* Language Programme Styles */
        .uni-language-section {
            margin-bottom: var(--md);
        }
        .uni-language-title {
            font-size: 0.75rem;
            font-weight: 600;
            color: var(--lavender-grey);
            text-transform: uppercase;
            letter-spacing: 0.05em;
            margin-bottom: var(--sm);
            display: flex;
            align-items: center;
            gap: 6px;
        }
        .uni-language-title i {
            font-size: 0.7rem;
            color: var(--flag-red);
        }
        .language-tags {
            display: flex;
            flex-wrap: wrap;
            gap: var(--sm);
        }
        .language-tag {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 6px 12px;
            border-radius: var(--capsule-radius);
            font-size: 0.75rem;
            font-weight: 600;
        }
        .language-tag.english {
            background: rgba(43, 45, 66, 0.1);
            color: var(--space-indigo);
        }
        .language-tag.chinese {
            background: rgba(217, 4, 41, 0.1);
            color: var(--flag-red);
        }
        .language-tag i {
            font-size: 0.65rem;
        }

        /* Majors Styles */
        .uni-majors-section {
            margin-bottom: var(--md);
        }
        .uni-majors-title {
            font-size: 0.75rem;
            font-weight: 600;
            color: var(--lavender-grey);
            text-transform: uppercase;
            letter-spacing: 0.05em;
            margin-bottom: var(--sm);
            display: flex;
            align-items: center;
            gap: 6px;
        }
        .uni-majors-title i {
            font-size: 0.7rem;
            color: var(--flag-red);
        }
        .majors-tags {
            display: flex;
            flex-wrap: wrap;
            gap: var(--xs);
        }
        .major-tag {
            display: inline-flex;
            align-items: center;
            padding: 4px 10px;
            background: var(--lavender-grey-light);
            border-radius: 6px;
            font-size: 0.7rem;
            font-weight: 500;
            color: var(--space-indigo);
            transition: var(--transition-fast);
        }
        .major-tag:hover {
            background: var(--space-indigo);
            color: var(--white);
        }


        header {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            z-index: 9999;
            padding: var(--md) 0;
            background-color: rgba(255, 255, 255, 0.95);
            backdrop-filter: blur(20px);
            -webkit-backdrop-filter: blur(20px);
            border-bottom: 1px solid var(--lavender-grey-light);
        }
        .header-inner {
            max-width: 1280px;
            width: 92%;
            margin: 0 auto;
            display: flex;
            align-items: center;
            justify-content: space-between;
        }
        .logo {
            font-family: 'Plus Jakarta Sans', sans-serif;
            font-weight: 800;
            font-size: 1.5rem;
            color: var(--space-indigo);
            display: flex;
            align-items: center;
            gap: var(--sm);
        }
        .logo i {
            color: var(--flag-red);
        }
        .desktop-nav {
            display: flex;
            align-items: center;
            gap: var(--xl);
        }
        .nav-container {
            position: relative;
            display: flex;
            align-items: center;
            padding: 4px;
            background: var(--platinum);
            border-radius: var(--btn-radius);
        }
        .nav-links {
            display: flex;
            gap: 0;
            position: relative;
            z-index: 2;
            margin: 0;
            padding: 0;
        }
        .nav-links li {
            list-style: none;
        }
        .nav-links a {
            display: block;
            color: var(--space-indigo);
            font-weight: 500;
            padding: 10px 20px;
            border-radius: var(--btn-radius);
            position: relative;
            z-index: 2;
        }
        .nav-links a.active {
            color: var(--white);
        }
        .nav-indicator {
            position: absolute;
            top: 4px;
            left: 0;
            height: calc(100% - 8px);
            background: var(--space-indigo);
            border-radius: var(--btn-radius);
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            z-index: 1;
            pointer-events: none;
        }
        .hamburger {
            display: none;
            font-size: 1.5rem;
            color: var(--space-indigo);
            cursor: pointer;
            padding: var(--sm);
        }
        .hamburger:hover {
            color: var(--flag-red);
        }


        .mobile-menu {
            position: fixed;
            bottom: -100%;
            left: 0;
            width: 100%;
            background: rgba(255, 255, 255, 0.98);
            backdrop-filter: blur(30px);
            -webkit-backdrop-filter: blur(30px);
            border-top-left-radius: var(--card-radius);
            border-top-right-radius: var(--card-radius);
            box-shadow: 0 -8px 32px rgba(43, 45, 66, 0.15);
            padding: var(--xl);
            z-index: 99999;
            transition: bottom 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        }
        .mobile-menu.active {
            bottom: 0;
        }
        .mobile-menu .nav-links {
            flex-direction: column;
            gap: var(--sm);
            padding: var(--md) 0;
        }
        .mobile-menu .nav-links a {
            padding: var(--md);
            border-bottom: 1px solid var(--lavender-grey-light);
            width: 100%;
        }
        .menu-close {
            text-align: right;
            font-size: 1.5rem;
            cursor: pointer;
            color: var(--lavender-grey);
            margin-bottom: var(--md);
        }


        /* =========================================
           HERO BACKGROUND IMAGE SETTING
           =========================================
           To set your local hero background image:
           1. Place your image file in the same folder as this HTML file
           2. Update the --hero-bg-image variable in the :root section (line 20-47)
           3. Example: --hero-bg-image: url('your-image.jpg');

           If no image is set, the background will default to white.
        */

        .hero {
            padding: 8rem 0 var(--4xl);
            background-color: var(--white);
            background-image: var(--hero-bg-image-light);
            background-size: cover;
            background-position: center;
            background-repeat: no-repeat;
            text-align: center;
            min-height: 90vh;
            display: flex;
            align-items: center;
        }
        .hero-content {
            position: relative;
        }
        .hero-badge {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            padding: 8px 20px;
            background: rgba(217, 4, 41, 0.1);
            border-radius: 50px;
            font-size: 0.875rem;
            font-weight: 600;
            color: var(--flag-red);
            margin-bottom: var(--lg);
            animation: fadeInUp 0.3s ease-out;
        }
        .hero-badge i {
            font-size: 0.75rem;
        }
        .hero h1 {
            margin-bottom: var(--lg);
            font-family: 'Space Grotesk', 'Plus Jakarta Sans', sans-serif;
            font-weight: 900;
            letter-spacing: -0.03em;
            animation: fadeInUp 0.3s ease-out 0.2s both;
        }

        .hero h1 .gold-text {
            background: linear-gradient(135deg, #FFD700 0%, #FDB931 25%, #FFD700 50%, #DAA520 75%, #FFD700 100%);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            position: relative;
            display: inline-block;
            animation: goldShimmer 3s ease-in-out infinite;
            background-size: 200% 200%;
            -webkit-text-stroke: 0.5px rgba(139, 90, 43, 0.8);
            text-shadow:
                0 0 30px rgba(255, 215, 0, 0.3),
                0 0 60px rgba(255, 215, 0, 0.2),
                0 0 90px rgba(255, 215, 0, 0.1);
        }

        .hero h1 .gold-text::after {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: inherit;
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            filter: blur(20px);
            opacity: 0.4;
            z-index: -1;
        }

        @keyframes goldShimmer {
            0%, 100% {
                background-position: 0% 50%;
                filter: brightness(1) saturate(1);
            }
            50% {
                background-position: 100% 50%;
                filter: brightness(1.1) saturate(1.1);
            }
        }

        @keyframes goldGlow {
            0%, 100% {
                filter: drop-shadow(0 0 8px rgba(255, 215, 0, 0.4));
            }
            50% {
                filter: drop-shadow(0 0 20px rgba(255, 215, 0, 0.7));
            }
        }
        .hero p {
            max-width: 700px;
            margin: 0 auto var(--2xl);
            font-size: 1.35rem;
            line-height: 1.8;
            color: var(--space-indigo);
            opacity: 0.85;
            animation: fadeInUp 0.5s ease-out 0.4s both;
        }
        .hero-stats {
            display: flex;
            justify-content: center;
            gap: var(--3xl);
            margin-bottom: var(--2xl);
            animation: fadeInUp 0.5s ease-out 0.6s both;
        }
        .hero-stat {
            text-align: center;
        }
        .hero-stat-number {
            font-family: 'Plus Jakarta Sans', sans-serif;
            font-size: 2.5rem;
            font-weight: 800;
            color: var(--flag-red);
            line-height: 1;
            margin-bottom: var(--xs);
        }
        .hero-stat-label {
            font-size: 0.875rem;
            color: var(--lavender-grey);
            font-weight: 500;
        }
        .hero-buttons {
            display: flex;
            gap: var(--md);
            justify-content: center;
            flex-wrap: wrap;
            animation: fadeInUp 0.5s ease-out 0.8s both;
        }
        @keyframes fadeInUp {
            from {
                opacity: 0;
                transform: translateY(30px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

        .universities-section {
            background: var(--white);
        }
        .uni-card {
            background: var(--platinum);
            border: 1px solid var(--lavender-grey-light);
        }
        .uni-card:hover {
            background: var(--white);
        }
        .uni-header {
            display: flex;
            align-items: center;
            gap: var(--md);
            margin-bottom: var(--md);
        }
        .uni-logo {
            width: 60px;
            height: 60px;
            background: var(--white);
            border-radius: var(--input-radius);
            display: flex;
            align-items: center;
            justify-content: center;
            box-shadow: var(--shadow-sm);
            flex-shrink: 0;
        }
        .uni-logo i {
            font-size: 1.5rem;
            color: var(--flag-red);
        }
        .uni-info h4 {
            margin-bottom: 4px;
        }
        .uni-location {
            font-size: 0.875rem;
            color: var(--lavender-grey);
            display: flex;
            align-items: center;
            gap: 6px;
        }
        .uni-capsules {
            display: flex;
            flex-wrap: wrap;
            gap: var(--sm);
            margin: var(--md) 0;
            padding: var(--md) 0;
            border-top: 1px solid var(--lavender-grey-light);
            border-bottom: 1px solid var(--lavender-grey-light);
        }
        .uni-features {
            margin-top: auto;
        }
        .uni-features li {
            display: flex;
            align-items: center;
            gap: var(--sm);
            font-size: 0.9rem;
            color: var(--lavender-grey);
            margin-bottom: var(--sm);
        }
        .uni-features li i {
            color: var(--flag-red);
            font-size: 0.8rem;
        }


        .stories-section {
            background: var(--space-indigo);
            position: relative;
        }
        .stories-section h2 {
            color: var(--white);
        }
        .stories-section p {
            color: var(--lavender-grey);
        }
        .stories-slider-wrapper {
            position: relative;
            padding: var(--xl) 0;
        }
        .stories-slider {
            display: flex;
            gap: var(--lg);
            overflow-x: auto;
            scroll-behavior: smooth;
            cursor: grab;
            padding: var(--lg) 0;
            scrollbar-width: none;
            -ms-overflow-style: none;
            user-select: none;
        }
        .stories-slider::-webkit-scrollbar {
            display: none;
        }
        .stories-slider:active {
            cursor: grabbing;
        }
        .story-card {
            flex: 0 0 380px;
            background: var(--white);
            border-radius: var(--card-radius);
            padding: var(--xl);
            display: flex;
            flex-direction: column;
            gap: var(--md);
            box-shadow: var(--shadow-md);
        }
        .story-header {
            display: flex;
            align-items: center;
            gap: var(--md);
        }
        .story-avatar {
            width: 64px;
            height: 64px;
            background: linear-gradient(135deg, var(--flag-red), var(--punch-red));
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--white);
            font-weight: 700;
            font-size: 1.25rem;
            flex-shrink: 0;
        }
        .story-meta h4 {
            margin-bottom: 4px;
        }
        .story-meta p {
            font-size: 0.875rem;
            color: var(--lavender-grey);
        }
        .story-uni-tag {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 6px 12px;
            background: var(--lavender-grey-light);
            border-radius: var(--capsule-radius);
            font-size: 0.75rem;
            font-weight: 600;
            color: var(--space-indigo);
        }
        .story-quote {
            font-size: 1rem;
            line-height: 1.8;
            color: var(--space-indigo);
            font-style: italic;
            position: relative;
            padding-left: var(--lg);
        }
        .story-quote::before {
            content: '"';
            position: absolute;
            left: 0;
            top: -8px;
            font-size: 3rem;
            color: var(--flag-red);
            opacity: 0.3;
            font-family: Georgia, serif;
        }
        .slider-controls {
            display: flex;
            justify-content: center;
            gap: var(--md);
            margin-top: var(--lg);
        }
        .slider-btn {
            width: 48px;
            height: 48px;
            border-radius: 50%;
            background: var(--white);
            border: none;
            color: var(--space-indigo);
            cursor: pointer;
            transition: var(--transition-fast);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.125rem;
        }
        .slider-btn:hover {
            background: var(--flag-red);
            color: var(--white);
        }


        .contact-section {
            background: var(--platinum);
        }
        .contact-wrapper {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: var(--2xl);
            align-items: stretch;
        }
        .contact-wrapper > * {
            width: 100%;
            max-width: none;
        }
        .contact-info-card {
            background: var(--space-indigo);
            border-radius: var(--card-radius);
            padding: var(--2xl);
            color: var(--white);
            position: relative;
            overflow: hidden;
            height: 100%;
            display: flex;
            flex-direction: column;
            box-sizing: border-box;
        }
        .contact-info-card-content {
            flex: 1;
            display: flex;
            flex-direction: column;
            gap: var(--lg);
        }
        .contact-info-card::before {
            content: '';
            position: absolute;
            top: -50%;
            right: -50%;
            width: 200px;
            height: 200px;
            background: radial-gradient(circle, rgba(239, 35, 60, 0.2) 0%, transparent 70%);
            border-radius: 50%;
        }
        .contact-info-card h3 {
            color: var(--white);
            font-size: 2rem;
            margin-bottom: var(--sm);
        }
        .contact-info-card > p {
            color: var(--lavender-grey);
            margin-bottom: var(--xl);
        }
        .contact-info-card-header {
            margin-bottom: var(--xl);
        }
        .contact-methods {
            display: flex;
            flex-direction: column;
            gap: var(--xl);
        }
        .contact-method {
            display: flex;
            align-items: flex-start;
            gap: var(--md);
        }
        .contact-method-icon {
            width: 48px;
            height: 48px;
            background: rgba(255, 255, 255, 0.1);
            border-radius: var(--input-radius);
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--flag-red);
            font-size: 1.25rem;
            flex-shrink: 0;
        }
        .contact-method-text h4 {
            color: var(--white);
            margin-bottom: 4px;
        }
        .contact-method-text p {
            color: var(--lavender-grey);
            font-size: 0.95rem;
        }
        .social-links {
            display: flex;
            gap: var(--md);
            margin-top: var(--xl);
            padding-top: var(--xl);
            border-top: 1px solid rgba(255, 255, 255, 0.1);
        }
        .social-links a {
            width: 44px;
            height: 44px;
            background: rgba(255, 255, 255, 0.1);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--white);
            transition: var(--transition-fast);
        }
        .social-links a:hover {
            background: var(--flag-red);
            transform: translateY(-3px);
        }
        .contact-form-card {
            background: var(--white);
            border-radius: var(--card-radius);
            padding: var(--2xl);
            box-shadow: var(--shadow-lg);
            height: 100%;
            display: flex;
            flex-direction: column;
            box-sizing: border-box;
        }
        .contact-form-card h3 {
            margin-bottom: var(--xl);
        }
        .form-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: var(--md);
        }
        .form-full {
            grid-column: span 2;
        }
        .form-group {
            position: relative;
        }
        .form-group label {
            display: block;
            font-size: 0.875rem;
            font-weight: 600;
            color: var(--space-indigo);
            margin-bottom: var(--sm);
        }
        .submit-btn {
            width: 100%;
            padding: 16px;
            margin-top: var(--md);
        }

        footer {
            background: var(--space-indigo);
            padding: var(--4xl) 0 var(--xl);
            color: var(--white);
        }
        .footer-grid {
            display: grid;
            grid-template-columns: 2fr 1fr 1fr 1fr 1.5fr;
            gap: var(--2xl);
            margin-bottom: var(--3xl);
        }
        .footer-brand {
            max-width: 300px;
        }
        .footer-brand .logo {
            color: var(--white);
            margin-bottom: var(--md);
        }
        .footer-brand p {
            color: var(--lavender-grey);
            font-size: 0.95rem;
            margin-bottom: var(--lg);
        }
        .footer-heading {
            font-size: 1rem;
            font-weight: 700;
            margin-bottom: var(--lg);
            color: var(--white);
        }
        .footer-links {
            display: flex;
            flex-direction: column;
            gap: var(--sm);
        }
        .footer-links a {
            color: var(--lavender-grey);
            font-size: 0.95rem;
            transition: var(--transition-fast);
            display: flex;
            align-items: center;
            gap: var(--sm);
        }
        .footer-links a:hover {
            color: var(--white);
            padding-left: 4px;
        }
        .footer-links a i {
            font-size: 0.75rem;
        }
        .newsletter-form {
            display: flex;
            gap: var(--sm);
        }
        .newsletter-input {
            flex: 1;
            padding: 12px var(--md);
            border: none;
            border-radius: var(--input-radius);
            background: rgba(255, 255, 255, 0.1);
            color: var(--white);
            font-size: 0.95rem;
        }
        .newsletter-input::placeholder {
            color: var(--lavender-grey);
        }
        .newsletter-btn {
            padding: 12px 20px;
            background: var(--flag-red);
            border: none;
            border-radius: var(--input-radius);
            color: var(--white);
            cursor: pointer;
            transition: var(--transition-fast);
        }
        .newsletter-btn:hover {
            background: var(--punch-red);
        }
        .popular-cities {
            display: flex;
            flex-wrap: wrap;
            gap: var(--sm);
        }
        .city-tag {
            padding: 6px 12px;
            background: rgba(255, 255, 255, 0.1);
            border-radius: var(--capsule-radius);
            font-size: 0.8rem;
            color: var(--lavender-grey);
        }
        .footer-bottom {
            padding-top: var(--xl);
            border-top: 1px solid rgba(255, 255, 255, 0.1);
            display: flex;
            justify-content: space-between;
            align-items: center;
            flex-wrap: wrap;
            gap: var(--md);
        }
        .footer-bottom p {
            color: var(--lavender-grey);
            font-size: 0.875rem;
        }
        .legal-links {
            display: flex;
            gap: var(--lg);
        }
        .legal-links a {
            color: var(--lavender-grey);
            font-size: 0.875rem;
            transition: var(--transition-fast);
        }
        .legal-links a:hover {
            color: var(--white);
        }

        .faq-section {
            background: var(--white);
        }
        .faq-container {
            max-width: 800px;
            margin: 0 auto;
        }
        .faq-item {
            border-bottom: 1px solid var(--lavender-grey-light);
        }
        .faq-question {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: var(--lg) 0;
            cursor: pointer;
            transition: var(--transition-fast);
        }
        .faq-question:hover {
            color: var(--flag-red);
        }
        .faq-question h4 {
            font-size: 1.1rem;
            font-weight: 600;
            margin: 0;
        }
        .faq-icon {
            width: 28px;
            height: 28px;
            background: var(--lavender-grey-light);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--space-indigo);
            font-size: 0.875rem;
            transition: var(--transition-fast);
            flex-shrink: 0;
        }
        .faq-item.active .faq-icon {
            background: var(--flag-red);
            color: var(--white);
            transform: rotate(180deg);
        }
        .faq-answer {
            max-height: 0;
            overflow: hidden;
            transition: max-height 0.3s ease-out;
        }
        .faq-answer p {
            padding-bottom: var(--lg);
            color: var(--lavender-grey);
            line-height: 1.8;
        }
        .faq-item.active .faq-answer {
            max-height: 200px;
        }

        /* Dark Mode Styles */
        [data-theme="dark"] body {
            background-color: var(--dark-platinum);
            color: var(--lavender-grey);
        }

        [data-theme="dark"] h1,
        [data-theme="dark"] h2,
        [data-theme="dark"] h3,
        [data-theme="dark"] h4,
        [data-theme="dark"] h5 {
            color: var(--white);
        }

        [data-theme="dark"] p {
            color: var(--dark-lavender-grey);
        }

        [data-theme="dark"] .modern-card {
            background: var(--dark-white);
            box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
        }

        [data-theme="dark"] .modern-card:hover {
            background: var(--dark-white-light);
        }

        [data-theme="dark"] header {
            background-color: rgba(30, 33, 48, 0.95);
            border-bottom-color: rgba(255, 255, 255, 0.1);
        }

        [data-theme="dark"] .logo {
            color: var(--white);
        }

        [data-theme="dark"] .nav-container {
            background: var(--dark-white-light);
        }

        [data-theme="dark"] .nav-links a {
            color: var(--lavender-grey);
        }

        [data-theme="dark"] .nav-links a.active {
            color: var(--white);
        }

        [data-theme="dark"] .nav-indicator {
            background: var(--dark-white-light);
        }

        [data-theme="dark"] .hero {
            background-color: var(--dark-space-indigo);
            background-image: var(--hero-bg-image-dark);
        }

        [data-theme="dark"] .hero p {
            color: var(--dark-lavender-grey);
        }

        [data-theme="dark"] .universities-section {
            background: var(--dark-space-indigo);
        }

        [data-theme="dark"] .uni-filter-section {
            background: var(--dark-white);
        }

        [data-theme="dark"] .filter-group label {
            color: var(--white);
        }

        [data-theme="dark"] .filter-select {
            background: var(--dark-platinum);
            border-color: rgba(255, 255, 255, 0.1);
            color: var(--white);
        }

        [data-theme="dark"] .filter-select:focus {
            background-color: var(--dark-white-light);
        }

        [data-theme="dark"] .filter-results-count {
            border-top-color: rgba(255, 255, 255, 0.1);
        }

        [data-theme="dark"] .uni-card {
            background: var(--dark-white);
            border-color: rgba(255, 255, 255, 0.1);
        }

        [data-theme="dark"] .uni-card:hover {
            background: var(--dark-white-light);
        }

        [data-theme="dark"] .uni-capsules {
            border-top-color: rgba(255, 255, 255, 0.1);
            border-bottom-color: rgba(255, 255, 255, 0.1);
        }

        [data-theme="dark"] .capsule-tag {
            background: rgba(255, 255, 255, 0.1);
            color: var(--lavender-grey);
        }

        [data-theme="dark"] .capsule-tag.rank {
            background: var(--dark-white-light);
            color: var(--white);
        }

        [data-theme="dark"] .capsule-tag.league {
            background: rgba(239, 35, 60, 0.2);
            color: var(--punch-red);
        }

        [data-theme="dark"] .uni-location {
            color: var(--dark-lavender-grey);
        }

        [data-theme="dark"] .uni-features li {
            color: var(--dark-lavender-grey);
        }

        [data-theme="dark"] .major-tag {
            background: rgba(255, 255, 255, 0.1);
            color: var(--lavender-grey);
        }

        [data-theme="dark"] .major-tag:hover {
            background: var(--white);
            color: var(--space-indigo);
        }

        [data-theme="dark"] .language-tag.english {
            background: rgba(255, 255, 255, 0.1);
            color: var(--lavender-grey);
        }

        [data-theme="dark"] .language-tag.chinese {
            background: rgba(217, 4, 41, 0.2);
            color: var(--punch-red);
        }

        [data-theme="dark"] .stories-section {
            background: var(--dark-space-indigo);
        }

        [data-theme="dark"] .stories-section h2 {
            color: var(--white);
        }

        [data-theme="dark"] .story-card {
            background: var(--dark-white);
        }

        [data-theme="dark"] .story-meta p {
            color: var(--dark-lavender-grey);
        }

        [data-theme="dark"] .story-quote {
            color: var(--lavender-grey);
        }

        [data-theme="dark"] .story-uni-tag {
            background: rgba(255, 255, 255, 0.1);
            color: var(--lavender-grey);
        }

        [data-theme="dark"] .faq-section {
            background: var(--dark-space-indigo);
        }

        [data-theme="dark"] .faq-item {
            border-bottom-color: rgba(255, 255, 255, 0.1);
        }

        [data-theme="dark"] .faq-question {
            color: var(--white);
        }

        [data-theme="dark"] .faq-question:hover {
            color: var(--punch-red);
        }

        [data-theme="dark"] .faq-icon {
            background: rgba(255, 255, 255, 0.1);
            color: var(--lavender-grey);
        }

        [data-theme="dark"] .faq-answer p {
            color: var(--dark-lavender-grey);
        }

        [data-theme="dark"] .contact-section {
            background: var(--dark-space-indigo);
        }

        [data-theme="dark"] .contact-info-card {
            background: var(--dark-white);
        }

        [data-theme="dark"] .contact-form-card {
            background: var(--dark-white);
        }

        [data-theme="dark"] .contact-form-card h3 {
            color: var(--white);
        }

        [data-theme="dark"] .form-group label {
            color: var(--white);
        }

        [data-theme="dark"] .modern-input {
            background: var(--dark-platinum);
            border-color: rgba(255, 255, 255, 0.1);
            color: var(--white);
        }

        [data-theme="dark"] .modern-input::placeholder {
            color: var(--dark-lavender-grey);
        }

        [data-theme="dark"] .modern-input:focus {
            background: var(--dark-white-light);
        }

        [data-theme="dark"] .btn-secondary {
            border-color: var(--lavender-grey);
            color: var(--lavender-grey);
        }

        [data-theme="dark"] .btn-secondary:hover {
            background: var(--white);
            color: var(--space-indigo);
        }

        [data-theme="dark"] footer {
            background: var(--dark-space-indigo);
        }

        [data-theme="dark"] .footer-brand .logo {
            color: var(--white);
        }

        [data-theme="dark"] .footer-heading {
            color: var(--white);
        }

        [data-theme="dark"] .footer-links a:hover {
            color: var(--white);
        }

        [data-theme="dark"] .city-tag {
            background: rgba(255, 255, 255, 0.1);
            color: var(--dark-lavender-grey);
        }

        [data-theme="dark"] .newsletter-input {
            background: rgba(255, 255, 255, 0.1);
            color: var(--white);
        }

        [data-theme="dark"] .newsletter-input::placeholder {
            color: var(--dark-lavender-grey);
        }

        [data-theme="dark"] .legal-links a:hover {
            color: var(--white);
        }

        [data-theme="dark"] .mobile-menu {
            background: rgba(30, 33, 48, 0.98);
        }

        [data-theme="dark"] .mobile-menu .nav-links a {
            border-bottom-color: rgba(255, 255, 255, 0.1);
            color: var(--lavender-grey);
        }

        [data-theme="dark"] .hamburger {
            color: var(--white);
        }

        [data-theme="dark"] .menu-close {
            color: var(--lavender-grey);
        }

        [data-theme="dark"] .mobile-language-btn {
            background: var(--dark-platinum);
            border-color: rgba(255, 255, 255, 0.1);
            color: var(--white);
        }

        [data-theme="dark"] .mobile-language-dropdown {
            background: var(--dark-platinum);
        }

        [data-theme="dark"] .mobile-language-option {
            color: var(--lavender-grey);
        }

        [data-theme="dark"] .mobile-language-option:hover,
        [data-theme="dark"] .mobile-language-option.current {
            background: var(--dark-white-light);
        }

        [data-theme="dark"] .view-all-universities .btn-primary {
            box-shadow: 0 8px 20px rgba(217, 4, 41, 0.3);
        }

        [data-theme="dark"] .language-selector {
            background: var(--dark-platinum);
        }

        [data-theme="dark"] .language-btn {
            background: var(--dark-platinum);
            color: var(--lavender-grey);
        }

        [data-theme="dark"] .language-btn:hover {
            background: var(--dark-white-light);
        }

        [data-theme="dark"] .language-dropdown {
            background: var(--dark-white);
        }

        [data-theme="dark"] .language-option {
            color: var(--lavender-grey);
        }

        [data-theme="dark"] .language-option:hover {
            background: var(--dark-platinum);
        }

        [data-theme="dark"] .language-option.current {
            background: var(--dark-platinum);
        }

        [data-theme="dark"] .scroll-up-btn {
            background: var(--flag-red);
            box-shadow: 0 8px 24px rgba(217, 4, 41, 0.3);
        }

        [data-theme="dark"] .scroll-up-btn:hover {
            box-shadow: 0 12px 30px rgba(217, 4, 41, 0.5);
        }

        [data-theme="dark"] .slider-btn {
            background: var(--dark-white);
            color: var(--white);
        }

        [data-theme="dark"] .slider-btn:hover {
            background: var(--flag-red);
            color: var(--white);
        }

        [data-theme="dark"] .contact-info-card h3 {
            color: var(--white);
        }

        [data-theme="dark"] .contact-info-card > p {
            color: var(--dark-lavender-grey);
        }

        [data-theme="dark"] .contact-method-text h4 {
            color: var(--white);
        }

        [data-theme="dark"] .contact-method-text p {
            color: var(--dark-lavender-grey);
        }

        [data-theme="dark"] .footer-bottom p {
            color: var(--dark-lavender-grey);
        }

        [data-theme="dark"] .hero-stat-label {
            color: var(--dark-lavender-grey);
        }

        [data-theme="dark"] .hero-badge {
            background: rgba(217, 4, 41, 0.2);
            color: var(--punch-red);
        }

        [data-theme="dark"] .theme-toggle-btn {
            background: var(--dark-white-light);
            color: var(--lavender-grey);
        }

        [data-theme="dark"] .theme-toggle-btn:hover {
            background: rgba(255, 255, 255, 0.2);
        }

        [data-theme="dark"] .theme-toggle-mobile {
            color: var(--white);
        }

        [data-theme="dark"] .theme-toggle-mobile span {
            color: var(--white);
        }


        @media (max-width: 1024px) {
            .footer-grid {
                grid-template-columns: repeat(3, 1fr);
            }
            .footer-brand {
                grid-column: span 3;
                max-width: 100%;
                text-align: center;
            }
            .footer-brand .logo {
                justify-content: center;
            }
            .footer-brand p {
                max-width: 500px;
                margin: 0 auto var(--lg);
            }
            .social-links {
                justify-content: center;
            }
        }
        @media (max-width: 992px) {
            .desktop-nav {
                display: none;
            }
            .hamburger {
                display: block;
            }
            .contact-wrapper {
                grid-template-columns: 1fr;
            }
            .story-card {
                flex: 0 0 300px;
            }
            .hero {
                padding-top: 8rem;
            }
        }
        @media (max-width: 768px) {
            .footer-grid {
                grid-template-columns: repeat(2, 1fr);
                text-align: center;
            }
            .footer-brand {
                grid-column: span 2;
            }
            .form-grid {
                grid-template-columns: 1fr;
            }
            .form-full {
                grid-column: span 1;
            }
            .newsletter-form {
                flex-direction: column;
            }
            .footer-bottom {
                flex-direction: column;
                text-align: center;
            }
            .hero-buttons {
                flex-direction: column;
                align-items: center;
            }
            .hero-buttons .btn {
                width: 100%;
                max-width: 300px;
            }
        }
        @media (max-width: 480px) {
            .footer-grid {
                grid-template-columns: 1fr;
            }
            .footer-brand {
                grid-column: span 1;
            }
            .story-card {
                flex: 0 0 280px;
            }
        }

        /* Scroll Up Button Styles */
        .scroll-up-btn {
            position: fixed;
            bottom: 30px;
            right: 30px;
            width: 50px;
            height: 50px;
            background: var(--flag-red);
            color: var(--white);
            border: none;
            border-radius: 50%;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.25rem;
            box-shadow: var(--shadow-md);
            opacity: 0;
            visibility: hidden;
            transform: translateY(20px);
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            z-index: 9999;
        }
        .scroll-up-btn.visible {
            opacity: 1;
            visibility: visible;
            transform: translateY(0);
        }
        .scroll-up-btn:hover {
            background: var(--punch-red);
            transform: translateY(-5px);
            box-shadow: 0 12px 30px rgba(217, 4, 41, 0.3);
        }
        .scroll-up-btn:active {
            transform: scale(0.95);
        }

        /* Theme Toggle Button Styles */
        .theme-toggle {
            position: relative;
            margin-left: var(--md);
        }
        .theme-toggle-btn {
            display: flex;
            align-items: center;
            justify-content: center;
            width: 44px;
            height: 44px;
            background: var(--platinum);
            border: none;
            border-radius: 50%;
            cursor: pointer;
            font-size: 1.1rem;
            color: var(--space-indigo);
            transition: var(--transition-fast);
        }
        .theme-toggle-btn:hover {
            background: var(--lavender-grey-light);
            transform: scale(1.05);
        }
        .theme-toggle-btn i {
            transition: transform 0.3s ease, opacity 0.3s ease;
        }
        .theme-toggle-btn .sun-icon {
            position: absolute;
            opacity: 1;
            transform: rotate(0deg) scale(1);
        }
        .theme-toggle-btn .moon-icon {
            position: absolute;
            opacity: 0;
            transform: rotate(-90deg) scale(0.5);
        }
        .theme-toggle.dark .theme-toggle-btn .sun-icon {
            opacity: 0;
            transform: rotate(90deg) scale(0.5);
        }
        .theme-toggle.dark .theme-toggle-btn .moon-icon {
            opacity: 1;
            transform: rotate(0deg) scale(1);
        }

        /* Mobile Theme Toggle Styles */
        .theme-toggle-mobile {
            display: none;
        }
        .switch {
            position: relative;
            display: inline-block;
            width: 52px;
            height: 28px;
        }
        .switch input {
            opacity: 0;
            width: 0;
            height: 0;
        }
        .slider {
            position: absolute;
            cursor: pointer;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background-color: var(--lavender-grey-light);
            transition: 0.4s;
            border-radius: 34px;
        }
        .slider:before {
            position: absolute;
            content: "";
            height: 20px;
            width: 20px;
            left: 4px;
            bottom: 4px;
            background-color: white;
            transition: 0.4s;
            border-radius: 50%;
            box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
        }
        input:checked + .slider {
            background-color: var(--flag-red);
        }
        input:checked + .slider:before {
            transform: translateX(24px);
        }

        /* Language Selector Styles */
        .language-selector {
            position: relative;
            margin-left: var(--md);
        }
        .language-btn {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 8px 16px;
            background: var(--platinum);
            border: none;
            border-radius: var(--btn-radius);
            cursor: pointer;
            font-size: 0.9rem;
            font-weight: 500;
            color: var(--space-indigo);
            transition: var(--transition-fast);
        }
        .language-btn:hover {
            background: var(--lavender-grey-light);
        }
        .language-btn i {
            font-size: 0.8rem;
            transition: transform 0.3s ease;
        }
        .language-selector.active .language-btn i {
            transform: rotate(180deg);
        }
        .language-dropdown {
            position: absolute;
            top: calc(100% + 8px);
            right: 0;
            background: var(--white);
            border-radius: var(--input-radius);
            box-shadow: var(--shadow-lg);
            min-width: 180px;
            opacity: 0;
            visibility: hidden;
            transform: translateY(-10px);
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            z-index: 10000;
            overflow: hidden;
        }
        .language-selector.active .language-dropdown {
            opacity: 1;
            visibility: visible;
            transform: translateY(0);
        }
        .language-option {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 12px 16px;
            cursor: pointer;
            transition: var(--transition-fast);
            color: var(--space-indigo);
            font-size: 0.9rem;
        }
        .language-option:hover {
            background: var(--platinum);
        }
        .language-option.current {
            background: var(--lavender-grey-light);
            font-weight: 600;
        }
        .language-option .lang-flag {
            width: 20px;
            height: 20px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 0.75rem;
            background: var(--lavender-grey-light);
        }
        .language-option .lang-name {
            flex: 1;
        }
        .language-option .lang-check {
            opacity: 0;
            color: var(--flag-red);
            font-size: 0.75rem;
        }
        .language-option.current .lang-check {
            opacity: 1;
        }

        @media (max-width: 992px) {
            .language-selector {
                margin-left: var(--sm);
            }
            .language-btn {
                padding: 6px 12px;
                font-size: 0.8rem;
            }
            .theme-toggle {
                margin-left: var(--sm);
            }
            .theme-toggle-btn {
                width: 40px;
                height: 40px;
                font-size: 1rem;
            }
        }
        @media (max-width: 768px) {
            .scroll-up-btn {
                bottom: 20px;
                right: 20px;
                width: 44px;
                height: 44px;
                font-size: 1rem;
            }
        }

        /* Mobile Language Selector Styles */
        .mobile-language-selector {
            display: none;
            margin: var(--md) 0;
            position: relative;
        }
        .mobile-language-btn {
            display: flex;
            align-items: center;
            gap: 10px;
            width: 100%;
            padding: 14px var(--md);
            background: var(--platinum);
            border: 2px solid var(--lavender-grey-light);
            border-radius: var(--input-radius);
            cursor: pointer;
            font-size: 1rem;
            font-weight: 500;
            color: var(--space-indigo);
            transition: var(--transition-fast);
            justify-content: space-between;
        }
        .mobile-language-btn:hover {
            border-color: var(--flag-red);
        }
        .mobile-language-btn i:first-child {
            font-size: 1.1rem;
            color: var(--flag-red);
        }
        .mobile-language-btn i:last-child {
            font-size: 0.8rem;
            transition: transform 0.3s ease;
        }
        .mobile-language-selector.active .mobile-language-btn i:last-child {
            transform: rotate(180deg);
        }
        .mobile-language-dropdown {
            display: none;
            background: var(--platinum);
            border-radius: var(--input-radius);
            margin-top: var(--sm);
            overflow: hidden;
        }
        .mobile-language-selector.active .mobile-language-dropdown {
            display: block;
        }
        .mobile-language-option {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 14px var(--md);
            cursor: pointer;
            transition: var(--transition-fast);
            color: var(--space-indigo);
            font-size: 1rem;
        }
        .mobile-language-option:hover {
            background: var(--white);
        }
        .mobile-language-option.current {
            background: var(--white);
            font-weight: 600;
        }
        .mobile-language-option .lang-flag {
            width: 24px;
            height: 24px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 0.9rem;
        }
        .mobile-language-option .lang-name {
            flex: 1;
        }
        .mobile-language-option .lang-check {
            opacity: 0;
            color: var(--flag-red);
            font-size: 0.875rem;
        }
        .mobile-language-option.current .lang-check {
            opacity: 1;
        }

        @media (max-width: 992px) {
            .mobile-language-selector {
                display: block;
            }
            .theme-toggle-mobile {
                display: flex;
            }
            .theme-toggle {
                display: none;
            }
        }

        /* Show theme toggle on mobile menu */
        .theme-toggle-mobile {
            display: none;
        }

        /* =========================================
           RESPONSIVE IMAGE STYLES
           ========================================= */

        /* Make all images responsive by default */
        img {
            max-width: 100%;
            height: auto;
            display: block;
        }

        /* Header logo image specific styling */
        .logo img {
            height: 40px;
            width: auto;
            max-width: 200px;
            display: inline-block;
            vertical-align: middle;
        }

        /* University card logo images */
        .uni-logo img,
        .uni-logo-img {
            width: 100%;
            height: 100%;
            object-fit: contain;
            border-radius: var(--input-radius);
        }

        /* Images inside cards or containers */
        .modern-card img,
        .uni-card img,
        .story-card img {
            width: 100%;
            height: auto;
            object-fit: cover;
        }

        /* Fixed height images for card sections */
        .card-image {
            width: 100%;
            height: 200px;
            object-fit: cover;
            border-radius: var(--input-radius);
            margin-bottom: var(--md);
        }

        /* Hero section images */
        .hero-image {
            width: 100%;
            max-width: 1200px;
            height: auto;
            margin: var(--2xl) auto 0;
            display: block;
        }

        /* Section header images */
        .section-image {
            width: 100%;
            max-width: 800px;
            height: auto;
            margin: 0 auto var(--xl);
            display: block;
            border-radius: var(--card-radius);
        }

        /* Grid gallery images */
        .gallery-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: var(--lg);
        }

        .gallery-grid img {
            width: 100%;
            height: 200px;
            object-fit: cover;
            border-radius: var(--card-radius);
            transition: var(--transition-medium);
        }

        .gallery-grid img:hover {
            transform: scale(1.02);
            box-shadow: var(--shadow-lg);
        }

        /* Background image containers */
        .image-container {
            position: relative;
            width: 100%;
            overflow: hidden;
            border-radius: var(--card-radius);
        }

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

        /* Circular images (for avatars, logos, etc.) */
        .circular-image {
            width: 100px;
            height: 100px;
            border-radius: 50%;
            object-fit: cover;
            border: 3px solid var(--white);
            box-shadow: var(--shadow-md);
        }

        /* Thumbnail images */
        .thumbnail {
            width: 80px;
            height: 80px;
            object-fit: cover;
            border-radius: var(--input-radius);
            flex-shrink: 0;
        }

        /* Featured image with caption */
        .featured-image-wrapper {
            margin-bottom: var(--xl);
        }

        .featured-image {
            width: 100%;
            max-height: 400px;
            object-fit: cover;
            border-radius: var(--card-radius);
            margin-bottom: var(--md);
        }

        .image-caption {
            text-align: center;
            font-size: 0.875rem;
            color: var(--lavender-grey);
            font-style: italic;
        }