/* --- Base / Reset --- */
    :root{
      --accent:#e65858; /* red */
      --accent-dark:#c44040;
      --accent-light:#f0a0a0;
      --muted:#6b7280;
      --cream:#f6f4f2;
      --card:#ffffffcc;
      --blue-card:#e65858;
      --dark:#292929;
      --darker:#1a1a1a;
      --light:#f8fafc;
      --white:#ffffff;
      --radius:16px;
      --radius-lg:24px;
      --gutter:32px;
      --shadow-sm:0 2px 8px rgba(0,0,0,0.08);
      --shadow-md:0 8px 25px rgba(0,0,0,0.15);
      --shadow-lg:0 20px 60px rgba(0,0,0,0.25);
      --gradient-primary:linear-gradient(135deg, var(--accent), var(--accent-dark));
      --gradient-light:linear-gradient(135deg, #ffffff, #f1f5f9);
      --transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    }
    *{box-sizing:border-box;margin:0;padding:0}
    html{scroll-behavior:smooth;font-size:16px}
    html,body{height:100%;margin:0;font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen,Ubuntu,Cantarell,'Helvetica Neue',sans-serif;color:#1f2937;overflow-x:hidden;line-height:1.6}
    a{color:inherit;text-decoration:none;transition:var(--transition)}
    img{max-width:100%;height:auto;display:block}
    button{border:none;background:none;cursor:pointer;font-family:inherit}
    
    /* Typography improvements */
    h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;color:#ffffff}
    p{line-height:1.7;color:#475569}
    
    /* Enhanced focus states for accessibility */
    :focus{outline:2px solid var(--accent);outline-offset:2px}
    
    /* Better touch targets for mobile */
    @media (max-width:820px){
      a,button{min-height:44px;min-width:44px;display:inline-flex;align-items:center;justify-content:center}
    }

    /* --- Page layout --- */
    header{position:fixed;left:0;right:0;top:0;z-index:40;background:linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.9));backdrop-filter:blur(16px);padding:16px 32px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(230,88,88,0.1);transition:var(--transition)}
    header.scrolled{background:linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.95));box-shadow:var(--shadow-md)}
    .logo{display:flex;align-items:center;gap:12px}
    .logo .mark{width:200px;display:flex;align-items:center;justify-content:center;color:white;font-weight:700;font-size:14px;transition:var(--transition)}
    .logo .mark:hover{transform:scale(1.05)}

    nav.desktop{display:flex;gap:18px;align-items:center}
    nav.desktop a{
        padding:8px 10px;
        color:#0f172a;
        font-weight:600;
        position:relative;
        transition:var(--transition);
    }
    nav.desktop a::after {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        height: 2px;
        background: var(--accent);
        transform: scaleX(0);
        transition: transform 0.3s ease;
    }
    nav.desktop a:hover::after {
        transform: scaleX(1);
    }
    nav.desktop a:hover {
        color: var(--accent);
    }
    .cta{
        background:var(--gradient-primary);
        color:#fff;
        padding:10px 18px;
        border-radius:25px;
        font-weight:600;
        box-shadow:var(--shadow-sm);
        transition:var(--transition);
    }
    .cta:hover {
        transform: translateY(-2px);
        box-shadow:var(--shadow-md);
    }

    /* Hamburger */
    .hamburger{display:none;width:48px;height:48px;border-radius:10px;align-items:center;justify-content:center;cursor:pointer;flex-direction:column;background:rgba(230,88,88,0.1);border:1px solid rgba(230,88,88,0.2)}
    .hamburger span{display:block;width:24px;height:3px;background:var(--accent);margin:3px 0;transition:all .3s;border-radius:2px}
    .hamburger.open span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}
    .hamburger.open span:nth-child(2){opacity:0}
    .hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}

    /* --- Hero --- */
    .hero{height:860px;display:flex;align-items:flex-end;position:relative;background-image:url('assets/outdoor.jpg');background-size:cover;background-position:center;background-attachment:fixed;border-bottom-left-radius:20px;border-bottom-right-radius:20px;}
    .hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,31,48,0.3),rgba(13,31,48,0.6));}
    .hero-inner{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:80px 32px 60px 32px;width:100%;display:flex;gap:28px;align-items:flex-end}
    .hero-content{color:white;max-width:780px}
    .hero h1{font-size:56px;line-height:1.02;margin:0 0 12px;font-weight:700;letter-spacing:0.6px}
    .hero p{margin:0 0 18px;color:#e6f0f6}
    .hero .buttons{display:flex;gap:12px}
    .btn-ghost{border:1px solid rgba(255,255,255,0.35);padding:10px 16px;border-radius:10px;color:white}
    .btn-primary{background:linear-gradient(90deg,var(--accent),var(--accent-dark));padding:10px 16px;border-radius:10px;color:#fff}
    
    /* Hero image previews */
    .hero-images{margin-left:auto;color:#fff;display:flex;flex-direction:column;gap:10px;align-items:flex-end}
    .hero-images .preview-img-1{width:180px;height:120px;border-radius:10px;overflow:hidden;box-shadow:0 12px 30px rgba(2,6,23,0.5);background:rgba(255,255,255,0.06);backdrop-filter:blur(3px)}
    .hero-images .preview-img-2{width:140px;height:100px;border-radius:10px;overflow:hidden;box-shadow:0 12px 30px rgba(2,6,23,0.5);background:rgba(255,255,255,0.04);backdrop-filter:blur(3px)}
    .hero-images .preview-img-3{width:110px;height:80px;border-radius:10px;overflow:hidden;box-shadow:0 12px 30px rgba(2,6,23,0.5);background:rgba(255,255,255,0.03);backdrop-filter:blur(3px)}
    
    /* Search bar container */
    .search-container{margin-top:18px;max-width:900px}

    /* --- Middle search bar (floating) --- */
    .search-bar{position:relative;margin-top:18px;background:var(--card);padding:16px;border-radius:12px;display:flex;gap:10px;box-shadow:0 12px 30px rgba(8,24,48,0.28);align-items:center}
    .search-col{display:flex;flex-direction:column;gap:8px}
    .search-col label{font-size:12px;color:var(--muted)}
    .search-col input, .search-col select{padding:10px;border-radius:8px;border:1px solid #e6eef2;min-width:130px}
    .search-submit{margin-left:auto}
    .search-submit button{background:var(--accent);color:#fff;padding:12px 18px;border-radius:10px;border:none;font-weight:700}

    /* --- Content sections --- */
    main{max-width:1200px;margin:40px auto;padding:0 24px 80px}
    .two-col{display:grid;grid-template-columns:340px 1fr;gap:32px;align-items:center}
    .section-title{font-size:13px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:10px}
    .heading-lg{font-size:28px;margin:0 0 12px}
    .lead{color:#475569}
    
    /* About section images */
    .about-images-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
    .about-img-small{height:200px;border-radius:12px;overflow:hidden}
    .about-img-small img{width:100%;height:100%;object-fit:cover}
    .about-img-large{height:220px;border-radius:12px;overflow:hidden}
    .about-img-large img{width:100%;height:100%;object-fit:cover;filter:contrast(1.03) saturate(1.02)}
    .about-text{margin-top:14px}
    .btn-container{margin-top:16px}
    .btn-primary.inline{display:inline-block}

    .amenities-card{background:var(--blue-card);color:#fff;padding:28px;border-radius:16px;box-shadow:0 18px 40px rgba(47,155,179,0.14)}
    .amenities-list{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}
    .amenities-list li{list-style:none;padding:6px 0}

    /* Full width amenities section */
    .amenities-section{position:relative;margin:60px -100vw;min-height:500px;display:flex;align-items:center;border-radius:0;padding:0 100vw}
    .amenities-bg{position:absolute;left:0;right:0;top:0;bottom:0;background-image:url('assets/badroom.jpg');background-size:cover;background-position:center;background-attachment:fixed;filter:brightness(0.4)}
    .amenities-overlay{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:60px 32px;width:100%;display:flex;justify-content:flex-end}
    .amenities-content{color:#fff}
    .amenities-card-new{background:var(--blue-card);color:#fff;padding:32px;border-radius:12px;max-width:480px;box-shadow:0 20px 60px rgba(0,0,0,0.3)}
    .amenities-card-new h3{margin:0 0 12px;color:#fff;font-size:28px}
    .amenities-card-new p{margin:0 0 16px;color:#fff;opacity:.95}
    .amenities-grid{margin-top:20px;padding:0;list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:12px}
    .amenities-grid li{color:#fff;display:flex;align-items:center;gap:8px}
    .amenities-grid li i{margin-right:4px;font-size:16px}

    /* Rooms grid */
    .rooms-section{margin-top:30px}
    .rooms-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
    .rooms-header h3{margin:0}
    .rooms-header .btn-primary{font-size:14px;padding:8px 16px}
    .rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
    .room-card{border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 8px 24px rgba(15,23,42,0.06)}
    .room-card img{height:180px;object-fit:cover;width:100%}
    .room-card .meta{padding:12px}
    .room-card .meta .description{color:var(--muted);font-size:13px;margin-top:8px}

    /* Testimonial */
    .testimonial{position:relative;margin:60px -100vw;min-height:500px;border-radius:0;overflow:hidden;padding:0 100vw;display:flex;align-items:center}
    .testimonial .bg{position:absolute;left:0;right:0;top:0;bottom:0;background-image:url('assets/team.jpg');background-size:cover;background-position:center;background-attachment:fixed;filter:brightness(0.4);height:auto}
    .testimonial-overlay{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:60px 32px;width:100%;display:flex;justify-content:flex-start}
    .testimonial .card{position:relative;left:auto;top:auto;max-width:480px;background:var(--blue-card);color:#fff;padding:32px;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,0.3)}
    .testimonial .card p{margin:0 0 12px}
    .avatar{width:44px;height:44px;border-radius:50%;background:#fff;display:inline-block;margin-right:10px}
    
    /* Testimonial card content */
    .testimonial .card .label{color:#fff;font-size:11px;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;opacity:0.8}
    .testimonial .card h3{margin:0 0 12px;color:#fff;font-size:24px}
    .testimonial .card .quote{margin:0 0 16px;color:#fff;opacity:0.95}
    .testimonial .card .author-info{display:flex;align-items:center}
    .testimonial .card .author-name{display:block;color:#fff}
    .testimonial .card .author-role{font-size:12px;opacity:.85;color:#fff}

    /* Restaurant */
    .restaurant{display:grid;grid-template-columns:360px 1fr;gap:20px;align-items:start;margin-top:30px}
    .restaurant img{border-radius:10px}
    
    /* Contact section */
    .contact-section-spacing{margin-top:16px}
    .contact-list{margin-top:8px;color:var(--muted);list-style:none;padding:0}
    .contact-list li{margin-bottom:8px;display:flex;align-items:center;gap:8px}
    .contact-list li i{color:var(--accent);font-size:16px}
    .partners-list{margin-top:8px;color:var(--muted);list-style:none;padding:0}
    .partners-list li{margin-bottom:8px;display:flex;align-items:center;gap:8px}
    .partners-list li i{color:var(--accent);font-size:16px}

    /* Footer */
    footer{background:#0a0f1a;color:#e6eef2;padding:0;margin-top:60px;border-top:3px solid var(--accent);min-height:auto}
    .footer-content{max-width:1200px;margin:0 auto;padding:50px 24px 30px}
    .footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;margin-bottom:30px}
    .footer-brand{max-width:400px}
    .footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:16px}
    .footer-logo img{width:50px;height:50px;object-fit:contain}
    .footer-logo strong{color:#fff;font-size:16px;display:block}
    .footer-tagline{margin:2px 0 0 0;color:var(--accent);font-size:12px;font-style:italic}
    .footer-description{color:#9ca3af;margin:12px 0;line-height:1.6;font-size:13px}
    .footer-owner{color:#9ca3af;margin:12px 0;font-size:13px;display:flex;align-items:center;gap:8px}
    .footer-owner i{color:var(--accent)}
    .socials{display:flex;gap:8px;margin-top:16px}
    .socials a{width:40px;height:40px;border-radius:8px;background:rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:center;color:#fff;transition:all 0.3s ease;font-size:16px}
    .socials a:hover{background:var(--accent);transform:translateY(-3px);box-shadow:0 6px 16px rgba(230,88,88,0.3)}
    .footer-section-title{font-weight:700;margin-bottom:14px;color:#fff;font-size:15px;border-bottom:2px solid var(--accent);padding-bottom:8px;display:inline-block}
    .footer-nav{display:flex;flex-direction:column;gap:8px}
    .footer-nav a{display:flex;align-items:center;gap:10px;transition:all 0.3s ease;color:#9ca3af;padding:4px 0;font-size:13px}
    .footer-nav a:hover{color:var(--accent);padding-left:6px}
    .footer-nav a i{font-size:13px;width:18px;color:var(--accent)}
    .footer-contact{color:#9ca3af;font-size:13px}
    .footer-contact p{margin:0 0 10px;display:flex;align-items:center;gap:10px}
    .footer-contact i{color:var(--accent);font-size:14px;width:18px}
    .footer-address{color:#9ca3af;font-size:13px}
    .footer-address p{margin:0;display:flex;align-items:flex-start;gap:10px;line-height:1.5}
    .footer-address i{color:var(--accent);margin-top:2px;font-size:14px}
    .footer-hours{color:#9ca3af;margin-top:10px;font-size:13px}
    .footer-hours p{margin:0 0 6px;display:flex;align-items:center;gap:10px}
    .footer-hours i{color:var(--accent);font-size:13px;width:18px}
    .footer-bottom{text-align:center;padding:20px 0;border-top:1px solid rgba(255,255,255,0.1);background:#050810}
    .footer-bottom p{margin:0;font-size:13px;color:#6b7280}
    .footer-bottom .fa-heart{color:var(--accent);font-size:11px}
    
    /* --- Portfolio Section --- */
    .portfolio-section{margin-top:60px;position:relative}
    .portfolio-header{text-align:center;margin-bottom:50px;animation:fadeInUp 0.8s ease-out}
    .portfolio-header .section-title{display:inline-block;margin-bottom:12px;position:relative;padding-bottom:8px}
    .portfolio-header .section-title::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:60px;height:3px;background:var(--gradient-primary);border-radius:2px}
    .portfolio-header h2{font-size:36px;margin-bottom:16px;color:#0f172a;font-weight:800;letter-spacing:-0.5px}
    .portfolio-header p{color:#475569;max-width:600px;margin:0 auto;font-size:15px;line-height:1.8}
    
    .portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px;margin-top:40px}
    .portfolio-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:all 0.4s cubic-bezier(0.4,0,0.2,1);position:relative;display:flex;flex-direction:column;animation:fadeInUp 0.6s ease-out backwards;border:1px solid rgba(0,0,0,0.04)}
    .portfolio-card:nth-child(1){animation-delay:0.1s}
    .portfolio-card:nth-child(2){animation-delay:0.2s}
    .portfolio-card:nth-child(3){animation-delay:0.3s}
    .portfolio-card:nth-child(4){animation-delay:0.4s}
    .portfolio-card:hover{transform:translateY(-12px) scale(1.02);box-shadow:var(--shadow-lg);border-color:rgba(230,88,88,0.2)}
    
    .portfolio-card-image{width:100%;height:260px;overflow:hidden;position:relative;background:linear-gradient(135deg,#f8fafc,#e6f0f6)}
    .portfolio-card-image::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(230,88,88,0.05),transparent);z-index:1;opacity:0;transition:opacity 0.4s ease}
    .portfolio-card:hover .portfolio-card-image::before{opacity:1}
    .portfolio-card-image img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s cubic-bezier(0.4,0,0.2,1);filter:brightness(0.95) saturate(1.1)}
    .portfolio-card:hover .portfolio-card-image img{transform:scale(1.15) rotate(2deg);filter:brightness(1) saturate(1.2)}
    
    .portfolio-card-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 40%,rgba(0,0,0,0.8));display:flex;align-items:flex-end;padding:24px;opacity:0;transition:all 0.4s cubic-bezier(0.4,0,0.2,1);z-index:2}
    .portfolio-card:hover .portfolio-card-overlay{opacity:1}
    .portfolio-card-overlay .tag{background:var(--gradient-primary);color:#fff;padding:6px 14px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;box-shadow:0 4px 12px rgba(230,88,88,0.4);transform:translateY(10px);transition:transform 0.4s cubic-bezier(0.4,0,0.2,1) 0.1s}
    .portfolio-card:hover .portfolio-card-overlay .tag{transform:translateY(0)}
    
    .portfolio-card-content{padding:28px;flex:1;display:flex;flex-direction:column;background:#fff;position:relative}
    .portfolio-card-title{font-size:21px;margin-bottom:12px;color:#0f172a;font-weight:700;letter-spacing:-0.3px;transition:color 0.3s ease}
    .portfolio-card:hover .portfolio-card-title{color:var(--accent)}
    .portfolio-card-description{color:#475569;font-size:14px;line-height:1.7;margin-bottom:18px;flex:1}
    
    .portfolio-card-meta{display:flex;align-items:center;justify-content:space-between;padding-top:18px;border-top:2px solid #f1f5f9;margin-top:auto;transition:border-color 0.3s ease}
    .portfolio-card:hover .portfolio-card-meta{border-top-color:rgba(230,88,88,0.2)}
    .portfolio-card-stats{display:flex;gap:18px;font-size:13px;color:var(--muted)}
    .portfolio-card-stats span{display:flex;align-items:center;gap:6px;transition:transform 0.3s ease}
    .portfolio-card:hover .portfolio-card-stats span{transform:translateY(-2px)}
    .portfolio-card-stats i{color:var(--accent);font-size:15px;transition:transform 0.3s ease}
    .portfolio-card:hover .portfolio-card-stats i{transform:scale(1.2)}
    
    .portfolio-card-link{color:var(--accent);font-weight:700;font-size:14px;display:flex;align-items:center;gap:8px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);padding:8px 14px;border-radius:8px;margin:-8px -14px -8px 0}
    .portfolio-card-link:hover{gap:12px;background:rgba(230,88,88,0.08)}
    .portfolio-card-link i{font-size:13px;transition:transform 0.3s ease}
    .portfolio-card-link:hover i{transform:translateX(4px)}
    
    /* --- Enhanced Portfolio Section --- */
    .portfolio-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin:50px 0;padding:40px 0;background:linear-gradient(135deg,rgba(230,88,88,0.05),rgba(230,88,88,0.02));border-radius:var(--radius);position:relative;overflow:hidden}
    .portfolio-stats::before{content:'';position:absolute;top:-20px;right:-20px;width:150px;height:150px;background:radial-gradient(circle,rgba(230,88,88,0.1),transparent);border-radius:50%}
    .stat-item{text-align:center;padding:20px;position:relative;z-index:1}
    .stat-number{font-size:42px;font-weight:800;color:var(--accent);line-height:1;margin-bottom:8px;text-shadow:0 2px 4px rgba(230,88,88,0.1)}
    .stat-label{font-size:14px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:1px}
    
    .portfolio-clients{margin-top:60px}
    .clients-title{font-size:24px;text-align:center;margin-bottom:40px;color:#0f172a;font-weight:700;position:relative;padding-bottom:12px}
    .clients-title::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:80px;height:3px;background:var(--gradient-primary);border-radius:2px}
    
    .accreditation-section{margin-top:80px;padding:50px;background:linear-gradient(135deg,#f8fafc,#eef5f9);border-radius:var(--radius-lg);position:relative;overflow:hidden}
    .accreditation-section::before{content:'';position:absolute;top:-30%;right:-15%;width:300px;height:300px;background:radial-gradient(circle,rgba(230,88,88,0.06),transparent);border-radius:50%;animation:float 12s ease-in-out infinite}
    
    .accreditation-content{position:relative;z-index:1;text-align:center;max-width:800px;margin:0 auto}
    .accreditation-badge{display:inline-flex;align-items:center;gap:20px;background:#fff;padding:24px 32px;border-radius:var(--radius);box-shadow:var(--shadow-md);margin-bottom:24px;border:2px solid rgba(230,88,88,0.1)}
    .badge-icon{width:60px;height:60px;background:var(--gradient-primary);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
    .badge-icon i{font-size:28px;color:#fff}
    .badge-content h4{margin:0 0 4px;font-size:20px;color:#0f172a;font-weight:700}
    .badge-content p{margin:0 0 8px;color:var(--muted);font-size:14px}
    .rating-stars{display:flex;gap:4px}
    .rating-stars i{color:#ffd700;font-size:16px}
    .accreditation-text{font-size:16px;line-height:1.7;color:#475569;text-align:center}
    
    /* Mobile optimizations for portfolio */
    @media (max-width:820px){
      .portfolio-stats{grid-template-columns:repeat(2,1fr);gap:20px;margin:30px 0;padding:30px 20px}
      .stat-number{font-size:32px}
      .stat-label{font-size:13px}
      .clients-title{font-size:22px}
      .accreditation-section{margin-top:50px;padding:30px 20px}
      .accreditation-badge{flex-direction:column;text-align:center;gap:16px;padding:20px}
      .badge-icon{width:50px;height:50px}
      .badge-icon i{font-size:24px}
    }
    
    /* --- Products & Services Section --- */
    .services-section{margin-top:80px;padding:80px 0;background:linear-gradient(135deg,#f8fafc 0%,#eef5f9 50%,#e6f0f6 100%);border-radius:var(--radius-lg);position:relative;overflow:hidden}
    .services-section::before{content:'';position:absolute;top:-50%;right:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(230,88,88,0.08),transparent);border-radius:50%;animation:float 20s ease-in-out infinite}
    .services-section::after{content:'';position:absolute;bottom:-40%;left:-5%;width:400px;height:400px;background:radial-gradient(circle,rgba(230,88,88,0.06),transparent);border-radius:50%;animation:float 15s ease-in-out infinite reverse}
    
    .services-header{text-align:center;margin-bottom:60px;position:relative;z-index:1;animation:fadeInUp 0.8s ease-out}
    .services-header .section-title{display:inline-block;margin-bottom:14px;position:relative;padding-bottom:8px}
    .services-header .section-title::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:70px;height:3px;background:var(--gradient-primary);border-radius:2px}
    .services-header h2{font-size:38px;margin-bottom:18px;color:#0f172a;font-weight:800;letter-spacing:-0.8px}
    .services-header p{color:#475569;max-width:700px;margin:0 auto;font-size:16px;line-height:1.8}
    
    .services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px;padding:0 40px;position:relative;z-index:1}
    .service-card{background:#fff;padding:36px;border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:all 0.4s cubic-bezier(0.4,0,0.2,1);border:2px solid rgba(0,0,0,0.04);position:relative;overflow:hidden;animation:fadeInUp 0.6s ease-out backwards}
    .service-card:nth-child(1){animation-delay:0.1s}
    .service-card:nth-child(2){animation-delay:0.2s}
    .service-card:nth-child(3){animation-delay:0.3s}
    .service-card:nth-child(4){animation-delay:0.4s}
    .service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:var(--gradient-primary);transform:scaleX(0);transform-origin:left;transition:transform 0.5s cubic-bezier(0.4,0,0.2,1)}
    .service-card::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(230,88,88,0.02),transparent);opacity:0;transition:opacity 0.4s ease}
    .service-card:hover{transform:translateY(-10px) scale(1.02);box-shadow:0 16px 40px rgba(230,88,88,0.15);border-color:rgba(230,88,88,0.3)}
    .service-card:hover::before{transform:scaleX(1)}
    .service-card:hover::after{opacity:1}
    
    .service-icon{width:70px;height:70px;background:linear-gradient(135deg,rgba(230,88,88,0.12),rgba(230,88,88,0.06));border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:24px;transition:all 0.5s cubic-bezier(0.4,0,0.2,1);position:relative;overflow:hidden}
    .service-icon::before{content:'';position:absolute;inset:0;background:var(--gradient-primary);opacity:0;transition:opacity 0.4s ease}
    .service-card:hover .service-icon{transform:scale(1.15) rotate(5deg);box-shadow:0 8px 24px rgba(230,88,88,0.25)}
    .service-card:hover .service-icon::before{opacity:1}
    .service-icon i{font-size:32px;color:var(--accent);transition:all 0.4s ease;position:relative;z-index:1}
    .service-card:hover .service-icon i{color:#fff;transform:scale(1.1) rotate(-5deg)}
    
    .service-title{font-size:22px;margin-bottom:14px;color:#0f172a;font-weight:700;letter-spacing:-0.4px;transition:color 0.3s ease;line-height:1.3}
    .service-card:hover .service-title{color:var(--accent)}
    .service-description{color:#475569;font-size:14px;line-height:1.8;margin-bottom:24px}
    
    .service-features{list-style:none;padding:0;margin:0 0 24px 0}
    .service-features li{color:#475569;font-size:13px;padding:10px 0;display:flex;align-items:center;gap:12px;border-bottom:1px solid #f1f5f9;transition:all 0.3s ease}
    .service-features li:last-child{border-bottom:none}
    .service-features li:hover{padding-left:8px;color:#0f172a}
    .service-features li i{color:var(--accent);font-size:15px;min-width:20px;transition:transform 0.3s ease}
    .service-features li:hover i{transform:scale(1.3) rotate(10deg)}
    
    .service-cta{display:inline-flex;align-items:center;gap:10px;color:var(--accent);font-weight:700;font-size:14px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);padding:10px 18px;border-radius:10px;background:rgba(230,88,88,0.05);margin:-10px}
    .service-cta:hover{gap:14px;background:rgba(230,88,88,0.12);transform:translateX(4px)}
    .service-cta i{font-size:13px;transition:transform 0.3s ease}
    .service-cta:hover i{transform:translateX(6px)}
    
    /* Featured service highlight */
    .service-card.featured{background:var(--gradient-primary);color:#fff;border:none;box-shadow:0 12px 40px rgba(230,88,88,0.3);position:relative;overflow:hidden}
    .service-card.featured::before{display:none}
    .service-card.featured::after{background:linear-gradient(135deg,rgba(255,255,255,0.1),transparent);opacity:1}
    .service-card.featured:hover{box-shadow:0 20px 60px rgba(230,88,88,0.4);transform:translateY(-12px) scale(1.03)}
    .service-card.featured .service-icon{background:rgba(255,255,255,0.25);box-shadow:0 8px 24px rgba(0,0,0,0.2)}
    .service-card.featured .service-icon i{color:#fff}
    .service-card.featured:hover .service-icon{background:rgba(255,255,255,0.35);transform:scale(1.15) rotate(5deg)}
    .service-card.featured .service-title{color:#fff}
    .service-card.featured:hover .service-title{color:#fff;text-shadow:0 2px 8px rgba(0,0,0,0.15)}
    .service-card.featured .service-description{color:rgba(255,255,255,0.95)}
    .service-card.featured .service-features li{color:rgba(255,255,255,0.95);border-bottom-color:rgba(255,255,255,0.2)}
    .service-card.featured .service-features li:hover{color:#fff;padding-left:8px}
    .service-card.featured .service-features li i{color:#fff}
    .service-card.featured .service-cta{color:#fff;background:rgba(255,255,255,0.25);padding:12px 20px;border-radius:10px;font-weight:700}
    .service-card.featured .service-cta:hover{background:rgba(255,255,255,0.35);gap:16px}
    
    /* Floating animation */
    @keyframes float{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(5deg)}}
    
    /* Mobile navigation */
    .mobile-nav{position:fixed;right:0;top:0;bottom:0;width:280px;background:linear-gradient(135deg,#fff 0%,#f9fafb 100%);box-shadow:-4px 0 20px rgba(0,0,0,0.2);z-index:50;overflow-y:auto;animation:slideIn 0.3s ease;transform:translateX(0)}
    .mobile-nav.closing{animation:slideOut 0.3s ease;transform:translateX(100%)}
    @keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
    @keyframes slideOut{from{transform:translateX(0)}to{transform:translateX(100%)}}
    .mobile-nav-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:2px solid var(--accent);background:linear-gradient(90deg,var(--accent),var(--accent-dark))}
    .mobile-nav-logo{width:45px;height:45px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.2);border-radius:10px}
    .mobile-nav-logo img{width:100%;height:100%;object-fit:contain}
    .mobile-nav-close{background:none;border:none;color:white;font-size:32px;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:transform 0.2s ease}
    .mobile-nav-close:active{transform:scale(0.9)}
    .mobile-nav a{display:flex;align-items:center;gap:14px;padding:14px 20px;color:#1f2937;border-bottom:1px solid #e5e7eb;transition:all 0.3s ease;font-weight:500;font-size:15px}
    .mobile-nav a:last-child{border-bottom:none}
    .mobile-nav a:hover{background:#f0f1f3;padding-left:24px;color:var(--accent)}
    .mobile-nav a i{font-size:18px;width:24px;color:var(--accent);display:flex;align-items:center;justify-content:center}
    .mobile-nav .cta-mobile{background:linear-gradient(90deg,var(--accent),var(--accent-dark));color:white;margin:16px;border-radius:25px;justify-content:center;border-bottom:none;box-shadow:0 4px 12px rgba(230,88,88,0.25);font-weight:600}
    .mobile-nav .cta-mobile:hover{background:linear-gradient(90deg,var(--accent-dark),var(--accent));box-shadow:0 6px 20px rgba(230,88,88,0.4)}

    /* --- Professional Contact Form --- */
    .contact-form{margin:24px 0;background:#f8fafc;padding:24px;border-radius:12px;border:1px solid #e2e8f0}
    .form-group{margin-bottom:20px}
    .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
    .form-group label{display:block;margin-bottom:6px;font-weight:600;color:#374151;font-size:14px}
    .form-group input, .form-group textarea, .form-group select{
        width:100%;
        padding:12px 16px;
        border:1px solid #d1d5db;
        border-radius:8px;
        font-size:14px;
        font-family:inherit;
        transition:border-color 0.3s ease, box-shadow 0.3s ease;
        background:#ffffff;
    }
    .form-group input:focus, .form-group textarea:focus, .form-group select:focus{
        outline:none;
        border-color:var(--accent);
        box-shadow:0 0 0 3px rgba(230, 88, 88, 0.1);
    }
    .form-group textarea{resize:vertical;min-height:120px;line-height:1.5}
    .btn-primary{
        background:var(--gradient-primary);
        color:#ffffff;
        border:none;
        padding:12px 24px;
        border-radius:8px;
        font-weight:600;
        cursor:pointer;
        transition:all 0.3s ease;
        display:inline-flex;
        align-items:center;
        justify-content:center;
        gap:8px;
    }
    .btn-primary:hover{
        transform:translateY(-2px);
        box-shadow:var(--shadow-md);
    }
    
    /* Professional animations */
    @keyframes fadeInUp {
        from { opacity: 0; transform: translateY(30px); }
        to { opacity: 1; transform: translateY(0); }
    }
    
    @keyframes slideIn {
        from { opacity: 0; transform: translateX(-30px); }
        to { opacity: 1; transform: translateX(0); }
    }
    
    .hero-content { animation: fadeInUp 1s ease-out; }
    .section-title { animation: slideIn 0.8s ease-out; }
    
    /* Enhanced button styles */
    .btn-ghost:hover {
        background: rgba(255,255,255,0.1);
        transform: translateY(-2px);
    }
    
    /* Professional loading states */
    .loading {
        position: relative;
        color: transparent;
    }
    .loading::after {
        content: '';
        position: absolute;
        width: 16px;
        height: 16px;
        top: 50%;
        left: 50%;
        margin-left: -8px;
        margin-top: -8px;
        border-radius: 50%;
        border: 2px solid transparent;
        border-top-color: #ffffff;
        animation: spin 1s linear infinite;
    }
    @keyframes spin { to { transform: rotate(360deg); } }
    
    /* Professional mobile form improvements */
    @media (max-width:820px){
      .form-row{grid-template-columns:1fr;gap:0}
      .contact-form{padding:20px 16px;margin:20px 0}
      .form-group input, .form-group textarea{font-size:16px}
    }
    
    /* Enhanced mobile menu */
    .mobile-nav{
        position:fixed;
        right:0;
        top:0;
        bottom:0;
        width:280px;
        background:linear-gradient(135deg,#fff 0%,#f9fafb 100%);
        box-shadow:-4px 0 20px rgba(0,0,0,0.2);
        z-index:50;
        overflow-y:auto;
        animation:slideIn 0.3s ease;
        transform:translateX(0)
    }
    .mobile-nav.closing{animation:slideOut 0.3s ease;transform:translateX(100%)}
    @keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
    @keyframes slideOut{from{transform:translateX(0)}to{transform:translateX(100%)}}
    .mobile-nav-header{
        display:flex;
        align-items:center;
        justify-content:space-between;
        padding:16px 20px;
        border-bottom:2px solid var(--accent);
        background:linear-gradient(90deg,var(--accent),var(--accent-dark))
    }
    .mobile-nav-logo{
        width:45px;
        height:45px;
        display:flex;
        align-items:center;
        justify-content:center;
        background:rgba(255,255,255,0.2);
        border-radius:10px
    }
    .mobile-nav-logo img{width:100%;height:100%;object-fit:contain}
    .mobile-nav-close{
        background:none;
        border:none;
        color:white;
        font-size:32px;
        cursor:pointer;
        padding:0;
        width:40px;
        height:40px;
        display:flex;
        align-items:center;
        justify-content:center;
        transition:transform 0.2s ease
    }
    .mobile-nav-close:active{transform:scale(0.9)}
    .mobile-nav a{
        display:flex;
        align-items:center;
        gap:14px;
        padding:14px 20px;
        color:#1f2937;
        border-bottom:1px solid #e5e7eb;
        transition:all 0.3s ease;
        font-weight:500;
        font-size:15px
    }
    .mobile-nav a:last-child{border-bottom:none}
    .mobile-nav a:hover{background:#f0f1f3;padding-left:24px;color:var(--accent)}
    .mobile-nav a i{
        font-size:18px;
        width:24px;
        color:var(--accent);
        display:flex;
        align-items:center;
        justify-content:center
    }
    .mobile-nav .cta-mobile{
        background:linear-gradient(90deg,var(--accent),var(--accent-dark));
        color:white;
        margin:16px;
        border-radius:25px;
        justify-content:center;
        border-bottom:none;
        box-shadow:0 4px 12px rgba(230,88,88,0.25);
        font-weight:600
    }
    .mobile-nav .cta-mobile:hover{
        background:linear-gradient(90deg,var(--accent-dark),var(--accent));
        box-shadow:0 6px 20px rgba(230,88,88,0.4)
    }
    
    /* Enhanced mobile responsiveness */
    @media (max-width:820px){
      header{padding:12px 16px;flex-wrap:nowrap}
      .logo img{max-width:160px;height:auto}
      nav.desktop{display:none}
      .hamburger{display:flex}
      .hero{min-height:65vh;padding:0;background-attachment:scroll}
      .hero-inner{padding:40px 20px;flex-direction:column;align-items:center;text-align:center}
      .hero-content{text-align:center;max-width:100%;padding:0 8px}
      .hero-content h1{font-size:2.2rem;line-height:1.15;margin-bottom:1rem}
      .hero-content p{font-size:1rem;line-height:1.65;margin-bottom:1.5rem;max-width:600px;margin-left:auto;margin-right:auto}
      .hero .buttons{flex-direction:row;gap:12px;width:100%;justify-content:center;flex-wrap:wrap}
      .hero .buttons a{flex:1;min-width:140px;text-align:center;padding:12px 20px}
      .hero-images{display:none}
      
      /* Search bar mobile */
      .search-bar{flex-direction:column;align-items:stretch}
      .search-col{width:100%}
      .search-col input, .search-col select{width:100%;min-width:unset}
      .search-submit{margin-left:0;width:100%}
      .search-submit button{width:100%;padding:14px 18px}
      main{padding:0 16px 60px}
      
      /* About section mobile */
      .two-col{grid-template-columns:1fr;gap:2rem}
      .about-images-grid{margin-bottom:1rem}
      .about-img-small img,.about-img-large img{height:150px;object-fit:cover}
      
      /* Amenities mobile */
      .amenities-section{margin:40px -50px;padding:40px 50px}
      .amenities-card-new{max-width:100%;padding:24px}
      .amenities-grid{grid-template-columns:1fr;gap:0.5rem}
      
      /* Rooms mobile */
      .rooms-grid{grid-template-columns:1fr}
      .rooms-header{flex-direction:column;gap:1rem}
      .room-card img{height:200px}
      
      /* Restaurant/Contact mobile */
      .restaurant{grid-template-columns:1fr;gap:1.5rem}
      .restaurant img{height:200px;object-fit:cover}
      
      /* Portfolio mobile */
      .portfolio-grid{grid-template-columns:1fr;gap:24px}
      .portfolio-card{animation:fadeInUp 0.6s ease-out}
      .portfolio-card:nth-child(n){animation-delay:0.1s}
      .portfolio-card-image{height:240px}
      .portfolio-card-content{padding:24px}
      .portfolio-card-meta{flex-direction:column;align-items:flex-start;gap:14px}
      .portfolio-card-stats{flex-wrap:wrap;gap:12px}
      .portfolio-header h2{font-size:30px}
      
      /* Services mobile */
      .services-section{padding:50px 0;margin-top:50px}
      .services-section::before,.services-section::after{display:none}
      .services-grid{grid-template-columns:1fr;gap:24px;padding:0 20px}
      .service-card{padding:28px;animation:fadeInUp 0.6s ease-out}
      .service-card:nth-child(n){animation-delay:0.1s}
      .services-header h2{font-size:30px}
      .service-icon{width:65px;height:65px}
      .service-icon i{font-size:30px}
      
      /* Testimonial mobile */
      .testimonial{margin:40px -50px;padding:40px 50px}
      .testimonial .card{max-width:100%;padding:24px}
      
      /* Footer mobile */
      .footer-grid{grid-template-columns:1fr;gap:2rem}
      .footer-brand{text-align:center}
      .footer-nav{align-items:center}
      .footer-contact p, .footer-address p{justify-content:center}
    }