/* =========================================================
   Sobha Realty — campaign microsite prototype
   Original editorial system. Palette anchored in brief.
   ========================================================= */

:root{
  --bg:#F8F6F1;
  --bg-deep:#EFEBE2;
  --surface:#FFFFFF;
  --ink:#171B1C;
  --ink-soft:#2A3030;
  --muted:#65706C;
  --muted-2:#8B8A82;
  --primary:#1F6B4E;    /* community greenery */
  --primary-deep:#114334;
  --primary-tint:#E7EFE9;
  --signal:#B51E23;     /* Sobha red */
  --signal-deep:#7C1418;
  --accent:#A8844F;     /* warm metal / stone */
  --accent-tint:#F1E9DA;
  --border:#DDD7CC;
  --border-soft:#E8E2D5;
  --focus:#16846C;
  --shadow-1: 0 1px 0 rgba(23,27,28,.06), 0 12px 32px -16px rgba(23,27,28,.18);
  --shadow-2: 0 1px 0 rgba(23,27,28,.06), 0 24px 60px -24px rgba(23,27,28,.32);

  --serif: "Cormorant Garamond","EB Garamond",Georgia,serif;
  --sans: "Inter","Helvetica Neue",Arial,sans-serif;
  --mono: "JetBrains Mono","IBM Plex Mono",ui-monospace,Menlo,monospace;

  --maxw: 1320px;
  --gutter: clamp(20px, 4vw, 64px);
}

*{ box-sizing:border-box }
html,body{ margin:0; padding:0 }
html{ scroll-behavior:smooth }
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  font-size:15px;
  line-height:1.55;
  letter-spacing:0;
}
img{ display:block; max-width:100%; height:auto }
button{ font:inherit; color:inherit; cursor:pointer }
a{ color:inherit; text-decoration:none }

/* -------- type -------- */
.eyebrow{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:"";
  width:18px; height:1px;
  background:currentColor;
  opacity:.7;
}
.h-display{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(44px, 7vw, 104px);
  line-height:.98;
  letter-spacing:-.012em;
  color:var(--ink);
  margin:0;
}
.h-display em{
  font-style:italic;
  color:var(--primary-deep);
}
.h-1{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(34px, 4.6vw, 64px);
  line-height:1.02;
  letter-spacing:-.01em;
  margin:0;
}
.h-2{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(26px, 2.8vw, 40px);
  line-height:1.1;
  letter-spacing:-.008em;
  margin:0;
}
.lead{
  font-size:clamp(16px, 1.3vw, 19px);
  line-height:1.55;
  color:var(--ink-soft);
  max-width:60ch;
}
.body{
  font-size:15px;
  line-height:1.65;
  color:var(--ink-soft);
}
.fine{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted-2);
}
.num{
  font-family:var(--serif);
  font-feature-settings:"tnum","lnum";
  font-weight:400;
}

/* -------- container -------- */
.container{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--gutter);
  position:relative;
}

/* -------- top bar / nav -------- */
.topbar{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(248,246,241,.86);
  backdrop-filter:saturate(160%) blur(12px);
  -webkit-backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--border-soft);
}
.topbar-inner{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
  height:72px;
}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
}
.brand-mark{
  width:34px; height:34px;
  display:grid; place-items:center;
  background:var(--ink);
  color:#fff;
  font-family:var(--serif);
  font-size:22px;
  letter-spacing:-.02em;
  line-height:1;
  border-radius:2px;
}
.brand-mark .dot{
  width:5px; height:5px; background:var(--signal); border-radius:50%;
  position:absolute; transform:translate(13px,-9px);
}
.brand-text{
  display:flex; flex-direction:column; line-height:1;
}
.brand-text b{
  font-family:var(--serif);
  font-weight:500;
  font-size:18px;
  letter-spacing:.01em;
  color:var(--ink);
}
.brand-text span{
  font-family:var(--mono);
  font-size:9.5px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
  margin-top:4px;
}

