/* ===== BASE ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
    --bg:#0f0906;
    --surface:#1a120d;
    --surface-2:#241a13;
    --border:rgba(255,200,150,0.1);
    --text:#faf5f0;
    --text-muted:#b8a99a;
    --accent:#d4442a;
    --accent-hover:#b8351f;
    --gold:#c8a45c;
    --warm-glow:rgba(212,68,42,0.08);
    --radius:8px;
    --transition:0.25s ease;
    --font-heading:'Playfair Display',Georgia,serif;
    --font-body:'Source Sans 3',-apple-system,sans-serif;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
h1,h2,h3{font-family:var(--font-heading)}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;font-size:0.9rem;font-weight:600;border-radius:var(--radius);border:1.5px solid transparent;cursor:pointer;transition:all var(--transition);font-family:var(--font-body);text-decoration:none}
.btn-sm{padding:8px 18px;font-size:0.85rem}
.btn-lg{padding:15px 32px;font-size:1rem}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 6px 20px rgba(212,68,42,0.3)}
.btn-outline-light{background:transparent;color:var(--text);border-color:rgba(255,255,255,0.3)}
.btn-outline-light:hover{border-color:#fff;background:rgba(255,255,255,0.05)}
.btn-block{width:100%;justify-content:center}

/* ===== NAV ===== */
.navbar{position:fixed;top:0;left:0;right:0;z-index:100;padding:16px 0;transition:all var(--transition);background:transparent}
.navbar.scrolled{background:rgba(15,9,6,0.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-flex{display:flex;align-items:center;justify-content:space-between}
.logo{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;letter-spacing:0.02em}
.logo em{font-style:italic;color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{font-size:0.85rem;color:var(--text-muted);transition:color var(--transition);font-weight:500}
.nav-links a:hover{color:var(--text)}
.mobile-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.mobile-toggle span{display:block;width:22px;height:2px;background:var(--text);transition:all var(--transition)}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,9,6,0.5) 0%,rgba(15,9,6,0.8) 100%);z-index:1}
.hero-img{position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1517248135467-4c7edcad34c4?w=1400&q=80') center/cover no-repeat;z-index:0}
.hero-content{position:relative;z-index:2;max-width:700px}
.hero-tag{font-size:0.8rem;text-transform:uppercase;letter-spacing:0.15em;color:var(--gold);margin-bottom:16px;font-weight:600}
.hero h1{font-size:clamp(2.5rem,6vw,4.5rem);font-weight:800;line-height:1.1;margin-bottom:20px;letter-spacing:-0.02em}
.hero-sub{font-size:clamp(0.95rem,2vw,1.15rem);color:var(--text-muted);margin-bottom:36px;line-height:1.7}
.hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ===== STATS BAR ===== */
.stats-bar{padding:40px 0;border-bottom:1px solid var(--border);background:var(--surface)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stat{padding:12px 8px;border-left:1px solid var(--border)}
.stat:first-child{border-left:none}
.stat-num{display:block;font-family:var(--font-heading);font-size:clamp(1.6rem,3vw,2rem);font-weight:800;color:var(--gold);letter-spacing:-0.02em;margin-bottom:4px}
.stat-label{font-size:0.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.08em;font-weight:500}

/* ===== REVIEWS ===== */
.reviews{padding:80px 0;background:var(--surface)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review-card{padding:28px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;gap:16px;transition:all var(--transition)}
.review-card:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 10px 30px rgba(0,0,0,0.25)}
.review-stars{color:var(--accent);font-size:1.1rem;letter-spacing:3px}
.review-text{font-size:0.95rem;color:var(--text);line-height:1.65;flex:1;font-style:italic}
.review-meta{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--border)}
.review-meta strong{display:block;font-size:0.9rem;color:var(--text);font-weight:600}
.review-meta > div span{display:block;font-size:0.75rem;color:var(--text-muted);margin-top:2px}
.review-source{font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--gold);padding:4px 10px;border:1px solid var(--gold);border-radius:999px}

/* ===== PRESS ===== */
.press{padding:32px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg)}
.press-inner{display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap}
.press-label{font-size:0.75rem;text-transform:uppercase;letter-spacing:0.15em;color:var(--gold);font-weight:700}
.press-logos{display:flex;gap:36px;flex-wrap:wrap;justify-content:center;align-items:center}
.press-logos span{font-family:var(--font-heading);font-size:1.05rem;font-weight:700;color:var(--text-muted);letter-spacing:0.02em;opacity:0.75;transition:all var(--transition);font-style:italic}
.press-logos span:hover{opacity:1;color:var(--text)}

/* ===== URGENCY ===== */
.urgency-note{display:inline-block;background:rgba(212,68,42,0.12);border:1px solid rgba(212,68,42,0.35);color:var(--accent)!important;padding:10px 16px!important;border-radius:var(--radius);font-size:0.85rem!important;font-weight:600;margin-bottom:24px!important;margin-top:-4px!important}

