/* ═══════════════════════════════════════════════════════════
   VILLA AMWAJ — PRO MAX POLISH LAYER
   Premium refinements: gradients, shadows, motion, hierarchy
   ═══════════════════════════════════════════════════════════ */

/* Global typographic rhythm */
html{font-feature-settings:"ss01" 1,"cv01" 1,"cv02" 1}
::selection{background:var(--accent);color:#fff}

/* Smooth page-in */
body{opacity:0;animation:pageIn .8s var(--ease-out) forwards}
@keyframes pageIn{to{opacity:1}}

/* ─── AMBIENT BACKGROUND TEXTURE ─── */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;
  background:
    radial-gradient(1200px 600px at 85% -5%,rgba(11,94,107,.06),transparent 60%),
    radial-gradient(900px 500px at -5% 10%,rgba(186,92,59,.05),transparent 55%),
    radial-gradient(800px 500px at 50% 100%,rgba(184,136,74,.04),transparent 55%);
}

/* ─── HEADER REFINEMENTS ─── */
.site-header{
  background:rgba(250,247,240,.78)!important;
  backdrop-filter:saturate(200%) blur(20px);
  -webkit-backdrop-filter:saturate(200%) blur(20px);
  border-bottom:1px solid rgba(231,223,205,.6)!important;
}
.top-bar{
  background:linear-gradient(90deg,#F2EAD5 0%,#F6EFDB 50%,#F2EAD5 100%)!important;
}
.top-bar-left .tb-dot{
  box-shadow:0 0 8px rgba(11,94,107,.5);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}

.nav-menu>li>a{
  font-size:.76rem!important;font-weight:600!important;
  letter-spacing:.16em!important;
  transition:color .2s;
}
.nav-menu>li>a::after{
  height:2px!important;background:var(--accent)!important;
  border-radius:2px;bottom:0!important;
}

.nav-phone-ic{
  background:rgba(11,94,107,.06);
  border-color:rgba(11,94,107,.14)!important;
}
.nav-phone:hover .nav-phone-ic{
  background:var(--accent)!important;border-color:var(--accent)!important;
  transform:rotate(-8deg) scale(1.05);
  transition:all .3s var(--ease-spring);
}
.nav-phone:hover .nav-phone-ic svg{stroke:#fff!important}

/* Language switch premium */
.lang-switch a{font-weight:500}
.lang-switch a.active{
  color:var(--accent)!important;font-weight:700;
}

/* ─── LISTING HEADER HERO ─── */
.listing-header{
  position:relative;padding:64px 0 32px!important;
  animation:slideUp .9s var(--ease-out) both;
}
@keyframes slideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

.listing-title::before{
  content:"VILLA · SIDI KAOUKI";
  display:block;font-size:.7rem;font-weight:600;
  letter-spacing:.32em;color:var(--accent);
  margin-bottom:14px;
}

.meta-rating{
  background:linear-gradient(135deg,rgba(184,136,74,.12),rgba(184,136,74,.04));
  padding:4px 11px;border-radius:999px;
  border:1px solid rgba(184,136,74,.2);
  color:var(--text)!important;font-weight:600!important;
}
.meta-star{color:var(--gold)!important;filter:drop-shadow(0 0 4px rgba(184,136,74,.4))}

.gf-pill{
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%)!important;
  color:#fff!important;border:none!important;
  padding:4px 12px!important;
  font-weight:600!important;letter-spacing:.04em;
  box-shadow:0 4px 14px rgba(11,94,107,.3);
}

/* ─── GALLERY — LUXE ─── */
.gallery{
  grid-template-rows:280px 280px!important;
  gap:10px!important;
  animation:fadeUp 1s var(--ease-out) .1s both;
  border-radius:18px;overflow:hidden;
  box-shadow:var(--shadow-lg);
}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.g-main,.g-item{border-radius:0!important}
.g-main::after,.g-item::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(14,22,32,.15) 100%);
  pointer-events:none;opacity:0;transition:opacity .4s;
}
.g-main:hover::after,.g-item:hover::after{opacity:1}
.gallery img,.g-main img{transition:transform .8s var(--ease-out)!important}
.g-main:hover img,.g-item:hover img{transform:scale(1.06)!important}

.show-all-btn{
  background:rgba(255,255,255,.95)!important;
  backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.5)!important;
  box-shadow:0 12px 32px rgba(14,22,32,.18)!important;
}