.nav{
  display:flex; gap:28px;
  justify-self:center;
}
.nav a{
  font-size:13px;
  color:var(--ink-soft);
  padding:6px 2px;
  position:relative;
}
.nav a:hover{ color:var(--primary-deep) }
.nav a.active::after{
  content:""; position:absolute;
  left:0; right:0; bottom:-3px; height:1px;
  background:var(--primary);
}

.top-right{
  display:flex; align-items:center; gap:12px;
}

/* -------- locale switcher -------- */
.locale{
  display:flex;
  align-items:center;
  gap:4px;
  border:1px solid var(--border);
  border-radius:999px;
  padding:3px;
  background:rgba(255,255,255,.6);
}
.locale button{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:6px 10px;
  border:0;
  background:transparent;
  border-radius:999px;
  color:var(--muted);
  line-height:1;
}
.locale button.active{
  background:var(--ink);
  color:#fff;
}
.locale button:hover:not(.active){ color:var(--ink) }

/* -------- buttons -------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 22px;
  font-size:13px;
  letter-spacing:.02em;
  border-radius:2px;
  border:1px solid transparent;
  background:var(--ink);
  color:#fff;
  cursor:pointer;
  transition:transform .15s ease, background .2s ease, color .2s ease;
}
.btn:hover{ background:var(--primary-deep) }
.btn .arrow{
  width:14px; height:1px; background:currentColor; position:relative;
}
.btn .arrow::after{
  content:""; position:absolute;
  right:0; top:-3px; width:7px; height:7px;
  border-top:1px solid currentColor;
  border-right:1px solid currentColor;
  transform:rotate(45deg);
}
.btn-primary{ background:var(--signal); }
.btn-primary:hover{ background:var(--signal-deep) }
.btn-ghost{
  background:transparent;
  color:var(--ink);
  border:1px solid var(--border);
}
.btn-ghost:hover{ border-color:var(--ink); background:transparent }
.btn-line{
  background:transparent;
  color:var(--ink);
  padding:14px 0;
  border:0;
  border-bottom:1px solid var(--ink);
  border-radius:0;
}
.btn-sm{ padding:9px 14px; font-size:12px }
.btn-wide{ padding:16px 28px }

/* -------- hero -------- */
.hero{
  position:relative;
  min-height:780px;
  background:#0a1310;
  color:#fff;
  overflow:hidden;
  display:flex;
  align-items:flex-end;
}
.hero-media{
  position:absolute; inset:0;
  background-size:cover;
  background-position:center;
  filter:saturate(102%) contrast(102%);
}
.hero-media::after{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(10,19,16,.35) 0%, rgba(10,19,16,.05) 25%, rgba(10,19,16,.6) 75%, rgba(10,19,16,.92) 100%);
}
.hero-inner{
  position:relative;
  width:100%;
  padding-bottom:64px;
  padding-top:120px;
}
.hero-meta{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:48px;
  flex-wrap:wrap;
}
.hero-title{
  color:#fff;
  max-width:18ch;
}
.hero-title em{ color:#cfb98a; font-style:italic }
.hero-sub{
  color:rgba(255,255,255,.78);
  max-width:48ch;
  font-size:17px;
  line-height:1.55;
}
.hero-status{
  display:flex;
  gap:36px;
  align-items:flex-end;
  color:rgba(255,255,255,.88);
}
.hero-status .col{
  display:flex; flex-direction:column; gap:6px;
  min-width:140px;
}
.hero-status .label{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.6);
}
.hero-status .val{
  font-family:var(--serif);
  font-size:22px;
  line-height:1.1;
}
.hero-cta{
  display:flex; gap:10px;
  margin-top:34px;
}
.hero-cta .btn-primary{ background:var(--signal) }
.hero-cta .btn-ghost{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.35);
  color:#fff;
}
.hero-cta .btn-ghost:hover{ background:rgba(255,255,255,.16); border-color:rgba(255,255,255,.65) }
.hero-eyebrow{
  color:rgba(255,255,255,.82);
}
.hero-eyebrow::before{ background:rgba(255,255,255,.6) }

