/* ===== DESIGN TOKENS ===== */
:root {
  --clr-bg: #0f0f0f;
  --clr-surface: #1a1a1a;
  --clr-surface-alt: #242424;
  --clr-accent: #c9a96e;
  --clr-accent-light: #e2c992;
  --clr-text: #f0ece4;
  --clr-text-muted: #a8a29e;
  --clr-border: rgba(201,169,110,.18);
  --font-heading: 'Playfair Display', serif;
  --font-body: 'Inter', sans-serif;
  --radius: 16px;
  --transition: .35s cubic-bezier(.4,0,.2,1);
}

/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--clr-bg);color:var(--clr-text);line-height:1.7;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}

/* ===== UTILITY ===== */
.container{width:min(1140px,90%);margin-inline:auto}
.section-pad{padding:5rem 0}
.accent{color:var(--clr-accent)}
.text-center{text-align:center}

/* ===== TOP BAR ===== */
.topbar{background:var(--clr-accent);color:var(--clr-bg);text-align:center;padding:.5rem 1rem;font-size:.82rem;font-weight:600;letter-spacing:.03em;position:relative;display:flex;align-items:center;justify-content:center;gap:.6rem}
.topbar a{color:var(--clr-bg);text-decoration:underline}

/* ===== LANGUAGE SWITCHER ===== */
#lang-switcher{position:absolute;right:1rem;top:50%;transform:translateY(-50%);appearance:none;-webkit-appearance:none;background:rgba(0,0,0,.15);color:var(--clr-bg);border:1.5px solid rgba(0,0,0,.2);border-radius:6px;padding:.3rem 2rem .3rem .8rem;font-size:.72rem;font-weight:700;font-family:var(--font-body);cursor:pointer;outline:none;letter-spacing:.04em;text-transform:uppercase;transition:background .2s ease;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%230f0f0f'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .7rem center;background-size:10px 6px}
#lang-switcher:hover,#lang-switcher:focus{background:rgba(0,0,0,.3)}
#lang-switcher option{background:var(--clr-surface-alt);color:var(--clr-text);font-weight:500}

/* ===== NAVBAR ===== */
.navbar{position:sticky;top:0;z-index:100;background:rgba(15,15,15,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--clr-border);padding:.9rem 0;transition:var(--transition)}
.navbar .container{display:flex;align-items:center;justify-content:space-between}
.nav-brand{font-family:var(--font-heading);font-size:1.35rem;color:var(--clr-accent);letter-spacing:.04em}
.nav-links{display:flex;gap:1.8rem;list-style:none;align-items:center}
.nav-links a{font-size:.88rem;font-weight:500;color:var(--clr-text-muted);transition:color var(--transition);position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--clr-accent);transition:width var(--transition)}
.nav-links a:hover,.nav-links a:focus{color:var(--clr-accent)}
.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--clr-accent)!important;color:var(--clr-bg)!important;padding:.55rem 1.4rem;border-radius:999px;font-weight:600!important;transition:transform var(--transition),box-shadow var(--transition)}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(201,169,110,.35)}
.nav-cta::after{display:none!important}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{width:24px;height:2px;background:var(--clr-text);border-radius:2px;transition:var(--transition)}

/* ===== HERO ===== */
.hero{position:relative;height:92vh;min-height:520px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(15,15,15,.45) 0%,rgba(15,15,15,.78) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;max-width:720px;padding:0 1.5rem;animation:fadeUp .9s ease-out}
.hero-badge{display:inline-block;padding:.35rem 1rem;border:1px solid var(--clr-accent);border-radius:999px;font-size:.75rem;text-transform:uppercase;letter-spacing:.14em;color:var(--clr-accent);margin-bottom:1.2rem}
.hero h1{font-family:var(--font-heading);font-size:clamp(2.2rem,5vw,3.6rem);line-height:1.15;margin-bottom:.8rem;color:#fff}
.hero p{font-size:1.05rem;color:rgba(255,255,255,.78);max-width:540px;margin:0 auto 2rem}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 2rem;border-radius:999px;font-weight:600;font-size:.92rem;transition:transform var(--transition),box-shadow var(--transition);cursor:pointer;border:none}
.btn-primary{background:var(--clr-accent);color:var(--clr-bg)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(201,169,110,.4)}
.btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.btn-outline:hover{border-color:var(--clr-accent);color:var(--clr-accent);transform:translateY(-2px)}

