:root{
  --emerald-900:#072019;
  --emerald-800:#0b2c22;
  --emerald-700:#114231;
  --emerald-600:#16573f;
  --emerald-500:#1f6b50;
  --cream:#f5efe1;
  --cream-2:#efe6d2;
  --sand:#e4d4b2;
  --gold:#c6a35e;
  --gold-soft:#d9bd86;
  --ink:#16241d;
  --ink-soft:#3f5046;
  --line:rgba(20,45,35,.14);
  --display:"Cormorant Garamond", Georgia, serif;
  --sans:"Jost", system-ui, sans-serif;
  --mono:"DM Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --maxw:1180px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:130px;background:linear-gradient(180deg, var(--emerald-800), var(--emerald-900) 70%) fixed, var(--emerald-900);}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:transparent;
  -webkit-font-smoothing:antialiased;
}
body[data-lang="ar"]{ --display:"El Messiri", Georgia, serif; --sans:"Tajawal", system-ui, sans-serif; }
body[data-lang="ar"] .marquee-item i{ display:none; }

/* ===== Warm "Oasis" theme — derived from the salon interior photos ===== */
[data-theme="oasis"]{
  --emerald-900:#221a13;
  --emerald-800:#2c2218;
  --emerald-700:#3e3022;
  --emerald-600:#4d3b29;
  --emerald-500:#634d37;
  --cream:#f6eddc;
  --cream-2:#efe3cd;
  --sand:#e4d2b0;
  --gold:#b98f50;
  --gold-soft:#d9b97e;
  --ink:#352a20;
  --ink-soft:#6f5c48;
  --line:rgba(53,42,32,.15);
}
[data-theme="oasis"] .site-head.scrolled{ background:rgba(34,26,19,.72); }
[data-theme="oasis"] .mobile-menu{ background:rgba(34,26,19,.96); }
[data-theme="oasis"] .hero::before{ background:linear-gradient(95deg, rgba(20,14,9,.5) 0%, rgba(20,14,9,.15) 42%, transparent 65%); }
[data-theme="oasis"] .surface{ background:linear-gradient(180deg, rgba(246,237,220,.93), rgba(238,227,205,.96)); }
[data-theme="oasis"] .promo-card{ background:linear-gradient(135deg, rgba(44,34,24,.94), rgba(62,48,34,.94)); border-color:rgba(185,143,80,.45); }

/* images that fill a framed container */
.frame-img{ width:100%; height:100%; object-fit:cover; display:block; }

/* ===== "Emerald & Sand" — deep forest emerald + warm sand neutrals + brass ===== */
[data-theme="esand"]{
  --emerald-900:#0c241b;
  --emerald-800:#103024;
  --emerald-700:#1c4a37;
  --emerald-600:#235a43;
  --emerald-500:#2f6e52;
  --cream:#f6eddc;
  --cream-2:#efe3cd;
  --sand:#e4d2b0;
  --gold:#bb9152;
  --gold-soft:#d9b97e;
  --ink:#27291f;
  --ink-soft:#5f5c4b;
  --line:rgba(39,41,31,.15);
}
[data-theme="esand"] .site-head.scrolled{ background:rgba(12,36,27,.74); }
[data-theme="esand"] .mobile-menu{ background:rgba(12,36,27,.96); }
[data-theme="esand"] .hero::before{ background:linear-gradient(95deg, rgba(8,26,18,.5) 0%, rgba(8,26,18,.15) 42%, transparent 65%); }
[data-theme="esand"] .surface{ background:linear-gradient(180deg, rgba(246,237,220,.93), rgba(238,227,205,.96)); }
[data-theme="esand"] .promo-card{ background:linear-gradient(135deg, rgba(16,48,36,.94), rgba(28,74,55,.94)); border-color:rgba(187,145,82,.5); }

/* ---- live shader wallpaper ---- */
#bg-shader{
  position:fixed; inset:0; width:100vw; height:100vh; z-index:-2;
  opacity:0; transition:opacity 1s ease; pointer-events:none;
}
#root{ opacity:0; transition:opacity .5s ease; }
body.app-ready #root{ opacity:1; }
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.5;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
body.no-grain .grain{ display:none; }

