:root{
  --bg:#0F0F11;
  --bg-2:#15151A;
  --surface:#F6F4EF;
  --surface-2:#EDEAE2;
  --text:#F6F4EF;
  --text-dark:#0F0F11;
  --muted:#B9B2A6;
  --muted-dark:#5E5A52;
  --primary:#9A7F50;
  --secondary:#E5E0D6;
  --accent:#6F8793;
  --border:#2A2A2D;
  --border-light:#E0DCD2;
  --focus:#C7A96B;
}

html[data-accent="sea"]{ --primary:#6F8793; --focus:#94AAB6; }
html[data-accent="ink"]{ --primary:#E5E0D6; --focus:#F6F4EF; }

*{ box-sizing:border-box; margin:0; padding:0; }
html, body{ background:var(--bg); color:var(--text); }
body{
  font-family:'Inter', system-ui, sans-serif;
  font-weight:300;
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
html[lang="ar"] body{ font-family:'Noto Naskh Arabic','Inter',serif; }
html[lang="ar"] body{ direction:rtl; }

a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
input, textarea, select{ font:inherit; color:inherit; }

/* type */
.serif{ font-family:'Cormorant Garamond', 'Times New Roman', serif; font-weight:300; letter-spacing:.005em; }
.eyebrow{
  font-family:'Inter', sans-serif;
  font-size:11px; letter-spacing:.32em; text-transform:uppercase;
  color:var(--muted); font-weight:500;
}
.eyebrow .dot{ display:inline-block; width:4px; height:4px; border-radius:50%; background:var(--primary); vertical-align:middle; margin:0 .75em; }

/* layout */
.shell{ width:100%; }
.wrap{ width:100%; max-width:1440px; margin:0 auto; padding:0 48px; }
@media (max-width: 720px){ .wrap{ padding:0 24px; } }

section{ position:relative; }

/* NAV */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 48px;
  transition:background .4s ease, backdrop-filter .4s ease, border-color .4s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(15,15,17,.78);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom-color:var(--border);
}
.nav-logo svg{ height:14px; width:auto; }
.nav-mid{ display:flex; gap:36px; }
.nav-mid a{ font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); transition:color .2s; }
.nav-mid a:hover, .nav-mid a.is-active{ color:var(--text); }
.nav-right{ display:flex; align-items:center; gap:18px; }
.nav-locale{
  display:flex; gap:0; font-size:11px; letter-spacing:.2em; color:var(--muted);
  border:1px solid var(--border); border-radius:999px; overflow:hidden;
}
.nav-locale button{ padding:6px 10px; color:var(--muted); transition:all .2s; }
.nav-locale button.is-active{ background:var(--text); color:var(--bg); }
.nav-cta{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 18px;
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  border:1px solid var(--primary); color:var(--text);
  border-radius:0;
  transition:background .25s, color .25s;
}
.nav-cta:hover{ background:var(--primary); color:var(--bg); }

@media (max-width: 920px){
  .nav{ padding:18px 24px; }
  .nav-mid{ display:none; }
}

/* HERO */
.hero{
  position:relative; height:100vh; min-height:680px;
  overflow:hidden;
  display:flex; align-items:flex-end;
}
.hero-bg{ position:absolute; inset:0; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity 1.6s ease; }
.hero-bg img.is-active{ opacity:1; }
.hero-vignette{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(15,15,17,.55) 0%, rgba(15,15,17,0) 30%, rgba(15,15,17,0) 60%, rgba(15,15,17,.78) 100%),
    linear-gradient(90deg, rgba(15,15,17,.35) 0%, rgba(15,15,17,0) 60%);
  pointer-events:none;
}
.hero-grain{
  position:absolute; inset:0; pointer-events:none; opacity:.06; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/></svg>");
}
.hero-content{
  position:relative; z-index:2; width:100%;
  padding-bottom:80px;
}
.hero-eyebrow{ margin-bottom:28px; }
.hero-h1{
  font-family:'Cormorant Garamond', serif;
  font-weight:300;
  font-size: clamp(64px, 11vw, 180px);
  line-height:.92;
  letter-spacing:-.02em;
  color:var(--text);
}
.hero-h1 .sub{ font-style:italic; font-weight:300; color:var(--muted); font-size:.32em; letter-spacing:.06em; display:block; margin-top:.6em;}
.hero-sub{
  margin-top:32px;
  max-width:520px;
  font-size:18px; line-height:1.55;
  color:var(--secondary); font-weight:300;
}
.hero-actions{ margin-top:48px; display:flex; gap:14px; flex-wrap:wrap; }
.btn{
  display:inline-flex; align-items:center; gap:14px;
  padding:16px 26px;
  font-size:11px; letter-spacing:.22em; text-transform:uppercase; font-weight:500;
  transition:all .25s;
  border-radius:0;
  cursor:pointer;
}
.btn-primary{ background:var(--primary); color:var(--bg); border:1px solid var(--primary); }
.btn-primary:hover{ background:transparent; color:var(--text); }
.btn-ghost{ background:transparent; color:var(--text); border:1px solid rgba(246,244,239,.35); }
.btn-ghost:hover{ border-color:var(--text); }
.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); }

