*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --bg:#0d1117;--bg2:#111827;--bg3:#161d2b;--surface:#1e2a3a;
  --accent:#d4a847;--accent2:#a07020;--ink:#e8edf5;--muted:#6b7a94;--faint:#3d4f68;
  --border:rgba(255,255,255,.07);--r:10px;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:'DM Sans',system-ui,sans-serif;font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
.container{max-width:1160px;margin:0 auto;padding:0 24px}
.section{padding:96px 0}.section-sm{padding:64px 0}
.display{font-family:'Playfair Display',Georgia,serif;font-weight:600;line-height:1.15;color:var(--ink)}
.display-xl{font-size:clamp(42px,6vw,80px)}.display-lg{font-size:clamp(32px,4vw,52px)}.display-md{font-size:clamp(26px,3vw,38px)}
.accent-text{color:var(--accent)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:var(--r);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:500;text-decoration:none;cursor:pointer;border:none;transition:all .2s ease}
.btn-primary{background:var(--accent);color:#0d1117}.btn-primary:hover{background:var(--accent2)}
.btn-outline{background:transparent;border:1px solid rgba(212,168,71,.4);color:var(--accent)}.btn-outline:hover{background:rgba(212,168,71,.08)}
.gold-line{display:block;width:48px;height:2px;background:var(--accent);margin:16px 0 24px}
.gold-line.center{margin-left:auto;margin-right:auto}

/* ── HEADER ── */
#header{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 24px;transition:background .3s,box-shadow .3s}
#header.scrolled,
#header.site-header,
.site-header{background:rgba(13,17,23,.95);backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(255,255,255,.06)}
.site-header{position:sticky;top:0;left:0;right:0;z-index:100;padding:0 24px}
.header-inner{max-width:1160px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:10px;font-family:'Playfair Display',serif;font-size:22px;font-weight:600;color:var(--accent);text-decoration:none}
.logo svg{flex-shrink:0}
.logo-sub{display:block;font-family:'DM Sans',sans-serif;font-size:10px;font-weight:400;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-top:1px}
nav{display:flex;align-items:center;gap:36px}
nav a{font-size:14px;color:rgba(232,237,245,.7);text-decoration:none;transition:color .15s}
nav a:hover{color:var(--ink)}
.nav-cta{padding:10px 24px!important;background:var(--accent)!important;color:#0d1117!important;border-radius:var(--r);font-weight:500}
.nav-cta:hover{background:var(--accent2)!important;color:#0d1117!important}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.burger span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px;transition:all .25s}
.mobile-nav{display:none;flex-direction:column;gap:4px;padding:16px 24px 20px;background:rgba(13,17,23,.98);border-top:1px solid var(--border)}
.mobile-nav a{display:block;padding:12px 0;font-size:16px;color:var(--muted);text-decoration:none;border-bottom:1px solid var(--border)}
.mobile-nav a:last-child{border-bottom:none}
.mobile-nav.open{display:flex}
/* Lang row inside mobile nav */
.mobile-nav-langs{display:flex;gap:8px;flex-wrap:wrap;padding:12px 0;border-bottom:1px solid var(--border)}
.mnl-opt{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:20px;border:1px solid var(--border);font-size:12px;font-weight:600;color:var(--muted);text-decoration:none;transition:all .15s}
.mnl-opt:hover{border-color:rgba(212,168,71,.4);color:var(--accent)}
.mnl-opt.active{background:rgba(212,168,71,.1);border-color:rgba(212,168,71,.4);color:var(--accent)}
.nav-active{color:var(--ink)!important}

/* ── HERO ── */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{
  position:absolute;
  inset:0;
  /* background-image задаётся inline через PHP (CSS-переменная --banner) */
  background-image:var(--hero-banner-avif, var(--hero-banner-webp, var(--hero-banner-png)));
  background-position:center;
  background-size:cover;
  background-repeat:no-repeat;
}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(13,17,23,.92) 0%,rgba(13,17,23,.7) 50%,rgba(13,17,23,.4) 100%)}
.hero-content{position:relative;z-index:1;max-width:680px;padding-top:72px}
.hero-label{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:24px}
.hero-label::before{content:'';display:block;width:32px;height:1px;background:var(--accent)}
.hero-content h1{margin-bottom:20px}
.hero-content p{font-size:18px;color:rgba(232,237,245,.75);max-width:520px;margin-bottom:40px}
.hero-btns{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.scroll-hint{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);z-index:1}
.scroll-hint::after{content:'';display:block;width:1px;height:40px;background:linear-gradient(to bottom,var(--muted),transparent)}

/* ── BOOKING STRIP ── */
.booking-strip{background:var(--bg2);border-top:1px solid var(--border);position:relative}
.booking-strip .container{position:relative}
.booking-form{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:0;position:relative}
.booking-field{padding:24px 28px;border-right:1px solid var(--border);cursor:pointer;position:relative;transition:background .15s}
.booking-field:last-child{border-right:none;padding:20px 24px}
.booking-field label{display:block;font-size:10px;font-weight:600;letter-spacing:.10em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;pointer-events:none}
.booking-field-value{font-size:15px;color:var(--ink);pointer-events:none}
.booking-field-value.ph{color:var(--faint)}
.book-btn{width:100%;height:100%;background:var(--accent);color:#0d1117;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;padding:24px 40px;transition:background .2s;white-space:nowrap}
.book-btn:hover{background:var(--accent2)}

/* ── DATE PICKER ── */
/* dp-popup is outside the grid, anchored to .container (position:relative) */
.dp-popup{display:none;position:absolute;top:calc(100% + 4px);left:0;z-index:500;background:var(--surface);border:1px solid rgba(212,168,71,.3);border-radius:14px;padding:24px;min-width:640px;box-shadow:0 24px 64px rgba(0,0,0,.6)}
.dp-popup.open{display:block}
.dp-hint{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);text-align:center;margin-bottom:16px}
.dp-months{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.dp-month-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.dp-month-title{font-family:'Playfair Display',serif;font-size:15px;color:var(--ink)}
.dp-nav-btn{background:none;border:1px solid rgba(255,255,255,.1);color:var(--muted);cursor:pointer;font-size:16px;padding:3px 10px;border-radius:6px;line-height:1.4;transition:all .15s}
.dp-nav-btn:hover{color:var(--accent);border-color:rgba(212,168,71,.4)}
.dp-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px}
.dp-wd{text-align:center;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);padding:4px 0}
.dp-days{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}
.dp-day{text-align:center;padding:9px 2px;font-size:13px;color:var(--ink);border-radius:6px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s,color .1s}
.dp-day:hover{background:rgba(212,168,71,.18);color:var(--accent)}
.dp-day-disabled{color:var(--faint)!important;cursor:default!important;pointer-events:none}
.dp-day-start,.dp-day-end{background:var(--accent)!important;color:#0d1117!important;font-weight:700}
.dp-day-range{background:rgba(212,168,71,.15);color:var(--accent);border-radius:0}
.dp-footer{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}
.dp-nights{font-size:13px;color:var(--muted)}
.dp-nights strong{color:var(--accent)}
.dp-clear-btn{background:none;border:none;font-size:13px;color:var(--muted);cursor:pointer;padding:0;font-family:'DM Sans',sans-serif;transition:color .15s}
.dp-clear-btn:hover{color:var(--accent)}

/* ── GUEST PICKER ── */
.gp-popup{display:none;position:absolute;top:calc(100% + 4px);left:0;z-index:500;background:var(--surface);border:1px solid rgba(212,168,71,.3);border-radius:14px;padding:20px 24px;min-width:200px;box-shadow:0 24px 64px rgba(0,0,0,.6)}
.gp-popup.open{display:block}
.gp-row{display:flex;align-items:center;justify-content:space-between;gap:20px}
.gp-label{font-size:14px;color:var(--ink)}
.gp-ctrl{display:flex;align-items:center;gap:14px}
.gp-btn{width:32px;height:32px;border-radius:50%;border:1px solid rgba(212,168,71,.4);background:none;color:var(--accent);font-size:20px;cursor:pointer;line-height:1;transition:background .15s}
.gp-btn:hover{background:rgba(212,168,71,.1)}
.gp-count{font-size:16px;font-weight:600;color:var(--ink);min-width:18px;text-align:center}

/* ── RESULTS ── */
#results-section{display:none;background:var(--bg3);border-top:1px solid var(--border);padding:48px 0}
.results-header{margin-bottom:32px}
.results-header h2{font-family:'Playfair Display',serif;font-size:28px;font-weight:600;color:var(--ink);margin-bottom:6px}
.results-header p{color:var(--muted);font-size:15px}
.results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}
.result-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:border-color .2s}
.result-card-img{width:100%;height:180px;object-fit:cover;display:block;border-bottom:1px solid var(--border)}
.result-card-img-placeholder{width:100%;height:140px;background:var(--bg3);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border)}
.result-card:hover{border-color:rgba(212,168,71,.35)}
.result-card-body{padding:24px}
.result-type{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.result-name{font-family:'Playfair Display',serif;font-size:20px;font-weight:500;color:var(--ink);margin-bottom:12px}
.result-amenities{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.result-amenity{font-size:11px;padding:3px 8px;background:rgba(255,255,255,.05);border-radius:4px;color:var(--muted)}
.result-price-row{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:16px;padding-top:12px;border-top:1px solid var(--border)}
.result-price-main{font-family:'Playfair Display',serif;font-size:28px;font-weight:600;color:var(--accent);line-height:1}
.result-price-sub{font-size:12px;color:var(--muted);margin-top:3px}
.result-total{font-size:13px;color:var(--muted);text-align:right}
.result-total strong{display:block;font-size:16px;font-weight:600;color:var(--ink)}
.result-book-btn{width:100%;padding:12px;background:var(--accent);color:#0d1117;border:none;border-radius:var(--r);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}
.result-book-btn:hover{background:var(--accent2)}
.no-results{text-align:center;padding:48px 24px;color:var(--muted)}
.no-results svg{margin:0 auto 16px;display:block;opacity:.4}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.6);align-items:center;justify-content:center;padding:16px}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:32px;width:100%;max-width:440px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}
.modal-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:500;color:var(--ink)}
.modal-sub{font-size:13px;color:var(--muted);margin-top:3px}
.modal-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:24px;line-height:1;padding:0;flex-shrink:0}
.modal-form{display:flex;flex-direction:column;gap:14px}
.modal-field label{display:block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:5px}
.modal-field input{width:100%;background:var(--bg2);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:10px 14px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ink);outline:none;transition:border-color .15s}
.modal-field input:focus{border-color:var(--accent)}
.modal-field input::placeholder{color:var(--faint)}
.modal-summary{background:var(--bg2);border-radius:8px;padding:14px 16px;margin-bottom:4px;font-size:13px;color:var(--muted);line-height:1.7}
.modal-summary strong{color:var(--ink)}
.modal-submit{width:100%;padding:13px;background:var(--accent);color:#0d1117;border:none;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:4px}
.modal-submit:hover{background:var(--accent2)}
.modal-submit:disabled{opacity:.5;cursor:not-allowed}
.modal-success{text-align:center;padding:24px 0}
.modal-success-icon{font-size:48px;margin-bottom:16px}
.modal-success h3{font-family:'Playfair Display',serif;font-size:22px;color:var(--ink);margin-bottom:8px}
.modal-success p{color:var(--muted);font-size:14px}

/* ── CHOOSE SECTION ── */
.choose-header { margin-bottom: 48px; max-width: 600px; }
.choose-text h2 { margin-bottom: 8px; }
.choose-text p  { color: var(--muted); margin-bottom: 28px; }

.choose-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.choose-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.choose-card:hover {
  border-color: rgba(212,168,71,.4);
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,.3);
}
.choose-card-img-wrap {
  position: relative;
  height: 200px;
  overflow: hidden;
  background: var(--bg3);
}
.choose-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s ease;
}
.choose-card:hover .choose-card-img { transform: scale(1.06); }
.choose-card-tag {
  position: absolute;
  top: 10px;
  left: 10px;
  padding: 3px 9px;
  background: rgba(13,17,23,.75);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 5px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--accent);
}
.choose-card-body {
  padding: 16px 18px 18px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}
