    /* === MODERN RESET & BASE STYLES === */
    
    /* Modern CSS Custom Properties for Mobile */
    :root {
        --safe-area-inset-top: env(safe-area-inset-top);
        --safe-area-inset-bottom: env(safe-area-inset-bottom);
        --safe-area-inset-left: env(safe-area-inset-left);
        --safe-area-inset-right: env(safe-area-inset-right);
        
        --mobile-header-height: 70px;
        --touch-target-size: 48px;
        --mobile-spacing: 16px;
        --tablet-spacing: 24px;
        
        --primary-blue: #3b82f6;
        --primary-purple: #8b5cf6;
        --primary-cyan: #06b6d4;
        
        /* Mobile Typography Scale */
        --mobile-text-xs: 12px;
        --mobile-text-sm: 14px;
        --mobile-text-base: 16px;
        --mobile-text-lg: 18px;
        --mobile-text-xl: 20px;
        --mobile-text-2xl: 24px;
        --mobile-text-3xl: 28px;
        --mobile-text-4xl: 32px;
    }
    
    * {
        margin: 0;
        padding: 0;
        box-sizing: border-box;
        /* Enhanced touch scrolling */
        -webkit-overflow-scrolling: touch;
        /* Prevent text selection on touch */
        -webkit-touch-callout: none;
        -webkit-tap-highlight-color: transparent;
    }
    
    /* Modern Mobile Scroll Behavior */
    html {
        scroll-behavior: smooth;
        font-size: 16px;
        /* Support for safe areas */
        padding-top: var(--safe-area-inset-top);
        padding-bottom: var(--safe-area-inset-bottom);
        padding-left: var(--safe-area-inset-left);
        padding-right: var(--safe-area-inset-right);
    }
    
    body {
        font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
        line-height: 1.7;
        color: #1e293b;
        background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 50%, #f1f5f9 100%);
        margin: 0;
        padding: 0;
        position: relative;
        overflow-x: hidden;
        transition: background-color 0.3s ease, color 0.3s ease;
        /* Prevent rubber band scrolling on iOS */
        overscroll-behavior-y: none;
        /* Enhanced mobile rendering */
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        text-rendering: optimizeSpeed;
    }
    
    /* === DARK MODE SUPPORT === */
    body.dark-mode {
        background: linear-gradient(135deg, #0f172a 0%, #1e293b 50%, #334155 100%);
        color: #e2e8f0;
    }
    
    body.dark-mode .header {
        background: rgba(15, 23, 42, 0.95);
        border-bottom: 1px solid rgba(71, 85, 105, 0.3);
    }
    
    body.dark-mode .header.scrolled {
        background: rgba(15, 23, 42, 0.98);
        box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
    }
    
    /* === MODERN BACKGROUND PATTERN === */
    body::before {
        content: '';
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-image: 
            radial-gradient(circle at 20% 80%, rgba(59, 130, 246, 0.05) 0%, transparent 50%),
            radial-gradient(circle at 80% 20%, rgba(139, 92, 246, 0.05) 0%, transparent 50%),
            radial-gradient(circle at 40% 40%, rgba(16, 185, 129, 0.03) 0%, transparent 50%);
        background-size: 800px 800px;
        pointer-events: none;
        z-index: -1;
        animation: backgroundShift 20s ease-in-out infinite;
    }
    
    @keyframes backgroundShift {
        0%, 100% { transform: translate(0, 0) rotate(0deg); }
        50% { transform: translate(-10px, -10px) rotate(1deg); }
    }
    
    /* === FLOATING PARTICLES === */
    .floating-particles {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        pointer-events: none;
        z-index: -1;
        opacity: 0.4;
    }
    
    .particle {
        position: absolute;
        width: 4px;
        height: 4px;
        background: linear-gradient(45deg, #3b82f6, #8b5cf6);
        border-radius: 50%;
        animation: float 6s ease-in-out infinite;
    }
    
    .particle:nth-child(1) { left: 10%; animation-delay: 0s; }
    .particle:nth-child(2) { left: 20%; animation-delay: 1s; }
    .particle:nth-child(3) { left: 30%; animation-delay: 2s; }
    .particle:nth-child(4) { left: 40%; animation-delay: 3s; }
    .particle:nth-child(5) { left: 50%; animation-delay: 4s; }
    .particle:nth-child(6) { left: 60%; animation-delay: 5s; }
    .particle:nth-child(7) { left: 70%; animation-delay: 0.5s; }
    .particle:nth-child(8) { left: 80%; animation-delay: 1.5s; }
    .particle:nth-child(9) { left: 90%; animation-delay: 2.5s; }
    
    @keyframes float {
        0%, 100% { transform: translateY(100vh) rotate(0deg); opacity: 0; }
        10%, 90% { opacity: 1; }
        50% { transform: translateY(-100px) rotate(180deg); }
    }
    
    /* === SCROLL PROGRESS INDICATOR === */
    .scroll-progress {
        position: fixed;
        top: 0;
        left: 0;
        width: 0%;
        height: 3px;
        background: linear-gradient(90deg, #3b82f6, #8b5cf6, #06b6d4);
        z-index: 9999;
        transition: width 0.3s ease;
        box-shadow: 0 0 10px rgba(59, 130, 246, 0.5);
    }
    
    /* === SCROLL TO TOP BUTTON === */
    .scroll-to-top {
        position: fixed;
        bottom: 30px;
        right: 30px;
        width: 50px;
        height: 50px;
        background: linear-gradient(135deg, #3b82f6, #8b5cf6);
        color: white;
        border: none;
        border-radius: 50%;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 20px;
        z-index: 1000;
        opacity: 0;
        visibility: hidden;
        transform: translateY(20px);
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        box-shadow: 0 8px 25px rgba(59, 130, 246, 0.3);
    }
    
    .scroll-to-top.visible {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
    }
    
    .scroll-to-top:hover {
        transform: translateY(-3px) scale(1.1);
        box-shadow: 0 12px 35px rgba(59, 130, 246, 0.4);
        background: linear-gradient(135deg, #2563eb, #7c3aed);
    }
    
    /* === DARK MODE TOGGLE === */
    .dark-mode-toggle {
        position: fixed;
        top: 20px;
        right: 20px;
        width: 50px;
        height: 25px;
        background: linear-gradient(135deg, #64748b, #475569);
        border: none;
        border-radius: 25px;
        cursor: pointer;
        z-index: 1000;
        transition: all 0.3s ease;
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    }
    
    .dark-mode-toggle::before {
        content: '';
        position: absolute;
        top: 2px;
        left: 2px;
        width: 21px;
        height: 21px;
        background: white;
        border-radius: 50%;
        transition: all 0.3s ease;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    }
    
    .dark-mode-toggle.active {
        background: linear-gradient(135deg, #3b82f6, #8b5cf6);
    }
    
    .dark-mode-toggle.active::before {
        transform: translateX(25px);
        background: #f1f5f9;
    }
    
    /* Mobile responsive positioning for dark mode toggle */
    @media (max-width: 768px) {
        .dark-mode-toggle {
            top: 15px;
            right: 80px; /* Position it to the left of mobile menu toggle */
            width: 40px;
            height: 20px;
        }
        
        .dark-mode-toggle::before {
            width: 16px;
            height: 16px;
        }
        
        .dark-mode-toggle.active::before {
            transform: translateX(20px);
        }
    }
    
    @media (max-width: 480px) {
        .dark-mode-toggle {
            top: 12px;
            right: 75px;
            width: 35px;
            height: 18px;
        }
        
        .dark-mode-toggle::before {
            width: 14px;
            height: 14px;
        }
        
        .dark-mode-toggle.active::before {
            transform: translateX(17px);
        }
    }
    
    /* === ENHANCED LOADING STATES === */
    .loading-overlay {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: linear-gradient(135deg, #f8fafc, #e2e8f0);
        display: flex;
        align-items: center;
        justify-content: center;
        z-index: 10000;
        opacity: 1;
        visibility: visible;
        transition: all 0.5s ease;
    }
    
    .loading-overlay.hidden {
        opacity: 0;
        visibility: hidden;
    }
    
    .loading-spinner {
        width: 60px;
        height: 60px;
        border: 4px solid rgba(59, 130, 246, 0.1);
        border-top: 4px solid #3b82f6;
        border-radius: 50%;
        animation: spin 1s linear infinite;
        position: relative;
    }
    
    .loading-spinner::after {
        content: '';
        position: absolute;
        top: -4px;
        left: -4px;
        right: -4px;
        bottom: -4px;
        border: 4px solid transparent;
        border-top: 4px solid #8b5cf6;
        border-radius: 50%;
        animation: spin 1.5s linear infinite reverse;
    }
    
    @keyframes spin {
        0% { transform: rotate(0deg); }
        100% { transform: rotate(360deg); }
    }
    
    .container {
        max-width: 1400px;
        margin: 0 auto;
        padding: 0 24px;
    }
    
    /* === MODERN HEADER STYLES === */
    .header {
        background: rgba(255, 255, 255, 0.85);
        backdrop-filter: blur(25px) saturate(180%);
        -webkit-backdrop-filter: blur(25px) saturate(180%);
        border-bottom: 1px solid rgba(226, 232, 240, 0.3);
        color: #1e293b;
        box-shadow: 
            0 4px 20px rgba(0, 0, 0, 0.08),
            0 1px 3px rgba(0, 0, 0, 0.1);
        position: fixed;
        width: 100%;
        top: 0;
        z-index: 1000;
        transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    }
    
    .header.scrolled {
        background: rgba(255, 255, 255, 0.95);
        backdrop-filter: blur(30px) saturate(200%);
        -webkit-backdrop-filter: blur(30px) saturate(200%);
        box-shadow: 
            0 8px 32px rgba(0, 0, 0, 0.12),
            0 2px 8px rgba(0, 0, 0, 0.08);
        transform: translateY(-1px);
    }
    
    .header::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: linear-gradient(135deg, 
            rgba(255, 255, 255, 0.1) 0%, 
            rgba(255, 255, 255, 0.05) 50%, 
            rgba(255, 255, 255, 0.1) 100%);
        pointer-events: none;
        z-index: -1;
    }
    
    .header-content {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 20px 0;
        position: relative;
    }
    
    .logo {
        font-family: 'Poppins', sans-serif;
        font-size: 28px;
        font-weight: 800;
        background: linear-gradient(135deg, #3b82f6, #8b5cf6, #06b6d4);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text;
        text-decoration: none;
        transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        display: flex;
        align-items: center;
        gap: 12px;
        position: relative;
        overflow: hidden;
    }
    
    .logo::before {
        content: '\f0ac';
        font-family: 'Font Awesome 6 Free';
        font-weight: 900;
        font-size: 32px;
        background: linear-gradient(135deg, #3b82f6, #8b5cf6);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text;
        transition: all 0.4s ease;
        animation: logoIconFloat 3s ease-in-out infinite;
    }
    
    .logo::after {
        content: '';
        position: absolute;
        top: 0;
        left: -100%;
        width: 100%;
        height: 100%;
        background: linear-gradient(90deg, 
            transparent, 
            rgba(255, 255, 255, 0.4), 
            transparent);
        transition: left 0.6s ease;
    }
    
    .logo:hover::after {
        left: 100%;
    }
    
    .logo:hover {
        transform: scale(1.05) rotate(1deg);
        filter: brightness(1.2) drop-shadow(0 0 10px rgba(59, 130, 246, 0.3));
    }
    
    .logo:hover::before {
        transform: scale(1.2) rotate(-5deg);
        animation-duration: 1s;
    }
    
    @keyframes logoIconFloat {
        0%, 100% { transform: translateY(0) rotate(0deg); }
        50% { transform: translateY(-2px) rotate(2deg); }
    }
    
    .nav-container {
        display: flex;
        align-items: center;
        gap: 32px;
    }
    
    .nav-menu {
        display: flex;
        list-style: none;
        gap: 8px;
        margin: 0;
        padding: 0;
    }
    
    .nav-menu li {
        position: relative;
    }
    
    .nav-menu a {
        color: #64748b;
        text-decoration: none;
        font-weight: 500;
        font-size: 15px;
        padding: 12px 20px;
        border-radius: 12px;
        transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        position: relative;
        display: flex;
        align-items: center;
        gap: 8px;
        overflow: hidden;
    }
    
    .nav-menu a::before {
        content: '';
        position: absolute;
        top: 0;
        left: -100%;
        width: 100%;
        height: 100%;
        background: linear-gradient(90deg, 
            transparent, 
            rgba(59, 130, 246, 0.1), 
            transparent);
        transition: left 0.6s ease;
    }
    
    .nav-menu a:hover::before {
        left: 100%;
    }
    
    .nav-menu a:hover {
        color: #3b82f6;
        background: rgba(59, 130, 246, 0.08);
        transform: translateY(-2px) scale(1.02);
        box-shadow: 0 4px 12px rgba(59, 130, 246, 0.15);
    }
    
    .nav-menu a:hover i {
        transform: scale(1.2) rotate(5deg);
    }
    
    .nav-menu a::after {
        content: '';
        position: absolute;
        bottom: 0;
        left: 50%;
        width: 0;
        height: 2px;
        background: linear-gradient(90deg, #3b82f6, #8b5cf6);
        border-radius: 1px;
        transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        transform: translateX(-50%);
    }
    
    .nav-menu a:hover::after {
        width: 80%;
    }
    
    .nav-menu a i {
        transition: all 0.3s ease;
    }
    
    .book-now-btn {
        background: linear-gradient(135deg, #3b82f6, #8b5cf6);
        color: white;
        padding: 12px 24px;
        border: none;
        border-radius: 12px;
        font-weight: 600;
        text-decoration: none;
        display: flex;
        align-items: center;
        gap: 8px;
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        box-shadow: 0 4px 20px rgba(59, 130, 246, 0.25);
        font-size: 14px;
    }
    
    .book-now-btn:hover {
        transform: translateY(-2px);
        box-shadow: 0 8px 32px rgba(59, 130, 246, 0.35);
        background: linear-gradient(135deg, #2563eb, #7c3aed);
    }
    
    /* === MOBILE MENU === */
    .mobile-menu-toggle {
        display: none;
        background: none;
        border: none;
        color: #64748b;
        font-size: 24px;
        cursor: pointer;
        padding: 12px;
        border-radius: 12px;
        transition: all 0.3s ease;
    }
    
    .mobile-menu-toggle:hover {
        background: rgba(59, 130, 246, 0.08);
        color: #3b82f6;
    }
    
    .mobile-menu {
        display: none;
        position: absolute;
        top: 100%;
        right: 0;
        left: 0;
        background: rgba(255, 255, 255, 0.98);
        backdrop-filter: blur(24px);
        border-radius: 0 0 24px 24px;
        padding: 32px 24px;
        box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
        border: 1px solid rgba(226, 232, 240, 0.8);
        border-top: none;
    }
    
    .mobile-menu.active {
        display: block;
        animation: slideDown 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    }
    
    @keyframes slideDown {
        from {
            opacity: 0;
            transform: translateY(-20px);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }
    .mobile-nav-menu {list-style: none;margin: 0;padding: 0;}
    .mobile-nav-menu li {margin-bottom: 12px;}
    .mobile-nav-menu a {
        color: #1e293b;
        text-decoration: none;
        font-weight: 600;
        font-size: 16px;
        padding: 16px 20px;
        display: block;
        border-radius: 12px;
        transition: all 0.3s ease;
        border: 1px solid rgba(59, 130, 246, 0.15);
        background: rgba(255, 255, 255, 0.8);
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    }
    .mobile-nav-menu a:hover, .mobile-nav-menu a:active {
        background: linear-gradient(135deg, #3b82f6, #2563eb);
        transform: translateX(5px);
        color: #ffffff;
        border-color: #3b82f6;
        box-shadow: 0 4px 15px rgba(59, 130, 246, 0.3);
    }
    .mobile-nav-menu a i {margin-right: 12px;width: 18px;color: inherit;}
    
    /* === ENHANCED MOBILE NAVIGATION === */
    .mobile-menu-backdrop {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0, 0, 0, 0.5);
        backdrop-filter: blur(4px);
        z-index: 999;
        opacity: 0;
        transition: opacity 0.3s ease;
    }
    
    .mobile-menu-backdrop.active {
        display: block;
        opacity: 1;
    }
    
    /* Enhanced Mobile Touch Interactions */
    .touch-feedback {
        position: relative;
        overflow: hidden;
    }
    
    .touch-feedback::before {
        content: '';
        position: absolute;
        top: 50%;
        left: 50%;
        width: 0;
        height: 0;
        border-radius: 50%;
        background: rgba(255, 255, 255, 0.3);
        transform: translate(-50%, -50%);
        transition: width 0.6s, height 0.6s;
        pointer-events: none;
        z-index: 1;
    }
    
    .touch-feedback:active::before {
        width: 300px;
        height: 300px;
    }
    
    /* Mobile Swipe Indicators */
    .swipe-indicator {
        display: none;
        position: absolute;
        bottom: 20px;
        left: 50%;
        transform: translateX(-50%);
        background: rgba(255, 255, 255, 0.9);
        padding: 8px 16px;
        border-radius: 20px;
        font-size: 12px;
        color: #64748b;
        z-index: 10;
        animation: swipeHint 3s ease-in-out infinite;
    }
    
    @keyframes swipeHint {
        0%, 70%, 100% { opacity: 0; transform: translateX(-50%) translateY(0); }
        10%, 60% { opacity: 1; transform: translateX(-50%) translateY(-5px); }
    }
    
    /* Mobile Pull-to-Refresh Indicator */
    .pull-to-refresh {
        position: absolute;
        top: -60px;
        left: 50%;
        transform: translateX(-50%);
        width: 40px;
        height: 40px;
        border: 3px solid #e2e8f0;
        border-top: 3px solid var(--primary-blue);
        border-radius: 50%;
        opacity: 0;
        transition: all 0.3s ease;
        z-index: 1000;
    }
    
    .pull-to-refresh.active {
        opacity: 1;
        animation: spin 1s linear infinite;
    }
    
    @keyframes spin {
        0% { transform: translateX(-50%) rotate(0deg); }
        100% { transform: translateX(-50%) rotate(360deg); }
    }
    
    /* === HERO SLIDER STYLES === */
    .hero-slider {
        position: relative;
        width: 100%;
        height: 100vh;
        max-height: 800px;
        min-height: 500px;
        overflow: hidden;
        background: #000;
    }
    
    .slider-container {
        position: relative;
        width: 100%;
        height: 100%;
        display: flex;
        transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    }
    
    .slider-slide {
        min-width: 100%;
        height: 100%;
        position: relative;
        display: flex;
        align-items: center;
        justify-content: center;
        background-size: cover;
        background-position: center;
        background-repeat: no-repeat;
    }
    
    .slider-slide::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: linear-gradient(
            135deg,
            rgba(0, 0, 0, 0.4) 0%,
            rgba(0, 0, 0, 0.2) 50%,
            rgba(0, 0, 0, 0.6) 100%
        );
        z-index: 1;
    }
    
    .slide-content {
        position: relative;
        z-index: 2;
        text-align: center;
        color: white;
        max-width: 800px;
        padding: 0 20px;
        animation: slideInUp 1s ease-out;
    }
    
    @keyframes slideInUp {
        from {
            opacity: 0;
            transform: translateY(50px);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }
    
    .slide-title {
        font-family: 'Poppins', sans-serif;
        font-size: 3.5rem;
        font-weight: 800;
        margin-bottom: 20px;
        text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
        line-height: 1.2;
    }
    
    .slide-subtitle {
        font-size: 1.3rem;
        margin-bottom: 30px;
        text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5);
        font-weight: 300;
        line-height: 1.4;
    }
    
    .slide-cta {
        display: inline-flex;
        align-items: center;
        gap: 12px;
        background: linear-gradient(135deg, #3b82f6, #8b5cf6);
        color: white;
        padding: 18px 36px;
        border-radius: 50px;
        text-decoration: none;
        font-weight: 600;
        font-size: 1.1rem;
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        box-shadow: 0 10px 30px rgba(59, 130, 246, 0.3);
        border: 2px solid transparent;
    }
    
    .slide-cta:hover {
        transform: translateY(-3px);
        box-shadow: 0 15px 40px rgba(59, 130, 246, 0.4);
        background: linear-gradient(135deg, #2563eb, #7c3aed);
        border-color: rgba(255, 255, 255, 0.2);
    }
    
    .slide-cta i {
        font-size: 1.2rem;
    }
    
    /* Slider Navigation */
    .slider-nav {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        z-index: 3;
        background: rgba(255, 255, 255, 0.1);
        backdrop-filter: blur(10px);
        border: 1px solid rgba(255, 255, 255, 0.2);
        color: white;
        width: 60px;
        height: 60px;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        transition: all 0.3s ease;
        font-size: 1.5rem;
    }
    
    .slider-nav:hover {
        background: rgba(255, 255, 255, 0.2);
        backdrop-filter: blur(15px);
        transform: translateY(-50%) scale(1.1);
        box-shadow: 0 8px 25px rgba(0, 0, 0, 0.2);
    }
    
    .slider-nav.prev {
        left: 30px;
    }
    
    .slider-nav.next {
        right: 30px;
    }
    
    /* Slider Dots */
    .slider-dots {
        position: absolute;
        bottom: 30px;
        left: 50%;
        transform: translateX(-50%);
        z-index: 3;
        display: flex;
        gap: 15px;
    }
    
    .slider-dot {
        width: 12px;
        height: 12px;
        border-radius: 50%;
        background: rgba(255, 255, 255, 0.4);
        cursor: pointer;
        transition: all 0.3s ease;
        border: 2px solid transparent;
    }
    
    .slider-dot.active {
        background: white;
        transform: scale(1.2);
        border-color: rgba(59, 130, 246, 0.5);
        box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.3);
    }
    
    .slider-dot:hover {
        background: rgba(255, 255, 255, 0.8);
        transform: scale(1.1);
    }
    
    /* Slider Loading Animation */
    .slide-loading {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: #1a1a1a;
        display: flex;
        align-items: center;
        justify-content: center;
        z-index: 1;
    }
    
    .slide-loading::after {
        content: '';
        width: 40px;
        height: 40px;
        border: 3px solid rgba(255, 255, 255, 0.3);
        border-top-color: #3b82f6;
        border-radius: 50%;
        animation: spin 1s linear infinite;
    }
    
    @keyframes spin {
        to { transform: rotate(360deg); }
    }
    
    /* Lazy Loading */
    .slider-slide[data-loaded="false"] {
        background-image: none !important;
    }
    
    /* Responsive Design */
    @media (max-width: 768px) {
        .hero-slider {
            height: 70vh;
            min-height: 400px;
        }
        
        .slide-title {
            font-size: 2.5rem;
            margin-bottom: 15px;
        }
        
        .slide-subtitle {
            font-size: 1.1rem;
            margin-bottom: 25px;
        }
        
        .slide-cta {
            padding: 15px 30px;
            font-size: 1rem;
        }
        
        .slider-nav {
            width: 50px;
            height: 50px;
            font-size: 1.2rem;
        }
        
        .slider-nav.prev {
            left: 15px;
        }
        
        .slider-nav.next {
            right: 15px;
        }
        
        .slider-dots {
            bottom: 20px;
            gap: 12px;
        }
        
        .slider-dot {
            width: 10px;
            height: 10px;
        }
    }
    
    @media (max-width: 480px) {
        .hero-slider {
            height: 60vh;
            min-height: 350px;
        }
        
        .slide-content {
            padding: 0 15px;
        }
        
        .slide-title {
            font-size: 2rem;
            margin-bottom: 12px;
        }
        
        .slide-subtitle {
            font-size: 1rem;
            margin-bottom: 20px;
        }
        
        .slide-cta {
            padding: 12px 24px;
            font-size: 0.9rem;
            gap: 8px;
        }
        
        .slider-nav {
            width: 45px;
            height: 45px;
            font-size: 1rem;
        }
        
        .slider-nav.prev {
            left: 10px;
        }
        
        .slider-nav.next {
            right: 10px;
        }
    }
    
    /* Reduced Motion */
    @media (prefers-reduced-motion: reduce) {
        .slider-container,
        .slide-content,
        .slider-nav,
        .slider-dot {
            transition: none;
            animation: none;
        }
        
        .slide-content {
            animation: none;
        }
    }
    
    /* === ENHANCED TOUCH IMPROVEMENTS === */
    @media (hover: none) and (pointer: coarse) {
        .slider-nav {
            width: 55px;
            height: 55px;
            background: rgba(255, 255, 255, 0.15);
            /* Enhanced touch target */
            min-width: var(--touch-target-size);
            min-height: var(--touch-target-size);
        }
        
        .slider-dot {
            width: 14px;
            height: 14px;
            /* Enhanced touch target */
            min-width: 32px;
            min-height: 32px;
            display: flex;
            align-items: center;
            justify-content: center;
        }
        
        .slide-cta {
            min-height: var(--touch-target-size);
            min-width: var(--touch-target-size);
        }
        
        /* Enhanced touch targets for all interactive elements */
        .mobile-menu-toggle,
        .dark-mode-toggle,
        .book-now-btn,
        .service-btn,
        .submit-btn,
        .modal-close,
        .nav-menu a {
            min-height: var(--touch-target-size);
            min-width: var(--touch-target-size);
            display: flex;
            align-items: center;
            justify-content: center;
            position: relative;
        }
        
        /* Remove hover effects on touch devices */
        .service-card, .destinations-item, .testimonial-card, .activity-card {
            transition: none;
        }
        
        /* Add touch feedback */
        .service-card:active, .destinations-item:active, .activity-card:active {
            transform: scale(0.98);
            transition: transform 0.1s ease;
        }
        
        /* Enhanced button touch feedback */
        .service-btn:active, .submit-btn:active, .book-now-btn:active {
            transform: scale(0.95);
            transition: transform 0.1s ease;
        }
    }

    .main-content {
        margin-top: 0;
        min-height: 500px;
        padding-top: 40px;
        /* Enhanced for safe areas */
        padding-left: max(var(--mobile-spacing), var(--safe-area-inset-left));
        padding-right: max(var(--mobile-spacing), var(--safe-area-inset-right));
    }
    
    /* === MODERN MOBILE GESTURES === */
    .swipe-container {
        position: relative;
        overflow: hidden;
        touch-action: pan-x;
    }
    
    .swipe-item {
        transform: translateX(0);
        transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    }
    
    .swipe-item.swiping {
        transition: none;
    }
    
    /* Mobile Scroll Snap */
    .scroll-snap-container {
        scroll-snap-type: x mandatory;
        scroll-behavior: smooth;
        -webkit-overflow-scrolling: touch;
    }
    
    .scroll-snap-item {
        scroll-snap-align: center;
        scroll-snap-stop: always;
    }
    
    /* === ENHANCED MOBILE TOUCH IMPROVEMENTS === */
    
    /* Modal opening state */
    .modal-opening {
        overflow: hidden;
    }
    
    /* Better touch targets for mobile */
    @media (max-width: 768px) {
        .service-card, .activity-card, .destinations-item {
            min-height: 48px; /* Minimum touch target size */
            position: relative;
        }
        
        /* Add touch feedback */
        .service-card:active, .activity-card:active, .destinations-item:active {
            transform: scale(0.98);
            transition: transform 0.1s ease;
        }
        
        /* Ensure proper touch areas */
        .service-card::after, .activity-card::after, .destinations-item::after {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            z-index: 1;
            pointer-events: auto;
        }
        
        /* Mobile modal improvements */
        .service-modal {
            margin: 15px;
            max-height: 90vh;
            border-radius: 15px;
        }
        
        .modal-close {
            width: 50px;
            height: 50px;
            font-size: 20px;
            /* Larger touch target for mobile */
        }
        
        /* Swipe indicators for better UX */
        .service-card, .activity-card, .destinations-item {
            position: relative;
        }
        
        .service-card:hover::before, .activity-card:hover::before, .destinations-item:hover::before {
            content: '👆 Tap to explore';
            position: absolute;
            top: 10px;
            right: 10px;
            background: rgba(59, 130, 246, 0.9);
            color: white;
            padding: 5px 10px;
            border-radius: 15px;
            font-size: 12px;
            font-weight: bold;
            opacity: 0;
            animation: fadeInOut 2s ease-in-out;
            z-index: 2;
        }
        
        @keyframes fadeInOut {
            0%, 100% { opacity: 0; }
            50% { opacity: 1; }
        }
        
        /* Better spacing for mobile */
        .service-info, .activity-info {
            padding: 20px 15px;
        }
        
        .service-title, .activity-title {
            font-size: 20px;
            margin-bottom: 12px;
        }
        
        .service-description, .activity-description {
            font-size: 14px;
            line-height: 1.5;
        }
        
        /* Enhanced mobile loading state */
        .mobile-card-loading {
            position: relative;
            opacity: 0.7;
            pointer-events: none;
        }
        
        .mobile-card-loading::after {
            content: '';
            position: absolute;
            top: 50%;
            left: 50%;
            width: 30px;
            height: 30px;
            border: 3px solid #f3f3f3;
            border-top: 3px solid #3b82f6;
            border-radius: 50%;
            transform: translate(-50%, -50%);
            animation: spin 1s linear infinite;
            z-index: 10;
        }
        
        @keyframes spin {
            0% { transform: translate(-50%, -50%) rotate(0deg); }
            100% { transform: translate(-50%, -50%) rotate(360deg); }
        }
        
        /* Mobile error state styling */
        .mobile-error-message {
            position: fixed;
            bottom: 20px;
            left: 20px;
            right: 20px;
            background: #dc2626;
            color: white;
            padding: 15px;
            border-radius: 10px;
            text-align: center;
            z-index: 10000;
            box-shadow: 0 10px 25px rgba(220, 38, 38, 0.3);
            animation: slideUpMobile 0.3s ease-out;
        }
        
        @keyframes slideUpMobile {
            from { 
                opacity: 0;
                transform: translateY(100px);
            }
            to { 
                opacity: 1;
                transform: translateY(0);
            }
        }
        
        /* Safe area handling for newer mobile devices */
        .service-modal-overlay {
            padding-top: max(20px, env(safe-area-inset-top));
            padding-bottom: max(20px, env(safe-area-inset-bottom));
            padding-left: max(20px, env(safe-area-inset-left));
            padding-right: max(20px, env(safe-area-inset-right));
        }
    }
    
    /* Very small mobile devices */
    @media (max-width: 480px) {
        .service-card, .activity-card, .destinations-item {
            margin-bottom: 15px;
        }
        
        .service-modal {
            margin: 10px;
            border-radius: 12px;
        }
        
        .modal-content {
            padding: 0 15px 15px;
        }
        
        .modal-service-title {
            font-size: 22px;
        }
        
        .modal-service-description {
            font-size: 15px;
        }
    }

    /* High DPI mobile devices */
    @media (-webkit-min-device-pixel-ratio: 2) and (max-width: 768px) {
        .service-card, .activity-card, .destinations-item {
            border-width: 0.5px; /* Thinner borders on high DPI */
        }
        
        .modal-close {
            border-width: 0.5px;
        }
    }
    



    /* === ACTIVITIES SECTION === */
    .activities-section {
        padding: 80px 0;
        background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 50%, #f1f5f9 100%);
        position: relative;
        overflow: hidden;
    }
    
    .activities-section::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: radial-gradient(circle at 30% 20%, rgba(59, 130, 246, 0.03) 0%, transparent 50%);
        pointer-events: none;
    }
    
    .activities-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
        gap: 30px;
        margin-top: 60px;
    }
    
    .activity-card {
        background: rgba(255, 255, 255, 0.9);
        backdrop-filter: blur(20px) saturate(180%);
        border-radius: 24px;
        overflow: hidden;
        box-shadow: 
            0 20px 40px rgba(0,0,0,0.08),
            0 8px 16px rgba(0,0,0,0.04);
        transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
        cursor: pointer;
        position: relative;
        min-height: 480px;
        display: flex;
        flex-direction: column;
        border: 1px solid rgba(255, 255, 255, 0.2);
        transform-style: preserve-3d;
    }
    
    .activity-card::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: linear-gradient(135deg, #3b82f6, #06b6d4);
        border-radius: 28px;
        padding: 2px;
        z-index: -1;
        opacity: 0;
        transition: opacity 0.5s ease;
        transform: scale(1.02);
    }
    
    .activity-card:hover::before {
        opacity: 1;
    }
    
    .activity-card:hover {
        transform: translateY(-20px) rotateX(5deg) rotateY(5deg) scale(1.03);
        box-shadow: 
            0 40px 80px rgba(0,0,0,0.15), 
            0 20px 40px rgba(59, 130, 246, 0.2),
            0 0 0 1px rgba(255, 255, 255, 0.1);
    }
    
    .activity-card:nth-child(even):hover {
        transform: translateY(-20px) rotateX(5deg) rotateY(-5deg) scale(1.03);
    }
    
    .activity-image-carousel {
        width: 100%;
        height: 220px;
        position: relative;
        overflow: hidden;
        pointer-events: none;
    }
    
    .activity-image-single {
        width: 100%;
        height: 220px;
        background-size: cover;
        background-position: center;
        background-repeat: no-repeat;
        position: relative;
        overflow: hidden;
        pointer-events: none;
    }
    
    .activity-image {
        width: 100%;
        height: 100%;
        background-size: cover;
        background-position: center;
        position: absolute;
        top: 0;
        left: 0;
        opacity: 0;
        transition: opacity 0.5s ease-in-out;
        pointer-events: none;
    }
    
    .activity-image.active {
        opacity: 1;
    }
    
    .activity-image::before,
    .activity-image-single::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: linear-gradient(135deg, rgba(59, 130, 246, 0.2) 0%, transparent 50%, rgba(245, 158, 11, 0.2) 100%);
        opacity: 0;
        transition: opacity 0.3s ease;
    }
    
    .activity-card:hover .activity-image::before,
    .activity-card:hover .activity-image-single::before {
        opacity: 1;
    }
    
    .activity-info {
        padding: 25px;
        flex: 1;
        display: flex;
        flex-direction: column;
        position: relative;
    }
    
    .activity-icon {
        font-size: 52px;
        margin-bottom: 20px;
        display: block;
        text-align: center;
        transition: transform 0.3s ease;
    }
    
    .activity-card:hover .activity-icon {
        transform: scale(1.1);
    }
    
    .activity-title {
        font-family: 'Poppins', sans-serif;
        font-size: 24px;
        color: #1e293b;
        margin-bottom: 15px;
        font-weight: 700;
        text-align: center;
        transition: color 0.3s ease;
    }
    
    .activity-card:hover .activity-title {
        color: #3b82f6;
    }
    
    .activity-description {
        color: #4a5568;
        font-size: 15px;
        margin-bottom: 20px;
        line-height: 1.7;
        text-align: center;
        flex: 1;
    }
    
    /* Responsive Design for Activities */
    @media (max-width: 768px) {
        .activities-section {
            padding: 60px 0;
        }
        
        .activities-grid {
            grid-template-columns: 1fr;
            gap: 25px;
            margin-top: 40px;
        }
        
        .activity-card {
            min-height: auto;
        }
        
        .activity-image-carousel,
        .activity-image-single {
            height: 200px;
        }
        
        .activity-info {
            padding: 20px;
        }
        
        .activity-title {
            font-size: 20px;
        }
        
        .activity-description {
            font-size: 14px;
            margin-bottom: 15px;
        }
    }
    
    @media (max-width: 480px) {
        .activities-section {
            padding: 50px 0;
        }
        
        .activities-grid {
            gap: 20px;
            margin-top: 35px;
        }
        
        .activity-image-carousel,
        .activity-image-single {
            height: 180px;
        }
        
        .activity-info {
            padding: 18px 15px;
        }
        
        .activity-icon {
            font-size: 44px;
            margin-bottom: 15px;
        }
        
        .activity-title {
            font-size: 18px;
            margin-bottom: 12px;
        }
        
        .activity-description {
            font-size: 13px;
            margin-bottom: 12px;
        }
    }

    /* === SERVICES SECTION === */
    .services-section {padding: 60px 0;}
    .section-title {
        text-align: center;
        font-family: 'Poppins', serif;
        font-size: 42px;
        background: linear-gradient(135deg, #3b82f6, #8b5cf6, #06b6d4);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text;
        margin-bottom: 60px;
        position: relative;
        display: inline-block;
        width: 100%;
        font-weight: 700;
        letter-spacing: -0.5px;
    }
    
    .section-title::after {
        content: '';
        position: absolute;
        bottom: -15px;
        left: 50%;
        transform: translateX(-50%);
        width: 100px;
        height: 4px;
        background: linear-gradient(90deg, #3b82f6, #8b5cf6, #06b6d4);
        border-radius: 2px;
        animation: titleUnderline 2s ease-in-out infinite;
    }
    
    .section-title::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: linear-gradient(135deg, 
            rgba(59, 130, 246, 0.1) 0%, 
            rgba(139, 92, 246, 0.1) 50%, 
            rgba(6, 182, 212, 0.1) 100%);
        border-radius: 12px;
        z-index: -1;
        opacity: 0;
        transition: opacity 0.3s ease;
    }
    
    .section-title:hover::before {
        opacity: 1;
    }
    
    @keyframes titleUnderline {
        0%, 100% { width: 100px; }
        50% { width: 120px; }
    }
    .services-grid {display: grid;grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));gap: 25px;margin-top: 60px;}
    .service-card {background: linear-gradient(145deg, #ffffff, #fefefe);border-radius: 20px;overflow: hidden;box-shadow: 0 10px 30px rgba(0,0,0,0.1);transition: all 0.4s ease;cursor: pointer;position: relative;min-height: 420px;display: flex;flex-direction: column;border: 2px solid transparent;}
    .service-card::before {content: '';position: absolute;top: 0;left: 0;right: 0;bottom: 0;background: linear-gradient(135deg, #3b82f6, #06b6d4);border-radius: 25px;padding: 2px;z-index: -1;opacity: 0;transition: opacity 0.4s ease;}
    .service-card:hover::before {opacity: 1;}
    .service-card:hover {transform: translateY(-15px) scale(1.02);box-shadow: 0 35px 70px rgba(0,0,0,0.15), 0 15px 30px rgba(220, 38, 38, 0.2);}
    .service-image {width: 100%;height: 180px;background-size: cover;background-position: center;position: relative;overflow: hidden;pointer-events: none;}
    .service-image::before {content: '';position: absolute;top: 0;left: 0;right: 0;bottom: 0;background: linear-gradient(135deg,rgba(220, 38, 38, 0.2) 0%,transparent 50%,rgba(245, 158, 11, 0.2) 100%);opacity: 0;transition: opacity 0.3s ease;}
    .service-card:hover .service-image::before {opacity: 1;}
    .service-info {padding: 20px;position: relative;}
    .service-icon {font-size: 48px;margin-bottom: 20px;display: block;text-align: center;}
    .service-title {font-family: 'Playfair Display', serif;font-size: 26px;color: #3b82f6;margin-bottom: 15px;font-weight: bold;text-align: center;}
    .service-description {color: #4a5568;font-size: 16px;margin-bottom: 20px;line-height: 1.7;text-align: center;}
    .service-features {list-style: none;padding: 0;margin-bottom: 25px;}
    .service-features li {padding: 8px 0;color: #2d3748;position: relative;padding-left: 25px;font-size: 15px;}
    .service-features li::before {content: '\f00c';font-family: 'Font Awesome 6 Free';font-weight: 900;position: absolute;left: 0;color: #10b981;font-weight: bold;}
    .service-btn {background: linear-gradient(135deg, #3b82f6, #8b5cf6);color: white;padding: 12px 25px;border: none;border-radius: 25px;font-weight: bold;cursor: pointer;text-decoration: none;display: block;text-align: center;transition: all 0.3s ease;width: 100%;font-size: 16px;}
    .service-btn:hover {background: linear-gradient(135deg, #8b5cf6, #7c3aed);transform: translateY(-2px);box-shadow: 0 8px 25px rgba(59, 130, 246, 0.3);}

    /* === SERVICE MODAL STYLES === */
    .service-modal-overlay {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(0, 0, 0, 0.8);
        backdrop-filter: blur(10px);
        z-index: 10000;
        display: none;
        align-items: center;
        justify-content: center;
        padding: 20px;
        animation: fadeIn 0.3s ease-out;
    }
    .service-modal-overlay.active {
        display: flex;
    }
    @keyframes fadeIn {
        from { opacity: 0; }
        to { opacity: 1; }
    }
    
    .service-modal {
        background: white;
        border-radius: 25px;
        max-width: 700px;
        width: 100%;
        max-height: 90vh;
        overflow-y: auto;
        box-shadow: 0 25px 50px rgba(0, 0, 0, 0.3);
        position: relative;
        animation: slideUp 0.4s ease-out;
    }
    @keyframes slideUp {
        from { 
            opacity: 0;
            transform: translateY(50px) scale(0.9);
        }
        to { 
            opacity: 1;
            transform: translateY(0) scale(1);
        }
    }
    
    .modal-header {
        position: relative;
        padding: 20px 30px 0;
        display: flex;
        justify-content: flex-end;
    }
    
    .modal-close {
        width: 40px;
        height: 40px;
        border-radius: 50%;
        border: none;
        background: linear-gradient(135deg, #3b82f6, #8b5cf6);
        color: white;
        font-size: 18px;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: all 0.3s ease;
        box-shadow: 0 4px 15px rgba(220, 38, 38, 0.3);
    }
    .modal-close:hover {
        transform: scale(1.1);
        box-shadow: 0 6px 20px rgba(220, 38, 38, 0.4);
    }
    
    .modal-content {
        padding: 0 30px 30px;
    }
    

    
    .modal-service-icon {
        font-size: 48px;
        text-align: center;
        margin-bottom: 20px;
        display: block;
    }
    
    .modal-service-title {
        font-family: 'Playfair Display', serif;
        font-size: 32px;
        color: #3b82f6;
        text-align: center;
        margin-bottom: 15px;
        font-weight: bold;
    }
    
    .modal-service-description {
        font-size: 18px;
        color: #4a5568;
        text-align: center;
        margin-bottom: 30px;
        line-height: 1.6;
    }
    
    .modal-service-details {
        background: linear-gradient(135deg, #fef7f0, #fff);
        border-radius: 15px;
        padding: 25px;
        margin-bottom: 30px;
        border: 2px solid rgba(220, 38, 38, 0.1);
    }
    
    .modal-service-features {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
        gap: 15px;
        margin-bottom: 25px;
    }
    
    .modal-feature-item {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 12px;
        background: white;
        border-radius: 10px;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
        transition: all 0.3s ease;
    }
    .modal-feature-item:hover {
        transform: translateX(5px);
        box-shadow: 0 4px 15px rgba(220, 38, 38, 0.1);
    }

    .modal-feature-item:hover .modal-feature-icon {
        background: linear-gradient(135deg, #06b6d4, #3b82f6);
        transform: scale(1.1);
        box-shadow: 0 6px 20px rgba(59, 130, 246, 0.4);
    }
    
    .modal-feature-icon {
        width: 45px;
        height: 45px;
        border-radius: 12px;
        background: linear-gradient(135deg, #3b82f6, #06b6d4);
        color: white;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 20px;
        flex-shrink: 0;
        box-shadow: 0 4px 15px rgba(59, 130, 246, 0.3);
        transition: all 0.3s ease;
        border: 2px solid rgba(255, 255, 255, 0.2);
    }
    
    .modal-feature-text {
        color: #2d3748;
        font-weight: 500;
        font-size: 15px;
    }
    

    
    .modal-contact-form {
        background: linear-gradient(135deg, #fef7f0, #fff);
        padding: 25px;
        border-radius: 15px;
        border: 2px solid rgba(220, 38, 38, 0.1);
    }
    
    .modal-form-title {
        font-family: 'Playfair Display', serif;
        font-size: 24px;
        color: #3b82f6;
        text-align: center;
        margin-bottom: 20px;
        font-weight: bold;
    }
    
    .modal-form-group {
        margin-bottom: 20px;
    }
    
    .modal-form-group label {
        display: block;
        color: #3b82f6;
        font-weight: bold;
        margin-bottom: 8px;
        font-size: 16px;
    }
    
    .modal-form-group input,
    .modal-form-group textarea {
        width: 100%;
        padding: 15px 20px;
        border: 2px solid rgba(220, 38, 38, 0.2);
        border-radius: 12px;
        font-size: 16px;
        font-family: 'Inter', Arial, sans-serif;
        background: white;
        transition: all 0.3s ease;
        box-sizing: border-box;
    }
    
    .modal-form-group input:focus,
    .modal-form-group textarea:focus {
        outline: none;
        border-color: #3b82f6;
        box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.1);
        transform: translateY(-2px);
    }
    
    .modal-form-group textarea {
        resize: vertical;
        min-height: 100px;
    }
    
    .modal-whatsapp-btn {
        background: linear-gradient(135deg, #25d366, #20b954);
        color: white;
        padding: 18px 40px;
        border: none;
        border-radius: 25px;
        font-size: 18px;
        font-weight: bold;
        cursor: pointer;
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 12px;
        transition: all 0.3s ease;
        box-shadow: 0 10px 25px rgba(37, 211, 102, 0.3);
        text-decoration: none;
    }
    .modal-whatsapp-btn:hover {
        transform: translateY(-3px);
        box-shadow: 0 15px 35px rgba(37, 211, 102, 0.4);
        background: linear-gradient(135deg, #20b954, #1da851);
    }
    
    .modal-whatsapp-btn i {
        font-size: 24px;
    }

    /* === MODAL AVAILABLE ACTIVITIES === */
    .modal-activities-section {
        background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 50%, #f1f5f9 100%);
        border-radius: 15px;
        padding: 25px;
        margin-bottom: 25px;
        border: 1px solid rgba(59, 130, 246, 0.1);
    }
    
    .modal-activities-title {
        font-family: 'Poppins', sans-serif;
        font-size: 20px;
        color: #1e293b;
        margin-bottom: 20px;
        font-weight: 600;
        text-align: center;
        position: relative;
    }
    
    .modal-activities-title::after {
        content: '';
        position: absolute;
        bottom: -8px;
        left: 50%;
        transform: translateX(-50%);
        width: 50px;
        height: 2px;
        background: linear-gradient(90deg, #8b5cf6, #06b6d4);
        border-radius: 1px;
    }
    
    .modal-activities-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        gap: 15px;
    }
    
    .modal-activity-item {
        background: rgba(255, 255, 255, 0.8);
        backdrop-filter: blur(10px);
        border-radius: 12px;
        padding: 15px;
        transition: all 0.3s ease;
        border: 1px solid rgba(255, 255, 255, 0.3);
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
    }
    
    .modal-activity-item:hover {
        transform: translateY(-3px);
        box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
        background: rgba(255, 255, 255, 0.9);
    }
    
    .modal-activity-item h5 {
        font-size: 16px;
        color: #3b82f6;
        margin-bottom: 10px;
        font-weight: 600;
        display: flex;
        align-items: center;
        gap: 8px;
    }
    
    .modal-activities-grid .modal-activity-item ul {
        list-style: none;
        padding: 0;
        margin: 0;
    }
    
    .modal-activities-grid .modal-activity-item li {
        padding: 4px 0;
        color: #4a5568;
        font-size: 13px;
        line-height: 1.4;
        position: relative;
        padding-left: 20px;
        list-style: none;
    }
    
    .modal-activities-grid .modal-activity-item li::before {
        content: '\f00c';
        font-family: 'Font Awesome 6 Free';
        font-weight: 900;
        position: absolute;
        left: 0;
        top: 2px;
        color: #10b981;
        font-size: 12px;
        line-height: 1;
    }
    
    /* Responsive Design for Modal Activities */
    @media (max-width: 768px) {
        .modal-activities-section {
            padding: 20px;
            margin-bottom: 20px;
        }
        
        .modal-activities-title {
            font-size: 18px;
            margin-bottom: 15px;
        }
        
        .modal-activities-grid {
            grid-template-columns: 1fr;
            gap: 12px;
        }
        
        .modal-activity-item {
            padding: 12px;
        }
        
        .modal-activity-item h5 {
            font-size: 15px;
            margin-bottom: 8px;
        }
        
        .modal-activities-grid .modal-activity-item li {
            font-size: 12px;
            padding: 3px 0;
            padding-left: 18px;
        }
        
        .modal-activities-grid .modal-activity-item li::before {
            font-size: 10px;
            top: 1px;
        }
    }

    /* === RESPONSIVE MODAL === */
    @media (max-width: 768px) {
        .service-modal {
            margin: 10px;
            max-height: 95vh;
            border-radius: 20px;
        }
        .modal-header {
            padding: 15px 20px 0;
        }
        .modal-content {
            padding: 0 20px 20px;
        }
        .modal-service-title {
            font-size: 24px;
        }
        .modal-service-description {
            font-size: 16px;
        }
        .modal-service-details,
        .modal-contact-form {
            padding: 20px;
        }
        .modal-service-features {
            grid-template-columns: 1fr;
        }
    }
    
    @media (max-width: 480px) {
        .service-modal-overlay {
            padding: 10px;
        }
        .modal-service-title {
            font-size: 24px;
        }
        .modal-service-description {
            font-size: 16px;
        }
        .modal-service-details,
        .modal-contact-form {
            padding: 15px;
        }
        .modal-whatsapp-btn {
            padding: 16px 30px;
            font-size: 16px;
        }
    }

    /* === DESTINATIONS SECTION === */
    .destinations-section {padding: 100px 0;background: linear-gradient(135deg, #fef7f0 0%, #ffffff 50%, #fef7f0 100%);}
    .destinations-grid {display: grid;grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));gap: 30px;margin-top: 60px;}
    .destinations-item {border-radius: 20px;overflow: hidden;box-shadow: 0 15px 35px rgba(0,0,0,0.1);transition: all 0.3s ease;cursor: pointer;position: relative;}
    .destinations-item:hover {transform: translateY(-10px);box-shadow: 0 25px 50px rgba(0,0,0,0.15);}
    .destinations-image {width: 100%;height: 300px;background-size: cover;background-position: center;position: relative;}
    .destinations-overlay {position: absolute;top: 0;left: 0;right: 0;bottom: 0;background: linear-gradient(135deg,rgba(220, 38, 38, 0.8) 0%,rgba(245, 158, 11, 0.8) 100%);opacity: 0;transition: all 0.3s ease;display: flex;align-items: center;justify-content: center;color: white;font-size: 48px;}
    .destinations-item:hover .destinations-overlay {opacity: 1;}
    .destinations-caption {padding: 20px;background: white;text-align: center;}
    .destinations-caption h3 {color: #3b82f6;font-family: 'Playfair Display', serif;margin-bottom: 8px;font-size: 20px;}
    .destinations-caption p {color: #6b7280;font-size: 14px;}

    /* === TESTIMONIALS SECTION === */
    .testimonials-section {padding: 100px 0;}
    .testimonials-grid {display: grid;grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));gap: 40px;margin-top: 60px;}
    .testimonial-card {background: white;padding: 40px;border-radius: 25px;box-shadow: 0 20px 40px rgba(0,0,0,0.1);position: relative;transition: all 0.3s ease;}
    .testimonial-card:hover {transform: translateY(-8px);box-shadow: 0 30px 60px rgba(0,0,0,0.15);}
    .testimonial-card::before {content: '"';position: absolute;top: -10px;left: 30px;font-size: 80px;color: #3b82f6;font-family: 'Playfair Display', serif;opacity: 0.3;}
    .testimonial-text {font-size: 16px;line-height: 1.8;color: #4a5568;margin-bottom: 25px;font-style: italic;}
    .testimonial-author {display: flex;align-items: center;gap: 15px;}
    .author-avatar {width: 60px;height: 60px;border-radius: 50%;background-size: cover;background-position: center;box-shadow: 0 4px 15px rgba(0,0,0,0.1);}
    .author-info h4 {color: #3b82f6;font-weight: bold;margin-bottom: 5px;}
    .author-info p {color: #6b7280;font-size: 14px;}
    .stars {color: #06b6d4;font-size: 18px;margin-top: 10px;}

    /* === CONTACT SECTION === */
    .contact-section {padding: 100px 0;background: linear-gradient(135deg, #fef7f0 0%, #ffffff 50%, #fef7f0 100%);}
    .contact-grid {display: grid;grid-template-columns: 1fr 1fr;gap: 60px;margin-top: 60px;}
    .contact-info {background: white;padding: 50px;border-radius: 25px;box-shadow: 0 25px 50px rgba(0,0,0,0.1);}
    .contact-item {display: flex;align-items: center;margin-bottom: 30px;padding: 20px;background: linear-gradient(135deg, #fef7f0, #fff);border-radius: 15px;transition: all 0.3s ease;}
    .contact-item:hover {transform: translateX(-8px);box-shadow: 0 10px 25px rgba(220, 38, 38, 0.15);}
    .contact-icon {width: 60px;height: 60px;background: linear-gradient(135deg, #3b82f6, #06b6d4);border-radius: 50%;display: flex;align-items: center;justify-content: center;font-size: 24px;color: white;margin-right: 20px;box-shadow: 0 8px 20px rgba(59, 130, 246, 0.3);}
    .contact-details h4 {color: #3b82f6;margin-bottom: 8px;font-size: 18px;font-weight: bold;}
    .contact-details p {color: #6b7280;margin: 0;line-height: 1.6;}
    .contact-form {background: white;padding: 50px;border-radius: 25px;box-shadow: 0 25px 50px rgba(0,0,0,0.1);}
    .form-group {margin-bottom: 25px;}
    .form-group label {display: block;color: #3b82f6;font-weight: bold;margin-bottom: 10px;font-size: 16px;}
    .form-group input,.form-group textarea {
        width: 100%;
        padding: 18px 24px;
        border: 2px solid rgba(226, 232, 240, 0.3);
        border-radius: 16px;
        font-size: 16px;
        font-family: 'Inter', Arial, sans-serif;
        background: rgba(255, 255, 255, 0.9);
        backdrop-filter: blur(10px);
        transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        box-sizing: border-box;
        color: #1e293b;
    }
    
    .form-group input:focus,.form-group textarea:focus {
        outline: none;
        border-color: #3b82f6;
        box-shadow: 
            0 0 0 4px rgba(59, 130, 246, 0.1),
            0 8px 25px rgba(59, 130, 246, 0.15);
        transform: translateY(-2px) scale(1.02);
        background: rgba(255, 255, 255, 1);
    }
    
    .form-group input::placeholder,
    .form-group textarea::placeholder {
        color: #94a3b8;
        transition: color 0.3s ease;
    }
    
    .form-group input:focus::placeholder,
    .form-group textarea:focus::placeholder {
        color: #cbd5e1;
    }
    .form-group textarea {resize: vertical;min-height: 120px;}
    .submit-btn {background: linear-gradient(135deg, #3b82f6, #8b5cf6);color: white;padding: 18px 40px;border: none;border-radius: 25px;font-size: 18px;font-weight: bold;cursor: pointer;width: 100%;transition: all 0.3s ease;box-shadow: 0 10px 25px rgba(59, 130, 246, 0.3);}
    .submit-btn:hover {transform: translateY(-3px);box-shadow: 0 15px 35px rgba(59, 130, 246, 0.4);background: linear-gradient(135deg, #8b5cf6, #7c3aed);}

    /* === FOOTER === */
    .footer {
        background: linear-gradient(135deg, #0f172a, #1e293b, #334155);
        color: white;
        position: relative;
        overflow: hidden;
    }
    
    .footer::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background-image: 
            radial-gradient(circle at 20% 50%, rgba(59, 130, 246, 0.1) 0%, transparent 50%),
            radial-gradient(circle at 80% 20%, rgba(139, 92, 246, 0.1) 0%, transparent 50%);
        pointer-events: none;
        animation: footerGlow 8s ease-in-out infinite;
    }
    
    @keyframes footerGlow {
        0%, 100% { opacity: 0.3; }
        50% { opacity: 0.6; }
    }
    .footer-content {padding: 80px 0 30px;position: relative;z-index: 1;}
    .footer-grid {display: grid;grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));gap: 50px;margin-bottom: 50px;}
    .footer-section h3 {color: #06b6d4;margin-bottom: 25px;font-size: 24px;font-weight: bold;font-family: 'Playfair Display', serif;}
    .footer-section p,.footer-section li {color: #d1d5db;line-height: 1.8;margin-bottom: 12px;}
    .footer-section ul {list-style: none;padding: 0;}
    .footer-section a {color: #d1d5db;text-decoration: none;transition: color 0.3s ease;}
    .footer-section a:hover {color: #06b6d4;}
    .social-links {display: flex;gap: 15px;margin-top: 25px;}
    .social-links a {width: 50px;height: 50px;background: linear-gradient(135deg, #3b82f6, #06b6d4);color: white;display: flex;align-items: center;justify-content: center;border-radius: 50%;font-size: 20px;text-decoration: none;transition: all 0.3s ease;box-shadow: 0 5px 15px rgba(59, 130, 246, 0.3);}
    .social-links a:hover {transform: translateY(-5px) scale(1.1);box-shadow: 0 10px 25px rgba(220, 38, 38, 0.4);}
    .footer-bottom {border-top: 1px solid rgba(255,255,255,0.1);padding: 30px 0;text-align: center;position: relative;z-index: 1;}
    .footer-bottom p {color: #9ca3af;margin: 0;}

    /* === ENHANCED RESPONSIVE DESIGN === */
    
    /* Large Tablets */
    @media (max-width: 1024px) {
        .services-grid {grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));gap: 30px;}
        .contact-grid {grid-template-columns: 1fr;gap: 40px;}
        
        .container {
            padding: 0 var(--tablet-spacing);
        }
    }
    
    /* Modern Tablet Portrait */
    @media (max-width: 834px) {
        .header-content {
            padding: 16px 0;
        }
        
        .section-title {
            font-size: var(--mobile-text-4xl);
            margin-bottom: 40px;
        }
        
        .container {
            padding: 0 var(--mobile-spacing);
        }
    }
    
    /* Standard Mobile Devices */
    @media (max-width: 768px) {
        .header-content {padding: 15px 0;}
        .logo {font-size: 22px;}
        .logo::before {font-size: 24px;}
        .nav-menu {display: none;}
        .book-now-btn {display: none;}
        .mobile-menu-toggle {display: block;}
        
        .mobile-menu {
            padding: 25px 20px;
            background: rgba(255, 255, 255, 0.98);
            backdrop-filter: blur(24px);
            border: 1px solid rgba(226, 232, 240, 0.8);
            /* Enhanced for safe areas */
            padding-left: max(20px, var(--safe-area-inset-left));
            padding-right: max(20px, var(--safe-area-inset-right));
        }
        
        .mobile-nav-menu a {
            font-size: var(--mobile-text-base);
            padding: 15px 18px;
            color: #1e293b;
            font-weight: 600;
            /* Enhanced touch target */
            min-height: var(--touch-target-size);
        }
        
        .mobile-nav-menu a:hover, .mobile-nav-menu a:active {
            color: #ffffff;
            background: linear-gradient(135deg, #3b82f6, #2563eb);
        }
        
        .main-content {
            margin-top: var(--mobile-header-height);
            padding: var(--mobile-spacing);
        }
        
        .section-title {font-size: var(--mobile-text-3xl);margin-bottom: 40px;}
        
        .services-section {padding: 60px 0;}
        .services-grid {grid-template-columns: 1fr;gap: 25px;margin-top: 40px;}
        .service-card {min-height: auto;padding: 0;}
        .service-image {height: 180px;}
        .service-info {padding: 25px 20px;}
        .service-title {font-size: var(--mobile-text-xl);}
        .service-description {font-size: var(--mobile-text-sm);margin-bottom: 20px;}
        .service-features li {font-size: var(--mobile-text-sm);padding: 6px 0;}
        .service-btn {padding: 12px 20px;font-size: var(--mobile-text-sm);}
        
        .destinations-section {padding: 60px 0;}
        .destinations-grid {grid-template-columns: 1fr;gap: 20px;margin-top: 40px;}
        .destinations-image {height: 220px;}
        .destinations-caption h3 {font-size: var(--mobile-text-lg);}
        .destinations-caption p {font-size: var(--mobile-text-sm);}
        
        .testimonials-section {padding: 60px 0;}
        .testimonials-grid {grid-template-columns: 1fr;gap: 25px;margin-top: 40px;}
        .testimonial-card {padding: 30px 25px;}
        .testimonial-text {font-size: var(--mobile-text-sm);line-height: 1.6;}
        
        .contact-section {padding: 60px 0;}
        .contact-grid {grid-template-columns: 1fr;gap: 40px;margin-top: 40px;}
        .contact-info,.contact-form {padding: 30px 25px;}
        .contact-item {flex-direction: column;text-align: center;padding: 20px;}
        .contact-icon {margin-right: 0;margin-bottom: 15px;}
        .form-group input,.form-group textarea {padding: 15px;font-size: var(--mobile-text-base);}
        .submit-btn {padding: 16px 30px;font-size: var(--mobile-text-base);}
        
        .footer-content {padding: 60px 0 25px;}
        .footer-grid {grid-template-columns: 1fr;gap: 40px;text-align: center;}
        .footer-section h3 {font-size: var(--mobile-text-lg);}
        .social-links {justify-content: center;}
        
        /* Show swipe indicators on mobile */
        .swipe-indicator {
            display: block;
        }
    }
    
    /* Modern Mobile Devices */
    /* Modern Mobile Devices */
    @media (max-width: 480px) {
        .container {
            padding: 0 var(--mobile-spacing);
            /* Enhanced for safe areas */
            padding-left: max(var(--mobile-spacing), var(--safe-area-inset-left));
            padding-right: max(var(--mobile-spacing), var(--safe-area-inset-right));
        }
        
        .header-content {padding: 12px 0;}
        .logo {font-size: var(--mobile-text-lg);}
        .logo::before {font-size: var(--mobile-text-xl);}
        
        .mobile-menu {
            padding: 20px 15px;
            border-radius: 0 0 20px 20px;
            /* Enhanced for safe areas */
            padding-left: max(15px, var(--safe-area-inset-left));
            padding-right: max(15px, var(--safe-area-inset-right));
        }
        
        .mobile-nav-menu li {margin-bottom: 10px;}
        .mobile-nav-menu a {
            font-size: var(--mobile-text-sm);
            padding: 14px 16px;
            color: #1e293b;
            font-weight: 600;
            background: rgba(255, 255, 255, 0.9);
            border: 1px solid rgba(59, 130, 246, 0.2);
            min-height: var(--touch-target-size);
        }
        
        .mobile-nav-menu a:hover, .mobile-nav-menu a:active {
            color: #ffffff;
            background: linear-gradient(135deg, #3b82f6, #2563eb);
            transform: translateX(3px);
        }
        
        .mobile-nav-menu a i {
            margin-right: 10px;
            width: 16px;
        }
        
        .main-content {
            margin-top: calc(var(--mobile-header-height) - 5px);
            padding: var(--mobile-spacing);
        }
        
        .section-title {font-size: var(--mobile-text-2xl);margin-bottom: 35px;}
        
        .services-section {padding: 50px 0;}
        .services-grid {gap: 20px;margin-top: 35px;}
        .service-card {margin-bottom: 0;}
        .service-image {height: 160px;}
        .service-info {padding: 20px 15px;}
        .service-title {font-size: var(--mobile-text-lg);margin-bottom: 12px;}
        .service-description {font-size: var(--mobile-text-sm);margin-bottom: 15px;}
        .service-features li {font-size: var(--mobile-text-xs);padding: 5px 0;}
        .service-btn {padding: 12px 18px;font-size: var(--mobile-text-sm);}
        
        .destinations-section {padding: 50px 0;}
        .destinations-grid {gap: 18px;margin-top: 35px;}
        .destinations-image {height: 200px;}
        .destinations-caption {padding: 15px;}
        .destinations-caption h3 {font-size: var(--mobile-text-lg);margin-bottom: 6px;}
        .destinations-caption p {font-size: var(--mobile-text-xs);}
        
        .testimonials-section {padding: 50px 0;}
        .testimonials-grid {gap: 20px;margin-top: 35px;}
        .testimonial-card {padding: 25px 20px;}
        .testimonial-card::before {font-size: 60px;top: -5px;left: 20px;}
        .testimonial-text {font-size: var(--mobile-text-sm);line-height: 1.5;margin-bottom: 20px;}
        .author-avatar {width: 50px;height: 50px;}
        .author-info h4 {font-size: var(--mobile-text-sm);}
        .author-info p {font-size: var(--mobile-text-xs);}
        .stars {font-size: var(--mobile-text-base);}
        
        .contact-section {padding: 50px 0;}
        .contact-grid {gap: 30px;margin-top: 35px;}
        .contact-info,.contact-form {padding: 25px 20px;}
        .contact-item {padding: 18px;}
        .contact-icon {width: 50px;height: 50px;font-size: var(--mobile-text-lg);}
        .contact-details h4 {font-size: var(--mobile-text-base);}
        .contact-details p {font-size: var(--mobile-text-sm);}
        .form-group {margin-bottom: 20px;}
        .form-group label {font-size: var(--mobile-text-sm);margin-bottom: 8px;}
        .form-group input,.form-group textarea {padding: 14px;font-size: var(--mobile-text-sm);}
        .form-group textarea {min-height: 100px;}
        .submit-btn {padding: 15px 25px;font-size: var(--mobile-text-sm);}
        
        .footer-content {padding: 50px 0 20px;}
        .footer-grid {gap: 35px;}
        .footer-section h3 {font-size: var(--mobile-text-lg);margin-bottom: 20px;}
        .footer-section p,.footer-section li {font-size: var(--mobile-text-sm);margin-bottom: 10px;}
        .social-links a {width: 45px;height: 45px;font-size: var(--mobile-text-lg);}
        .footer-bottom {padding: 25px 0;}
        .footer-bottom p {font-size: var(--mobile-text-sm);}
    }
    
    /* Small Mobile Devices (iPhone SE, etc.) */
    @media (max-width: 375px) {
        .container {
            padding: 0 calc(var(--mobile-spacing) - 1px);
            /* Enhanced for safe areas */
            padding-left: max(calc(var(--mobile-spacing) - 1px), var(--safe-area-inset-left));
            padding-right: max(calc(var(--mobile-spacing) - 1px), var(--safe-area-inset-right));
        }
        
        .header-content {padding: 10px 0;}
        .logo {font-size: calc(var(--mobile-text-lg) - 2px);}
        .logo::before {font-size: var(--mobile-text-lg);}
        
        .mobile-menu {
            padding: 18px 12px;
            border-radius: 0 0 18px 18px;
        }
        
        .mobile-nav-menu li {margin-bottom: 8px;}
        .mobile-nav-menu a {
            font-size: var(--mobile-text-sm);
            padding: 12px 14px;
            color: #1e293b;
            font-weight: 600;
            background: rgba(255, 255, 255, 0.95);
            border: 1px solid rgba(59, 130, 246, 0.25);
        }
        
        .mobile-nav-menu a:hover, .mobile-nav-menu a:active {
            color: #ffffff;
            background: linear-gradient(135deg, #3b82f6, #2563eb);
            transform: translateX(2px);
        }
        
        .mobile-nav-menu a i {
            margin-right: 8px;
            width: 14px;
        }
        
        .main-content {
            margin-top: calc(var(--mobile-header-height) - 10px);
            padding-top: calc(var(--mobile-spacing) + 14px);
        }
        
        .section-title {font-size: calc(var(--mobile-text-2xl) - 4px);margin-bottom: 30px;}
        
        .services-section {padding: 40px 0;}
        .services-grid {gap: 18px;margin-top: 30px;}
        .service-image {height: 140px;}
        .service-info {padding: 18px 12px;}
        .service-title {font-size: calc(var(--mobile-text-lg) - 2px);margin-bottom: 10px;}
        .service-description {font-size: var(--mobile-text-xs);margin-bottom: 12px;}
        .service-features li {font-size: var(--mobile-text-xs);padding: 4px 0;padding-left: 20px;}
        .service-btn {padding: 10px 15px;font-size: var(--mobile-text-xs);}
        
        .destinations-section {padding: 40px 0;}
        .destinations-grid {gap: 15px;margin-top: 30px;}
        .destinations-image {height: 180px;}
        .destinations-caption {padding: 12px;}
        .destinations-caption h3 {font-size: var(--mobile-text-base);margin-bottom: 5px;}
        .destinations-caption p {font-size: var(--mobile-text-xs);}
        
        .testimonials-section {padding: 40px 0;}
        .testimonials-grid {gap: 18px;margin-top: 30px;}
        .testimonial-card {padding: 20px 15px;}
        .testimonial-card::before {font-size: 50px;top: -2px;left: 15px;}
        .testimonial-text {font-size: var(--mobile-text-xs);line-height: 1.4;margin-bottom: 18px;}
        .author-avatar {width: 45px;height: 45px;}
        .author-info h4 {font-size: var(--mobile-text-sm);}
        .author-info p {font-size: var(--mobile-text-xs);}
        .stars {font-size: var(--mobile-text-sm);}
        
        .contact-section {padding: 40px 0;}
        .contact-grid {gap: 25px;margin-top: 30px;}
        .contact-info,.contact-form {padding: 20px 15px;}
        .contact-item {padding: 15px;flex-direction: row;text-align: left;}
        .contact-icon {width: 45px;height: 45px;font-size: var(--mobile-text-lg);margin-right: 15px;margin-bottom: 0;}
        .contact-details h4 {font-size: var(--mobile-text-sm);}
        .contact-details p {font-size: var(--mobile-text-xs);}
        .form-group {margin-bottom: 18px;}
        .form-group label {font-size: var(--mobile-text-sm);margin-bottom: 6px;}
        .form-group input,.form-group textarea {padding: 12px;font-size: var(--mobile-text-sm);}
        .submit-btn {padding: 14px 20px;font-size: var(--mobile-text-sm);}
        
        .footer-content {padding: 40px 0 18px;}
        .footer-grid {gap: 30px;}
        .footer-section h3 {font-size: var(--mobile-text-base);margin-bottom: 18px;}
        .footer-section p,.footer-section li {font-size: var(--mobile-text-xs);margin-bottom: 8px;}
        .social-links a {width: 40px;height: 40px;font-size: var(--mobile-text-base);}
        .footer-bottom {padding: 20px 0;}
        .footer-bottom p {font-size: var(--mobile-text-xs);}
    }
    
    /* Extra Enhanced Mobile Features */
    @media (max-width: 480px) {
        /* Enhanced Mobile Animations */
        .slide-in-mobile {
            animation: slideInMobile 0.5s ease-out;
        }
        
        @keyframes slideInMobile {
            from {
                opacity: 0;
                transform: translateY(30px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }
        
        /* Mobile-specific scroll improvements */
        .mobile-scroll-smooth {
            scroll-behavior: smooth;
            overflow-x: hidden;
            overflow-y: auto;
        }
        
        /* Enhanced mobile loading states */
        .mobile-loading-skeleton {
            background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
            background-size: 200% 100%;
            animation: loading 1.5s infinite;
        }
        
        @keyframes loading {
            0% {
                background-position: 200% 0;
            }
            100% {
                background-position: -200% 0;
            }
        }
    }