.hero-meta{
  position:absolute; bottom:32px; right:48px; z-index:2;
  display:flex; gap:48px; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted);
}
.hero-meta .meta-label{ color:var(--muted); opacity:.7; display:block; margin-bottom:6px; font-size:10px; }
.hero-meta .meta-value{ color:var(--text); font-weight:400; letter-spacing:.16em; }

.hero-counter{
  position:absolute; bottom:32px; left:48px; z-index:2;
  display:flex; align-items:center; gap:16px;
  font-size:11px; letter-spacing:.2em; color:var(--muted);
}
.hero-counter .num{ color:var(--text); font-family:'Cormorant Garamond', serif; font-size:24px; line-height:1; letter-spacing:0; }

@media (max-width: 920px){
  .hero{ padding-left:0; padding-right:0; }
  .hero-content{ padding-bottom:120px; }
  .hero-meta{ right:24px; gap:24px; }
  .hero-counter{ left:24px; }
}

/* section base */
.section{ padding:140px 0; }
.section-dark{ background:var(--bg); }
.section-light{ background:var(--surface); color:var(--text-dark); }
.section-light .eyebrow{ color:var(--muted-dark); }
.section-light .serif{ color:var(--text-dark); }

.section-title{
  font-family:'Cormorant Garamond', serif;
  font-weight:300;
  font-size:clamp(36px, 5vw, 64px);
  line-height:1.05;
  letter-spacing:-.01em;
  margin-top:18px;
}

/* VISION */
.vision-grid{ display:grid; grid-template-columns:1fr 1fr; gap:96px; align-items:start; }
.vision-grid .col-left{ position:sticky; top:120px; }
.vision-body{ font-size:20px; line-height:1.6; color:var(--secondary); max-width:560px; font-weight:300; }
.vision-body p + p{ margin-top:1.4em; }
.vision-body .lead-cap::first-letter{
  font-family:'Cormorant Garamond', serif;
  font-style:italic;
  font-size:5em;
  line-height:.9;
  float:left;
  margin:.05em .2em -.1em 0;
  color:var(--primary);
}
@media (max-width: 920px){
  .vision-grid{ grid-template-columns:1fr; gap:48px; }
  .vision-grid .col-left{ position:static; }
}

/* ARCHITECTURE */
.arch{ background:var(--bg-2); padding:160px 0; }
.arch-grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:80px; align-items:center; }
.arch-img{ aspect-ratio:4/5; overflow:hidden; }
.arch-img img{ width:100%; height:100%; object-fit:cover; }
.arch-credit{
  margin-top:48px; padding-top:32px; border-top:1px solid var(--border);
  display:grid; grid-template-columns:auto 1fr; gap:8px 32px;
  font-size:12px; letter-spacing:.12em;
}
.arch-credit dt{ color:var(--muted); text-transform:uppercase; font-size:11px; letter-spacing:.2em; }
.arch-credit dd{ color:var(--text); }
@media (max-width: 920px){ .arch-grid{ grid-template-columns:1fr; gap:48px; } }