.choose-card-cap {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--muted);
}
.choose-card-name {
  font-family: 'Playfair Display', serif;
  font-size: 17px;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.3;
  margin-top: 2px;
}
.choose-card-price {
  font-size: 13px;
  color: var(--muted);
  margin-top: 4px;
}
.choose-card-price strong { color: var(--accent); }

/* ── FEATURES ── */
.features-bg{background:var(--bg2)}
.features-header{text-align:center;margin-bottom:64px}
.features-header h2{margin-bottom:8px}.features-header p{color:var(--muted);max-width:520px;margin:0 auto}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.feature-card{background:var(--bg3);padding:40px 36px;transition:background .2s}
.feature-card:hover{background:var(--surface)}
.feature-icon{width:52px;height:52px;border-radius:12px;background:rgba(212,168,71,.1);display:flex;align-items:center;justify-content:center;margin-bottom:24px;color:var(--accent)}
.feature-card h3{font-family:'Playfair Display',serif;font-size:22px;font-weight:500;margin-bottom:12px}
.feature-card p{color:var(--muted);font-size:15px;line-height:1.65}

/* ── LANGUAGE SWITCHER ── */
.lang-switcher { position: relative; }
.lang-current {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 6px 10px;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--border);
  border-radius: 8px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
  cursor: pointer;
  transition: all .15s;
  white-space: nowrap;
}
.lang-current:hover { border-color: rgba(212,168,71,.4); color: var(--accent); }
.lang-flag { font-size: 15px; line-height: 1; }
.lang-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  background: var(--surface);
  border: 1px solid rgba(212,168,71,.2);
  border-radius: 12px;
  padding: 6px;
  min-width: 160px;
  box-shadow: 0 16px 48px rgba(0,0,0,.5);
  z-index: 200;
}
.lang-dropdown.open { display: block; }
.lang-opt {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  font-size: 13px;
  color: var(--muted);
  text-decoration: none;
  border-radius: 8px;
  transition: all .12s;
}
.lang-opt:hover { background: rgba(255,255,255,.05); color: var(--ink); }
.lang-opt.active { color: var(--accent); }
.lang-opt span:first-child { font-size: 16px; }