.hero-marquee{
  position:absolute;
  top:96px;
  right:var(--gutter);
  border:1px solid rgba(255,255,255,.25);
  padding:8px 14px;
  border-radius:999px;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.9);
  display:flex;
  align-items:center;
  gap:10px;
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(6px);
}
.hero-marquee::before{
  content:"";
  width:6px; height:6px; border-radius:50%;
  background:var(--signal);
  box-shadow:0 0 0 4px rgba(181,30,35,.25);
  animation:pulse 2.2s infinite;
}
@keyframes pulse{
  0%,100%{ box-shadow:0 0 0 4px rgba(181,30,35,.25) }
  50%{ box-shadow:0 0 0 8px rgba(181,30,35,0) }
}

/* -------- credibility band -------- */
.cred{
  border-bottom:1px solid var(--border);
  background:var(--bg);
}
.cred-inner{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  padding:28px 0;
}
.cred-cell{
  display:flex; flex-direction:column; gap:6px;
  padding:0 var(--gutter) 0 0;
  border-right:1px solid var(--border-soft);
}
.cred-cell:last-child{ border-right:0 }
.cred-cell .num{
  font-size:34px;
  line-height:1;
}
.cred-cell .lbl{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
}
.cred-cell .src{
  font-size:11.5px;
  color:var(--muted-2);
  margin-top:2px;
}

/* -------- section frame -------- */
section{
  padding:clamp(72px, 9vw, 128px) 0;
  position:relative;
}
section.tight{ padding-block:clamp(56px, 7vw, 96px) }
.section-head{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:end;
  margin-bottom:56px;
}
.section-head .right{ justify-self:end; max-width:46ch }

/* -------- narrative split -------- */
.split{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:64px;
  align-items:center;
}
.split.flip{ grid-template-columns:1fr 1.05fr }
.plate{
  position:relative;
  aspect-ratio: 4 / 5;
  background:#222;
  overflow:hidden;
  border-radius:2px;
}
.plate img{
  width:100%; height:100%; object-fit:cover;
}
.plate .caption{
  position:absolute;
  left:16px; bottom:14px;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(255,255,255,.95);
  background:rgba(0,0,0,.35);
  padding:6px 10px;
  border-radius:2px;
  backdrop-filter:blur(6px);
}

/* -------- pillars (craftsmanship) -------- */
.pillars{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:32px;
  margin-top:36px;
}
.pillar{
  display:flex; flex-direction:column; gap:14px;
}
.pillar .step{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  color:var(--accent);
}
.pillar h4{
  font-family:var(--serif);
  font-weight:400;
  font-size:22px;
  margin:0;
  line-height:1.15;
}
.pillar p{
  font-size:13.5px;
  color:var(--muted);
  margin:0;
  line-height:1.55;
}
.pillar-line{
  height:1px; background:var(--border);
  margin:8px 0 0;
}

/* -------- residences -------- */
.res-tabs{
  display:flex; gap:0;
  border-bottom:1px solid var(--border);
  margin-bottom:40px;
}
.res-tabs button{
  background:transparent; border:0;
  padding:18px 22px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  position:relative;
  cursor:pointer;
}
.res-tabs button.active{
  color:var(--ink);
}
.res-tabs button.active::after{
  content:""; position:absolute;
  left:14px; right:14px; bottom:-1px; height:2px;
  background:var(--primary);
}

.res-panel{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:48px;
  align-items:start;
}
.res-img{
  aspect-ratio: 5 / 4;
  background:#1a1a1a;
  overflow:hidden;
  border-radius:2px;
  position:relative;
}
.res-img img{ width:100%; height:100%; object-fit:cover }
.res-spec{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  border-top:1px solid var(--border);
  margin-top:24px;
}
.res-spec .row{
  border-bottom:1px solid var(--border-soft);
  padding:14px 0;
  display:flex; justify-content:space-between; gap:16px;
}
.res-spec .row .k{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
}
.res-spec .row .v{ font-size:13.5px; color:var(--ink) }
.res-spec .row .v em{ color:var(--muted-2); font-style:normal }

.confirm-tag{
  display:inline-flex;
  align-items:center; gap:6px;
  padding:3px 8px;
  border:1px dashed var(--accent);
  color:var(--accent);
  font-family:var(--mono);
  font-size:9.5px;
  letter-spacing:.14em;
  text-transform:uppercase;
  border-radius:2px;
}