/* HOSPITALITY */
.hosp{ background:var(--surface); color:var(--text-dark); padding:160px 0; }
.hosp .eyebrow{ color:var(--muted-dark); }
.hosp-grid{ display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:end; }
.hosp-title{
  font-family:'Cormorant Garamond', serif;
  font-weight:300;
  font-size:clamp(40px, 5.5vw, 76px);
  line-height:1.02;
  color:var(--text-dark);
}
.hosp-title em{ font-style:italic; color:var(--primary); }
.hosp-body{ font-size:17px; line-height:1.65; color:#3A3830; max-width:480px; }
.hosp-body p + p{ margin-top:1.2em; }
.hosp-marks{
  margin-top:64px; padding-top:32px; border-top:1px solid #D9D4C8;
  display:flex; gap:48px; flex-wrap:wrap;
  font-family:'Cormorant Garamond', serif;
  font-size:18px; letter-spacing:.18em; color:var(--text-dark);
  text-transform:uppercase;
}
.hosp-marks span{ opacity:.65; }
.hosp-licensing{ margin-top:20px; font-size:11px; color:var(--muted-dark); letter-spacing:.08em; }
.hosp-img{ aspect-ratio:4/5; overflow:hidden; }
.hosp-img img{ width:100%; height:100%; object-fit:cover; }
@media (max-width: 920px){ .hosp-grid{ grid-template-columns:1fr; gap:48px; } }

/* LOCATION */
.loc{ padding:140px 0; }
.loc-title-row{ display:flex; justify-content:space-between; align-items:end; gap:48px; margin-bottom:64px; }
.loc-grid{ display:grid; grid-template-columns:1.2fr 1fr; gap:0; }
.loc-render{ aspect-ratio:16/10; position:relative; overflow:hidden; }
.loc-render img{ width:100%; height:100%; object-fit:cover; }
.loc-map{
  background:var(--bg-2);
  padding:48px; display:flex; flex-direction:column; justify-content:space-between;
  position:relative; min-height:100%;
  border:1px solid var(--border);
}
.loc-map-svg{ width:100%; aspect-ratio:1/1; max-height:340px; }
.loc-coords{
  margin-top:32px; padding-top:24px; border-top:1px solid var(--border);
  display:grid; grid-template-columns:1fr 1fr; gap:14px 32px;
  font-size:12px;
}
.loc-coords dt{ color:var(--muted); font-size:11px; letter-spacing:.18em; text-transform:uppercase; }
.loc-coords dd{ color:var(--text); letter-spacing:.04em; margin-top:2px; }
.loc-pois{ margin-top:48px; }
.loc-poi{
  display:flex; justify-content:space-between; align-items:baseline;
  padding:14px 0; border-bottom:1px dashed var(--border);
}
.loc-poi:last-child{ border-bottom:0; }
.loc-poi-name{ font-size:14px; color:var(--text); }
.loc-poi-d{ font-size:11px; color:var(--muted); letter-spacing:.16em; font-variant-numeric:tabular-nums; }

@media (max-width: 920px){
  .loc-grid{ grid-template-columns:1fr; }
  .loc-render{ aspect-ratio:16/10; }
  .loc-title-row{ flex-direction:column; align-items:flex-start; gap:16px; }
}

/* RESIDENCES */
.res{ background:var(--bg); padding:160px 0; }
.res-head{ display:grid; grid-template-columns:1fr 1.2fr; gap:80px; margin-bottom:80px; align-items:end; }
.res-stats{
  display:grid; grid-template-columns:repeat(4, 1fr);
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
.res-stat{
  padding:32px 0;
  border-right:1px solid var(--border);
}
.res-stat:last-child{ border-right:0; }
.res-stat-num{
  font-family:'Cormorant Garamond', serif;
  font-weight:300;
  font-size:64px; line-height:1; letter-spacing:-.01em;
  color:var(--text);
}
.res-stat-num sup{ font-size:.4em; color:var(--primary); font-family:inherit; top:-1.2em; margin-left:.1em; }
.res-stat-label{ margin-top:14px; font-size:11px; letter-spacing:.2em; color:var(--muted); text-transform:uppercase; }
.res-typology{
  margin-top:80px;
  display:grid; grid-template-columns:repeat(3, 1fr); gap:0;
  border-top:1px solid var(--border);
}
.res-row{
  display:contents;
}
.res-cell{
  padding:32px 24px; border-bottom:1px solid var(--border); border-right:1px solid var(--border);
  display:flex; flex-direction:column; justify-content:space-between; min-height:200px;
}
.res-cell:nth-child(3n){ border-right:0; }
.res-cell .typ-label{ font-size:11px; letter-spacing:.22em; color:var(--muted); text-transform:uppercase; }
.res-cell .typ-name{ font-family:'Cormorant Garamond', serif; font-size:32px; font-weight:300; line-height:1.05; margin-top:14px; }
.res-cell .typ-meta{ font-size:12px; color:var(--muted); margin-top:8px; }
.res-cell .typ-foot{ display:flex; justify-content:space-between; align-items:center; margin-top:auto; padding-top:24px; font-size:11px; letter-spacing:.18em; color:var(--muted); text-transform:uppercase; }
.res-cell .typ-foot .price{ color:var(--primary); }

.res-disclaim{ margin-top:48px; font-size:11px; color:var(--muted); letter-spacing:.06em; max-width:720px; }

@media (max-width: 920px){
  .res-head{ grid-template-columns:1fr; gap:32px; }
  .res-stats{ grid-template-columns:repeat(2,1fr); }
  .res-stat{ border-bottom:1px solid var(--border); }
  .res-stat:nth-child(2){ border-right:0; }
  .res-typology{ grid-template-columns:1fr; }
  .res-cell:nth-child(n){ border-right:0; }
}

/* AMENITIES */
.amen{ background:var(--surface); color:var(--text-dark); padding:160px 0; }
.amen .eyebrow{ color:var(--muted-dark); }
.amen-grid{ display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; margin-top:64px;}
.amen-img{ aspect-ratio:4/5; overflow:hidden; }
.amen-img img{ width:100%; height:100%; object-fit:cover; }
.amen-list{ display:grid; grid-template-columns:1fr 1fr; gap:0 32px; }
.amen-item{
  padding:24px 0; border-bottom:1px solid #D9D4C8;
  display:flex; align-items:baseline; gap:16px;
  font-size:15px; color:var(--text-dark);
}
.amen-item .num{ font-family:'Cormorant Garamond',serif; font-size:14px; color:var(--primary); font-feature-settings:"lnum"; min-width:32px; }
@media (max-width: 920px){ .amen-grid{ grid-template-columns:1fr; gap:32px; } .amen-list{ grid-template-columns:1fr; } }

/* GALLERY */
.gallery{ background:var(--bg); padding:140px 0; }
.gallery-head{ display:flex; justify-content:space-between; align-items:end; gap:48px; margin-bottom:48px; }
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  grid-auto-rows: 120px;
  gap:8px;
}
.gallery-tile{ overflow:hidden; position:relative; cursor:zoom-in; background:#1c1c20; }
.gallery-tile img{ width:100%; height:100%; object-fit:cover; transition:transform .9s ease; }
.gallery-tile:hover img{ transform:scale(1.04); }
.gallery-tile .caption{
  position:absolute; bottom:0; left:0; right:0; padding:14px 16px;
  font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted);
  background:linear-gradient(to top, rgba(0,0,0,.7), transparent);
  opacity:0; transition:opacity .3s;
}
.gallery-tile:hover .caption{ opacity:1; }
/* mosaic spans */
.g-1{ grid-column:span 7; grid-row:span 4; }
.g-2{ grid-column:span 5; grid-row:span 2; }
.g-3{ grid-column:span 5; grid-row:span 2; }
.g-4{ grid-column:span 4; grid-row:span 3; }
.g-5{ grid-column:span 4; grid-row:span 3; }
.g-6{ grid-column:span 4; grid-row:span 3; }
.g-7{ grid-column:span 8; grid-row:span 3; }
.g-8{ grid-column:span 4; grid-row:span 3; }
@media (max-width: 920px){
  .gallery-grid{ grid-template-columns:repeat(6, 1fr); grid-auto-rows:90px; }
  .g-1, .g-7{ grid-column:span 6; grid-row:span 3; }
  .g-2, .g-3, .g-4, .g-5, .g-6, .g-8{ grid-column:span 3; grid-row:span 2; }
}

/* LIGHTBOX */
.lightbox{
  position:fixed; inset:0; z-index:80;
  background:rgba(8,8,10,.94);
  display:flex; align-items:center; justify-content:center;
  animation:fadein .25s ease;
}
.lightbox-inner{ max-width:88vw; max-height:88vh; position:relative; }
.lightbox img{ max-width:88vw; max-height:88vh; object-fit:contain; }
.lightbox-close{
  position:absolute; top:24px; right:32px; color:var(--text);
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  padding:10px 18px; border:1px solid var(--border);
}
.lightbox-nav{ position:absolute; top:50%; transform:translateY(-50%); padding:24px; color:var(--text); font-size:32px; }
.lightbox-nav.prev{ left:24px; }
.lightbox-nav.next{ right:24px; }
@keyframes fadein{ from{opacity:0} to{opacity:1} }

/* REGISTER */
.reg{
  background:linear-gradient(180deg, var(--bg) 0%, #08080A 100%);
  padding:160px 0;
  position:relative; overflow:hidden;
}
.reg::before{
  content:""; position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:1px; height:80px; background:linear-gradient(to bottom, transparent, var(--primary));
}
.reg-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:96px; align-items:start; }
.reg-side{ position:sticky; top:120px; }
.reg-title{
  font-family:'Cormorant Garamond', serif; font-weight:300;
  font-size:clamp(40px, 5vw, 64px);
  line-height:1.02; letter-spacing:-.01em;
  margin-top:18px;
}
.reg-title em{ font-style:italic; color:var(--primary); }
.reg-blurb{ margin-top:32px; color:var(--muted); font-size:16px; line-height:1.6; max-width:420px; }
.reg-perks{ margin-top:48px; }
.reg-perk{ display:flex; gap:20px; padding:18px 0; border-bottom:1px solid var(--border); }
.reg-perk:first-child{ border-top:1px solid var(--border); }
.reg-perk .perk-num{ font-family:'Cormorant Garamond',serif; color:var(--primary); font-size:14px; min-width:32px; }
.reg-perk .perk-text{ font-size:13px; color:var(--secondary); }

.reg-form{
  background:rgba(255,255,255,.025);
  border:1px solid var(--border);
  padding:48px;
}
.reg-form .seg{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:0; margin-bottom:32px; border:1px solid var(--border); }
.reg-form .seg button{
  padding:14px 12px; font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted); border-right:1px solid var(--border); transition:all .2s;
}
.reg-form .seg button:last-child{ border-right:0; }
.reg-form .seg button.is-active{ background:var(--primary); color:var(--bg); }
.reg-form .seg button:hover:not(.is-active){ color:var(--text); }