/* ---- buttons ---- */
.btn{
  display:inline-flex; align-items:center; gap:.5em; justify-content:center;
  font-family:var(--sans); font-weight:500; font-size:15px; letter-spacing:.01em;
  padding:13px 24px; border-radius:999px; cursor:pointer; border:1px solid transparent;
  text-decoration:none; transition:transform .25s ease, background .25s ease, color .25s ease, box-shadow .25s ease, border-color .25s ease;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); }
.btn:active{ transform:translateY(0); }
.btn.sm{ padding:9px 18px; font-size:13.5px; }
.btn.full{ width:100%; }
.btn-primary{ background:var(--gold); color:var(--emerald-900); box-shadow:0 10px 30px -12px rgba(198,163,94,.7); }
.btn-primary:hover{ background:var(--gold-soft); }
.btn-gold{ background:var(--gold); color:var(--emerald-900); box-shadow:0 10px 30px -14px rgba(198,163,94,.6); }
.btn-gold:hover{ background:var(--gold-soft); }
.btn-ghost{ background:rgba(255,255,255,.06); color:var(--cream); border-color:rgba(245,239,225,.3); }
.btn-ghost:hover{ background:rgba(255,255,255,.14); }
.btn-outline{ background:transparent; color:var(--emerald-700); border-color:var(--emerald-600); }
.btn-outline:hover{ background:var(--emerald-700); color:var(--cream); border-color:var(--emerald-700); }
.btn-book{ background:var(--emerald-700); color:var(--cream); padding:11px 20px; font-size:14px; }
.btn-book:hover{ background:var(--emerald-600); }

/* ---- header ---- */
.site-head{
  position:fixed; top:0; left:0; right:0; z-index:50;
  transition:background .3s ease, box-shadow .3s ease, backdrop-filter .3s ease;
  padding:14px 0;
}
.site-head.scrolled{
  background:rgba(8,30,23,.72); backdrop-filter:blur(16px);
  box-shadow:0 1px 0 rgba(245,239,225,.08);
}
.head-inner{
  max-width:var(--maxw); margin:0 auto; padding:0 28px;
  display:flex; align-items:center; gap:24px;
}
.brand{ display:flex; align-items:center; gap:12px; text-decoration:none; color:var(--cream); }
.brand-logo{ height:58px; width:auto; display:block; flex-shrink:0; }
.brand-text{ display:flex; flex-direction:column; line-height:1; gap:4px; border-inline-start:1px solid rgba(245,239,225,.28); padding-inline-start:12px; }
.brand-oasis{ font-family:var(--mono); font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--cream); }
.brand-name{ font-family:var(--display); font-size:21px; font-weight:600; letter-spacing:.02em; white-space:nowrap; }
.brand-name.light{ color:var(--cream); }
.brand-sub{ font-family:var(--mono); font-size:9.5px; letter-spacing:.28em; text-transform:uppercase; opacity:.65; margin-top:3px; }
.head-nav{ display:flex; gap:26px; margin-inline-start:auto; }
.head-nav a{
  color:var(--cream); text-decoration:none; font-size:14.5px; font-weight:400; opacity:.82;
  position:relative; padding:4px 0; transition:opacity .2s ease;
}
.head-nav a::after{ content:""; position:absolute; left:0; bottom:-2px; height:1px; width:0; background:var(--gold); transition:width .25s ease; }
.head-nav a:hover{ opacity:1; }
.head-nav a:hover::after{ width:100%; }
.head-actions{ display:flex; align-items:center; gap:14px; }
.lang-toggle{
  background:transparent; border:1px solid rgba(245,239,225,.28); color:var(--cream);
  border-radius:999px; padding:7px 12px; font-family:var(--mono); font-size:12px; cursor:pointer;
  display:flex; gap:5px; align-items:center; letter-spacing:.05em;
}
.lang-toggle .on{ color:var(--gold); }
.lang-toggle .sep{ opacity:.4; }
.lang-toggle:hover{ border-color:rgba(245,239,225,.5); }
.menu-btn{ display:none; background:transparent; border:none; color:var(--cream); cursor:pointer; padding:4px; }
.mobile-menu{
  display:none; flex-direction:column; gap:6px; padding:16px 28px 22px;
  background:rgba(8,30,23,.96); backdrop-filter:blur(16px);
}
.mobile-menu a{ color:var(--cream); text-decoration:none; padding:12px 4px; font-size:16px; border-bottom:1px solid rgba(245,239,225,.08); }

