/* ═══════════════════════════════════════════════════════════════
   MANAZEL MAREZ — Master Stylesheet
   v19 — Hybrid: ChatGPT structure + v18 features
   ═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Tajawal:wght@300;400;500;700;900&family=Noto+Serif+Arabic:wght@400;500;600;700&display=swap');

:root{
  /* Colors */
  --bg:#faf6ef;
  --paper:#fffdfa;
  --ink:#1f1b16;
  --muted:#756a5d;
  --gold:#a8814b;
  --gold-light:#d8b06f;
  --gold-dark:#7a5d31;
  --brown:#5a3d22;
  --brown-deep:#1e1710;
  --line:#eadfce;
  --green:#1f9d55;
  --green-dark:#157a3f;
  --whatsapp:#25D366;
  --error:#c0392b;
  
  /* Typography */
  --font-ar:'Tajawal','Noto Serif Arabic',Arial,sans-serif;
  --font-en:'Cormorant Garamond',Georgia,serif;
  --font-sans:'Tajawal',Arial,sans-serif;
  
  /* Layout */
  --radius:26px;
  --radius-sm:14px;
  --radius-md:18px;
  --shadow:0 24px 70px rgba(73,48,21,.13);
  --shadow-sm:0 8px 24px rgba(73,48,21,.08);
  --shadow-lg:0 32px 80px rgba(73,48,21,.18);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.75;
  font-weight:400;
  overflow-x:hidden;
}
body.en{font-family:var(--font-en);}
body.en h1,body.en h2,body.en h3{font-family:var(--font-en);font-weight:600;}
a{text-decoration:none;color:inherit;transition:all .25s ease}
img{max-width:100%;display:block;height:auto}
button{cursor:pointer;font-family:inherit}
ul,ol{list-style:none}

/* ─── LAYOUT UTILITIES ─── */
.container{width:min(1280px,92vw);margin:0 auto}
.section{padding:80px 0;position:relative}
.section-sm{padding:60px 0}
.section-lg{padding:110px 0}
.section-bg{background:var(--paper)}
.section-band{
  background:linear-gradient(135deg,#3b2818 0%,#866137 100%);
  color:#fff;
}
.section-band h2,.section-band p,.section-band h3{color:#fff!important}
.section-band .lead{color:rgba(255,255,255,.85)!important}
.section-band .pill{
  background:rgba(255,255,255,.14);
  color:#fff;
  border-color:rgba(255,255,255,.28);
}

.head{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:24px;
  margin-bottom:36px;
  flex-wrap:wrap;
}
.head h2{margin-top:8px}

h1,h2,h3,h4{font-weight:700;line-height:1.2}
h1{font-size:clamp(38px,6vw,72px);line-height:1.08}
h2{font-size:clamp(30px,4vw,48px);color:var(--brown)}
h3{font-size:clamp(20px,2.5vw,28px)}
h4{font-size:clamp(16px,1.8vw,20px)}
.lead{
  font-size:clamp(16px,1.8vw,19px);
  color:var(--muted);
  max-width:760px;
  font-weight:400;
}

/* ─── PILL / TAG ─── */
.pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  border:1px solid rgba(168,129,75,.35);
  background:rgba(255,255,255,.85);
  border-radius:999px;
  padding:7px 14px;
  color:var(--brown);
  font-weight:700;
  font-size:13px;
  margin-bottom:14px;
  letter-spacing:.5px;
}
.tag{
  display:inline-flex;
  background:var(--brown);
  color:#fff;
  border-radius:999px;
  padding:5px 13px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.5px;
}
.tag-gold{background:linear-gradient(135deg,var(--gold),var(--gold-light));}

/* ─── BUTTONS ─── */
.btn{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  border-radius:999px;
  padding:14px 26px;
  font-weight:800;
  font-size:14px;
  border:1px solid transparent;
  cursor:pointer;
  text-decoration:none;
  transition:all .3s cubic-bezier(.4,0,.2,1);
  letter-spacing:.3px;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-light) 100%);
  color:#fff;
  box-shadow:0 8px 24px rgba(168,129,75,.35);
}
.btn-primary:hover{box-shadow:0 14px 32px rgba(168,129,75,.5)}
.btn-ghost{
  background:#fff;
  border-color:var(--line);
  color:var(--brown);
}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-outline{
  background:transparent;
  border-color:rgba(255,255,255,.5);
  color:#fff;
}
.btn-outline:hover{background:#fff;color:var(--brown)}
.btn-whatsapp{
  background:var(--whatsapp);
  color:#fff;
  box-shadow:0 6px 18px rgba(37,211,102,.35);
}
.btn-whatsapp:hover{background:var(--green-dark)}
.btn-sm{padding:10px 18px;font-size:13px}
.btn-lg{padding:18px 36px;font-size:16px}

/* ─── TOP TRUST BAR ─── */
.trust-bar{
  background:linear-gradient(90deg,var(--gold-dark) 0%,var(--gold) 50%,var(--gold-dark) 100%);
  color:#fff;
  padding:9px 16px;
  font-size:13px;
  text-align:center;
  position:relative;
  z-index:60;
  font-weight:600;
  letter-spacing:.4px;
}
.trust-bar-inner{
  display:inline-flex;
  align-items:center;
  gap:1.5rem;
  flex-wrap:wrap;
  justify-content:center;
}
.trust-item{display:inline-flex;align-items:center;gap:6px}
.trust-item strong{color:#fff;font-weight:800}
.trust-sep{
  width:1px;
  height:14px;
  background:rgba(255,255,255,.3);
}
@media(max-width:768px){
  .trust-bar{padding:7px 10px;font-size:11px}
  .trust-bar-inner{gap:.6rem}
  .trust-sep{display:none}
}

/* ─── HEADER ─── */
.site-hdr{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(250,246,239,.95);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--line);
}
.hdr-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  height:78px;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:900;
  text-decoration:none;
  color:var(--brown);
}
.brand img{
  width:50px;
  height:50px;
  object-fit:contain;
}
.brand-text{
  display:flex;
  flex-direction:column;
  line-height:1.1;
}
.brand-ar{font-family:'Noto Serif Arabic',serif;font-size:20px;color:var(--brown);font-weight:700}
.brand-en{font-size:11px;letter-spacing:2px;color:var(--gold-dark);font-weight:600;text-transform:uppercase}