/* ── EXTRAS CAROUSEL — SIDE ARROWS ── */
.extras-section-header {
  margin-bottom: 40px;
}
.extras-section-header > div > p { color: var(--muted); max-width: 520px; }

.extras-carousel-outer {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0;
}
.extras-arrow {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--bg3);
  color: var(--muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
  z-index: 2;
}
.extras-arrow:hover {
  border-color: rgba(212,168,71,.5);
  background: rgba(212,168,71,.1);
  color: var(--accent);
}
.extras-arrow:disabled { opacity: .25; cursor: default; pointer-events: none; }
.extras-arrow-l { margin-right: 16px; }
.extras-arrow-r { margin-left: 16px; }

/* ── MOBILE BOTTOM NAV ── */
.mobile-bottom-nav {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 200;
  background: rgba(17,24,39,.97);
  backdrop-filter: blur(16px);
  border-top: 1px solid rgba(212,168,71,.15);
  padding: 8px 0 max(8px, env(safe-area-inset-bottom));
  grid-template-columns: repeat(5, 1fr);
}
.mbn-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 4px 0;
  font-size: 10px;
  font-weight: 500;
  color: var(--muted);
  text-decoration: none;
  background: none;
  border: none;
  cursor: pointer;
  transition: color .15s;
  font-family: 'DM Sans', sans-serif;
  letter-spacing: .02em;
}
.mbn-item:hover, .mbn-item.mbn-active { color: var(--accent); }
.mbn-item svg { opacity: .7; transition: opacity .15s; }
.mbn-item:hover svg, .mbn-item.mbn-active svg { opacity: 1; }