.field{ margin-bottom:24px; position:relative; }
.field label{
  display:block; font-size:10px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted); margin-bottom:10px;
}
.field input, .field select, .field textarea{
  width:100%; background:transparent; border:0; border-bottom:1px solid var(--border);
  padding:12px 0; color:var(--text); font-size:15px;
  transition:border-color .2s;
}
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-bottom-color:var(--primary); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.field select{ -webkit-appearance:none; appearance:none; background:transparent; cursor:pointer; }
.field-select-wrap{ position:relative; }
.field-select-wrap::after{ content:""; position:absolute; right:0; bottom:18px; width:6px; height:6px; border-bottom:1px solid var(--muted); border-right:1px solid var(--muted); transform:rotate(45deg); pointer-events:none; }

.checkbox{
  display:flex; align-items:flex-start; gap:12px;
  font-size:12px; color:var(--muted); line-height:1.5;
  cursor:pointer; padding:14px 0;
}
.checkbox input{ position:absolute; opacity:0; }
.checkbox .box{
  width:16px; height:16px; border:1px solid var(--border); flex:0 0 16px;
  display:flex; align-items:center; justify-content:center; transition:all .2s;
}
.checkbox input:checked + .box{ background:var(--primary); border-color:var(--primary); }
.checkbox input:checked + .box::after{
  content:""; width:8px; height:4px; border-left:1.5px solid var(--bg); border-bottom:1.5px solid var(--bg);
  transform:rotate(-45deg) translateY(-1px);
}
.checkbox a{ color:var(--primary); border-bottom:1px solid var(--primary); }

