@font-face { font-family: 'Font Awesome 6 Free'; font-style: normal; font-weight: 900; font-display: swap; src: url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/webfonts/fa-solid-900.woff2') format('woff2'); } @font-face { font-family: 'Font Awesome 6 Brands'; font-style: normal; font-weight: 400; font-display: swap; src: url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/webfonts/fa-brands-400.woff2') format('woff2'); } :root{ --primary:#d4af37;--primary-dark:#e9b02d;--secondary:#8f0000;--accent:#f5f5f5;--text:#333;--text-light:#777;--bg:#fff;--glass:rgba(255, 255, 255, 0.1);--shadow:0 4px 30px rgba(0, 0, 0, 0.1);--radius:5px;} *{ margin:0;padding:0;box-sizing:border-box;} body{ font-family:'Outfit', sans-serif;color:var(--text);background-color:var(--bg);line-height:1.6;} .container{ max-width:1200px;margin:0 auto;padding:0 20px;} .topbar{ background:var(--secondary);padding:8px 0;font-size:0.85rem;border-bottom:1px solid rgba(143, 0, 0, 0.1);} .topbar .container{ display:flex;justify-content:space-between;align-items:center;} .topbar-left, .topbar-right{ display:flex;gap:20px;align-items:center;} .topbar-item{ display:flex;align-items:center;gap:8px;color:white;} .topbar-item i{ width:14px;text-align:center;} .topbar-right a{ color:var(--primary-dark);text-decoration:none;font-weight:500;} .topbar-right a:hover{ color:var(--primary);} header{ background:white;color:#8f0000;padding:12px 0;position:sticky;top:0;z-index:1000;box-shadow:0 2px 10px rgba(0, 0, 0, 0.05);} nav{ display:flex;justify-content:space-between;align-items:center;} .logo{ display:flex;align-items:center;text-decoration:none;} .nav-links{ display:flex;list-style:none;gap:30px;align-items:center;} .nav-links a{ color:#8f0000;text-decoration:none;font-weight:500;transition:all 0.3s;display:flex;align-items:center;} .nav-links a i{ margin-right:8px;font-size:0.9em;color:var(--primary);} .nav-links a:hover{ color:var(--primary);transform:translateY(-2px);} .mobile-only-logo{ display:none;} .btn-cta{ background:var(--primary);padding:10px 20px;border-radius:var(--radius);color:white !important;font-weight:600 !important;} .hero{ height:80vh;background:linear-gradient(rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6)), url('../img/hero.jpg') center/cover;display:flex;align-items:center;color:white;text-align:center;} .hero h1{ font-size:3.5rem;margin-bottom:20px;text-shadow:0 4px 10px rgba(0, 0, 0, 0.3);} .hero p{ font-size:1.2rem;margin-bottom:40px;opacity:0.9;text-shadow:0 2px 5px rgba(0, 0, 0, 0.3);} .booking-bar{ background:rgba(0, 0, 0, 0.8);backdrop-filter:blur(10px);border-top:1px solid rgba(255, 255, 255, 0.1);padding:20px 0;margin-top:-85px;position:relative;z-index:10;} .booking-bar form{ display:flex;align-items:center;justify-content:space-between;gap:15px;color:white;} .booking-label{ display:flex;align-items:center;gap:15px;min-width:200px;} .booking-label .icon-circle{ width:35px;height:35px;border:2px solid var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:0.9rem;} .booking-label h3{ font-size:0.9rem;letter-spacing:1px;line-height:1.2;} .booking-inputs{ display:flex;gap:10px;flex-grow:1;} .input-box{ background:rgba(255, 255, 255, 0.05);border:1px solid rgba(255, 255, 255, 0.2);padding:10px 15px;border-radius:var(--radius);color:white;display:flex;align-items:center;gap:10px;min-width:140px;cursor:pointer;} .input-box input, .input-box select{ background:transparent;border:none;color:white;outline:none;width:100%;font-size:0.85rem;appearance:none;-webkit-appearance:none;-moz-appearance:none;} .input-box select option{ background:var(--secondary);color:white;} .btn-find{ background:var(--primary);color:white;border:none;padding:12px 25px;border-radius:var(--radius);font-weight:700;font-size:0.85rem;cursor:pointer;white-space:nowrap;transition:background 0.3s;} .btn-find:hover{ background:var(--primary-dark);} .btn-primary{ background:var(--primary);color:var(--secondary);padding:15px 40px;border-radius:var(--radius);text-decoration:none;font-weight:600;font-size:1.1rem;display:inline-block;transition:transform 0.3s, box-shadow 0.3s;border:none;cursor:pointer;} .btn-primary:hover{ transform:translateY(-3px);box-shadow:0 10px 20px rgba(212, 175, 55, 0.3);} .btn-secondary{ border:2px solid var(--primary);color:var(--primary);padding:8px 20px;border-radius:var(--radius);text-decoration:none;font-weight:600;transition:background 0.3s, color 0.3s;} .btn-secondary:hover{ background:var(--primary);color:var(--secondary);} .room-types{ padding:80px 0;} .room-types h2{ font-size:2.5rem;margin-bottom:50px;text-align:center;} .room-grid{ display:grid;grid-template-columns:repeat(auto-fit, minmax(350px, 1fr));gap:30px;} .room-card{ background:white;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform 0.3s;} .room-card:hover{ transform:translateY(-10px);} .room-image{ height:250px;background-size:cover;background-position:center;position:relative;} .room-price-badge{ position:absolute;top:20px;right:20px;background:var(--primary);color:white;padding:5px 15px;border-radius:20px;font-weight:700;font-size:0.9rem;box-shadow:0 4px 10px rgba(0, 0, 0, 0.2);} .room-info{ padding:25px;} .room-info h3{ font-size:1.5rem;margin-bottom:10px;color:var(--secondary);} .room-info p{ color:var(--text-light);margin-bottom:15px;font-size:0.95rem;height:3em;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;} .btn-text{ color:var(--primary-dark);text-decoration:none;font-weight:600;font-size:0.9rem;display:flex;align-items:center;gap:8px;transition:transform 0.3s;} .btn-text:hover{ transform:translateX(5px);} .room-footer{ display:flex;justify-content:space-between;align-items:center;margin-top:20px;} .price{ font-weight:700;font-size:1.2rem;color:var(--primary-dark);} .rooms-page{ padding:60px 0;} .page-title{ font-size:3rem;text-align:center;margin-bottom:10px;} .page-subtitle{ text-align:center;color:var(--text-light);margin-bottom:60px;font-size:1.1rem;} .room-row{ display:flex;gap:40px;margin-bottom:60px;background:white;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);} .room-image-large{ flex:1;min-height:400px;background-size:cover;background-position:center;} .room-details{ flex:1;padding:40px;display:flex;flex-direction:column;justify-content:center;} .room-details h2{ font-size:2rem;margin-bottom:15px;} .room-details .description{ margin-bottom:25px;font-size:1.1rem;} .features{ list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:30px;} .features li::before{ content:"✓";margin-right:10px;color:var(--primary);font-weight:bold;} .room-action{ display:flex;justify-content:space-between;align-items:center;} .restaurant-preview{ padding:100px 0;background:#fff;} .section-grid{ display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center;} .img-premium{ width:100%;border-radius:var(--radius);box-shadow:20px 20px 60px rgba(0, 0, 0, 0.1);} .sub-title{ display:block;color:var(--primary);font-weight:700;text-transform:uppercase;letter-spacing:2px;margin-bottom:15px;font-size:0.9rem;} .menu-highlights{ margin:40px 0;} .menu-item-short{ display:flex;justify-content:space-between;align-items:flex-start;padding:20px 0;border-bottom:1px dashed #ddd;} .menu-item-short h4{ margin-bottom:5px;color:var(--secondary);} .menu-item-short p{ font-size:0.85rem;color:var(--text-light);} .item-price{ font-weight:700;color:var(--primary);} .special-offers{ padding:100px 0;background:#fdfaf5;} .offer-grid{ display:grid;grid-template-columns:repeat(auto-fit, minmax(400px, 1fr));gap:30px;margin-top:50px;} .offer-card{ display:flex;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 10px 30px rgba(0, 0, 0, 0.05);transition:transform 0.3s;} .offer-card:hover{ transform:translateY(-10px);} .offer-image{ flex:1;min-height:250px;background-size:cover;background-position:center;position:relative;} .offer-badge{ position:absolute;top:20px;left:20px;background:var(--secondary);color:white;padding:5px 15px;border-radius:20px;font-weight:700;font-size:0.8rem;} .offer-content{ flex:1.2;padding:30px;text-align:left;display:flex;flex-direction:column;justify-content:center;} .promo-box{ margin:15px 0 25px;background:#f9f9f9;padding:10px 15px;border-left:3px solid var(--primary);font-size:0.9rem;} .testimonials{ padding:100px 0;background:var(--secondary);color:white;position:relative;overflow:hidden;} .testimonials .sub-title{ color:var(--primary);} .testimonial-slider{ display:flex;justify-content:center;gap:30px;margin-top:60px;flex-wrap:wrap;} .testimonial-card{ background:rgba(255, 255, 255, 0.05);padding:40px;border-radius:var(--radius);max-width:350px;backdrop-filter:blur(10px);} .rating{ color:var(--primary);margin-bottom:20px;} .testimonial-card p{ font-style:italic;margin-bottom:25px;line-height:1.8;} .verified{ display:block;font-size:0.75rem;color:#4cd137;margin-top:10px;} .amenities-section{ padding:100px 0;background:#fff;} .amenities-grid{ display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:40px;margin-top:60px;} .amenity-item{ padding:40px;background:#fdfaf5;border-radius:var(--radius);transition:all 0.3s;border:1px solid #f0e6d6;} .amenity-item:hover{ transform:translateY(-5px);background:#fff;box-shadow:0 15px 35px rgba(212, 175, 55, 0.1);} .amenity-icon{ font-size:3rem;color:var(--primary);margin-bottom:25px;} .status-badge.maintenance{ background:#ff5252;color:white;} .status-badge{ display:inline-block;padding:4px 10px;border-radius:4px;font-size:0.75rem;font-weight:600;} .faq-section{ padding:100px 0;background:#f9f9f9;} .faq-accordion{ max-width:800px;margin:0 auto;} .faq-item{ background:#fff;margin-bottom:15px;border-radius:var(--radius);box-shadow:0 2px 10px rgba(0, 0, 0, 0.03);overflow:hidden;} .faq-question{ padding:25px 30px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background 0.3s;} .faq-question:hover{ background:#fafafa;} .faq-question h3{ font-size:1.1rem;margin:0;color:var(--secondary);} .faq-question i{ color:var(--primary);transition:transform 0.3s;} .faq-answer{ max-height:0;overflow:hidden;transition:all 0.4s ease-out;background:#fff;padding:0 30px;} .faq-answer.active{ max-height:500px;padding:0 30px 30px;} .faq-answer p{ color:var(--text-light);line-height:1.6;margin-top:0;} .about-section{ padding:100px 0;} .section-grid.reverse{ grid-template-columns:1.2fr 1fr;} .btn-play{ background:none;border:2px solid var(--primary);color:var(--secondary);padding:12px 30px;border-radius:var(--radius);font-weight:700;cursor:pointer;transition:0.3s;margin-top:25px;} .btn-play i{ margin-right:10px;color:var(--primary);} .btn-play:hover{ background:var(--primary);color:white;} .video-preview{ min-height:500px;border-radius:var(--radius);position:relative;background-size:cover;background-position:center;cursor:pointer;box-shadow:var(--shadow);} .play-overlay{ position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);font-size:5rem;color:rgba(255, 255, 255, 0.8);transition:0.3s;} .video-preview:hover .play-overlay{ color:var(--primary);transform:translate(-50%, -50%) scale(1.1);} .newsletter-section{ background:var(--secondary);padding:100px 0;position:relative;z-index:10;} .newsletter-card{ background:transparent;color:white;padding:0;width:100%;margin:0;box-shadow:none;text-align:center;} .newsletter-card h2{ margin-bottom:20px;font-size:2.5rem;} .newsletter-card p{ color:rgba(255, 255, 255, 0.8);margin-bottom:40px;font-size:1.1rem;} .newsletter-form{ display:flex;gap:15px;max-width:600px;margin:0 auto;} .newsletter-form input{ flex:1;padding:15px 25px;border-radius:var(--radius);border:none;font-size:1rem;} .sub-message{ margin-top:20px;font-size:0.9rem;} .sub-message.success{ color:#4cd137;} .sub-message.error{ color:#ff5252;} .video-modal{ display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0, 0, 0, 0.9);z-index:10000;justify-content:center;align-items:center;} .modal-content{ width:90%;max-width:1000px;position:relative;} .close-modal{ position:absolute;top:-40px;right:0;color:white;font-size:2rem;cursor:pointer;} .video-container{ padding-top:56.25%;position:relative;background:#111;border-radius:10px;} .video-placeholder{ position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;color:var(--text-light);} .video-placeholder i{ font-size:4rem;margin-bottom:20px;color:var(--primary);} @media (max-width:992px){ .section-grid.reverse{ grid-template-columns:1fr;} .video-preview{ min-height:300px;} .newsletter-form{ flex-direction:column;} } .price-tag{ font-size:2rem;font-weight:700;color:var(--primary-dark);} .price-tag span{ font-size:0.9rem;color:var(--text-light);font-weight:400;} @media (max-width:900px){ .room-row{ flex-direction:column;} } .main-footer{ background:radial-gradient(circle at top, #1a1a1a, #111);color:#ddd;padding:100px 0 0;position:relative;border-top:5px solid;border-image:linear-gradient(to right, transparent, var(--primary), transparent) 1;text-align:left;} .footer-grid{ display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:60px;padding-bottom:20px;} .footer-col h3{ color:var(--primary);font-size:1.1rem;text-transform:uppercase;letter-spacing:2px;font-weight:700;margin-bottom:35px;position:relative;} .footer-col p{ line-height:1.8;} .footer-logo img{ height:50px;width:auto;filter:brightness(0) invert(1);margin-bottom:25px;display:block;} .social-links{ display:flex;gap:15px;margin-top:25px;} .social-links a{ width:45px;height:45px;background:rgba(212, 175, 55, 0.05);border:1px solid rgba(212, 175, 55, 0.1);display:flex;align-items:center;justify-content:center;border-radius:50%;color:#fff;transition:0.3s cubic-bezier(0.4, 0, 0.2, 1);} .social-links a:hover{ background:var(--primary);transform:translateY(-5px);box-shadow:0 5px 15px rgba(212, 175, 55, 0.3);} .footer-col ul{ list-style:none;padding:0;} .footer-col ul li{ margin-bottom:15px;} .footer-col ul li a{ color:#bbb;transition:0.3s;text-decoration:none;display:inline-block;} .footer-col ul li a:hover{ color:var(--primary);transform:translateX(8px);} .contact-info p{ display:flex;gap:15px;margin-bottom:20px;align-items:center;} .contact-info i{ width:35px;height:35px;background:rgba(212, 175, 55, 0.1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:0.9rem;flex-shrink:0;} .footer-bottom{ background:#0a0a0a;padding:30px 0;border-top:1px solid rgba(255, 255, 255, 0.05);font-size:0.9rem;} .bottom-flex{ display:flex;justify-content:space-between;align-items:center;} .bottom-flex a{ color:var(--primary);font-weight:600;} .back-to-top{ position:absolute;top:-25px;left:50%;transform:translateX(-50%);width:50px;height:50px;background:var(--primary);color:#fff !important;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 5px 20px rgba(0, 0, 0, 0.5);transition:0.4s cubic-bezier(0.4, 0, 0.2, 1);z-index:10;text-decoration:none;} .back-to-top:hover{ transform:translateX(-50%) translateY(-5px);background:#fff;color:var(--primary) !important;} @media (max-width:1200px){ .footer-grid{ grid-template-columns:1fr 1fr;gap:50px;} } @media (max-width:768px){ .footer-grid{ grid-template-columns:1fr 1fr;text-align:center;gap:30px;} .footer-col.about, .footer-col.contact{ grid-column:span 2;} .footer-col h3{ margin-bottom:25px;} .footer-logo img{ margin:0 auto 25px;} .footer-col h3::after{ left:50%;transform:translateX(-50%);} .social-links{ justify-content:center;} .contact-info p{ justify-content:center;} .bottom-flex{ flex-direction:column;gap:15px;text-align:center;} } .modal-overlay{ position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0, 0, 0, 0.8);display:flex;justify-content:center;align-items:center;z-index:1000;backdrop-filter:blur(5px);} .modal-content{ background:white;padding:15px 30px;border-radius:15px;width:90%;max-width:550px;position:relative;box-shadow:0 20px 50px rgba(0, 0, 0, 0.3);max-height:95vh;overflow-y:auto;} .close-modal{ position:absolute;top:20px;right:25px;font-size:1.5rem;cursor:pointer;color:var(--text);transition:0.3s;} .close-modal:hover{ color:var(--primary);} .modal-content h2{ margin-bottom:12px;color:var(--secondary);font-size:1.6rem;border-bottom:2px solid var(--primary);padding-bottom:5px;} .form-row{ display:flex;gap:15px;} .form-row .form-group{ flex:1;} @media (max-width:600px){ .form-row{ flex-direction:column;gap:0;} } .mobile-menu-btn{ display:none;background:none;border:none;color:var(--secondary);font-size:1.5rem;cursor:pointer;transition:transform 0.3s;} .mobile-menu-btn:hover{ color:var(--primary);} @media (max-width:992px){ .mobile-menu-btn{ display:block;z-index:1002;position:relative;} .nav-links{ position:fixed;top:0;right:-100%;width:85%;max-width:320px;height:100vh;background:rgba(255, 255, 255, 0.95);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);flex-direction:column;align-items:flex-start;justify-content:center;box-shadow:-10px 0 50px rgba(0, 0, 0, 0.1);transition:right 0.5s cubic-bezier(0.4, 0, 0.2, 1);padding:30px;z-index:1001;overflow-y:auto;} .nav-links.active{ right:0;} .nav-links li{ width:100%;margin-bottom:2px;opacity:0;transform:translateX(30px);transition:all 0.4s ease;} .nav-links.active li{ opacity:1;transform:translateX(0);} .nav-links.active li:nth-child(1){ transition-delay:0.1s;} .nav-links.active li:nth-child(2){ transition-delay:0.15s;} .nav-links.active li:nth-child(3){ transition-delay:0.2s;} .nav-links.active li:nth-child(4){ transition-delay:0.25s;} .nav-links.active li:nth-child(5){ transition-delay:0.3s;} .nav-links.active li:nth-child(6){ transition-delay:0.35s;} .nav-links.active li:nth-child(7){ transition-delay:0.4s;} .nav-links.active li:nth-child(8){ transition-delay:0.45s;} .nav-links.active li:nth-child(9){ transition-delay:0.5s;} .nav-links.active li:nth-child(10){ transition-delay:0.55s;} .nav-links a{ font-size:1.1rem;padding:6px 0;display:flex;align-items:center;gap:15px;width:100%;border-bottom:1px solid rgba(0, 0, 0, 0.05);color:var(--secondary);} .nav-links a i{ width:24px;text-align:center;color:var(--primary);font-size:1.1rem;margin-right:0;} .nav-links .btn-cta{ margin-top:15px;width:100%;justify-content:center;border-radius:30px;} .mobile-only-logo{ display:block;width:100%;text-align:center;margin-bottom:10px;} .mobile-only-logo hr{ border:none;border-top:1px solid rgba(212, 175, 55, 0.2);margin:0;} .topbar .topbar-left{ display:none;} .topbar .container{ justify-content:center;} } @media (max-width:768px){ .hero h1{ font-size:2.2rem;} .booking-bar{ margin-top:0;padding:40px 0;background:var(--secondary);} .booking-bar form{ flex-direction:column;align-items:stretch;gap:25px;} .booking-label{ justify-content:center;text-align:center;} .booking-inputs{ flex-direction:column;gap:15px;} .input-box{ min-height:50px;} .section-grid, .section-grid.reverse{ grid-template-columns:1fr;gap:40px;text-align:center;} .room-grid, .offer-grid, .amenities-grid{ grid-template-columns:1fr;} .offer-card{ flex-direction:column;} .rooms-page{ padding:40px 0;} .page-title{ font-size:2.2rem;margin-bottom:20px;} .page-subtitle{ margin-bottom:40px;font-size:1rem;} .room-row{ flex-direction:column;margin-bottom:40px;gap:0;} .room-image-large{ min-height:300px;width:100%;} .room-details{ padding:30px 20px;text-align:center;} .room-details h2{ font-size:1.6rem;margin-bottom:10px;} .features{ grid-template-columns:1fr;gap:8px;text-align:left;max-width:300px;margin:0 auto 25px;} .room-action{ flex-direction:column;gap:15px;} .room-action .price-tag{ font-size:1.5rem;} .room-action .btn-primary{ width:100%;} } @media (max-width:480px){ .topbar{ font-size:0.7rem;} .logo img{ height:36px !important;} .hero h1{ font-size:1.8rem;} .hero p{ font-size:0.95rem;} .stat-card .value{ font-size:1.4rem;} } .room-card, .room-row{ position:relative;} .availability-badge{ position:absolute;top:15px;left:15px;padding:6px 15px;border-radius:25px;font-size:0.8rem;font-weight:700;text-transform:uppercase;z-index:10;letter-spacing:0.5px;box-shadow:0 4px 15px rgba(0, 0, 0, 0.2);animation:fadeIn 0.3s ease-out;} .availability-badge.available{ background:linear-gradient(135deg, #2e7d32, #43a047);color:white;border:1px solid rgba(255, 255, 255, 0.2);} .availability-badge.sold-out{ background:linear-gradient(135deg, #d32f2f, #f44336);color:white;border:1px solid rgba(255, 255, 255, 0.2);} .room-card.sold-out, .room-row.sold-out{ opacity:0.8;} .room-card.sold-out .room-image, .room-row.sold-out .room-image-large{ filter:grayscale(0.8) contrast(1.2);} .room-card.sold-out .btn-secondary, .room-row.sold-out .btn-primary{ background:#ccc !important;cursor:not-allowed;pointer-events:none;} @keyframes fadeIn{ from{ opacity:0;transform:translateY(-5px);} to{ opacity:1;transform:translateY(0);} }