.mbn-cta { color: var(--accent); }
.mbn-cta-circle {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: -20px;
  box-shadow: 0 4px 20px rgba(212,168,71,.4);
  transition: background .15s, transform .15s;
}
.mbn-cta-circle svg { stroke: #0d1117; }
.mbn-cta:hover .mbn-cta-circle { background: var(--accent2); transform: scale(1.08); }
.mbn-cta span { color: var(--accent); font-weight: 600; }

/* ── MOBILE LANG SHEET ── */
.mobile-lang-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.6);
  z-index: 300;
  backdrop-filter: blur(4px);
}
.mobile-lang-overlay.open { display: block; }
.mobile-lang-sheet {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 301;
  background: var(--bg2);
  border-top: 1px solid rgba(212,168,71,.2);
  border-radius: 20px 20px 0 0;
  padding: 12px 20px max(24px, env(safe-area-inset-bottom));
  transform: translateY(100%);
  transition: transform .35s cubic-bezier(.32,.72,0,1);
}
.mobile-lang-sheet.open { transform: translateY(0); }
.mls-handle {
  width: 36px; height: 4px;
  background: var(--faint);
  border-radius: 2px;
  margin: 0 auto 16px;
}
.mls-title {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: center;
  margin-bottom: 20px;
}
.mls-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.mls-opt {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 14px 8px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  text-decoration: none;
  transition: all .15s;
}
.mls-opt:hover, .mls-opt.active {
  border-color: rgba(212,168,71,.5);
  background: rgba(212,168,71,.08);
}
.mls-flag { font-size: 26px; line-height: 1; }
.mls-opt span:nth-child(2) { font-size: 13px; font-weight: 700; color: var(--ink); }
.mls-name { font-size: 10px; color: var(--muted); }
/* ── EXTRAS SECTION ── */
.extras-section { background: var(--bg2); }