.reg-submit{
  width:100%; margin-top:24px;
  padding:18px 24px;
  background:var(--primary); color:var(--bg);
  font-size:11px; letter-spacing:.24em; text-transform:uppercase; font-weight:500;
  display:flex; align-items:center; justify-content:space-between;
  transition:background .2s;
}
.reg-submit:hover{ background:var(--focus); }
.reg-submit:disabled{ opacity:.4; cursor:not-allowed; }
.reg-progress{
  display:flex; gap:6px; margin-bottom:24px;
}
.reg-progress span{ flex:1; height:1px; background:var(--border); }
.reg-progress span.is-active{ background:var(--primary); }

.reg-success{
  text-align:center; padding:32px 16px;
}
.reg-success .check{
  width:64px; height:64px; border-radius:50%; border:1px solid var(--primary);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 24px;
}
.reg-success .check::after{
  content:""; width:18px; height:9px;
  border-left:1px solid var(--primary); border-bottom:1px solid var(--primary);
  transform:rotate(-45deg) translateY(-3px);
}
.reg-success h3{ font-family:'Cormorant Garamond',serif; font-size:36px; font-weight:300; margin-bottom:14px; }
.reg-success p{ color:var(--muted); font-size:14px; max-width:380px; margin:0 auto; }
.reg-success .ref{ margin-top:24px; font-size:11px; letter-spacing:.2em; color:var(--primary); }