.hdr-menu{
  display:flex;
  gap:18px;
  font-size:14px;
  font-weight:700;
  color:var(--muted);
}
.hdr-menu a{position:relative;padding:6px 2px}
.hdr-menu a:hover,.hdr-menu a.active{color:var(--gold-dark)}
.hdr-menu a.active::after{
  content:'';
  position:absolute;
  bottom:0;left:0;right:0;
  height:2px;
  background:var(--gold);
}

.hdr-actions{
  display:flex;
  align-items:center;
  gap:12px;
}
.lang-curr-toggle{
  display:flex;
  gap:8px;
}
.lc-btn{
  background:transparent;
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 12px;
  font-size:12px;
  font-weight:700;
  color:var(--muted);
  cursor:pointer;
  transition:all .25s;
}
.lc-btn:hover{border-color:var(--gold);color:var(--gold-dark)}

/* MOBILE MENU */
.menu-toggle{
  display:none;
  background:transparent;
  border:none;
  font-size:24px;
  color:var(--brown);
  cursor:pointer;
  padding:6px;
}
.mobile-menu{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.5);
  z-index:100;
  display:none;
}
.mobile-menu.open{display:block}
.mobile-menu-inner{
  position:absolute;
  top:0;right:0;bottom:0;
  width:min(320px,80vw);
  background:#fff;
  padding:30px 24px;
  overflow-y:auto;
}
body.en .mobile-menu-inner{right:auto;left:0}
.mobile-menu-close{
  background:transparent;
  border:none;
  font-size:24px;
  color:var(--brown);
  cursor:pointer;
  margin-bottom:24px;
}
.mobile-menu a{
  display:block;
  padding:14px 0;
  border-bottom:1px solid var(--line);
  font-weight:700;
  color:var(--brown);
}
.mobile-menu a.active{color:var(--gold-dark)}

/* ─── HERO ─── */
.hero{
  position:relative;
  color:#fff;
  background:#1a1310;
  overflow:hidden;
  min-height:480px;
}
.hero-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
}
.hero::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(18,14,10,.85) 0%,rgba(18,14,10,.55) 50%,rgba(18,14,10,.35) 100%);
  z-index:1;
}
.hero-content{
  position:relative;
  z-index:2;
  padding:90px 0;
}
.hero-home{
  min-height:calc(100vh - 78px);
  display:flex;
  align-items:center;
}
.hero-home .container{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:50px;
  align-items:center;
  width:100%;
}
.hero h1{
  color:#fff;
  margin:14px 0 18px;
}
.hero p{
  font-size:clamp(16px,1.8vw,20px);
  color:#f5eadb;
  max-width:680px;
  margin-bottom:30px;
}
.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

/* HERO BOOKING WIDGET */
.hero-widget{
  background:rgba(255,253,250,.96);
  backdrop-filter:blur(20px);
  border-radius:30px;
  padding:24px;
  box-shadow:var(--shadow);
}
.hw-title{
  font-size:14px;
  font-weight:800;
  color:var(--brown);
  margin-bottom:16px;
  letter-spacing:.5px;
}
.hw-form{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.hw-field{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.hw-field label{
  font-size:11px;
  color:var(--muted);
  font-weight:700;
  letter-spacing:.5px;
  text-transform:uppercase;
}
.hw-field input,.hw-field select{
  padding:13px 14px;
  border-radius:14px;
  border:1px solid var(--line);
  font:inherit;
  font-size:14px;
  background:#fff;
  color:var(--ink);
}
.hw-field input:focus,.hw-field select:focus{
  outline:none;
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(168,129,75,.15);
}
.hw-submit{
  grid-column:1 / -1;
  margin-top:6px;
}

/* HERO STATS */
.hero-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-top:32px;
  max-width:580px;
}
.hero-stat{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  border-radius:18px;
  padding:14px 16px;
  text-align:center;
  backdrop-filter:blur(8px);
}
.hero-stat b{
  display:block;
  color:#ffe1a8;
  font-size:24px;
  font-weight:900;
  line-height:1.1;
  margin-bottom:4px;
}
.hero-stat span{
  font-size:11px;
  color:rgba(255,255,255,.85);
  letter-spacing:.5px;
}

/* GENERIC HERO (non-home) */
.hero-page{
  min-height:340px;
  display:flex;
  align-items:center;
  background-size:cover;
  background-position:center;
}
.hero-page .container{position:relative;z-index:2;text-align:center}

/* ─── GRIDS ─── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

/* ─── CARDS ─── */
.card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
  transition:all .35s cubic-bezier(.4,0,.2,1);
  display:flex;
  flex-direction:column;
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow);
}
.card-img{
  position:relative;
  height:240px;
  overflow:hidden;
}
.card-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .6s ease;
}
.card:hover .card-img img{transform:scale(1.05)}
.card-badge{
  position:absolute;
  top:14px;
  font-size:11px;
  font-weight:700;
  padding:5px 12px;
  border-radius:999px;
  letter-spacing:.5px;
}
.card-badge.popular{
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  color:#fff;
  right:14px;
}
body.en .card-badge.popular{right:auto;left:14px}
.card-body{
  padding:24px;
  display:flex;
  flex-direction:column;
  flex:1;
}
.card-body h3{
  margin-bottom:8px;
  color:var(--brown);
}
.card-body p{color:var(--muted);font-size:14px;margin-bottom:14px;flex:1}