/* ===== HIGHLIGHTS ===== */
.highlights{padding:60px 0;border-bottom:1px solid var(--border)}
.highlights-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.highlight-card{text-align:center;padding:24px 16px}
.highlight-emoji{font-size:2rem;display:block;margin-bottom:12px}
.highlight-card h3{font-size:0.95rem;font-weight:700;margin-bottom:4px}
.highlight-card p{font-size:0.8rem;color:var(--text-muted)}

/* ===== SECTION ===== */
.section-header{text-align:center;margin-bottom:48px}
.section-tag{font-size:0.75rem;text-transform:uppercase;letter-spacing:0.15em;color:var(--gold);font-weight:600;margin-bottom:10px}
.section-header h2{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;letter-spacing:-0.02em}

/* ===== MENU ===== */
.menu{padding:80px 0}
.menu-tabs{display:flex;justify-content:center;gap:8px;margin-bottom:40px;flex-wrap:wrap}
.menu-tab{padding:10px 24px;font-size:0.85rem;font-weight:600;font-family:var(--font-body);background:var(--surface);border:1.5px solid var(--border);border-radius:999px;color:var(--text-muted);cursor:pointer;transition:all var(--transition)}
.menu-tab:hover{border-color:var(--gold);color:var(--text)}
.menu-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}
.menu-panel{display:none}
.menu-panel.active{display:block}
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.menu-item{padding:20px 24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition)}
.menu-item:hover{border-color:var(--gold);transform:translateY(-2px)}
.menu-item-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.menu-item h3{font-size:1rem;font-weight:700}
.menu-price{font-size:0.95rem;font-weight:700;color:var(--gold);white-space:nowrap}
.menu-item p{font-size:0.85rem;color:var(--text-muted);line-height:1.5}
.menu-note{text-align:center;font-size:0.85rem;color:var(--text-muted);margin-top:32px}

/* ===== ABOUT ===== */
.about{padding:80px 0}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.about-img-placeholder{aspect-ratio:4/5;background:url('https://images.unsplash.com/photo-1555396273-367ea4eb4db5?w=800&q=80') center/cover no-repeat;border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;justify-content:center;color:transparent;font-size:0.9rem;overflow:hidden}
.about-img-placeholder span{font-size:0;margin-bottom:0}
.about-img-placeholder p{font-size:0}
.about-text .section-tag{margin-bottom:10px;display:block}
.about-text h2{font-size:2rem;font-weight:800;margin-bottom:20px}
.about-text p{font-size:0.95rem;color:var(--text-muted);line-height:1.7;margin-bottom:12px}
.about-features{display:flex;gap:24px;margin-top:24px}
.about-feature strong{display:block;font-size:0.85rem;color:var(--text)}
.about-feature span{font-size:0.8rem;color:var(--text-muted)}

/* ===== GALLERY ===== */
.gallery{padding:80px 0}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:180px;gap:12px}
.gallery-item{border-radius:var(--radius);overflow:hidden}
.gallery-item.tall{grid-row:span 2}
.gallery-item.wide{grid-column:span 2}
.gallery-placeholder{width:100%;height:100%;background:var(--surface);border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:0;color:transparent;line-height:1.4;text-align:center;transition:all var(--transition);background-size:cover;background-position:center;overflow:hidden}
.gallery-item:hover .gallery-placeholder{border-color:var(--gold);transform:scale(1.05)}

/* ===== INFO ===== */
.info{padding:80px 0}
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.info-card{padding:32px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}
.info-card h3{font-size:1.1rem;font-weight:700;margin-bottom:20px;color:var(--gold)}
.hours-list{display:flex;flex-direction:column;gap:12px}
.hours-row{display:flex;justify-content:space-between;font-size:0.9rem}
.hours-row span:first-child{color:var(--text-muted)}
.hours-row span:last-child{font-weight:600}
.hours-note{font-size:0.8rem;color:var(--text-muted);margin-top:16px;font-style:italic}
.info-address{font-size:0.95rem;color:var(--text-muted);line-height:1.6;margin-bottom:16px}
.map-placeholder{aspect-ratio:16/9;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);font-size:0.85rem}
.map-placeholder span{font-size:1.5rem;margin-bottom:4px}
.contact-lines{display:flex;flex-direction:column;gap:16px}
.contact-line strong{display:block;font-size:0.75rem;text-transform:uppercase;letter-spacing:0.08em;color:var(--text-muted);margin-bottom:2px}
.contact-line a{font-size:0.95rem;transition:color var(--transition)}
.contact-line a:hover{color:var(--accent)}