.extras-section-header { margin-bottom: 40px; }
.extras-section-header > div > p { color: var(--muted); max-width: 520px; }

/* ── DESKTOP: static grid + side arrows ── */
.extras-carousel-outer {
  position: relative;
}
.extras-arrow {
  display: none; /* hidden by default, shown on desktop */
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: rgba(13,17,23,.9);
  backdrop-filter: blur(8px);
  color: var(--muted);
  cursor: pointer;
  align-items: center;
  justify-content: center;
  transition: all .2s;
  z-index: 10;
}
.extras-arrow:hover {
  border-color: rgba(212,168,71,.5);
  background: rgba(212,168,71,.1);
  color: var(--accent);
}
.extras-arrow:disabled { opacity: .2; cursor: default; pointer-events: none; }
.extras-arrow-l { left: -24px; }
.extras-arrow-r { right: -24px; }

.extras-carousel-wrap { overflow: hidden; }

.extras-carousel {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

/* ── MOBILE: horizontal scroll ── */
@media(max-width:900px) {
  .extras-arrow { display: none !important; }
  .extras-dots { display: none !important; }

  .extras-carousel-wrap {
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    /* bleed to container edges */
    margin: 0 -24px;
    padding: 0 24px;
  }
  .extras-carousel-wrap::-webkit-scrollbar { display: none; }

  .extras-carousel {
    display: flex;
    gap: 16px;
    /* keep a peek of next card */
    padding-right: 24px;
  }
  .extras-card {
    flex-shrink: 0;
    width: calc(100vw - 80px);
    scroll-snap-align: start;
    max-width: 340px;
  }
}
@media(max-width:580px) {
  .extras-card { width: calc(100vw - 64px); }
}

/* ── Card ── */
.extras-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color .2s, transform .2s, box-shadow .2s;
  display: flex;
  flex-direction: column;
}
.extras-card:hover {
  border-color: rgba(212,168,71,.4);
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,.3);
}
.extras-card-img-wrap {
  position: relative;
  height: 220px;
  overflow: hidden;
  background: var(--bg3);
  flex-shrink: 0;
}
.extras-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s ease;
}
.extras-card:hover .extras-card-img { transform: scale(1.06); }
.extras-card-img-ph {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  color: var(--faint);
}
.extras-card-price-badge {
  position: absolute;
  bottom: 12px;
  right: 12px;
  padding: 5px 12px;
  background: rgba(13,17,23,.8);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(212,168,71,.35);
  border-radius: 20px;
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
}
.extras-card-body {
  padding: 20px 22px 22px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.extras-card-name {
  font-family: 'Playfair Display', serif;
  font-size: 20px;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 10px;
  line-height: 1.3;
}
.extras-card-desc {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.65;
  flex: 1;
  margin: 0;
}
.extras-card-footer {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.extras-card-note {
  font-size: 12px;
  color: var(--faint);
  display: flex;
  align-items: center;
  gap: 6px;
}
.extras-card-note::before {
  content: '';
  display: block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent);
  opacity: .6;
  flex-shrink: 0;
}

/* Dots — desktop only */
.extras-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 32px;
}
.extras-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--faint);
  cursor: pointer;
  transition: all .2s;
  border: none;
  padding: 0;
}
.extras-dot.active {
  width: 24px;
  border-radius: 3px;
  background: var(--accent);
}