/* PRICING */
.pricing{
  border-top:1px solid var(--line);
  padding-top:14px;
  margin-bottom:14px;
}
.price-from{
  font-size:11px;
  color:var(--muted);
  font-weight:600;
  letter-spacing:.5px;
  text-transform:uppercase;
}
.price-orig{
  text-decoration:line-through;
  color:#aaa;
  font-size:14px;
  margin-right:6px;
}
body.en .price-orig{margin-right:0;margin-left:6px}
.price-now{
  font-size:24px;
  font-weight:900;
  color:var(--gold-dark);
}
.price-unit{
  font-size:12px;
  color:var(--muted);
  margin-left:4px;
}
.price-asterisk{
  display:block;
  font-size:10px;
  color:var(--muted);
  margin-top:4px;
  font-style:italic;
}

/* AMENITIES */
.amenities{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-bottom:14px;
}
.amenity{
  background:#f5eddf;
  color:var(--brown);
  border-radius:999px;
  padding:4px 11px;
  font-size:12px;
  font-weight:600;
}

/* CARD ACTIONS */
.card-actions{
  display:flex;
  gap:8px;
  margin-top:auto;
}
.card-actions .btn{flex:1;font-size:13px;padding:12px 14px}
.card-actions .btn-whatsapp{flex:0 0 auto;padding:12px 16px}

/* ─── BOXES (icon boxes) ─── */
.box{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
  box-shadow:var(--shadow-sm);
  transition:all .3s;
  display:block;
  color:var(--ink);
}
a.box:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
  border-color:var(--gold);
}
.box-icon{
  width:54px;
  height:54px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,#f2e4ce,#e8d4ad);
  font-size:26px;
  margin-bottom:16px;
}
.box h3{margin-bottom:8px;color:var(--brown)}
.box p{color:var(--muted);font-size:14px}

/* ─── GALLERY ─── */
.gallery{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:14px;
}
.gallery img{
  height:260px;
  width:100%;
  object-fit:cover;
  border-radius:var(--radius);
  transition:transform .4s;
  cursor:pointer;
}
.gallery img:hover{transform:scale(1.02)}
.gallery img:first-child{height:534px;grid-row:span 2}

/* GALLERY 2x2 */
.gallery-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.gallery-2 img{height:280px;border-radius:var(--radius);object-fit:cover}

/* ─── VIDEO SECTION ─── */
.video-section{position:relative}
.video-card{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  border-radius:34px;
  padding:14px;
  box-shadow:var(--shadow);
}
.video-card video{
  display:block;
  width:100%;
  max-height:560px;
  object-fit:cover;
  border-radius:24px;
  background:#111;
}

/* ─── RATINGS ─── */
.ratings{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin:30px 0;
}
.rating-card{
  background:#fff;
  border:1px solid var(--line);
  border-top:4px solid var(--gold);
  border-radius:var(--radius);
  padding:32px 24px;
  text-align:center;
  box-shadow:var(--shadow-sm);
}
.rating-num{
  font-size:48px;
  font-weight:900;
  color:var(--gold-dark);
  line-height:1;
  margin-bottom:8px;
}
.rating-source{
  font-size:14px;
  font-weight:700;
  color:var(--brown);
  margin-bottom:4px;
}
.rating-label{
  font-size:12px;
  color:var(--muted);
  font-style:italic;
}

/* ─── REVIEWS ─── */
.review{
  background:#fff;
  border-left:4px solid var(--gold);
  padding:24px;
  border-radius:0 var(--radius) var(--radius) 0;
  box-shadow:var(--shadow-sm);
  margin-bottom:18px;
}
body.en .review{
  border-left:none;
  border-right:4px solid var(--gold);
  border-radius:var(--radius) 0 0 var(--radius);
}
.review-text{
  font-size:15px;
  color:var(--ink);
  font-style:italic;
  margin-bottom:14px;
  line-height:1.7;
}
.review-translated{
  font-size:13px;
  color:var(--muted);
  font-style:italic;
  padding-left:16px;
  border-left:2px solid var(--line);
  margin-top:10px;
}
.review-author{
  font-weight:800;
  color:var(--gold-dark);
  font-size:14px;
}
.review-meta{
  font-size:12px;
  color:var(--muted);
  margin-top:4px;
}
.review-translated-tag{
  display:inline-block;
  font-size:10px;
  color:var(--muted);
  background:#f5eddf;
  padding:2px 8px;
  border-radius:999px;
  margin-top:6px;
}