/* ---- shared section ---- */
main{ position:relative; z-index:2; }
.section{ max-width:var(--maxw); margin:0 auto; padding:96px 28px; }
.eyebrow{
  display:inline-block; font-family:var(--mono); font-size:11.5px; letter-spacing:.26em;
  text-transform:uppercase; color:var(--gold); margin-bottom:16px;
}
.section-head{ text-align:center; max-width:680px; margin:0 auto 56px; }
.section-title{
  font-family:var(--display); font-weight:500; font-size:clamp(34px,5vw,54px);
  line-height:1.04; letter-spacing:-.01em; margin:0 0 16px; color:var(--ink);
}
.section-title.left{ text-align:start; }
.section-sub{ font-size:16.5px; line-height:1.6; color:var(--ink-soft); margin:0; }
.section-sub.left{ text-align:start; }

/* ---- light surface that lets shader glow subtly ---- */
.surface{
  position:relative; z-index:2;
  background:linear-gradient(180deg, rgba(245,239,225,.93), rgba(239,230,210,.96));
  backdrop-filter:blur(3px);
  border-radius:40px 40px 0 0;
  box-shadow:0 -30px 80px -50px rgba(0,0,0,.6);
}
.surface::before{
  content:""; position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:60px; height:4px; border-radius:999px; background:var(--gold); opacity:.6; margin-top:18px;
}

/* ---- hero (dark, shader visible) ---- */
.hero{ position:relative; padding:160px 28px 60px; max-width:var(--maxw); margin:0 auto; }
.hero::before{
  content:""; position:absolute; top:-160px; bottom:0; left:50%; width:100vw; transform:translateX(-50%); z-index:-1;
  background:linear-gradient(95deg, rgba(7,32,25,.5) 0%, rgba(7,32,25,.15) 42%, transparent 65%);
}
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center; }
.hero-copy{ color:var(--cream); }
.display{
  font-family:var(--display); font-weight:500; line-height:.98; letter-spacing:-.015em;
  font-size:clamp(46px,7.2vw,90px); margin:0 0 24px;
}
.display span{ display:block; }
.display .accent{ font-style:italic; color:var(--gold-soft); }
.lead{ font-size:18px; line-height:1.62; color:rgba(245,239,225,.84); max-width:30em; margin:0 0 32px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:30px; }
.hero-rating{ display:flex; align-items:center; gap:12px; color:rgba(245,239,225,.8); font-size:14px; }
.hero-rating strong{ color:var(--cream); }
.hero-art{ position:relative; }
.hero-art-frame{
  aspect-ratio:4/5; border-radius:200px 200px 18px 18px; overflow:hidden;
  border:1px solid rgba(245,239,225,.18); box-shadow:0 40px 80px -40px rgba(0,0,0,.7);
}
.hero-art-frame image-slot{ --r:0; }
.hero-chip{
  position:absolute; bottom:24px; inset-inline-start:-26px;
  background:rgba(8,30,23,.78); backdrop-filter:blur(12px);
  border:1px solid rgba(245,239,225,.16); border-radius:16px; padding:14px 18px;
  display:flex; gap:12px; align-items:center; color:var(--cream);
  box-shadow:0 20px 40px -24px rgba(0,0,0,.6);
}
.hero-chip svg{ color:var(--gold); }
.chip-k{ font-family:var(--display); font-size:18px; line-height:1; }
.chip-v{ font-size:12px; opacity:.7; margin-top:4px; }