/* -------- amenities grid -------- */
.amenity-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-auto-rows:160px;
  gap:8px;
}
.am{
  position:relative;
  overflow:hidden;
  background:#1a1a1a;
  border-radius:2px;
}
.am img{ width:100%; height:100%; object-fit:cover; transition:transform .8s ease }
.am:hover img{ transform:scale(1.04) }
.am::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.7) 100%);
  pointer-events:none;
}
.am .label{
  position:absolute;
  left:14px; bottom:12px;
  color:#fff;
  z-index:2;
}
.am .label b{
  font-family:var(--serif);
  font-weight:400;
  font-size:18px;
  display:block;
}
.am .label span{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,.78);
}

/* default grid placement; specific cells set below */
.am.a{ grid-column:span 7; grid-row:span 2 }
.am.b{ grid-column:span 5; grid-row:span 1 }
.am.c{ grid-column:span 5; grid-row:span 1 }
.am.d{ grid-column:span 4; grid-row:span 2 }
.am.e{ grid-column:span 4; grid-row:span 1 }
.am.f{ grid-column:span 4; grid-row:span 1 }
.am.g{ grid-column:span 8; grid-row:span 2 }
.am.h{ grid-column:span 4; grid-row:span 1 }
.am.i{ grid-column:span 4; grid-row:span 1 }