/* ─── HOST ROW ─── */
.host-row{padding-bottom:36px!important}
.h-avatar{
  width:60px!important;height:60px!important;
  border:3px solid var(--white);
  box-shadow:0 8px 24px rgba(14,22,32,.12);
}

/* ─── HIGHLIGHTS ─── */
.highlights{padding:36px 0!important;gap:26px!important}
.hi{
  padding:18px 22px;border-radius:14px;
  background:linear-gradient(135deg,rgba(255,255,255,.6) 0%,rgba(242,234,213,.3) 100%);
  border:1px solid rgba(231,223,205,.6);
  transition:transform .3s var(--ease-out),box-shadow .3s,border-color .3s;
}
.hi:hover{
  transform:translateX(6px);
  box-shadow:var(--shadow-md);
  border-color:var(--accent);
}
.hi-icon{
  font-size:1.4rem!important;width:42px!important;height:42px;
  display:flex;align-items:center;justify-content:center;
  background:var(--accent-soft);border-radius:12px;
  margin-top:0!important;flex-shrink:0;
}
.hi-title{font-size:.95rem!important;font-weight:600!important;letter-spacing:-.01em;margin-bottom:4px!important}
.hi-desc{font-size:.85rem!important;line-height:1.6!important}

/* ─── DESCRIPTION ─── */
.desc-body{font-size:.93rem!important;line-height:1.8!important;color:var(--text-soft)!important}
.show-more-btn{
  color:var(--accent)!important;font-weight:600!important;
  padding:8px 0!important;
}
.show-more-btn:hover{text-decoration:none!important;gap:10px!important}

/* ─── BEDROOMS ─── */
.bed-card{
  border-radius:12px!important;border-color:var(--border-soft)!important;
  transition:all .35s var(--ease-out);cursor:pointer;
}
.bed-card img{transition:transform .6s var(--ease-out)}
.bed-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:var(--accent)!important;
}
.bed-card:hover img{transform:scale(1.05)}
.bed-body{padding:14px 16px!important}
.bed-name{font-weight:600!important;letter-spacing:-.01em}

/* ─── AMENITIES ─── */
.amen{
  padding:12px 14px;border-radius:10px;
  background:rgba(255,255,255,.4);
  border:1px solid transparent;
  transition:all .25s var(--ease-out);
}
.amen:hover{
  background:var(--white);border-color:var(--border-soft);
  transform:translateX(3px);
}
.amen-icon{
  width:28px!important;height:28px;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--accent-soft);border-radius:8px;
  font-size:.88rem!important;flex-shrink:0;
}
.amen-na .amen-icon{background:rgba(14,22,32,.04);opacity:.5}

.show-amen-btn{
  border-color:var(--accent)!important;
  color:var(--accent)!important;font-weight:600!important;
  padding:12px 28px!important;border-radius:999px!important;
  transition:all .3s var(--ease-out)!important;
}
.show-amen-btn:hover{
  background:var(--accent)!important;color:#fff!important;
  border-color:var(--accent)!important;
  transform:translateY(-2px);
  box-shadow:0 10px 24px rgba(11,94,107,.3);
}

/* ─── LOCATION MAP ─── */
.map-wrap{
  border-radius:14px!important;
  box-shadow:var(--shadow-md);
  border:1px solid var(--border-soft);
}

/* ─── BOOKING WIDGET — HERO CTA ─── */
.widget{
  border-radius:18px!important;
  border:1px solid rgba(231,223,205,.8)!important;
  box-shadow:0 24px 60px rgba(14,22,32,.1),0 2px 6px rgba(14,22,32,.05)!important;
  overflow:visible!important;
  position:sticky;top:120px;
  background:linear-gradient(180deg,#fff 0%,#FEFCF7 100%)!important;
}
.widget::before{
  content:"";position:absolute;top:-1px;left:24px;right:24px;
  height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);
  border-radius:2px;opacity:.4;
}
.widget-hdr{padding:28px 26px 0!important}