/* ─── FAQ ─── */
.faq-item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  margin-bottom:12px;
  overflow:hidden;
}
.faq-q{
  padding:20px 24px;
  font-weight:700;
  cursor:pointer;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  color:var(--brown);
  background:#fff;
  border:none;
  width:100%;
  text-align:right;
  font-size:15px;
  font-family:inherit;
}
body.en .faq-q{text-align:left}
.faq-q::after{
  content:'+';
  font-size:24px;
  color:var(--gold);
  transition:transform .3s;
}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{
  padding:0 24px;
  max-height:0;
  overflow:hidden;
  transition:max-height .4s,padding .4s;
  color:var(--muted);
  font-size:14px;
  line-height:1.8;
}
.faq-item.open .faq-a{
  padding:0 24px 22px;
  max-height:500px;
}

/* ─── COMPARE TABLE ─── */
.compare{
  width:100%;
  border-collapse:collapse;
  background:#fff;
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}
.compare th,.compare td{
  padding:16px;
  border-bottom:1px solid var(--line);
  text-align:right;
  font-size:14px;
}
body.en .compare th,body.en .compare td{text-align:left}
.compare th{
  background:#f5eddf;
  color:var(--brown);
  font-weight:800;
}
.compare tr:last-child td{border-bottom:none}

/* ─── FORMS ─── */
.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.form-field{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.form-field label{
  font-size:13px;
  font-weight:700;
  color:var(--brown);
}
.form-field input,.form-field select,.form-field textarea{
  padding:13px 14px;
  border-radius:14px;
  border:1px solid var(--line);
  font:inherit;
  font-size:14px;
  background:#fff;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  outline:none;
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(168,129,75,.15);
}
.form-field-full{grid-column:1 / -1}
.form-field textarea{min-height:130px;resize:vertical;font-family:inherit}

/* ─── INFO CARD ─── */
.info-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:32px;
  box-shadow:var(--shadow-sm);
}
.info-card h3{margin-bottom:16px;color:var(--brown)}
.info-card ul li{
  padding:10px 0;
  border-bottom:1px dashed var(--line);
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:var(--ink);
  font-size:14px;
}
.info-card ul li:last-child{border-bottom:none}
.info-card ul li::before{
  content:'✓';
  color:var(--gold);
  font-weight:900;
  flex-shrink:0;
}