/* -------- communities grid -------- */
.community-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.c-card{
  background:var(--surface);
  border:1px solid var(--border-soft);
  border-radius:2px;
  overflow:hidden;
  display:flex; flex-direction:column;
  text-align:left;
  transition:border-color .2s ease, transform .2s ease;
}
.c-card:hover{ border-color:var(--ink); transform:translateY(-2px) }
.c-card .img{
  aspect-ratio: 5 / 4;
  background:#1a1a1a;
  overflow:hidden;
  position:relative;
}
.c-card .img img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease }
.c-card:hover .img img{ transform:scale(1.04) }
.c-card .body-pad{
  padding:16px 18px 20px;
  display:flex; flex-direction:column; gap:6px;
}
.c-card .loc{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent);
}
.c-card h5{
  font-family:var(--serif);
  font-weight:400;
  font-size:22px;
  margin:0;
  line-height:1.1;
}
.c-card .desc{ font-size:12.5px; color:var(--muted); line-height:1.5 }
.c-card .pill{
  display:inline-flex;
  align-items:center; gap:6px;
  font-family:var(--mono);
  font-size:9.5px;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:3px 8px;
  border-radius:999px;
  background:var(--primary-tint);
  color:var(--primary-deep);
  width:max-content;
  margin-top:8px;
}
.c-card .pill.red{ background:#FCEAEC; color:var(--signal-deep) }
.c-card .pill.stone{ background:var(--accent-tint); color:var(--accent) }

/* -------- gallery strip -------- */
.gallery{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-auto-rows:140px;
  gap:6px;
}
.g{ overflow:hidden; background:#222; position:relative; border-radius:2px }
.g img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease }
.g:hover img{ transform:scale(1.05) }
.g1{ grid-column:span 4; grid-row:span 3 }
.g2{ grid-column:span 4; grid-row:span 2 }
.g3{ grid-column:span 4; grid-row:span 2 }
.g4{ grid-column:span 4; grid-row:span 1 }
.g5{ grid-column:span 4; grid-row:span 1 }

/* -------- legacy / about -------- */
.legacy{
  background:var(--ink);
  color:#f3efe6;
}
.legacy .h-1{ color:#fff }
.legacy .lead{ color:rgba(255,255,255,.78) }
.legacy .eyebrow{ color:rgba(255,255,255,.6) }
.legacy .num{ color:#fff }
.legacy .cred-cell{ border-right-color:rgba(255,255,255,.12) }
.legacy .cred-cell .lbl{ color:rgba(255,255,255,.6) }
.legacy .cred-cell .src{ color:rgba(255,255,255,.4) }
.legacy .pillars{ margin-top:0 }
.legacy .pillar p{ color:rgba(255,255,255,.6) }
.legacy .pillar h4{ color:#fff }
.legacy .pillar .step{ color:#cfb98a }
.legacy .pillar-line{ background:rgba(255,255,255,.12) }
.legacy-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:32px;
  margin-top:60px;
}
.legacy-card{
  position:relative;
  overflow:hidden;
  border-radius:2px;
  aspect-ratio:16/10;
}
.legacy-card img{
  width:100%; height:100%; object-fit:cover;
  opacity:.86;
}
.legacy-card .overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 30%, rgba(0,0,0,.7));
  pointer-events:none;
}
.legacy-card .ttl{
  position:absolute; left:24px; bottom:22px; right:24px;
  color:#fff;
  font-family:var(--serif);
  font-size:28px;
  line-height:1.05;
  z-index:2;
}
.legacy-card .ttl span{
  display:block;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.7);
  margin-bottom:8px;
}

/* -------- lead form -------- */
.lead-band{
  background:var(--bg-deep);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.lead-inner{
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  gap:72px;
  align-items:start;
}
.lead-form{
  background:var(--surface);
  border:1px solid var(--border);
  padding:36px;
  border-radius:2px;
  box-shadow:var(--shadow-1);
}
.lead-tabs{
  display:flex; gap:0;
  border-bottom:1px solid var(--border);
  margin:-36px -36px 32px;
  padding:0 36px;
}
.lead-tabs button{
  background:transparent; border:0;
  padding:18px 0;
  margin-right:24px;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
  position:relative;
  cursor:pointer;
}
.lead-tabs button.active{ color:var(--ink) }
.lead-tabs button.active::after{
  content:""; position:absolute;
  left:0; right:0; bottom:-1px; height:2px;
  background:var(--signal);
}

.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-bottom:14px;
}
.form-row.full{ grid-template-columns:1fr }
.field{
  display:flex; flex-direction:column; gap:6px;
}
.field label{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
}
.field input, .field select, .field textarea{
  appearance:none;
  -webkit-appearance:none;
  width:100%;
  border:0;
  border-bottom:1px solid var(--border);
  background:transparent;
  padding:10px 0;
  font:inherit;
  font-size:15px;
  color:var(--ink);
  outline:none;
  transition:border-color .2s ease;
  border-radius:0;
}
.field input:focus, .field select:focus, .field textarea:focus{ border-bottom-color:var(--primary) }
.field textarea{ resize:vertical; min-height:64px }
.field-tel{
  display:grid;
  grid-template-columns:90px 1fr;
  align-items:end;
  gap:8px;
}
.checkbox{
  display:flex; gap:10px; align-items:flex-start;
  font-size:12.5px; color:var(--muted);
  line-height:1.5;
}
.checkbox input{
  appearance:none; -webkit-appearance:none;
  width:16px; height:16px;
  border:1px solid var(--border);
  border-radius:2px;
  margin-top:2px;
  cursor:pointer;
  position:relative;
}
.checkbox input:checked{ background:var(--primary); border-color:var(--primary) }
.checkbox input:checked::after{
  content:"";
  position:absolute; left:4px; top:1px;
  width:5px; height:9px;
  border-right:2px solid #fff;
  border-bottom:2px solid #fff;
  transform:rotate(45deg);
}

.form-foot{
  display:flex; justify-content:space-between; align-items:center;
  gap:16px; margin-top:22px;
  flex-wrap:wrap;
}
.form-foot .privacy{
  font-size:11px; color:var(--muted-2); max-width:42ch;
}
.consent-note{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted-2);
  margin-top:18px;
}

/* multi-step progress */
.steps{
  display:flex; gap:6px;
  margin-bottom:24px;
}
.step-dot{
  flex:1;
  height:3px;
  background:var(--border);
  border-radius:2px;
  position:relative;
}
.step-dot.done{ background:var(--primary) }
.step-dot.current{ background:var(--ink) }
.step-meta{
  display:flex; justify-content:space-between;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:24px;
}
.step-meta b{ color:var(--ink); font-weight:500 }