.w-price-amount{
  background:linear-gradient(135deg,var(--text) 0%,var(--accent) 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.widget-price-note{
  color:var(--muted)!important;
}
.widget-price-note::before{
  width:6px!important;height:6px!important;
  box-shadow:0 0 8px rgba(186,92,59,.5);
}
.widget-price-note.high::before{box-shadow:0 0 8px rgba(11,94,107,.6)}

.w-price-breakdown{
  background:var(--sand)!important;
  border:1px solid var(--border-soft);
  border-radius:10px!important;
}
.w-breakdown-total{font-size:.95rem!important}

.w-dates{
  border-radius:10px!important;
  border:1.5px solid var(--border)!important;
  background:#FDFBF5;
  transition:border-color .25s,box-shadow .25s;
}
.w-dates:focus-within{
  border-color:var(--accent)!important;
  box-shadow:0 0 0 4px var(--accent-glow);
}
.w-date,.w-guests{transition:background .2s}
.w-date:hover,.w-guests:hover{background:rgba(11,94,107,.03)}

.reserve-btn{
  background:linear-gradient(135deg,#0B5E6B 0%,#073F48 100%)!important;
  padding:16px!important;font-size:.88rem!important;
  letter-spacing:.06em!important;font-weight:600!important;
  border-radius:10px!important;
  box-shadow:0 10px 24px rgba(11,94,107,.35),inset 0 1px 0 rgba(255,255,255,.15)!important;
  transition:transform .25s var(--ease-out),box-shadow .25s,filter .25s!important;
  position:relative;overflow:hidden;
}
.reserve-btn::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  transform:translateX(-100%);transition:transform .6s var(--ease-out);
}
.reserve-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 36px rgba(11,94,107,.42),inset 0 1px 0 rgba(255,255,255,.2)!important;
  filter:brightness(1.05);
}
.reserve-btn:hover::before{transform:translateX(100%)}
.reserve-btn:active{transform:translateY(0)}

.widget-rating .gs{color:var(--gold)!important}

.w-extra-item{
  font-size:.85rem!important;color:var(--text-soft)!important;
  padding:6px 0;
}
.w-extra-item .wi{
  width:28px!important;height:28px;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--accent-soft);border-radius:8px;
}