/* ---- marquee ---- */
.marquee{ overflow:hidden; margin-top:64px; border-block:1px solid rgba(245,239,225,.14); padding:18px 0; }
.marquee-track{ display:flex; width:max-content; animation:scroll 38s linear infinite; }
body[dir="rtl"] .marquee-track{ animation-direction:reverse; }
.marquee-set{ display:flex; }
.marquee-item{
  font-family:var(--display); font-style:italic; font-size:26px; color:rgba(245,239,225,.55);
  padding:0 4px; display:inline-flex; align-items:center; gap:22px;
}
.marquee-item i{ color:var(--gold); font-style:normal; padding-inline-start:22px; }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* ---- promo ---- */
.promo{ max-width:var(--maxw); margin:0 auto; padding:30px 28px 90px; }
.promo-card{
  position:relative; overflow:hidden; border-radius:26px; padding:54px 48px; text-align:center;
  background:linear-gradient(135deg, rgba(11,44,34,.92), rgba(17,66,49,.92));
  border:1px solid rgba(198,163,94,.4);
  box-shadow:0 40px 90px -50px rgba(0,0,0,.8);
}
.promo-glow{ position:absolute; inset:0; background:radial-gradient(60% 120% at 50% 0%, rgba(198,163,94,.22), transparent 60%); }
.promo-badge{
  position:relative; display:inline-block; font-family:var(--mono); font-size:11px; letter-spacing:.24em;
  text-transform:uppercase; color:var(--gold); border:1px solid rgba(198,163,94,.4);
  padding:7px 16px; border-radius:999px; margin-bottom:22px;
}
.promo-title{ position:relative; font-family:var(--display); font-weight:500; font-size:clamp(30px,4.6vw,50px); color:var(--cream); margin:0 0 14px; line-height:1.05; }
.promo-body{ position:relative; color:rgba(245,239,225,.82); font-size:16px; max-width:36em; margin:0 auto 28px; line-height:1.6; }
.promo .btn{ position:relative; }

/* ---- services ---- */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.svc-card{
  position:relative; padding:32px 28px 24px; border-radius:18px; text-decoration:none;
  background:rgba(255,255,255,.5); border:1px solid var(--line);
  display:flex; flex-direction:column; gap:12px; transition:transform .3s ease, box-shadow .3s ease, background .3s ease;
  overflow:hidden;
}
.svc-card:hover{ transform:translateY(-4px); background:rgba(255,255,255,.78); box-shadow:0 30px 60px -40px rgba(11,44,34,.6); }
.svc-icon{
  width:54px; height:54px; border-radius:14px; display:grid; place-items:center;
  background:var(--emerald-700); color:var(--gold-soft); margin-bottom:6px;
}
.svc-name{ font-family:var(--display); font-size:26px; font-weight:500; margin:0; color:var(--ink); }
.svc-desc{ font-size:14.5px; line-height:1.55; color:var(--ink-soft); margin:0; flex:1; }
.svc-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:10px; padding-top:14px; border-top:1px solid var(--line); }
.svc-from{ font-size:13px; color:var(--ink-soft); white-space:nowrap; }
.svc-from strong{ color:var(--emerald-700); font-weight:600; }
.svc-arrow{ color:var(--emerald-700); display:grid; place-items:center; transition:transform .25s ease; }
.svc-card:hover .svc-arrow{ transform:translateX(4px); }
body[dir="rtl"] .svc-card:hover .svc-arrow{ transform:translateX(-4px); }

/* ---- about (unified: story + proof band + space) ---- */
.about-para{ font-size:16.5px; line-height:1.72; color:var(--ink-soft); margin:0 0 16px; }
.about-para:last-of-type{ margin-bottom:0; }

/* about — centered intro, gently staggered photo tiles, inline credential bar */
.about .section-head{ margin-bottom:32px; }
.about-text{ max-width:60ch; margin:0 auto; text-align:center; }
.about-text .about-para{ font-size:17px; line-height:1.78; margin:0; }
.about-strip{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:start; margin-top:44px; }
.about-strip-item{ position:relative; margin:0; aspect-ratio:3/2; border-radius:18px; overflow:hidden; border:1px solid var(--line); box-shadow:0 26px 50px -42px rgba(34,26,19,.5); }
.about-strip-item:nth-child(2){ transform:translateY(34px); }
.about-strip-item .frame-img{ transition:transform .7s cubic-bezier(.2,.7,.2,1); }
.about-strip-item:hover .frame-img{ transform:scale(1.05); }
.about-strip-item figcaption{
  position:absolute; inset-inline-start:18px; bottom:15px;
  font-family:var(--display); font-style:italic; font-size:24px; color:var(--cream);
  text-shadow:0 1px 14px rgba(0,0,0,.55);
}