.success-pane{
  text-align:center;
  padding:24px 0;
}
.success-pane .check{
  width:54px; height:54px;
  border-radius:50%;
  background:var(--primary);
  color:#fff;
  display:grid; place-items:center;
  margin:0 auto 18px;
}
.success-pane .check svg{ width:24px; height:24px }
.success-pane h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:28px;
  margin:0 0 10px;
}
.success-pane p{
  color:var(--muted); margin:0 auto 22px; max-width:36ch;
}
.success-pane .ticket{
  margin:14px auto 18px;
  display:inline-flex;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  border:1px dashed var(--border);
  padding:8px 12px;
  border-radius:2px;
  color:var(--ink);
}

/* -------- channel routing chips -------- */
.route-row{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:8px;
  margin-bottom:18px;
}
.route-row label{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:14px 14px 12px;
  border:1px solid var(--border);
  border-radius:2px;
  cursor:pointer;
  background:#fff;
  transition:border-color .15s ease, background .15s ease;
}
.route-row label input{ display:none }
.route-row label .rk{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
}
.route-row label .rv{
  font-family:var(--serif);
  font-size:18px;
  line-height:1.1;
}
.route-row label.checked{
  border-color:var(--ink);
  background:var(--bg);
}
.route-row label.checked .rk{ color:var(--signal) }

/* -------- WhatsApp FAB -------- */
.fab{
  position:fixed;
  bottom:20px; right:20px;
  z-index:60;
  display:flex; gap:10px;
  align-items:center;
}
.fab-btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:12px 18px;
  border-radius:999px;
  background:#1f6b4e;
  color:#fff;
  border:0;
  font-size:13px;
  letter-spacing:.02em;
  cursor:pointer;
  box-shadow:var(--shadow-2);
  transition:transform .15s ease;
}
.fab-btn:hover{ transform:translateY(-2px) }
.fab-btn .wa-icon{
  width:18px; height:18px;
  background:#fff;
  color:#1f6b4e;
  border-radius:50%;
  display:grid; place-items:center;
  font-size:11px;
}

/* -------- modal -------- */
.modal-scrim{
  position:fixed; inset:0;
  background:rgba(10,12,12,.6);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  z-index:80;
  display:grid; place-items:center;
  padding:24px;
  animation:fadeIn .2s ease;
}
@keyframes fadeIn{ from{ opacity:0 } to{ opacity:1 } }
.modal{
  background:var(--surface);
  width:100%;
  max-width:720px;
  max-height:88vh;
  overflow:auto;
  border-radius:3px;
  box-shadow:var(--shadow-2);
  position:relative;
  animation:rise .25s ease;
}
@keyframes rise{ from{ transform:translateY(12px); opacity:0 } to{ transform:translateY(0); opacity:1 } }
.modal-inner{ padding:36px }
.modal .close{
  position:absolute; top:14px; right:14px;
  width:34px; height:34px;
  border:0; background:transparent;
  border-radius:50%;
  cursor:pointer;
  display:grid; place-items:center;
  color:var(--muted);
}
.modal .close:hover{ background:var(--bg-deep); color:var(--ink) }
.modal h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:30px;
  margin:0 0 6px;
  line-height:1.1;
}
.modal .sub{
  color:var(--muted);
  margin:0 0 24px;
}

/* gated brochure */
.brochure-modal{
  display:grid;
  grid-template-columns: 1fr 1.1fr;
}
.brochure-modal .preview{
  background:#1a1a1a;
  position:relative;
  min-height:400px;
  overflow:hidden;
}
.brochure-modal .preview img{
  width:100%; height:100%; object-fit:cover;
}
.brochure-modal .preview::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 40%, rgba(0,0,0,.78));
}
.brochure-modal .preview .meta{
  position:absolute; left:24px; right:24px; bottom:22px;
  color:#fff;
  z-index:2;
}
.brochure-modal .preview .meta span{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.7);
}
.brochure-modal .preview .meta h4{
  font-family:var(--serif);
  font-weight:400;
  font-size:30px;
  margin:6px 0 0;
}
.brochure-modal .preview .pdf-badge{
  position:absolute; top:18px; left:18px; z-index:2;
  display:inline-flex; gap:8px; align-items:center;
  background:rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.2);
  color:#fff;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  padding:5px 9px;
  border-radius:2px;
}
.brochure-modal .form-pane{ padding:32px }