/* ===== BOOKING ===== */
.booking{padding:80px 0}
.booking-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:start}
.booking-text .section-tag{display:block;margin-bottom:10px}
.booking-text h2{font-size:2rem;font-weight:800;margin-bottom:16px}
.booking-text > p{color:var(--text-muted);margin-bottom:28px;font-size:0.95rem;line-height:1.7}
.booking-info{display:flex;flex-direction:column;gap:16px}
.booking-detail strong{display:block;font-size:0.9rem;margin-bottom:2px}
.booking-detail span{font-size:0.85rem;color:var(--text-muted)}
.booking-form{padding:32px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:0.8rem;font-weight:600;color:var(--text-muted);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:11px 14px;font-size:0.9rem;font-family:var(--font-body);background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;transition:border-color var(--transition)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted);opacity:0.5}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--warm-glow)}
.form-group textarea{resize:vertical;min-height:70px}
.form-error{display:none;font-size:0.75rem;color:var(--accent);margin-top:4px}
.form-group.error input,.form-group.error select,.form-group.error textarea{border-color:var(--accent)}
.form-group.error .form-error{display:block}

/* ===== FOOTER ===== */
.footer{padding:48px 0 24px;border-top:1px solid var(--border)}
.footer-grid{display:flex;justify-content:space-between;align-items:start;flex-wrap:wrap;gap:24px;margin-bottom:32px}
.footer-logo{font-size:1.3rem}
.footer-tagline{font-size:0.85rem;color:var(--text-muted);margin-top:6px}
.footer-links,.footer-social{display:flex;gap:20px}
.footer-links a,.footer-social a{font-size:0.85rem;color:var(--text-muted);transition:color var(--transition)}
.footer-links a:hover,.footer-social a:hover{color:var(--accent)}
.footer-copy{text-align:center;font-size:0.75rem;color:var(--text-muted);opacity:0.5}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
    .nav-links{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:24px;z-index:99}
    .nav-links.open{display:flex}
    .nav-links a{font-size:1.2rem;color:var(--text)!important}
    .mobile-toggle{display:flex;z-index:101}
    .highlights-grid{grid-template-columns:1fr 1fr}
    .stats-grid{grid-template-columns:1fr 1fr;gap:12px}
    .stat{border-left:none;border-top:1px solid var(--border);padding-top:16px}
    .stat:first-child,.stat:nth-child(2){border-top:none;padding-top:12px}
    .reviews-grid{grid-template-columns:1fr}
    .press-inner{gap:16px;flex-direction:column}
    .press-logos{gap:20px}
    .menu-grid{grid-template-columns:1fr}
    .about-grid,.booking-grid{grid-template-columns:1fr}
    .info-grid{grid-template-columns:1fr}
    .gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
    .gallery-item.tall{grid-row:span 1}
    .gallery-item.wide{grid-column:span 1}
    .form-row{grid-template-columns:1fr}
    .hero-btns{flex-direction:column;align-items:center}
    .hero-btns .btn{width:100%;justify-content:center}
    .about-features{flex-direction:column;gap:12px}
    .footer-grid{flex-direction:column;align-items:center;text-align:center}
    .footer-links,.footer-social{justify-content:center}
}

@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms!important;transition-duration:0.01ms!important}}

/* ===== Floating WhatsApp Chat Button ===== */
.whatsapp-float {
    position: fixed; bottom: 24px; right: 24px; z-index: 998;
    width: 56px; height: 56px; border-radius: 50%;
    background: #25D366; display: flex; align-items: center; justify-content: center;
    box-shadow: 0 4px 16px rgba(37, 211, 102, 0.4);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    animation: whatsapp-pulse 2s infinite;
}
.whatsapp-float:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 24px rgba(37, 211, 102, 0.6);
}
.whatsapp-float::before {
    content: ''; position: absolute; inset: 0;
    border-radius: 50%; background: #25D366;
    opacity: 0.5; z-index: -1;
    animation: whatsapp-ripple 2s infinite;
}
@keyframes whatsapp-pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.05); }
}
@keyframes whatsapp-ripple {
    0% { transform: scale(1); opacity: 0.5; }
    100% { transform: scale(1.5); opacity: 0; }
}
.whatsapp-tooltip {
    position: absolute; right: 70px; top: 50%; transform: translateY(-50%);
    padding: 8px 14px; background: #333; color: #fff;
    font-size: 0.8rem; font-weight: 500; border-radius: 6px;
    white-space: nowrap; opacity: 0; pointer-events: none;
    transition: opacity 0.2s ease;
}
.whatsapp-tooltip::after {
    content: ''; position: absolute; top: 50%; right: -4px;
    transform: translateY(-50%) rotate(45deg);
    width: 8px; height: 8px; background: #333;
}
.whatsapp-float:hover .whatsapp-tooltip { opacity: 1; }
@media (max-width: 768px) {
    .whatsapp-float { bottom: 16px; right: 16px; width: 50px; height: 50px; }
    .whatsapp-float svg { width: 24px; height: 24px; }
    .whatsapp-tooltip { display: none; }
}
@media (prefers-reduced-motion: reduce) {
    .whatsapp-float, .whatsapp-float::before { animation: none; }
}