/* credential bar — inline, divided; deliberately not a rigid 3-card grid */
.about-pillars{ display:flex; justify-content:center; align-items:center; flex-wrap:wrap; gap:0; margin-top:70px; }
.about-pillar{ display:flex; align-items:center; gap:14px; padding:6px 36px; text-align:start; }
.about-pillar + .about-pillar{ border-inline-start:1px solid var(--line); }
.about-pillar-ic{ width:50px; height:50px; border-radius:14px; background:var(--emerald-700); color:var(--gold-soft); display:grid; place-items:center; flex-shrink:0; }
.about-pillar-t{ font-family:var(--display); font-size:21px; color:var(--ink); line-height:1.12; }
.about-pillar-d{ font-size:12.5px; color:var(--ink-soft); margin-top:3px; }

/* ---- reviews ---- */
.rev-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.rev-card{
  margin:0; background:rgba(255,255,255,.55); border:1px solid var(--line); border-radius:18px;
  padding:30px 28px; display:flex; flex-direction:column; gap:18px;
}
.rev-card blockquote{ margin:0; font-family:var(--display); font-size:21px; line-height:1.42; color:var(--ink); font-weight:400; }
.rev-card figcaption{ display:flex; align-items:center; gap:12px; margin-top:auto; padding-top:8px; }
.rev-avatar{
  width:42px; height:42px; border-radius:50%; background:var(--emerald-700); color:var(--cream);
  display:grid; place-items:center; font-family:var(--display); font-size:19px; flex-shrink:0;
}
.rev-name{ display:block; font-weight:500; font-size:14.5px; color:var(--ink); }
.rev-meta{ display:block; font-size:12px; color:var(--ink-soft); margin-top:2px; }
.rev-cta{ text-align:center; margin-top:40px; }
.reviews .btn-ghost{ color:var(--emerald-700); border-color:var(--emerald-600); background:transparent; }
.reviews .btn-ghost:hover{ background:var(--emerald-700); color:var(--cream); }

/* ---- faq ---- */
.faq{ max-width:840px; }
.faq-list{ display:flex; flex-direction:column; gap:12px; }
.faq-item{ border:1px solid var(--line); border-radius:14px; background:rgba(255,255,255,.45); overflow:hidden; transition:border-color .25s ease; }
.faq-item.open{ border-color:rgba(198,163,94,.5); }
.faq-q{
  width:100%; background:transparent; border:none; cursor:pointer; text-align:start;
  padding:22px 24px; display:flex; align-items:center; justify-content:space-between; gap:16px;
  font-family:var(--display); font-size:21px; color:var(--ink);
}
.faq-q svg{ color:var(--emerald-700); flex-shrink:0; }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .35s ease; }
.faq-item.open .faq-a{ max-height:240px; }
.faq-a p{ padding:0 24px 22px; margin:0; color:var(--ink-soft); font-size:15px; line-height:1.62; }

/* ---- contact ---- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:stretch; }
.contact-rows{ display:flex; flex-direction:column; gap:22px; margin:32px 0; }
.contact-row{ display:flex; gap:16px; align-items:flex-start; }
.contact-ic{ width:44px; height:44px; border-radius:12px; background:var(--emerald-700); color:var(--gold-soft); display:grid; place-items:center; flex-shrink:0; }
.contact-k{ font-family:var(--mono); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:5px; }
.contact-v{ color:var(--ink); font-size:15.5px; line-height:1.5; text-decoration:none; display:inline-block; }
a.contact-v:hover{ color:var(--emerald-700); }
.contact-cta{ display:flex; gap:14px; flex-wrap:wrap; }
.contact-map{ border-radius:20px; overflow:hidden; border:1px solid var(--line); min-height:440px; background:var(--emerald-800); filter:saturate(.9) contrast(1.02); }

/* ---- footer ---- */
.site-foot{ position:relative; z-index:2; background:var(--emerald-900); color:var(--cream); padding:72px 28px 32px; }
.foot-grid{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:48px; }
.foot-brand .brand{ margin-bottom:18px; }
.foot-logo-lockup{ display:flex; align-items:center; gap:14px; }
.foot-logo{ height:54px; width:auto; display:block; }
.brand-oasis.lg{ font-size:12px; letter-spacing:.24em; border-inline-start:1px solid rgba(245,239,225,.28); padding-inline-start:14px; }
.foot-blurb{ color:rgba(245,239,225,.7); font-size:14.5px; line-height:1.6; max-width:32em; margin:0 0 20px; }
.foot-social{ display:flex; gap:12px; }
.foot-social a{ width:40px; height:40px; border-radius:50%; border:1px solid rgba(245,239,225,.2); display:grid; place-items:center; color:var(--cream); transition:all .2s ease; }
.foot-social a:hover{ background:var(--gold); color:var(--emerald-900); border-color:var(--gold); }
.foot-links{ display:flex; flex-direction:column; gap:13px; }
.foot-links h4{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin:0 0 6px; font-weight:500; }
.foot-links a, .foot-links span{ color:rgba(245,239,225,.78); text-decoration:none; font-size:14px; }
.foot-links a:hover{ color:var(--cream); }
.foot-links .btn{ margin-top:6px; align-self:flex-start; }
.foot-base{
  max-width:var(--maxw); margin:48px auto 0; padding-top:24px; border-top:1px solid rgba(245,239,225,.12);
  display:flex; justify-content:center; align-items:center; gap:16px;
  font-size:12.5px; color:rgba(245,239,225,.6); flex-wrap:wrap;
}
.foot-rate{ display:flex; align-items:center; gap:8px; }