/* private viewing calendar */
.viewing-grid{
  display:grid;
  grid-template-columns: repeat(7, 1fr);
  gap:6px;
  margin:14px 0 6px;
}
.viewing-grid .day{
  border:1px solid var(--border);
  padding:10px 6px 12px;
  border-radius:2px;
  text-align:center;
  cursor:pointer;
  background:#fff;
  transition:all .15s ease;
}
.viewing-grid .day.disabled{
  opacity:.35; pointer-events:none;
}
.viewing-grid .day.active{
  background:var(--ink); color:#fff; border-color:var(--ink);
}
.viewing-grid .day .dow{
  font-family:var(--mono);
  font-size:9.5px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:3px;
}
.viewing-grid .day.active .dow{ color:rgba(255,255,255,.7) }
.viewing-grid .day .dnum{
  font-family:var(--serif);
  font-size:20px; line-height:1;
}
.time-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:6px;
  margin-top:14px;
}
.time-grid button{
  background:#fff;
  border:1px solid var(--border);
  padding:10px;
  border-radius:2px;
  font:inherit;
  font-size:13px;
  cursor:pointer;
}
.time-grid button.active{
  background:var(--primary);
  border-color:var(--primary);
  color:#fff;
}
.time-grid button:hover:not(.active){ border-color:var(--ink) }

/* -------- footer -------- */
footer.footer{
  background:#0E1212;
  color:rgba(255,255,255,.7);
  padding:80px 0 24px;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap:48px;
  padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer h6{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.5);
  margin:0 0 18px;
}
.footer ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px }
.footer ul a{ font-size:13px; color:rgba(255,255,255,.85) }
.footer ul a:hover{ color:#fff }
.footer .signin{
  font-family:var(--serif);
  font-size:26px;
  color:#fff;
  line-height:1.2;
  margin:0 0 16px;
}
.footer-bot{
  display:flex; justify-content:space-between;
  padding-top:22px;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,.4);
  gap:20px;
  flex-wrap:wrap;
}
.foot-phone-row{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:16px;
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.08);
}
.foot-phone-row .cell{
  display:flex; flex-direction:column; gap:4px;
}
.foot-phone-row .lbl{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.4);
}
.foot-phone-row .val{
  font-family:var(--serif);
  font-size:20px;
  color:#fff;
}

/* -------- responsive (light pass) -------- */
@media (max-width: 1100px){
  .nav{ display:none }
  .section-head{ grid-template-columns:1fr }
  .section-head .right{ justify-self:start; max-width:60ch }
  .split, .split.flip, .lead-inner{ grid-template-columns:1fr; gap:32px }
  .pillars{ grid-template-columns:repeat(2,1fr) }
  .community-grid{ grid-template-columns:repeat(2,1fr) }
  .amenity-grid{ grid-auto-rows:130px }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px }
  .brochure-modal{ grid-template-columns:1fr }
  .brochure-modal .preview{ min-height:240px; aspect-ratio:5/3 }
}
@media (max-width: 640px){
  .pillars{ grid-template-columns:1fr }
  .community-grid{ grid-template-columns:1fr }
  .cred-inner{ grid-template-columns:1fr 1fr }
  .res-panel{ grid-template-columns:1fr }
  .route-row{ grid-template-columns:1fr 1fr }
  .form-row{ grid-template-columns:1fr }
}

/* -------- localized copy (RTL preview) -------- */
[data-locale="ar"]{ direction:rtl }
[data-locale="ar"] .eyebrow::before{ display:none }
[data-locale="ar"] .nav a.active::after, [data-locale="ar"] .res-tabs button.active::after, [data-locale="ar"] .lead-tabs button.active::after{ left:auto }

/* utility */
.row-between{ display:flex; justify-content:space-between; align-items:center }
.gap-12{ gap:12px } .gap-16{ gap:16px } .gap-24{ gap:24px }
.mt-12{ margin-top:12px } .mt-24{ margin-top:24px } .mt-48{ margin-top:48px }
.text-right{ text-align:right }
.divider{ height:1px; background:var(--border); margin:0 }