/* ─── FOOTER ─── */
.footer{
  background:linear-gradient(180deg,#1e1815 0%,#0f0b09 100%);
  color:rgba(255,255,255,.7);
  padding:60px 0 0;
  border-top:3px solid var(--gold);
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1.4fr;
  gap:40px;
  padding-bottom:40px;
}
.footer-brand img{
  width:auto;
  height:84px;
  margin-bottom:18px;
  filter:drop-shadow(0 0 8px rgba(168,129,75,.15));
}
.footer-brand p{
  font-size:14px;
  line-height:1.85;
  color:rgba(255,255,255,.55);
  max-width:340px;
}
.footer-col h4{
  color:var(--gold);
  font-size:13px;
  font-weight:800;
  letter-spacing:2.5px;
  text-transform:uppercase;
  margin-bottom:18px;
  padding-bottom:10px;
  border-bottom:1px solid rgba(168,129,75,.2);
}
.footer-col ul li{margin-bottom:10px}
.footer-col a{
  color:rgba(255,255,255,.6);
  font-size:14px;
  transition:color .25s;
}
.footer-col a:hover{color:var(--gold-light)}
.footer-contact p{
  margin-bottom:10px;
  font-size:14px;
  display:flex;
  gap:8px;
  align-items:flex-start;
}
.footer-contact .fc-icon{color:var(--gold);font-size:14px;flex-shrink:0}

.footer-bot{
  border-top:1px solid rgba(168,129,75,.15);
  padding:22px 0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
  font-size:12px;
  color:rgba(255,255,255,.4);
}

/* ─── FLOATING BUTTONS ─── */
.fab-stack{
  position:fixed;
  bottom:20px;
  right:20px;
  display:flex;
  flex-direction:column;
  gap:12px;
  z-index:40;
  opacity:0;
  pointer-events:none;
  transition:all .4s ease;
}
body.en .fab-stack{right:auto;left:20px}
.fab-stack.show{opacity:1;pointer-events:auto}
.fab-book{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  color:#fff;
  padding:14px 22px;
  border-radius:50px;
  font-size:13px;
  font-weight:800;
  letter-spacing:1px;
  text-transform:uppercase;
  border:none;
  cursor:pointer;
  box-shadow:0 8px 24px rgba(168,129,75,.4);
  text-decoration:none;
  animation:fabPulse 2.5s infinite;
}
.fab-book:hover{transform:translateY(-2px) scale(1.04)}
@keyframes fabPulse{
  0%,100%{box-shadow:0 8px 24px rgba(168,129,75,.4),0 0 0 0 rgba(216,176,111,.5)}
  50%{box-shadow:0 8px 24px rgba(168,129,75,.4),0 0 0 14px rgba(216,176,111,0)}
}
.fab-wa{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:54px;height:54px;
  background:var(--whatsapp);
  border-radius:50%;
  box-shadow:0 6px 20px rgba(37,211,102,.4);
  transition:all .3s;
}
.fab-wa:hover{transform:scale(1.1)}
.fab-wa svg{width:30px;height:30px;fill:#fff}

/* MOBILE BAR */
.mobile-bar{
  display:none;
  position:fixed;
  bottom:0;left:0;right:0;
  background:#fff;
  padding:10px 14px;
  border-top:1px solid var(--line);
  z-index:45;
  gap:10px;
}
.mobile-bar .btn{flex:1}

/* ─── BILINGUAL DISPLAY ─── */
[data-en]{display:none}
body.en [data-ar]{display:none}
body.en [data-en]{display:inline}

/* ─── ANIMATIONS ─── */
.fade-in{
  opacity:0;
  transform:translateY(20px);
  transition:all .8s ease;
}
.fade-in.visible{
  opacity:1;
  transform:translateY(0);
}

/* ─── RESPONSIVE ─── */
@media(max-width:1100px){
  .hdr-menu{display:none}
  .menu-toggle{display:block}
  .hero-home .container{grid-template-columns:1fr;gap:30px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media(max-width:768px){
  .section{padding:60px 0}
  .section-lg{padding:80px 0}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;gap:18px}
  .ratings{grid-template-columns:1fr;gap:14px}
  .gallery,.gallery-2{grid-template-columns:1fr 1fr}
  .gallery img:first-child{grid-row:auto;height:280px;grid-column:1 / -1}
  .form-grid{grid-template-columns:1fr}
  .hw-form{grid-template-columns:1fr}
  .hero-stats{grid-template-columns:repeat(3,1fr);gap:8px}
  .hero-stat b{font-size:18px}
  .hero-stat span{font-size:9px}
  .head{flex-direction:column;align-items:flex-start}
  .footer-grid{grid-template-columns:1fr;text-align:center}
  .footer-brand p{max-width:100%}
  .mobile-bar{display:flex}
  body{padding-bottom:78px}
  .fab-stack{bottom:90px;right:14px}
  body.en .fab-stack{left:14px}
  .footer-bot{flex-direction:column;text-align:center}
}
@media(max-width:520px){
  .hero h1{font-size:34px}
  .compare{font-size:12px}
  .compare th,.compare td{padding:10px 8px}
}

/* ─── PAGE-SPECIFIC OVERLAY FOR HEROES ─── */
.hero-page::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(18,14,10,.75),rgba(18,14,10,.55));
  z-index:1;
}
.hero-page > .container{position:relative;z-index:2}
.hero-page h1{margin:14px 0 12px}
.hero-page p{font-size:18px;color:#f5eadb;max-width:640px;margin:0 auto}

/* ═══ APARTMENT GALLERY MODAL ═══ */
.apt-modal{
  position:fixed;inset:0;
  background:rgba(0,0,0,.92);
  z-index:1000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:20px;
}
.apt-modal.open{display:flex}
.am-content{
  max-width:1100px;
  width:100%;
  background:#fff;
  border-radius:24px;
  overflow:hidden;
  position:relative;
  max-height:92vh;
  display:flex;
  flex-direction:column;
}
.am-close{
  position:absolute;
  top:14px;right:14px;
  background:rgba(0,0,0,.6);
  color:#fff;
  border:none;
  width:42px;height:42px;
  border-radius:50%;
  font-size:24px;
  cursor:pointer;
  z-index:5;
  transition:all .2s;
}
.am-close:hover{background:rgba(0,0,0,.85);transform:scale(1.05)}
body.en .am-close{right:auto;left:14px}

.am-slider{
  position:relative;
  background:#000;
  height:480px;
}
.am-slider img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:none;
}
.am-slider img.active{display:block}
.am-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  background:rgba(255,255,255,.9);
  border:none;
  width:46px;height:46px;
  border-radius:50%;
  font-size:22px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--brown);
  font-weight:700;
  box-shadow:0 4px 12px rgba(0,0,0,.3);
  transition:all .2s;
}
.am-nav:hover{background:#fff;transform:translateY(-50%) scale(1.1)}
.am-prev{right:14px}
.am-next{left:14px}
body.en .am-prev{right:auto;left:14px}
body.en .am-next{left:auto;right:14px}
.am-counter{
  position:absolute;
  bottom:14px;
  left:50%;
  transform:translateX(-50%);
  background:rgba(0,0,0,.6);
  color:#fff;
  padding:6px 14px;
  border-radius:50px;
  font-size:13px;
  font-weight:600;
}
.am-thumbs{
  display:flex;
  gap:8px;
  padding:14px;
  background:#f8f5f0;
  overflow-x:auto;
  border-bottom:1px solid var(--line);
}
.am-thumbs img{
  width:80px;
  height:60px;
  object-fit:cover;
  border-radius:8px;
  cursor:pointer;
  opacity:.5;
  transition:all .25s;
  flex-shrink:0;
  border:2px solid transparent;
}
.am-thumbs img:hover{opacity:.8}
.am-thumbs img.active{opacity:1;border-color:var(--gold)}
.am-body{
  padding:24px 28px;
  overflow-y:auto;
}
.am-title{
  color:var(--brown);
  font-size:24px;
  margin-bottom:6px;
}
.am-subtitle{
  color:var(--muted);
  margin-bottom:14px;
  font-size:15px;
}
.am-features{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:18px;
}
.am-feature{
  background:#f5eddf;
  color:var(--brown);
  border-radius:50px;
  padding:6px 14px;
  font-size:13px;
  font-weight:600;
}
.am-pricing{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  margin-bottom:18px;
}
.am-from-label{
  font-size:11px;
  color:var(--muted);
  font-weight:700;
  letter-spacing:.5px;
  text-transform:uppercase;
}
.am-price-now{
  font-size:30px;
  font-weight:900;
  color:var(--gold-dark);
  line-height:1;
}
.am-price-orig{
  text-decoration:line-through;
  color:#aaa;
  font-size:16px;
}
.am-price-unit{
  font-size:14px;
  color:var(--muted);
}
.am-actions{
  display:flex;
  gap:10px;
}
.am-actions .btn{flex:1}

@media(max-width:768px){
  .am-slider{height:280px}
  .am-thumbs img{width:60px;height:45px}
  .am-title{font-size:20px}
  .am-price-now{font-size:24px}
  .am-body{padding:18px 20px}
  .am-actions{flex-direction:column}
}

/* Make apartment cards clickable */
.card.clickable{cursor:pointer}
.card.clickable .card-img::after{
  content:'🔍';
  position:absolute;
  bottom:14px;
  right:14px;
  background:rgba(255,255,255,.95);
  width:38px;height:38px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  box-shadow:0 4px 12px rgba(0,0,0,.2);
  transition:all .3s;
}
body.en .card.clickable .card-img::after{right:auto;left:14px}
.card.clickable:hover .card-img::after{
  background:var(--gold);
  transform:scale(1.1);
}

/* ════════════════════════════════════════════════════════════
   v23 PREMIUM UPGRADES
   ════════════════════════════════════════════════════════════ */

/* ─── PREMIUM HERO (CENTERED, DARK OVERLAY) ─── */
.hero-premium{
  position:relative;
  min-height:88vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#fff;
  background:#0a0a0a;
  overflow:hidden;
}
.hero-premium .hero-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
}
.hero-premium::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,
    rgba(0,0,0,0.55) 0%,
    rgba(0,0,0,0.45) 50%,
    rgba(0,0,0,0.65) 100%);
  z-index:1;
}
.hero-premium .container{
  position:relative;
  z-index:2;
  max-width:900px;
}
.hero-premium .hero-eyebrow{
  display:inline-block;
  padding:8px 20px;
  border:1px solid rgba(216,176,111,.6);
  background:rgba(0,0,0,.3);
  color:var(--gold-light);
  border-radius:50px;
  font-size:13px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  margin-bottom:24px;
  backdrop-filter:blur(10px);
}
.hero-premium h1{
  color:#fff;
  font-size:clamp(42px, 7vw, 88px);
  font-weight:800;
  line-height:1.05;
  margin-bottom:20px;
  text-shadow:0 4px 30px rgba(0,0,0,.4);
}
.hero-premium .hero-tagline{
  font-size:clamp(17px, 2vw, 22px);
  color:rgba(255,255,255,.92);
  font-weight:400;
  margin-bottom:14px;
  letter-spacing:.3px;
}
.hero-premium .hero-tagline strong{
  color:var(--gold-light);
  font-weight:600;
}
.hero-premium .hero-sub{
  font-size:clamp(14px, 1.5vw, 16px);
  color:rgba(255,255,255,.75);
  margin-bottom:40px;
  font-style:italic;
}
.hero-premium .hero-actions{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
}
.hero-premium .btn-lg{
  padding:18px 40px;
  font-size:15px;
  letter-spacing:1px;
}

