/* ===========================================================
   NEO SUIT HOTELS — Modern luxe redesign 2026
   =========================================================== */
:root{
  --bg:#0b0f12; --bg2:#10161c; --surface:#161d24; --surface2:#1c252e;
  --line:rgba(255,255,255,.10); --line2:rgba(255,255,255,.06);
  --gold:#d8b87f; --gold2:#c19a5b; --gold-d:#8a6c3a;
  --text:#edeae3; --muted:#a7afb8; --muted2:#7f8893;
  --wa:#25d366; --wa-d:#1da851;
  --rad:18px; --rad-lg:26px; --rad-sm:12px;
  --shadow:0 24px 60px -20px rgba(0,0,0,.65);
  --maxw:1200px;
  --serif:'Fraunces',Georgia,serif; --sans:'Manrope',system-ui,-apple-system,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans); background:var(--bg); color:var(--text);
  line-height:1.6; font-size:16px; letter-spacing:.1px;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img,video{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer; border:0; background:none; color:inherit}
h1,h2,h3{font-family:var(--serif); font-weight:500; line-height:1.08; letter-spacing:-.5px}
em{font-style:italic; color:var(--gold)}
::selection{background:var(--gold); color:#1a1205}
.skip-link{position:absolute; left:-999px; top:0; background:var(--gold); color:#000; padding:10px 16px; z-index:999}
.skip-link:focus{left:8px; top:8px; border-radius:8px}

/* ---------- layout helpers ---------- */
.section{max-width:var(--maxw); margin:0 auto; padding:clamp(64px,9vw,120px) clamp(20px,5vw,40px)}
.section-head{max-width:680px; margin-bottom:clamp(36px,5vw,60px)}
.section-head.compact{margin-bottom:32px}
.kicker{display:inline-flex; align-items:center; gap:9px; font-family:var(--sans);
  font-size:12.5px; font-weight:700; letter-spacing:2.4px; text-transform:uppercase;
  color:var(--gold); margin-bottom:18px}
.kicker .dot{width:7px; height:7px; border-radius:50%; background:var(--gold); box-shadow:0 0 0 4px rgba(216,184,127,.18)}
h2{font-size:clamp(1.9rem,4.4vw,3.1rem)}
.section-head p{color:var(--muted); font-size:clamp(1rem,1.4vw,1.12rem); margin-top:16px}

/* ---------- buttons ---------- */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:13px 24px; border-radius:100px; font-weight:700; font-size:15px;
  letter-spacing:.2px; transition:transform .25s cubic-bezier(.2,.7,.3,1), box-shadow .25s, background .25s, color .25s;
  white-space:nowrap; will-change:transform}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-primary{background:linear-gradient(135deg,var(--gold) 0%,var(--gold2) 100%); color:#1a1205; box-shadow:0 14px 30px -12px rgba(216,184,127,.6)}
.btn-primary:hover{transform:translateY(-2px); box-shadow:0 20px 40px -12px rgba(216,184,127,.75)}
.btn-ghost{border:1px solid var(--line); color:var(--text); background:rgba(255,255,255,.02)}
.btn-ghost:hover{border-color:var(--gold); color:var(--gold)}
.btn-glass{background:rgba(255,255,255,.1); backdrop-filter:blur(10px); border:1px solid rgba(255,255,255,.22); color:#fff}
.btn-glass:hover{background:rgba(255,255,255,.18)}
.btn-white{background:#fff; color:#13181d}
.btn-dark{background:#14191e; border:1px solid var(--line); color:var(--text)}
.btn-dark:hover{border-color:var(--gold); color:var(--gold)}
.btn-xl{padding:16px 30px; font-size:16px}

/* ---------- header ---------- */
.site-header{position:sticky; top:0; z-index:100; display:flex; align-items:center; justify-content:space-between;
  gap:18px; padding:14px clamp(16px,4vw,40px);
  background:rgba(11,15,18,.55); backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid transparent; transition:background .3s, border-color .3s, padding .3s}
.site-header.scrolled{background:rgba(9,12,15,.9); border-bottom-color:var(--line2); padding-top:10px; padding-bottom:10px}
.brand img{height:54px; width:auto; transition:height .3s}
.site-header.scrolled .brand img{height:46px}
.desktop-nav{display:flex; gap:30px; margin-left:auto; margin-right:8px}
.desktop-nav a{font-size:14.5px; font-weight:600; color:var(--muted); position:relative; padding:6px 0}
.desktop-nav a::after{content:""; position:absolute; left:0; bottom:0; width:0; height:2px; background:var(--gold); transition:width .3s}
.desktop-nav a:hover{color:var(--text)}
.desktop-nav a:hover::after{width:100%}
.header-actions{display:flex; align-items:center; gap:10px}
.language-select{background:rgba(255,255,255,.05); color:var(--text); border:1px solid var(--line);
  border-radius:100px; padding:8px 10px; font-size:13px; font-weight:600; cursor:pointer}
.language-select option{background:#12171c}
.translate-box{display:none}
.header-actions .btn{padding:10px 18px; font-size:14px}
.nav-toggle{display:none; flex-direction:column; gap:5px; padding:8px}
.nav-toggle span{width:22px; height:2px; background:var(--text); border-radius:2px; transition:.3s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile drawer */
.mobile-drawer{position:fixed; inset:0 0 0 auto; width:min(82vw,340px); z-index:99;
  background:rgba(13,18,23,.97); backdrop-filter:blur(20px); border-left:1px solid var(--line);
  display:flex; flex-direction:column; gap:6px; padding:96px 26px 30px;
  transform:translateX(105%); transition:transform .4s cubic-bezier(.2,.7,.3,1); visibility:hidden}
.mobile-drawer.open{transform:none; visibility:visible}
.mobile-drawer a{font-family:var(--serif); font-size:22px; padding:12px 0; border-bottom:1px solid var(--line2); color:var(--text)}
.drawer-actions{display:flex; flex-direction:column; gap:10px; margin-top:20px}
.drawer-actions .btn{width:100%}

/* ---------- hero ---------- */
.hero{position:relative; min-height:100svh; display:flex; flex-direction:column; justify-content:center;
  padding:clamp(90px,14vh,150px) clamp(20px,5vw,40px) 70px; overflow:hidden; isolation:isolate}
.hero-media{position:absolute; inset:0; z-index:-1}
.hero-video,.hero-fallback{position:absolute; inset:0; width:100%; height:100%; object-fit:cover}
.hero-fallback{z-index:-1}
.hero-scrim{position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(8,11,14,.55) 0%,rgba(8,11,14,.35) 35%,rgba(8,11,14,.8) 78%,var(--bg) 100%),
             radial-gradient(120% 80% at 18% 30%,rgba(8,11,14,.25),rgba(8,11,14,.85))}
.hero-inner{max-width:var(--maxw); width:100%; margin:0 auto; display:grid;
  grid-template-columns:1.15fr .85fr; gap:clamp(28px,5vw,64px); align-items:center}
.hero-copy{max-width:640px}
.hero-copy h1{font-size:clamp(2.6rem,6.4vw,5rem); margin:6px 0 20px}
.hero-copy .lead{color:rgba(237,234,227,.82); font-size:clamp(1.02rem,1.5vw,1.22rem); max-width:540px}
.hero-actions{display:flex; flex-wrap:wrap; gap:14px; margin:32px 0 36px}
.hero-stats{display:flex; gap:clamp(20px,4vw,42px); list-style:none; flex-wrap:wrap}
.hero-stats li{display:flex; flex-direction:column}
.hero-stats strong{font-family:var(--serif); font-size:clamp(1.5rem,2.6vw,2rem); color:var(--gold)}
.hero-stats span{font-size:12.5px; color:var(--muted); letter-spacing:.6px; text-transform:uppercase}

/* booking console */
.booking-console{background:linear-gradient(180deg,rgba(28,37,46,.86),rgba(18,24,30,.92));
  backdrop-filter:blur(18px); border:1px solid rgba(255,255,255,.12); border-radius:var(--rad-lg);
  padding:24px; box-shadow:var(--shadow)}
.console-top{display:flex; align-items:center; gap:10px; font-size:13.5px; font-weight:600; color:var(--muted); margin-bottom:18px}
.live-dot{width:9px; height:9px; border-radius:50%; background:var(--wa); box-shadow:0 0 0 0 rgba(37,211,102,.5); animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 10px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
.reservation-form{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.reservation-form label{display:flex; flex-direction:column; gap:6px; font-size:12px; font-weight:600; color:var(--muted2); letter-spacing:.4px}
.reservation-form input,.reservation-form select{background:rgba(255,255,255,.04); border:1px solid var(--line);
  border-radius:var(--rad-sm); padding:12px; color:var(--text); font-family:inherit; font-size:14px; font-weight:600}
.reservation-form input:focus,.reservation-form select:focus{outline:none; border-color:var(--gold)}
.reservation-form select option{background:#12171c}
.console-cta{grid-column:1 / -1; width:100%; margin-top:4px}
.console-phone{display:block; text-align:center; margin-top:14px; font-weight:700; font-size:18px; color:var(--gold); letter-spacing:.5px}

.scroll-hint{position:absolute; bottom:22px; left:50%; transform:translateX(-50%); width:26px; height:42px;
  border:2px solid rgba(255,255,255,.35); border-radius:14px; display:flex; justify-content:center; padding-top:8px}
.scroll-hint span{width:4px; height:8px; border-radius:2px; background:var(--gold); animation:scrolldot 1.8s infinite}
@keyframes scrolldot{0%{opacity:0; transform:translateY(-4px)}40%{opacity:1}80%{opacity:0; transform:translateY(10px)}}

/* ---------- feature strip ---------- */
.feature-strip{max-width:var(--maxw); margin:0 auto; padding:26px clamp(20px,5vw,40px);
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px; border-bottom:1px solid var(--line2)}
.feature-strip div{display:flex; align-items:center; gap:12px; font-size:14px; font-weight:600; color:var(--muted)}
.feature-strip i{flex:0 0 auto; width:26px; height:26px; background:var(--gold); -webkit-mask-size:contain; mask-size:contain; -webkit-mask-repeat:no-repeat; mask-repeat:no-repeat; -webkit-mask-position:center; mask-position:center}

/* ---------- icons (mask) ---------- */
[data-ico]{display:inline-block; width:1em; height:1em; background:currentColor;
  -webkit-mask-repeat:no-repeat; mask-repeat:no-repeat; -webkit-mask-position:center; mask-position:center; -webkit-mask-size:contain; mask-size:contain}
i[data-ico="phone"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.6 10.8c1.4 2.8 3.8 5.2 6.6 6.6l2.2-2.2c.3-.3.7-.4 1-.2 1.2.4 2.4.6 3.6.6.6 0 1 .4 1 1V20c0 .6-.4 1-1 1C10.6 21 3 13.4 3 4c0-.6.4-1 1-1h3.4c.6 0 1 .4 1 1 0 1.3.2 2.5.6 3.6.1.4 0 .8-.3 1z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.6 10.8c1.4 2.8 3.8 5.2 6.6 6.6l2.2-2.2c.3-.3.7-.4 1-.2 1.2.4 2.4.6 3.6.6.6 0 1 .4 1 1V20c0 .6-.4 1-1 1C10.6 21 3 13.4 3 4c0-.6.4-1 1-1h3.4c.6 0 1 .4 1 1 0 1.3.2 2.5.6 3.6.1.4 0 .8-.3 1z'/%3E%3C/svg%3E")}
i[data-ico="wa"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2a10 10 0 0 0-8.5 15.2L2 22l4.9-1.5A10 10 0 1 0 12 2m0 18a8 8 0 0 1-4.2-1.2l-.3-.2-2.9.9.9-2.8-.2-.3A8 8 0 1 1 12 20m4.4-5.6c-.2-.1-1.4-.7-1.6-.8s-.4-.1-.6.1-.6.8-.8 1-.3.2-.5.1a6.5 6.5 0 0 1-3.2-2.8c-.2-.4.2-.4.6-1.2.1-.2 0-.4 0-.5s-.6-1.4-.8-2-.4-.4-.6-.4h-.5a1 1 0 0 0-.7.3A3 3 0 0 0 6 8.3a5.2 5.2 0 0 0 1.1 2.7 11.8 11.8 0 0 0 4.6 4c2.7 1.2 2.7.8 3.2.7a2.6 2.6 0 0 0 1.7-1.2 2.1 2.1 0 0 0 .1-1.2c0-.1-.2-.2-.4-.3'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2a10 10 0 0 0-8.5 15.2L2 22l4.9-1.5A10 10 0 1 0 12 2m0 18a8 8 0 0 1-4.2-1.2l-.3-.2-2.9.9.9-2.8-.2-.3A8 8 0 1 1 12 20m4.4-5.6c-.2-.1-1.4-.7-1.6-.8s-.4-.1-.6.1-.6.8-.8 1-.3.2-.5.1a6.5 6.5 0 0 1-3.2-2.8c-.2-.4.2-.4.6-1.2.1-.2 0-.4 0-.5s-.6-1.4-.8-2-.4-.4-.6-.4h-.5a1 1 0 0 0-.7.3A3 3 0 0 0 6 8.3a5.2 5.2 0 0 0 1.1 2.7 11.8 11.8 0 0 0 4.6 4c2.7 1.2 2.7.8 3.2.7a2.6 2.6 0 0 0 1.7-1.2 2.1 2.1 0 0 0 .1-1.2c0-.1-.2-.2-.4-.3'/%3E%3C/svg%3E")}
i[data-ico="wifi"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 18a2 2 0 1 0 0 4 2 2 0 0 0 0-4M5 12.5l2 2a7 7 0 0 1 10 0l2-2a10 10 0 0 0-14 0M1.5 9l2 2a12 12 0 0 1 17 0l2-2a15 15 0 0 0-21 0'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 18a2 2 0 1 0 0 4 2 2 0 0 0 0-4M5 12.5l2 2a7 7 0 0 1 10 0l2-2a10 10 0 0 0-14 0M1.5 9l2 2a12 12 0 0 1 17 0l2-2a15 15 0 0 0-21 0'/%3E%3C/svg%3E")}
i[data-ico="key"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M14 2a6 6 0 0 0-5.8 7.5L2 15.7V22h6v-2h2v-2h2l1.5-1.5A6 6 0 1 0 14 2m2.5 5A1.5 1.5 0 1 1 18 5.5 1.5 1.5 0 0 1 16.5 7'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M14 2a6 6 0 0 0-5.8 7.5L2 15.7V22h6v-2h2v-2h2l1.5-1.5A6 6 0 1 0 14 2m2.5 5A1.5 1.5 0 1 1 18 5.5 1.5 1.5 0 0 1 16.5 7'/%3E%3C/svg%3E")}
i[data-ico="pin"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2a7 7 0 0 0-7 7c0 5 7 13 7 13s7-8 7-13a7 7 0 0 0-7-7m0 9.5A2.5 2.5 0 1 1 12 6.5a2.5 2.5 0 0 1 0 5'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2a7 7 0 0 0-7 7c0 5 7 13 7 13s7-8 7-13a7 7 0 0 0-7-7m0 9.5A2.5 2.5 0 1 1 12 6.5a2.5 2.5 0 0 1 0 5'/%3E%3C/svg%3E")}
i[data-ico="spark"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2l1.8 5.4L19 9.2l-4.6 3.3L16 18l-4-3.2L8 18l1.6-5.5L5 9.2l5.2-1.8z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2l1.8 5.4L19 9.2l-4.6 3.3L16 18l-4-3.2L8 18l1.6-5.5L5 9.2l5.2-1.8z'/%3E%3C/svg%3E")}

/* ---------- suites ---------- */
.suite-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
.suite-card{background:var(--surface); border:1px solid var(--line2); border-radius:var(--rad-lg); overflow:hidden;
  transition:transform .4s cubic-bezier(.2,.7,.3,1), border-color .4s, box-shadow .4s}
.suite-card:hover{transform:translateY(-8px); border-color:rgba(216,184,127,.4); box-shadow:var(--shadow)}
.suite-card.feature{border-color:rgba(216,184,127,.35)}
.suite-img{position:relative; aspect-ratio:4/3; overflow:hidden}
.suite-img img{width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.3,1)}
.suite-card:hover .suite-img img{transform:scale(1.07)}
.badge{position:absolute; top:14px; left:14px; background:var(--gold); color:#1a1205; font-size:11.5px; font-weight:800;
  letter-spacing:.5px; padding:6px 12px; border-radius:100px; text-transform:uppercase}
.suite-body{padding:24px}
.suite-no{font-family:var(--serif); font-size:14px; color:var(--gold-d)}
.suite-body h3{font-size:1.5rem; margin:4px 0 10px}
.suite-body p{color:var(--muted); font-size:14.5px}
.suite-cta{display:inline-block; margin-top:16px; color:var(--gold); font-weight:700; font-size:14px; transition:gap .3s}
.suite-cta:hover{letter-spacing:.3px}

/* ---------- experience ---------- */
.experience{display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,70px); align-items:center}
.experience-media{border-radius:var(--rad-lg); overflow:hidden; aspect-ratio:4/4.4; box-shadow:var(--shadow)}
.experience-media img{width:100%; height:100%; object-fit:cover}
.flow-list{display:flex; flex-direction:column; gap:22px; margin:30px 0}
.flow-step{display:flex; gap:18px; align-items:flex-start}
.flow-step span{flex:0 0 auto; width:42px; height:42px; border-radius:50%; display:grid; place-items:center;
  font-family:var(--serif); font-size:18px; color:var(--gold); border:1px solid rgba(216,184,127,.4); background:rgba(216,184,127,.06)}
.flow-step strong{display:block; font-size:17px; margin-bottom:3px}
.flow-step p{color:var(--muted); font-size:14.5px}

/* ---------- gallery masonry ---------- */
.masonry{columns:4; column-gap:16px}
.masonry .ph{break-inside:avoid; margin-bottom:16px; width:100%; border-radius:var(--rad); overflow:hidden; display:block; position:relative}
.masonry .ph img{width:100%; height:auto; transition:transform .6s, filter .4s; display:block}
.masonry .ph:hover img{transform:scale(1.05); filter:brightness(1.05)}
.masonry .ph::after{content:"⤢"; position:absolute; inset:0; display:grid; place-items:center; font-size:24px; color:#fff;
  background:rgba(11,15,18,.4); opacity:0; transition:.3s}
.masonry .ph:hover::after{opacity:1}

/* lightbox */
.lightbox{position:fixed; inset:0; z-index:200; background:rgba(7,9,12,.94); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center; padding:30px; opacity:0; visibility:hidden; transition:opacity .3s}
.lightbox.open{opacity:1; visibility:visible}
.lightbox img{max-width:92vw; max-height:88vh; border-radius:14px; box-shadow:var(--shadow)}
.lb-close{position:absolute; top:22px; right:26px; font-size:26px; color:#fff; width:46px; height:46px; border-radius:50%; background:rgba(255,255,255,.1)}

/* ---------- video tour ---------- */
.video-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.video-card{background:var(--surface); border:1px solid var(--line2); border-radius:var(--rad); overflow:hidden}
.video-card video{width:100%; aspect-ratio:9/16; object-fit:cover; background:#000}
.video-card figcaption{padding:13px 15px; font-size:13px; color:var(--muted)}

/* ---------- zones ---------- */
.zones{display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,60px); align-items:center}
.zone-chips{display:flex; flex-wrap:wrap; gap:10px}
.zone-chips span{padding:10px 16px; border-radius:100px; border:1px solid var(--line); background:rgba(255,255,255,.02);
  font-size:13.5px; font-weight:600; color:var(--muted)}
.zone-chips span.primary{background:var(--gold); color:#1a1205; border-color:var(--gold)}
.map-link{margin-top:26px}

/* ---------- seo content ---------- */
.seo-content h2{max-width:760px}
.seo-columns{columns:2; column-gap:46px; margin-top:26px}
.seo-columns p{color:var(--muted); font-size:14.5px; margin-bottom:16px; break-inside:avoid}

/* ---------- keyword grid ---------- */
.keyword-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.keyword-grid article{background:var(--surface); border:1px solid var(--line2); border-radius:var(--rad); padding:24px; transition:.35s}
.keyword-grid article:hover{border-color:rgba(216,184,127,.35); transform:translateY(-5px)}
.keyword-grid span{font-size:12px; font-weight:700; letter-spacing:.8px; text-transform:uppercase; color:var(--gold)}
.keyword-grid h3{font-size:1.18rem; margin:12px 0 8px}
.keyword-grid p{color:var(--muted); font-size:13.5px}

/* ---------- faq ---------- */
.faq-list{display:flex; flex-direction:column; gap:12px; max-width:840px}
.faq-list details{background:var(--surface); border:1px solid var(--line2); border-radius:var(--rad); padding:4px 22px; transition:border-color .3s}
.faq-list details[open]{border-color:rgba(216,184,127,.35)}
.faq-list summary{list-style:none; cursor:pointer; padding:18px 0; font-weight:700; font-size:16px; display:flex; justify-content:space-between; align-items:center; gap:16px}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+"; font-size:24px; color:var(--gold); transition:transform .3s; line-height:1}
.faq-list details[open] summary::after{transform:rotate(45deg)}
.faq-list p{color:var(--muted); padding-bottom:20px; font-size:14.5px}

/* ---------- reviews ---------- */
.review-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.review-card{background:var(--surface); border:1px solid var(--line2); border-radius:var(--rad); padding:26px}
.review-card .stars{color:var(--gold); letter-spacing:3px; margin-bottom:14px; font-size:14px}
.review-card blockquote{font-family:var(--serif); font-size:1.15rem; line-height:1.4; margin-bottom:16px}
.review-card figcaption{font-size:13px; color:var(--muted2); font-weight:600}

/* ---------- final cta ---------- */
.final-cta{padding:clamp(20px,5vw,40px)}
.final-cta-inner{max-width:var(--maxw); margin:0 auto; background:
   radial-gradient(120% 140% at 0% 0%,rgba(216,184,127,.16),transparent 55%), linear-gradient(180deg,var(--surface2),var(--surface));
  border:1px solid rgba(216,184,127,.22); border-radius:var(--rad-lg); padding:clamp(34px,5vw,64px);
  display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center}
.final-copy h2{font-size:clamp(1.8rem,3.6vw,2.7rem)}
.final-copy p{color:var(--muted); margin-top:14px}
.contact-actions{display:flex; flex-direction:column; gap:12px}
.contact-tile{display:flex; flex-direction:column; gap:3px; background:rgba(255,255,255,.03); border:1px solid var(--line);
  border-radius:var(--rad); padding:18px 22px; transition:.3s}
.contact-tile:hover{border-color:var(--gold); transform:translateX(4px)}
.contact-tile span{font-size:12.5px; color:var(--muted2); letter-spacing:.6px; text-transform:uppercase}
.contact-tile strong{font-size:19px; font-family:var(--serif)}
.contact-tile.whatsapp{background:linear-gradient(135deg,rgba(37,211,102,.16),rgba(37,211,102,.05)); border-color:rgba(37,211,102,.4)}
.contact-tile.whatsapp strong{color:var(--wa)}

/* ---------- footer ---------- */
.site-footer{text-align:center; padding:50px 20px 120px; border-top:1px solid var(--line2)}
.site-footer img{margin:0 auto 16px; opacity:.85}
.site-footer p{color:var(--muted2); font-size:13.5px}
.footer-nav{display:flex; gap:22px; justify-content:center; margin-top:18px}
.footer-nav a{font-size:13.5px; color:var(--muted); font-weight:600}
.footer-nav a:hover{color:var(--gold)}
.powered-by{display:inline-flex; align-items:center; justify-content:center; gap:8px; margin-top:18px; color:var(--muted); font-size:13.5px; font-weight:700}
.powered-by img{height:18px; width:auto; margin:0}

/* ---------- sticky mobile bar + desktop float ---------- */
.mobile-action-bar{display:none; position:fixed; left:0; right:0; bottom:0; z-index:90;
  background:rgba(10,14,18,.92); backdrop-filter:blur(14px); border-top:1px solid var(--line);
  padding:10px 12px calc(10px + env(safe-area-inset-bottom)); gap:10px}
.mobile-action-bar a{flex:1; display:flex; align-items:center; justify-content:center; gap:8px;
  padding:14px; border-radius:var(--rad-sm); font-weight:700; font-size:15px}
.mab-call{background:rgba(255,255,255,.08); color:var(--text)}
.mab-wa{background:linear-gradient(135deg,var(--wa),var(--wa-d)); color:#fff}

.desktop-float{position:fixed; right:22px; bottom:24px; z-index:80; display:flex; flex-direction:column; gap:12px}
.desktop-float a{width:56px; height:56px; border-radius:50%; display:grid; place-items:center; font-size:24px; box-shadow:var(--shadow); transition:transform .3s}
.desktop-float a:hover{transform:scale(1.1)}
.float-wa{background:linear-gradient(135deg,var(--wa),var(--wa-d)); color:#fff}
.float-call{background:#1a2128; color:var(--gold); border:1px solid var(--line)}

/* ---------- reveal ---------- */
.reveal{opacity:0; transform:translateY(28px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1; transform:none}

/* ---------- responsive ---------- */
@media (max-width:1024px){
  .hero-inner{grid-template-columns:1fr; gap:34px}
  .booking-console{max-width:440px}
  .masonry{columns:3}
  .video-grid,.keyword-grid,.review-grid{grid-template-columns:repeat(2,1fr)}
  .feature-strip{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .desktop-nav{display:none}
  .nav-toggle{display:flex}
  .header-actions .btn-ghost{display:none}
  .language-select{display:none}
  .suite-grid{grid-template-columns:1fr; max-width:440px; margin:0 auto}
  .experience,.zones,.final-cta-inner{grid-template-columns:1fr}
  .experience-media{aspect-ratio:16/11}
  .seo-columns{columns:1}
  .masonry{columns:2}
  .mobile-action-bar{display:flex}
  .desktop-float{display:none}
  .site-footer{padding-bottom:96px}
  .hero{min-height:auto; padding-bottom:50px}
}
@media (max-width:520px){
  .reservation-form{grid-template-columns:1fr 1fr}
  .video-grid,.keyword-grid,.review-grid{grid-template-columns:1fr}
  .masonry{columns:1}
  .hero-copy h1{font-size:clamp(2.3rem,9vw,3rem)}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important; scroll-behavior:auto!important}
  .reveal{opacity:1; transform:none; transition:none}
}