/* ─── REVIEWS — DARK PREMIUM ─── */
.reviews-section{
  background:linear-gradient(160deg,#14202A 0%,#0B1319 100%)!important;
  position:relative;overflow:hidden;
}
.reviews-section .page{position:relative;z-index:1}

.bar-fill{
  background:linear-gradient(90deg,var(--gold),rgba(184,136,74,.6))!important;
  box-shadow:0 0 8px rgba(184,136,74,.4);
  height:2px!important;
}
.bar-track{height:2px!important}

.rev-card{
  background:rgba(255,255,255,.05)!important;
  border:1px solid rgba(255,255,255,.09)!important;
  border-radius:16px!important;
  padding:30px!important;
  transition:all .4s var(--ease-out)!important;
}
.rev-card:hover{
  background:linear-gradient(135deg,rgba(255,255,255,.08) 0%,rgba(255,255,255,.03) 100%)!important;
  border-color:rgba(184,136,74,.35)!important;
  transform:translateY(-4px);
  box-shadow:0 20px 40px rgba(0,0,0,.3);
}
.rev-stars{color:var(--gold)!important;font-size:.72rem!important;letter-spacing:3px!important}
.rev-text{
  color:rgba(255,255,255,.82)!important;
  font-size:.92rem!important;line-height:1.75!important;
  font-style:normal!important;
}
.rev-name{font-weight:600!important;color:#fff!important}
.rev-meta{color:rgba(255,255,255,.45)!important;font-size:.72rem!important;letter-spacing:.06em}
.rev-avatar{
  box-shadow:0 4px 12px rgba(0,0,0,.3);
  font-weight:700!important;
}

.revs-arrow{
  width:44px!important;height:44px!important;
  border:1px solid rgba(255,255,255,.2)!important;
  background:rgba(255,255,255,.04)!important;
  transition:all .3s var(--ease-out)!important;
}
.revs-arrow:hover{
  background:var(--gold)!important;border-color:var(--gold)!important;
  transform:scale(1.08);
}
.revs-arrow:hover svg{stroke:#fff!important}

.revs-dot{
  transition:all .3s var(--ease-out)!important;
}
.revs-dot:hover{background:rgba(255,255,255,.5)!important}
.revs-dot.active{background:var(--gold)!important;transform:scale(1.5)!important}

/* ─── HOST SECTION ─── */
.host-section{
  background:linear-gradient(180deg,#fff 0%,#FDFBF5 100%)!important;
}
.host-big-av{
  width:84px!important;height:84px!important;
  border:4px solid #fff;
  box-shadow:0 12px 32px rgba(14,22,32,.14);
}
.host-profile{margin-bottom:28px!important;gap:20px!important}

.h-badge{
  padding:10px 14px;border-radius:10px;
  background:rgba(11,94,107,.04);border:1px solid rgba(11,94,107,.1);
  color:var(--text-soft)!important;font-size:.86rem!important;font-weight:500;
  transition:all .25s var(--ease-out);
}
.h-badge:hover{
  background:var(--accent-soft);border-color:rgba(11,94,107,.25);
  transform:translateX(4px);
}
.h-badge>span:first-child{
  width:24px;display:inline-flex;justify-content:center;
}

.contact-btn{
  background:linear-gradient(135deg,#0E1620 0%,#24313D 100%)!important;
  padding:14px 28px!important;
  border-radius:999px!important;
  font-weight:600!important;letter-spacing:.04em;
  box-shadow:0 10px 24px rgba(14,22,32,.25)!important;
  transition:all .3s var(--ease-out)!important;
}
.contact-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 32px rgba(14,22,32,.35)!important;
  background:linear-gradient(135deg,#0B5E6B 0%,#073F48 100%)!important;
}

.host-right-card{
  background:linear-gradient(135deg,#FDFBF5 0%,#F5EEE0 100%)!important;
  border-radius:16px!important;padding:32px!important;
  border:1px solid var(--border-soft)!important;
  box-shadow:var(--shadow-sm);
}
.hrc-title{font-size:1rem!important;font-weight:700!important;letter-spacing:-.015em}
.hstat{
  border-radius:10px!important;padding:16px!important;
  border-color:var(--border-soft)!important;
  transition:transform .25s var(--ease-out),box-shadow .25s;
}
.hstat:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.hstat-lbl{font-size:.68rem!important;letter-spacing:.1em!important;font-weight:600!important}

.also-card{
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%)!important;
  border:none!important;border-radius:16px!important;padding:28px!important;
  color:#fff!important;
  box-shadow:0 16px 36px rgba(11,94,107,.25)!important;
}
.also-label{color:rgba(255,255,255,.7)!important;font-weight:600!important;letter-spacing:.12em!important}
.also-items{color:rgba(255,255,255,.9)!important;font-size:.9rem!important}
.also-link{
  background:var(--gold)!important;color:#fff!important;
  padding:11px 24px!important;border-radius:999px!important;
  font-weight:600!important;margin-top:18px!important;
  box-shadow:0 8px 20px rgba(184,136,74,.35)!important;
  transition:all .3s var(--ease-out)!important;
}
.also-link:hover{
  background:#fff!important;color:var(--accent-dark)!important;
  transform:translateY(-2px);
  box-shadow:0 12px 28px rgba(184,136,74,.5)!important;
}

/* ─── THINGS TO KNOW ─── */
.ttk-section{padding:80px 0 100px!important}
.ttk-item{
  padding:12px 14px;border-radius:10px;
  margin-bottom:10px!important;
  background:rgba(255,255,255,.4);
  border:1px solid transparent;
  transition:all .25s var(--ease-out);
}
.ttk-item:hover{
  background:#fff;border-color:var(--border-soft);
  transform:translateX(4px);
}
.ttk-icon{
  width:28px!important;height:28px;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--accent-soft);border-radius:8px;
  margin-top:0!important;font-size:.92rem!important;
  flex-shrink:0;
}
.ttk-col-title{
  color:var(--accent)!important;font-weight:600!important;
  letter-spacing:.14em!important;
}

/* ─── FOOTER ─── */
.site-footer{
  background:linear-gradient(180deg,#0E1620 0%,#050A0E 100%)!important;
}
.site-footer::before{
  width:60px!important;height:2px!important;
  background:linear-gradient(90deg,transparent,var(--gold),transparent)!important;
}

.footer-h{color:#fff!important;font-weight:600!important;letter-spacing:.18em!important}
.footer-h::before{background:var(--gold)!important;width:22px!important}

.footer-list a{transition:all .25s var(--ease-out)!important}
.footer-list a:hover{color:var(--gold)!important;padding-left:6px}

.footer-socials a:hover{
  background:var(--gold)!important;border-color:var(--gold)!important;
  box-shadow:0 8px 20px rgba(184,136,74,.3);
}

.footer-newsletter:focus-within{border-color:var(--gold)!important}
.footer-newsletter button{
  background:var(--gold)!important;
  transition:all .25s var(--ease-out)!important;
}
.footer-newsletter button:hover{background:#8f6a36!important;filter:brightness(1.1)}

.footer-contact-item svg{stroke:var(--gold)!important}
.footer-contact a:hover{color:var(--gold)!important}

.footer-pay-chip{
  border-color:rgba(184,136,74,.2)!important;
  background:rgba(184,136,74,.05)!important;
  transition:all .25s var(--ease-out);
}
.footer-pay-chip:hover{
  background:rgba(184,136,74,.15)!important;
  border-color:var(--gold)!important;
  color:#fff!important;
}

.footer-bottom a:hover{color:var(--gold)!important}

/* ─── MOBILE CTA ─── */
.mobile-cta{
  box-shadow:0 -16px 40px rgba(14,22,32,.12)!important;
  backdrop-filter:blur(12px);
  background:rgba(255,255,255,.95)!important;
}
.mc-btn{
  background:linear-gradient(135deg,#0B5E6B 0%,#073F48 100%)!important;
  padding:13px 26px!important;font-weight:600!important;
  border-radius:999px!important;letter-spacing:.04em;
  box-shadow:0 8px 20px rgba(11,94,107,.3)!important;
}
.mc-btn:hover{transform:translateY(-1px);filter:brightness(1.05)}

/* ─── SCROLL REVEAL ─── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ─── MOBILE CTA REFINEMENTS ─── */
.mc-price-line{font-weight:700;font-size:1rem;letter-spacing:-.02em}
.mc-unit{color:var(--muted);font-weight:400;font-size:.88rem}
.mobile-cta .mc-btn{
  background:linear-gradient(135deg,#0B5E6B 0%,#073F48 100%)!important;
  border:none;padding:13px 24px!important;border-radius:999px!important;
  font-size:.84rem!important;font-weight:600!important;letter-spacing:.04em;
  color:#fff;cursor:pointer;
  box-shadow:0 8px 20px rgba(11,94,107,.3)!important;
  transition:all .25s var(--ease-out)!important;
  white-space:nowrap;
}
.mobile-cta .mc-btn:hover{transform:translateY(-1px);filter:brightness(1.06)}

/* ─── MOBILE BOOKING SHEET ─── */
.mob-backdrop{
  display:none;position:fixed;inset:0;
  background:rgba(10,16,22,.55);
  backdrop-filter:blur(4px);
  z-index:500;
  opacity:0;transition:opacity .35s var(--ease-out);
}
.mob-backdrop.open{display:block;opacity:1}

.mob-sheet{
  position:fixed;bottom:0;left:0;right:0;z-index:501;
  background:#fff;
  border-radius:24px 24px 0 0;
  box-shadow:0 -24px 60px rgba(10,16,22,.18);
  transform:translateY(100%);
  transition:transform .4s var(--ease-out);
  max-height:92dvh;overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.mob-sheet.open{transform:translateY(0)}

.mob-sheet-drag{
  display:flex;justify-content:center;
  padding:14px 0 4px;cursor:pointer;
}
.mob-sheet-drag span{
  width:40px;height:4px;border-radius:99px;
  background:var(--border);display:block;
}

.mob-sheet-hdr{
  display:flex;justify-content:space-between;align-items:flex-start;
  padding:4px 24px 20px;
  border-bottom:1px solid var(--border-soft);
}
.mob-sheet-price-row{display:flex;align-items:baseline;gap:6px;margin-bottom:4px}
.mob-sheet-amount{font-size:1.8rem;font-weight:700;letter-spacing:-.03em;color:var(--text)}
.mob-sheet-unit{font-size:.9rem;color:var(--muted);font-weight:400}
.mob-sheet-rating{font-size:.8rem;color:var(--muted)}
.mob-sheet-close{
  background:var(--sand);border:none;width:36px;height:36px;
  border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:var(--text);
  transition:background .2s,transform .2s;
}
.mob-sheet-close:hover{background:var(--border);transform:scale(1.08)}

.mob-sheet-body{padding:20px 24px 32px;padding-bottom:max(32px,env(safe-area-inset-bottom))}

/* Date + guests inputs */
.mob-dates-wrap{
  border:1.5px solid var(--border);border-radius:12px;
  overflow:hidden;margin-bottom:14px;
  transition:border-color .25s,box-shadow .25s;
}
.mob-dates-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}

.mob-dates-grid{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--border)}
.mob-date-field{padding:14px 16px;background:#FDFBF5;transition:background .2s}
.mob-date-field:hover{background:rgba(11,94,107,.03)}
.mob-date-field--right{border-left:1px solid var(--border)}
.mob-date-field label,
.mob-guests-field label{
  display:block;font-size:.62rem;font-weight:700;
  letter-spacing:.12em;color:var(--muted);
  margin-bottom:5px;
}
.mob-date-field input{
  border:none;outline:none;background:none;
  font-family:'DM Sans',sans-serif;font-size:.95rem;
  color:var(--text);width:100%;cursor:pointer;
  font-weight:500;
}
.mob-guests-field{padding:14px 16px;background:#FDFBF5;transition:background .2s}
.mob-guests-field:hover{background:rgba(11,94,107,.03)}
.mob-guests-field select{
  border:none;outline:none;background:none;
  font-family:'DM Sans',sans-serif;font-size:.95rem;
  color:var(--text);width:100%;cursor:pointer;
  font-weight:500;
}

/* Breakdown */
.mob-breakdown{
  background:var(--sand);border-radius:10px;
  padding:14px 16px;margin-bottom:14px;
  font-size:.86rem;
  border:1px solid var(--border-soft);
}
.mob-breakdown:empty{display:none}
.mob-bd-row{display:flex;justify-content:space-between;padding:3px 0;color:var(--muted)}
.mob-bd-total{
  border-top:1px solid var(--border);margin-top:8px;padding-top:8px;
  font-weight:700;color:var(--text);font-size:.95rem;
  display:flex;justify-content:space-between;
}

/* Reserve button */
.mob-reserve-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;padding:17px;margin-bottom:10px;
  background:linear-gradient(135deg,#0B5E6B 0%,#073F48 100%);
  color:#fff;border-radius:12px;text-decoration:none;
  font-size:.92rem;font-weight:700;letter-spacing:.04em;
  box-shadow:0 12px 28px rgba(11,94,107,.35);
  transition:all .3s var(--ease-out);
}
.mob-reserve-btn:hover{transform:translateY(-2px);filter:brightness(1.06);box-shadow:0 18px 36px rgba(11,94,107,.42)}

.mob-reserve-note{
  text-align:center;font-size:.76rem;
  color:var(--muted);margin-bottom:20px;
}

.mob-extras{
  display:flex;flex-direction:column;gap:10px;
  padding-top:16px;border-top:1px solid var(--border-soft);
}
.mob-extra{
  display:flex;align-items:center;gap:10px;
  font-size:.86rem;color:var(--text-soft);
}
.mob-extra span{
  width:30px;height:30px;border-radius:8px;
  background:var(--accent-soft);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:.9rem;flex-shrink:0;
}

/* Hide sheet on desktop */
@media(min-width:961px){
  .mob-backdrop,.mob-sheet{display:none!important}
  .mobile-cta{display:none!important}
}

/* Fix widget-price-note dot when empty */
.widget-price-note:empty{display:none}

/* ─── FOCUS STATES ─── */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible{
  outline:2px solid var(--accent);outline-offset:3px;border-radius:4px;
}

/* ─── REDUCED MOTION ─── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  body{opacity:1!important;animation:none!important}
}

/* ─── RESPONSIVE TWEAKS ─── */
@media(max-width:960px){
  .listing-title{font-size:2.4rem!important}
  .listing-title em{font-size:1.3rem!important}
  .gallery{grid-template-rows:240px 240px!important}
  .rev-big-num{font-size:4.2rem!important}
}
@media(max-width:600px){
  .listing-header{padding:36px 0 20px!important}
  .listing-title{font-size:1.9rem!important}
  .listing-title em{font-size:1.08rem!important}
  .listing-title::before{font-size:.64rem;margin-bottom:10px}
  .gallery{border-radius:14px}
  .hi{padding:14px 16px}
  .hi-icon{width:36px!important;height:36px;font-size:1.15rem!important}
  .rev-card{padding:22px!important}
  .rev-big-num{font-size:3.6rem!important}
  .widget{border-radius:14px!important}
  .reviews-section{padding:64px 0!important}
  .host-section{padding:56px 0!important}
  .ttk-section{padding:56px 0 80px!important}
}