/* Make hero section fade-in elegantly */
.hero-premium .container > * {
  opacity:0;
  animation:heroFadeUp 1s ease-out forwards;
}
.hero-premium .hero-eyebrow { animation-delay:.2s; }
.hero-premium h1 { animation-delay:.4s; }
.hero-premium .hero-tagline { animation-delay:.6s; }
.hero-premium .hero-sub { animation-delay:.7s; }
.hero-premium .hero-actions { animation-delay:.8s; }

@keyframes heroFadeUp{
  from{ opacity:0; transform:translateY(20px); }
  to{ opacity:1; transform:translateY(0); }
}

/* ─── STRONGER CARD HOVER ─── */
.card{
  transition:all .45s cubic-bezier(.4,0,.2,1);
}
.card:hover{
  transform:translateY(-8px);
  box-shadow:0 30px 60px rgba(73,48,21,.18);
}
.card.clickable .card-img::after{
  background:rgba(255,255,255,.95);
  width:46px;height:46px;
  font-size:18px;
  opacity:0;
  transition:all .35s;
}
.card.clickable:hover .card-img::after{
  opacity:1;
  background:var(--gold);
  color:#fff;
  transform:scale(1.08);
}

/* ─── STICKY MOBILE BOOK BUTTON (Single, Bold) ─── */
.mobile-book-bar{
  display:none;
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  background:#000;
  padding:14px 20px;
  z-index:100;
  box-shadow:0 -8px 24px rgba(0,0,0,.25);
}
.mobile-book-bar a{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  background:#fff;
  color:#000;
  padding:14px;
  border-radius:50px;
  font-weight:800;
  font-size:15px;
  letter-spacing:.5px;
  text-decoration:none;
  transition:all .3s;
  text-transform:uppercase;
}
.mobile-book-bar a:hover{
  background:var(--gold);
  color:#fff;
}