/* ===== FEATURES STRIP ===== */
.features-strip{background:var(--clr-surface);border-top:1px solid var(--clr-border);border-bottom:1px solid var(--clr-border);padding:2.5rem 0}
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.feature-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.feature-icon{font-size:1.8rem}
.feature-label{font-size:.82rem;color:var(--clr-text-muted);font-weight:500}

/* ===== ABOUT ===== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.about-img{border-radius:var(--radius);overflow:hidden;position:relative}
.about-img img{transition:transform .6s ease}
.about-img:hover img{transform:scale(1.03)}
.about-tag{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--clr-accent);margin-bottom:.6rem}
.about h2{font-family:var(--font-heading);font-size:clamp(1.6rem,3vw,2.4rem);margin-bottom:1rem;line-height:1.25}
.about p{color:var(--clr-text-muted);margin-bottom:1.2rem}

/* ===== GALLERY ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.gallery-card{border-radius:var(--radius);overflow:hidden;position:relative;aspect-ratio:4/3}
.gallery-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gallery-card:hover img{transform:scale(1.06)}
.gallery-card .card-label{position:absolute;bottom:0;left:0;right:0;padding:1rem 1.2rem;background:linear-gradient(transparent,rgba(0,0,0,.7));font-size:.85rem;font-weight:500}

/* ===== AMENITIES ===== */
.amenities-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem;margin-top:2rem}
.amenity{display:flex;align-items:center;gap:.8rem;padding:1rem 1.2rem;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:12px;transition:border-color var(--transition)}
.amenity:hover{border-color:var(--clr-accent)}
.amenity-icon{font-size:1.4rem;flex-shrink:0}
.amenity-text{font-size:.9rem}

/* ===== INFO / HOURS ===== */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
.info-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius);padding:2.2rem}
.info-card h3{font-family:var(--font-heading);font-size:1.3rem;margin-bottom:1.2rem;color:var(--clr-accent)}
.info-row{display:flex;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid var(--clr-border);font-size:.9rem}
.info-row:last-child{border-bottom:none}
.info-row .label{color:var(--clr-text-muted)}

/* ===== MAP ===== */
.map-wrapper{border-radius:var(--radius);overflow:hidden;border:1px solid var(--clr-border);height:360px;margin-top:2rem}
.map-wrapper iframe{width:100%;height:100%;border:0;filter:grayscale(.3) contrast(1.1)}

/* ===== CTA SECTION ===== */
.cta-section{background:linear-gradient(135deg,var(--clr-surface) 0%,#1f1b14 100%);text-align:center;padding:5rem 0;border-top:1px solid var(--clr-border)}
.cta-section h2{font-family:var(--font-heading);font-size:clamp(1.6rem,3vw,2.4rem);margin-bottom:.8rem}
.cta-section p{color:var(--clr-text-muted);max-width:480px;margin:0 auto 2rem}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ===== FOOTER ===== */
.footer{background:var(--clr-surface);border-top:1px solid var(--clr-border);padding:3rem 0 1.5rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2.5rem;margin-bottom:2rem}
.footer h4{font-family:var(--font-heading);color:var(--clr-accent);margin-bottom:.8rem;font-size:1.05rem}
.footer p,.footer li{font-size:.85rem;color:var(--clr-text-muted);line-height:1.8}
.footer ul{list-style:none}
.footer a:hover{color:var(--clr-accent)}
.footer-bottom{text-align:center;padding-top:1.5rem;border-top:1px solid var(--clr-border);font-size:.78rem;color:var(--clr-text-muted)}

/* ===== ANIMATIONS ===== */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
  .hamburger{display:flex}
  .nav-links{position:fixed;top:0;right:-100%;width:70%;height:100vh;flex-direction:column;background:var(--clr-surface);padding:5rem 2rem 2rem;gap:1.6rem;transition:right var(--transition);box-shadow:-4px 0 30px rgba(0,0,0,.5)}
  .nav-links.open{right:0}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid,.info-grid,.footer-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .hero{height:80vh;min-height:460px}
  .topbar{flex-wrap:wrap;padding:.5rem 1rem .5rem .5rem;font-size:.75rem}
  #lang-switcher{position:static;transform:none;margin-left:auto}
}
@media(max-width:480px){
  .gallery-grid{grid-template-columns:1fr}
  .features-grid{grid-template-columns:1fr 1fr}
}