/* ── TESTIMONIALS ── */
.testimonials-bg{
  position:relative;
  background:url('/images/banner.png') center/cover no-repeat;
  background-image:image-set(
    url('/images/banner.avif') type('image/avif'),
    url('/images/banner.webp') type('image/webp'),
    url('/images/banner.png') type('image/png')
  );
  background-position:center;
  background-size:cover;
  background-repeat:no-repeat;
}
.testimonials-bg::before{content:'';position:absolute;inset:0;background:rgba(13,17,23,.88)}
.testimonials-bg .container{position:relative;z-index:1}
.testimonials-header{text-align:center;margin-bottom:56px}
.testimonials-header h2{margin-bottom:8px}.testimonials-header p{color:var(--muted)}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonial-card{background:rgba(30,42,58,.8);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.07);border-radius:var(--r);padding:32px}
.testimonial-stars{color:var(--accent);font-size:14px;letter-spacing:2px;margin-bottom:16px}
.testimonial-text{color:rgba(232,237,245,.8);font-size:15px;line-height:1.7;margin-bottom:24px;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:12px}
.author-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent2),var(--accent));display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#0d1117;flex-shrink:0}
.author-name{font-size:14px;font-weight:500;color:var(--ink)}.author-sub{font-size:12px;color:var(--muted);margin-top:1px}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px}
.contact-info h2{margin-bottom:8px}.contact-info p{color:var(--muted);margin-bottom:40px}
.contact-details{display:flex;flex-direction:column;gap:16px}
.contact-item{display:flex;align-items:flex-start;gap:14px;padding:16px;background:var(--bg2);border-radius:var(--r)}
.contact-item-icon{width:36px;height:36px;border-radius:8px;background:rgba(212,168,71,.1);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-item-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.contact-item-val{font-size:15px;color:var(--ink);margin-top:2px}
.contact-form{display:flex;flex-direction:column;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}
.form-group input,.form-group textarea{background:var(--bg2);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:12px 16px;font-family:'DM Sans',sans-serif;font-size:15px;color:var(--ink);outline:none;transition:border-color .15s;resize:vertical}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--faint)}
.form-group input:focus,.form-group textarea:focus{border-color:var(--accent)}

/* ── FOOTER ── */
footer{background:var(--bg2);border-top:1px solid var(--border);padding:40px 0}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.footer-copy{font-size:13px;color:var(--muted)}
.footer-links{display:flex;gap:24px}
.footer-links a{font-size:13px;color:var(--muted);text-decoration:none;transition:color .15s}
.footer-links a:hover{color:var(--accent)}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  nav{display:none}
  .burger{display:flex}
  .mobile-bottom-nav{display:grid}
  body{padding-bottom:72px}
  .choose-cards{grid-template-columns:1fr 1fr}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:48px}
  .features-grid,.testimonials-grid{grid-template-columns:1fr}
  .booking-form{grid-template-columns:1fr 1fr}
  .booking-field:nth-child(2){border-right:none}
  .booking-field:nth-child(3){grid-column:1/-1;border-top:1px solid var(--border)}
  .booking-field:nth-child(4){grid-column:1/-1;border-top:1px solid var(--border)}
  .book-btn{padding:20px}
  .dp-popup{min-width:calc(100vw - 48px)}
  .dp-months{grid-template-columns:1fr}
  .results-grid{grid-template-columns:1fr}
  .hero-content p{font-size:16px}
  .extras-section-header{flex-direction:column;align-items:flex-start;gap:16px}
}
@media(max-width:580px){
  .choose-cards{grid-template-columns:1fr}
  .booking-form{grid-template-columns:1fr}
  .booking-field{border-right:none;border-bottom:1px solid var(--border)}
  .about-stats{grid-template-columns:1fr 1fr}
}