/* ─── WHY US SECTION ─── */
.why-us-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  margin-top:40px;
}
.why-us-item{
  text-align:center;
  padding:32px 20px;
  background:#fff;
  border-radius:var(--radius);
  border:1px solid var(--line);
  transition:all .35s ease;
}
.why-us-item:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow);
  border-color:var(--gold);
}
.why-us-icon{
  width:72px;
  height:72px;
  margin:0 auto 18px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,#f5eddf,#e8d4ad);
  font-size:32px;
}
.why-us-item h3{
  color:var(--brown);
  font-size:18px;
  margin-bottom:8px;
  font-weight:700;
}
.why-us-item p{
  color:var(--muted);
  font-size:13px;
  line-height:1.7;
}

/* ─── BIGGER HEADINGS, MORE WHITESPACE ─── */
.section-lg{ padding:120px 0; }
.section{ padding:90px 0; }
@media(max-width:768px){
  .section-lg{ padding:70px 0; }
  .section{ padding:60px 0; }
}

h2{ font-size:clamp(32px, 4.5vw, 56px); font-weight:800; letter-spacing:-.5px; }

/* Reduce header link sizes slightly to allow more menu items */
.hdr-menu a { font-size:13px; }

/* ─── RESPONSIVE ADJUSTMENTS ─── */
@media(max-width:1100px){
  .why-us-grid{ grid-template-columns:repeat(2,1fr); }
}
@media(max-width:768px){
  .hero-premium{ min-height:78vh; }
  .why-us-grid{ grid-template-columns:1fr 1fr; gap:14px; }
  .why-us-item{ padding:24px 14px; }
  .why-us-icon{ width:60px; height:60px; font-size:26px; }
  
  .mobile-book-bar{ display:block; }
  body{ padding-bottom:78px; }
  
  /* Hide old mobile-bar on mobile (replaced by mobile-book-bar) */
  .mobile-bar{ display:none !important; }
  
  /* Adjust floating buttons to be above sticky book bar */
  .fab-stack{ bottom:90px; }
}

/* ─── EXPANDED GALLERY THUMBNAILS (for 6-8 images) ─── */
.am-thumbs{
  flex-wrap:wrap;
}

/* ─── APARTMENT MODAL DETAILS ROW ─── */
.am-details-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin-bottom:18px;
  padding:14px;
  background:#faf6ef;
  border-radius:14px;
  border:1px solid var(--line);
}
.am-detail-item{
  display:flex;
  align-items:center;
  gap:10px;
}
.am-detail-icon{
  font-size:22px;
  flex-shrink:0;
}
.am-detail-label{
  font-size:11px;
  color:var(--muted);
  font-weight:600;
  letter-spacing:.4px;
  text-transform:uppercase;
}
.am-detail-value{
  font-size:14px;
  color:var(--brown);
  font-weight:700;
}
@media(max-width:600px){
  .am-details-row{ grid-template-columns:1fr; gap:8px; padding:12px; }
}

/* Mobile adjustments */
@media(max-width:768px){
  
  
  .bm-title{
    font-size:13px;
  }
  
  
  
}



/* ════════════════════════════════════════════════════════════
   v26 — TRANSITION MODAL (Elegant New-Tab Booking)
   Replaces the iframe modal with a friendly transition card
   ════════════════════════════════════════════════════════════ */

.booking-modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.85);
  z-index:2000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:20px;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.booking-modal.open{
  display:flex;
  animation:bmFadeIn .35s cubic-bezier(.4,0,.2,1);
}
@keyframes bmFadeIn{
  from{ opacity:0 }
  to{ opacity:1 }
}