/* image-slot theming */
image-slot{ --is-bg:rgba(11,44,34,.5); --is-fg:rgba(245,239,225,.55); }

/* ---- space gallery (inside About) ---- */
.about-space{ margin-top:54px; }
.gallery-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.gallery-item{ position:relative; margin:0; aspect-ratio:4/5; border-radius:16px; overflow:hidden; border:1px solid var(--line); box-shadow:0 24px 50px -40px rgba(34,26,19,.6); }
.gallery-item .frame-img{ transition:transform .7s cubic-bezier(.2,.7,.2,1); }
.gallery-item:hover .frame-img{ transform:scale(1.06); }
.gallery-item figcaption{
  position:absolute; inset-inline:0; bottom:0; padding:34px 16px 14px;
  font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase;
  color:#fff; background:linear-gradient(transparent, rgba(20,14,9,.66));
}

/* ===================== pricing page ===================== */
.price-hero{ position:relative; max-width:var(--maxw); margin:0 auto; padding:152px 28px 64px; }
.price-hero::before{
  content:""; position:absolute; top:-152px; bottom:0; left:50%; width:100vw; transform:translateX(-50%); z-index:-1;
  background:linear-gradient(95deg, rgba(7,32,25,.45) 0%, rgba(7,32,25,.12) 42%, transparent 65%);
}
.price-hero-inner{ display:grid; grid-template-columns:1.15fr .85fr; gap:48px; align-items:end; }
.price-hero .display{ font-size:clamp(44px,6.6vw,84px); margin-bottom:0; }
.price-hero-copy{ color:var(--cream); }
.price-lead{ font-size:17px; line-height:1.6; color:rgba(245,239,225,.84); margin:22px 0 22px; max-width:34em; }
.price-hero-cta{ display:flex; gap:14px; flex-wrap:wrap; }
.price-note{ font-size:13px; color:rgba(245,239,225,.55); line-height:1.55; max-width:34em; }
.price-newguest{
  display:inline-flex; align-items:center; gap:9px; font-family:var(--mono); font-size:11px;
  letter-spacing:.18em; text-transform:uppercase; color:var(--gold);
  border:1px solid rgba(198,163,94,.4); padding:8px 16px; border-radius:999px; margin-bottom:22px;
}
.price-newguest .dot{ width:7px; height:7px; border-radius:50%; background:var(--gold); }

/* sticky category nav */
.price-nav{ position:sticky; top:60px; z-index:20; }
.price-nav-inner{
  max-width:var(--maxw); margin:0 auto; padding:14px 28px;
  display:flex; gap:10px; overflow-x:auto; scrollbar-width:none;
  background:rgba(245,239,225,.82); backdrop-filter:blur(12px);
  border-block:1px solid var(--line);
}
.price-nav-inner::-webkit-scrollbar{ display:none; }
.price-nav a{
  flex-shrink:0; font-family:var(--sans); font-size:14px; padding:9px 18px; border-radius:999px;
  text-decoration:none; border:1px solid var(--line); color:var(--ink-soft); transition:all .2s ease; white-space:nowrap;
}
.price-nav a:hover{ border-color:var(--emerald-600); color:var(--emerald-700); }
.price-nav a.active{ background:var(--emerald-700); border-color:var(--emerald-700); color:var(--cream); }