@media (max-width: 920px){
  .reg-grid{ grid-template-columns:1fr; gap:48px; }
  .reg-side{ position:static; }
  .reg-form{ padding:32px 24px; }
  .field-row{ grid-template-columns:1fr; }
}

/* FOOTER */
.footer{
  background:#08080A;
  padding:80px 0 32px;
  border-top:1px solid var(--border);
}
.footer-grid{
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px;
  padding-bottom:64px; border-bottom:1px solid var(--border);
}
.footer-logo svg{ height:18px; }
.footer-tag{ margin-top:18px; font-family:'Cormorant Garamond',serif; font-size:18px; font-style:italic; color:var(--muted); }
.footer-col h5{
  font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:var(--muted); font-weight:500;
  margin-bottom:18px;
}
.footer-col a, .footer-col p{
  display:block; font-size:13px; color:var(--secondary); padding:6px 0;
  transition:color .2s;
}
.footer-col a:hover{ color:var(--primary); }

.footer-bottom{ display:flex; justify-content:space-between; margin-top:32px; font-size:11px; color:var(--muted); letter-spacing:.1em; flex-wrap:wrap; gap:12px;}

@media (max-width: 920px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
}

/* PROJECT SWITCHER STRIP (intro-strip-like) */
.next-projects{
  background:var(--bg); padding:140px 0; border-top:1px solid var(--border);
}
.np-head{ display:flex; justify-content:space-between; align-items:end; margin-bottom:48px; gap:24px; }
.np-grid{ display:grid; grid-template-columns:repeat(4, 1fr); gap:18px; }
.np-card{
  cursor:pointer; position:relative; overflow:hidden;
}
.np-card .np-img{ aspect-ratio:3/4; overflow:hidden; background:#1a1a1e; }
.np-card .np-img img{ width:100%; height:100%; object-fit:cover; transition:transform .9s ease, opacity .4s; }
.np-card:hover .np-img img{ transform:scale(1.05); }
.np-card.is-active .np-img img{ opacity:.55; }
.np-card .np-meta{ padding:18px 0 0; }
.np-card .np-name{ font-family:'Cormorant Garamond', serif; font-size:24px; font-weight:300; }
.np-card .np-sub{ font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-top:6px; }
.np-card .np-marker{
  position:absolute; top:14px; left:14px;
  font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--text);
  background:rgba(15,15,17,.7); backdrop-filter:blur(8px);
  padding:6px 10px;
}
.np-card.is-active .np-marker{ background:var(--primary); color:var(--bg); }
@media (max-width: 920px){ .np-grid{ grid-template-columns:1fr 1fr; } }

/* FAB sticky bar mobile */
.mobile-cta{
  display:none;
  position:fixed; bottom:0; left:0; right:0; z-index:40;
  padding:14px 16px; gap:10px;
  background:rgba(15,15,17,.94); backdrop-filter:blur(12px);
  border-top:1px solid var(--border);
}
.mobile-cta button{
  flex:1; padding:14px; font-size:10px; letter-spacing:.22em; text-transform:uppercase;
  background:var(--primary); color:var(--bg);
}
.mobile-cta button.alt{ background:transparent; color:var(--text); border:1px solid var(--border); }
@media (max-width: 720px){ .mobile-cta{ display:flex; } }

/* MILESTONE strip on home overview */
.brand-strip{
  background:var(--bg-2); border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  padding:32px 0;
}
.brand-strip-inner{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:32px;
  font-size:12px; color:var(--muted);
}
.brand-strip-inner div{ display:flex; flex-direction:column; gap:6px; }
.brand-strip-inner .v{ font-family:'Cormorant Garamond', serif; font-size:28px; font-weight:300; color:var(--text); }
.brand-strip-inner .l{ font-size:10px; letter-spacing:.22em; text-transform:uppercase; }
.brand-strip-inner .src{ font-size:10px; color:var(--muted); opacity:.65; }
@media (max-width: 720px){ .brand-strip-inner{ grid-template-columns:1fr 1fr; } }

/* RTL fixes */
html[dir="rtl"] .nav-logo svg{ transform:none; }
html[dir="rtl"] .hero-meta{ left:48px; right:auto; }
html[dir="rtl"] .hero-counter{ right:48px; left:auto; }
html[dir="rtl"] .btn-arrow::after{ left:0; right:auto; transform:rotate(-135deg); top:-3px; }

/* utility */
.divider{ height:1px; background:var(--border); margin:24px 0; }
.muted{ color:var(--muted); }
.scrim-text{ position:relative; }