.bm-content-transition{
  background:linear-gradient(180deg,#fffdfa 0%,#faf6ef 100%);
  border-radius:24px;
  padding:48px 40px 36px;
  max-width:520px;
  width:100%;
  text-align:center;
  position:relative;
  box-shadow:0 30px 80px rgba(0,0,0,.4);
  border:1px solid rgba(168,129,75,.2);
  animation:bmSlideUp .4s cubic-bezier(.4,0,.2,1);
}
@keyframes bmSlideUp{
  from{ opacity:0; transform:translateY(20px) scale(.96); }
  to{ opacity:1; transform:translateY(0) scale(1); }
}

.bm-close-x{
  position:absolute;
  top:14px;
  right:14px;
  background:rgba(168,129,75,.1);
  border:none;
  width:36px;height:36px;
  border-radius:50%;
  font-size:20px;
  cursor:pointer;
  color:var(--brown);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .25s;
}
body.en .bm-close-x{ right:auto; left:14px; }
.bm-close-x:hover{
  background:var(--gold);
  color:#fff;
  transform:rotate(90deg);
}

/* Animated icon */
.bm-trans-icon{
  position:relative;
  width:96px;
  height:96px;
  margin:0 auto 24px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.bm-trans-pulse{
  position:absolute;
  inset:0;
  border-radius:50%;
  background:linear-gradient(135deg,#d8b06f,#f5e0a8);
  opacity:.3;
  animation:bmPulse 2s ease-in-out infinite;
}
@keyframes bmPulse{
  0%,100%{ transform:scale(1); opacity:.3; }
  50%{ transform:scale(1.15); opacity:.15; }
}
.bm-trans-emoji{
  position:relative;
  font-size:48px;
  z-index:1;
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  width:80px;height:80px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 12px 30px rgba(168,129,75,.35);
}

.bm-trans-title{
  font-size:28px;
  color:var(--brown);
  margin-bottom:10px;
  font-weight:800;
  letter-spacing:-.3px;
}

.bm-trans-subtitle{
  color:var(--muted);
  font-size:15px;
  line-height:1.6;
  margin-bottom:28px;
  max-width:380px;
  margin-left:auto;
  margin-right:auto;
}

/* Features list */
.bm-trans-features{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:30px;
  padding:18px 20px;
  background:rgba(168,129,75,.06);
  border:1px solid rgba(168,129,75,.15);
  border-radius:14px;
}
.bm-trans-feature{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:14px;
  color:var(--ink);
  font-weight:600;
  text-align:start;
}
.bm-tf-icon{
  font-size:18px;
  flex-shrink:0;
}

/* Action buttons */
.bm-trans-actions{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:18px;
}
.bm-trans-go{
  width:100%;
  padding:16px 24px;
  font-size:15px;
  letter-spacing:.5px;
  box-shadow:0 12px 28px rgba(168,129,75,.4);
  animation:bmGoPulse 2.5s ease-in-out infinite;
}
@keyframes bmGoPulse{
  0%,100%{ box-shadow:0 12px 28px rgba(168,129,75,.4); }
  50%{ box-shadow:0 12px 36px rgba(168,129,75,.6); }
}
.bm-trans-go:focus{
  outline:3px solid var(--gold-light);
  outline-offset:3px;
}

.bm-trans-note{
  font-size:12px;
  color:var(--muted);
  font-style:italic;
  margin-top:10px;
}

/* Mobile */
@media(max-width:600px){
  .bm-content-transition{
    padding:36px 24px 28px;
    border-radius:20px;
  }
  .bm-trans-title{ font-size:22px; }
  .bm-trans-subtitle{ font-size:14px; }
  .bm-trans-feature{ font-size:13px; }
  .bm-trans-icon{ width:80px; height:80px; }
  .bm-trans-emoji{ width:64px; height:64px; font-size:36px; }
}


/* ════════════════════════════════════════════════════════════
   MOBILE HEADER FIXES (v27 - improved)
   Show brand text always, just sized appropriately
   ════════════════════════════════════════════════════════════ */

@media(max-width:768px){
  .hdr-inner{
    height:auto;
    min-height:60px;
    padding:8px 0;
    gap:6px;
  }
  
  /* Brand: always visible */
  .brand{
    gap:8px;
    flex-shrink:1;
    min-width:0;
  }
  .brand img{
    width:42px;
    height:42px;
    flex-shrink:0;
  }
  .brand-text{
    line-height:1.05;
    overflow:hidden;
    display:flex !important;  /* Override any previous hide */
    flex-direction:column;
  }
  .brand-ar{
    font-size:14px;
    white-space:nowrap;
  }
  .brand-en{
    font-size:9px;
    letter-spacing:1px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    max-width:120px;
  }
  
  /* Header actions: compact */
  .hdr-actions{
    gap:5px;
    flex-shrink:0;
  }
  .hdr-actions .btn-sm{
    padding:8px 12px;
    font-size:12px;
  }
  .lc-btn{
    padding:5px 8px;
    font-size:11px;
  }
  .menu-toggle{
    font-size:22px;
    padding:4px;
  }
}

@media(max-width:480px){
  /* On very small screens, shorten brand text */
  .brand img{
    width:38px;
    height:38px;
  }
  .brand-ar{
    font-size:13px;
  }
  .brand-en{
    font-size:8px;
    max-width:90px;
  }
  .hdr-actions{
    gap:4px;
  }
  .lc-btn{
    padding:4px 6px;
    font-size:10px;
  }
  .hdr-actions .btn-sm{
    padding:7px 10px;
    font-size:11px;
  }
}

@media(max-width:380px){
  /* Tiny screens — keep AR text only, hide EN subtitle */
  .brand-en{
    display:none;
  }
  .brand-ar{
    font-size:14px;
  }
}

/* Remove padding-bottom that was for old mobile-book-bar */
@media(max-width:768px){
  body{ padding-bottom:0 !important; }
  .fab-stack{ bottom:20px !important; }
}