.price-body{ max-width:var(--maxw); margin:0 auto; padding:24px 28px 96px; }
.price-cat{ display:grid; grid-template-columns:.78fr 1.42fr; gap:56px; padding:54px 0; border-top:1px solid var(--line); scroll-margin-top:140px; }
.price-cat:first-child{ border-top:none; }
.price-cat-head{ position:sticky; top:140px; align-self:start; }
.price-cat-icon{
  width:52px; height:52px; border-radius:14px; display:grid; place-items:center;
  background:var(--emerald-700); color:var(--gold-soft); margin-bottom:18px;
}
.price-cat-name{ font-family:var(--display); font-weight:500; font-size:clamp(30px,3.6vw,42px); color:var(--ink); margin:0 0 10px; line-height:1.02; }
.price-cat-blurb{ font-size:14.5px; line-height:1.55; color:var(--ink-soft); margin:0 0 20px; max-width:26em; }
.price-list{ display:flex; flex-direction:column; }
.price-row{ display:flex; align-items:baseline; gap:14px; padding:17px 2px; border-bottom:1px solid var(--line); }
.price-row:last-child{ border-bottom:none; }
.pname{ font-family:var(--display); font-size:22px; color:var(--ink); font-weight:500; line-height:1.1; flex-shrink:0; white-space:nowrap; }
@media(max-width:480px){ .pname{ white-space:normal; max-width:60%; } }
.punit{ font-size:12px; color:var(--ink-soft); margin-inline-start:9px; font-family:var(--sans); white-space:nowrap; }
.pleader{ flex:1; border-bottom:1px dotted rgba(20,45,35,.28); transform:translateY(-5px); min-width:18px; }
.pamt{ font-family:var(--display); font-size:23px; font-weight:600; color:var(--emerald-700); white-space:nowrap; }
.pamt .pfrom{ font-family:var(--sans); font-size:11.5px; font-weight:400; color:var(--ink-soft); margin-inline-end:7px; letter-spacing:.04em; }
.pamt .pcur{ font-family:var(--mono); font-size:13px; font-weight:400; margin-inline-end:3px; }
.price-cat-cta{ margin-top:26px; }

/* ---- responsive ---- */
@media(max-width:980px){
  .head-nav{ display:none; }
  .menu-btn{ display:block; }
  .site-head.menu-open, .mobile-menu{ display:flex; }
  .head-actions .btn-book{ display:none; }
  .hero-grid{ grid-template-columns:1fr; gap:40px; }
  .hero-art{ max-width:440px; margin:0 auto; width:100%; }
  .svc-grid, .rev-grid{ grid-template-columns:repeat(2,1fr); }
  .gallery-grid{ grid-template-columns:repeat(2,1fr); }
  .contact-grid{ grid-template-columns:1fr; gap:36px; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:32px; }
  .foot-brand{ grid-column:1/-1; }
  .price-hero-inner{ grid-template-columns:1fr; gap:28px; }
  .price-cat{ grid-template-columns:1fr; gap:24px; padding:44px 0; }
  .price-cat-head{ position:static; }
}
@media(max-width:620px){
  .section{ padding:68px 20px; }
  .head-inner{ padding:0 20px; }
  .hero{ padding:128px 20px 40px; }
  .svc-grid, .rev-grid{ grid-template-columns:1fr; }
  .about-strip{ grid-template-columns:1fr; }
  .about-strip-item:nth-child(2){ transform:none; }
  .about-pillars{ flex-direction:column; align-items:center; gap:22px; margin-top:40px; }
  .about-pillar{ padding:0; text-align:center; }
  .about-pillar + .about-pillar{ border-inline-start:none; }
  .promo-card{ padding:40px 24px; }
  .foot-grid{ grid-template-columns:1fr; }
  .hero-chip{ inset-inline-start:0; }
  .price-hero{ padding:120px 20px 48px; }
  .price-body{ padding:16px 20px 72px; }
  .pname{ font-size:19px; }
  .pamt{ font-size:20px; }
}

/* ---- language toggle as EN/AR switch links ---- */
.lang-toggle a{ color:var(--cream); text-decoration:none; transition:color .2s ease; }
.lang-toggle a:hover{ color:var(--gold); }
.lang-toggle a.on{ color:var(--gold); }
/* keep the gold "from/AED" eyebrows tidy in Arabic */
body[data-lang="ar"] .eyebrow{ letter-spacing:.08em; }
