/* ====================================================================
   fäm Properties — Palm Central microsite
   Cinematic dark hero · editorial paper sections · restrained red accent
   ==================================================================== */

:root{
  /* Brand */
  --fam-red:#E8222E;
  --fam-red-700:#C21B26;
  --fam-red-soft:#F9E2E3;
  --fam-grey:#78777A;

  /* Dark (cinematic) */
  --noir:#0E0F11;
  --ink:#16181B;
  --ink-2:#1C1F23;
  --line-d:#262A2E;
  --line-d-2:#33373C;

  /* Light (editorial) */
  --paper:#FAFAF8;
  --paper-2:#F4F2EC;
  --stone:#EFEDE9;
  --ink-l:#16181B;
  --ink-l-2:#3A3B3D;
  --muted:#8C8A86;
  --line:#E4E1DB;
  --line-2:#D7D2C8;

  /* Type */
  --font-display:"Cormorant Garamond", "Times New Roman", serif;
  --font-body:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-mono:"JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
  --font-ar:"IBM Plex Sans Arabic", var(--font-body);

  /* Rhythm */
  --r1:8px; --r2:16px; --r3:24px; --r4:40px; --r5:64px; --r6:96px; --r7:140px;

  /* Container */
  --max:1320px;
  --max-wide:1520px;
  --gutter:32px;
}

*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  scroll-behavior:smooth;
}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink-l);
  font-size:16px;
  line-height:1.6;
  font-weight:400;
}
body[dir="rtl"]{ font-family:var(--font-ar); }

img,svg{display:block; max-width:100%;}
a{color:inherit; text-decoration:none;}
button{font-family:inherit; cursor:pointer; border:0; background:none; color:inherit;}
ul,ol{list-style:none; margin:0; padding:0;}
p{margin:0 0 1em;}
:focus-visible{outline:2px solid var(--fam-red); outline-offset:3px; border-radius:3px;}

.mono{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); }
.honeypot{ position:absolute; left:-9999px; }

/* ====================================================================
   Containers
   ==================================================================== */
.container{ width:100%; max-width:var(--max); margin:0 auto; padding:0 var(--gutter); }
.container-wide{ max-width:var(--max-wide); }
.container-grid{
  display:grid;
  grid-template-columns: 220px 1fr;
  gap: 80px;
  align-items:start;
}
@media (max-width: 960px){
  .container-grid{ grid-template-columns: 1fr; gap: 24px; }
}

.section{ padding: var(--r7) 0; position:relative; }
.section-tight{ padding: calc(var(--r7) - 28px) 0; }
.section-thin{ padding: 70px 0; }
.section-paper{ background:var(--paper); color:var(--ink-l); }
.section-stone{ background:var(--paper-2); color:var(--ink-l); }
.section-ink{ background:var(--noir); color:#EAEAE8; }
.section-data{
  background:linear-gradient(180deg, #ffffff 0%, #F8F7F3 100%);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  color:var(--ink-l);
}

.section-meta{
  font-family:var(--font-mono);
  font-size:.72rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
  padding-top:14px;
  border-top:1px solid var(--line);
}
.section-meta-dark{ color:#7E8086; border-top-color:var(--line-d); }
.section-meta .sec-no{ color:var(--fam-red); margin-right:6px; font-weight:500; }

/* ====================================================================
   Typography
   ==================================================================== */
.display-h2{
  font-family:var(--font-display);
  font-weight:400;
  font-size: clamp(2.4rem, 4.6vw, 4.4rem);
  line-height: 1.05;
  letter-spacing:-0.012em;
  color:var(--ink-l);
  margin:0 0 32px;
  max-width: 22ch;
  text-wrap: pretty;
}
.display-h2.tight{ margin-bottom:18px; }
.display-h2.on-dark{ color:#F2EFEA; }
.display-h2.data-h2{ max-width:18ch; font-size: clamp(2.2rem, 3.8vw, 3.6rem); }

.lead-eyebrow{
  font-family:var(--font-mono);
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--fam-red);
  margin:0 0 18px;
}
.section-lead{
  font-size: 1.12rem;
  line-height:1.55;
  color: var(--ink-l-2);
  max-width: 56ch;
  margin:0 0 28px;
}
.section-lead.on-dark{ color:#C9C7C3; }

.two-col{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  margin-top: 22px;
  max-width:72ch;
}
.two-col p{ color:var(--ink-l-2); font-size:1.02rem; line-height:1.66; }
@media (max-width:780px){ .two-col{ grid-template-columns:1fr; gap:20px; } }

.rule{ height:1px; width:80px; background:var(--ink-l); margin: 8px 0 24px; }
.rule-red{ background:var(--fam-red); height:2px; }

.ed-h3{
  font-family:var(--font-display);
  font-weight:500;
  font-size: 1.7rem;
  line-height:1.2;
  margin:0 0 16px;
  letter-spacing:-0.005em;
}

.footnote{ font-size:.78rem; color:var(--muted); margin-top:18px; line-height:1.5; }

/* ====================================================================
   Buttons
   ==================================================================== */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding: 14px 22px;
  font-family:var(--font-body);
  font-weight:500;
  font-size:.92rem;
  letter-spacing:.02em;
  border-radius:0;
  border:1px solid transparent;
  transition: background .2s ease, border-color .2s ease, color .2s ease, transform .2s ease;
  cursor:pointer;
  text-decoration:none;
  white-space:nowrap;
}
.btn-sm{ padding: 10px 16px; font-size:.84rem; }
.btn-lg{ padding: 18px 28px; font-size:1rem; }
.btn-primary{
  background:var(--fam-red); color:#fff; border-color:var(--fam-red);
}
.btn-primary:hover{ background:var(--fam-red-700); border-color:var(--fam-red-700); }
.btn-ghost-light{
  background:transparent; color:#fff; border-color:rgba(255,255,255,.55);
}
.btn-ghost-light:hover{ background:rgba(255,255,255,.08); border-color:#fff; }
.btn-ghost{
  background:transparent; color:var(--ink-l); border-color:var(--line-2);
}
.btn-ghost:hover{ border-color:var(--ink-l); }
.btn-ink{
  background:var(--ink-l); color:#fff; border-color:var(--ink-l);
}
.btn-ink:hover{ background:var(--noir); }
.btn-loader{
  width:14px; height:14px; border:2px solid currentColor; border-right-color:transparent;
  border-radius:50%; animation: spin .8s linear infinite; display:none;
}
.btn.is-loading .btn-label{ opacity:.6; }
.btn.is-loading .btn-loader{ display:inline-block; }
@keyframes spin{ to{ transform:rotate(360deg); } }

/* ====================================================================
   Top bar
   ==================================================================== */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:50;
  transition: background .35s ease, border-color .35s ease, color .35s ease;
  border-bottom: 1px solid transparent;
  color:#fff;
}
.topbar-inner{
  max-width: var(--max-wide);
  margin: 0 auto;
  padding: 14px var(--gutter);
  display:grid;
  grid-template-columns: auto 1fr auto;
  gap: 28px;
  align-items:center;
}
.topbar.is-scrolled{
  background: rgba(250,250,248,.93);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom-color: var(--line);
  color: var(--ink-l);
}
.brand{ display:flex; align-items:center; gap:14px; }
.brand-divider{
  width:1px; height:22px; background: currentColor; opacity:.32;
}
.brand-word{
  font-family:var(--font-display);
  font-size: 1.25rem;
  font-weight:500;
  letter-spacing:.02em;
}
.brand-fam{
  font-family:var(--font-body);
  font-weight:800;
  font-size: 1.55rem;
  letter-spacing:-0.02em;
  line-height:1;
  display:inline-flex; align-items:flex-start; gap:1px;
}
.brand-fam sup{ font-size:.42em; font-weight:600; line-height:1; margin-top:.2em; opacity:.7; }
.topnav{
  display:flex; gap:30px; justify-content:center;
}
.topnav a{
  font-size:.86rem;
  font-weight:500;
  letter-spacing:.02em;
  opacity:.85;
  position:relative;
  padding:6px 0;
}
.topnav a:hover{ opacity:1; }
.topnav a::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:1px;
  background:currentColor; transform:scaleX(0); transform-origin:left;
  transition:transform .25s ease;
}
.topnav a:hover::after{ transform:scaleX(1); }

.topbar-right{ display:flex; align-items:center; gap:18px; }
.lang-toggle{ display:flex; gap:2px; padding:3px; border:1px solid currentColor; border-color: rgba(255,255,255,.3); border-radius:999px; }
.topbar.is-scrolled .lang-toggle{ border-color: var(--line-2); }
.lang-btn{
  font-size:.72rem; letter-spacing:.06em; font-weight:500;
  padding: 6px 10px; border-radius:999px;
  opacity:.7; transition: all .2s ease;
}
.lang-btn.is-active{ background: currentColor; opacity:1; }
.lang-btn.is-active{ color: var(--ink-l); }
.topbar.is-scrolled .lang-btn.is-active{ color:#fff; }
.lang-btn:not(.is-active):hover{ opacity:1; }

.mobile-menu-btn{
  display:none;
  width:36px; height:36px;
  flex-direction:column; gap:5px; align-items:center; justify-content:center;
}
.mobile-menu-btn span{ width:22px; height:1.5px; background: currentColor; transition: transform .25s ease, opacity .2s ease; }
.mobile-menu-btn.is-open span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.mobile-menu-btn.is-open span:nth-child(2){ opacity: 0; }
.mobile-menu-btn.is-open span:nth-child(3){ transform: translateY(-6px) rotate(-45deg); }
.mobile-nav{
  display:none;
  background: rgba(14,15,17,.97);
  backdrop-filter: blur(20px);
  padding: 24px var(--gutter);
  flex-direction:column; gap:14px;
  border-top:1px solid var(--line-d);
}
.mobile-nav.is-open{ display:flex; }
.mobile-nav a{
  font-family:var(--font-display); font-size:1.4rem; color:#F2EFEA; padding: 4px 0;
}
.mobile-nav-cta{ margin-top:8px; }

@media (max-width: 1024px){
  .topnav{ display:none; }
  .mobile-menu-btn{ display:flex; }
  .topbar-right .btn{ display:none; }
}
@media (max-width: 640px){
  .lang-toggle{ display:none; }
}

/* ====================================================================
   Hero
   ==================================================================== */
.hero{
  position:relative;
  height: 100vh;
  min-height: 720px;
  color:#fff;
  overflow:hidden;
  display:flex; flex-direction:column; justify-content:flex-end;
}
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-media img{
  width:100%; height:100%; object-fit:cover;
  transform: scale(1.04);
  animation: heroZoom 28s ease-out forwards;
}
@keyframes heroZoom{ to{ transform: scale(1); } }
.hero-scrim{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(14,15,17,.7) 0%, rgba(14,15,17,.25) 28%, rgba(14,15,17,.15) 45%, rgba(14,15,17,.55) 75%, rgba(14,15,17,.92) 100%);
}
.hero-vignette{
  position:absolute; inset:0;
  background: radial-gradient(120% 70% at 50% 35%, transparent 30%, rgba(0,0,0,.45) 100%);
  pointer-events:none;
}

.hero-content{
  position:relative; z-index:2;
  padding: 0 var(--gutter) 80px;
  max-width: var(--max-wide);
  margin: 0 auto;
  width:100%;
}
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-mono);
  font-size:.74rem; letter-spacing:.16em; text-transform:uppercase;
  margin-bottom:28px;
  opacity:.92;
}
.hero-eyebrow .dot{ width:8px; height:8px; background:var(--fam-red); border-radius:50%; box-shadow:0 0 0 4px rgba(232,34,46,.18); }
.hero-title{
  font-family:var(--font-display);
  font-weight:400;
  font-size: clamp(3.6rem, 9vw, 8.4rem);
  line-height: .95;
  letter-spacing:-0.015em;
  margin: 0 0 24px;
  color:#fff;
}
.title-line{ display:block; }
.hero-sub{
  max-width: 56ch;
  font-size: 1.18rem;
  line-height:1.55;
  color: rgba(255,255,255,.96);
  margin: 0 0 38px;
  font-weight:400;
  text-shadow: 0 2px 24px rgba(0,0,0,.55), 0 1px 2px rgba(0,0,0,.4);
}
.hero-cta{ display:flex; flex-wrap:wrap; gap:12px; margin-bottom:52px; }
.hero-fact-row{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid rgba(255,255,255,.18);
  padding-top: 22px;
  max-width: 920px;
}
.fact{ display:flex; flex-direction:column; gap:6px; padding-right:24px; }
.fact + .fact{ border-left:1px solid rgba(255,255,255,.12); padding-left:24px; }
body[dir="rtl"] .fact + .fact{ border-left:0; border-right:1px solid rgba(255,255,255,.12); padding-right:24px; padding-left:0;}
.fact-label{
  font-family:var(--font-mono); font-size:.66rem; letter-spacing:.14em;
  text-transform:uppercase; color:rgba(255,255,255,.55);
}
.fact-value{
  font-family:var(--font-display); font-size: 1.4rem; font-weight:500;
  color:#fff; line-height:1.2;
}
@media (max-width:780px){
  .hero{ min-height: 640px; height: 92vh; }
  .hero-content{ padding-bottom:54px; }
  .hero-fact-row{ grid-template-columns: repeat(2, 1fr); gap:18px; padding-top:16px; }
  .fact + .fact{ border-left:0; padding-left:0; }
  .fact{ padding-right:0; }
}
.hero-scroll{
  position:absolute; left:50%; bottom:24px; transform:translateX(-50%);
  z-index:3;
  display:flex; flex-direction:column; align-items:center; gap:8px;
  color: rgba(255,255,255,.7);
  font-family:var(--font-mono); font-size:.62rem; letter-spacing:.2em; text-transform:uppercase;
}
.hero-scroll-line{
  width:1px; height:38px; background: rgba(255,255,255,.5);
  position:relative; overflow:hidden;
}
.hero-scroll-line::after{
  content:""; position:absolute; top:-38px; left:0; right:0; height:38px;
  background: linear-gradient(180deg, transparent, #fff);
  animation: scrollLine 2.2s ease-in-out infinite;
}
@keyframes scrollLine{
  0%{ top:-38px; } 60%{ top:38px; } 100%{ top:38px; }
}

/* ====================================================================
   Trust strip
   ==================================================================== */
.trust-strip{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin-top: 80px;
  border-top:1px solid var(--line);
  padding-top: 30px;
}
.trust-item{ display:flex; flex-direction:column; gap:8px; padding-right:24px; }
.trust-item + .trust-item{ border-left:1px solid var(--line); padding-left:24px; }
body[dir="rtl"] .trust-item + .trust-item{ border-left:0; border-right:1px solid var(--line); padding-left:0; padding-right:24px; }
.trust-num{
  font-family:var(--font-display); font-size: 2.2rem; line-height:1; font-weight:500; color: var(--ink-l);
}
.trust-num .plus{ color:var(--fam-red); font-size:1.4rem; vertical-align:.2em; margin-left:2px; }
.trust-lbl{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
@media (max-width: 780px){
  .trust-strip{ grid-template-columns: repeat(2, 1fr); gap: 22px; }
  .trust-item + .trust-item{ border-left:0; padding-left:0; }
  .trust-item{ padding-right:0; }
}

/* ====================================================================
   Location
   ==================================================================== */
.loc-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 60px;
  margin-top: 56px;
  align-items:start;
}
@media (max-width:960px){ .loc-grid{ grid-template-columns:1fr; gap:32px; } }
.map-frame{
  background:var(--paper-2);
  border:1px solid var(--line);
  aspect-ratio: 16/10;
  overflow:hidden;
  position:relative;
}
.map-pin{ animation: ping 2.4s ease-out infinite; transform-origin: 400px 380px; }
@keyframes ping{
  0%,60%,100%{ transform: scale(1); }
  20%{ transform: scale(1.15); }
}
.map-cap{
  margin-top:12px;
  display:flex; gap:18px; align-items:baseline;
  font-family:var(--font-mono);
  font-size:.72rem; letter-spacing:.06em; color:var(--muted);
}

.anchor-list{ border-top:1px solid var(--line); margin-top:6px; }
.anchor-list li{
  display:grid; grid-template-columns: 72px 1fr;
  gap: 20px; align-items:baseline;
  padding: 14px 0;
  border-bottom:1px solid var(--line);
}
.dist{
  font-family:var(--font-mono); font-size:.8rem; font-weight:500;
  color:var(--fam-red);
  letter-spacing:.02em;
}
.place{ font-size:1rem; color: var(--ink-l); }

/* ====================================================================
   Lifestyle (dark)
   ==================================================================== */
.section-ink .section-meta-dark{ color:#7E8086; border-top-color:var(--line-d); }
.lifestyle-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 32px;
  margin-top: 60px;
}
@media (max-width: 960px){ .lifestyle-grid{ grid-template-columns:1fr; gap:28px; } }
.life-card{ display:flex; flex-direction:column; }
.life-img{ aspect-ratio: 4/5; overflow:hidden; background:var(--ink); }
.life-img img{ width:100%; height:100%; object-fit:cover; transition: transform 1.2s ease; filter: brightness(.92); }
.life-card:hover .life-img img{ transform: scale(1.04); }
.life-text{ padding: 22px 4px 0; color:#D7D5D0; }
.life-num{ color:var(--fam-red); font-size:.8rem; }
.life-text h4{
  font-family:var(--font-display); font-weight:500;
  font-size: 1.5rem; line-height:1.2;
  margin: 8px 0 12px;
  color:#F2EFEA;
}
.life-text p{ color:#A9A8A4; font-size:.96rem; line-height:1.65; }

/* ====================================================================
   Residences
   ==================================================================== */
.res-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap: 22px;
  margin-top: 56px;
}
@media (max-width:1100px){ .res-grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width:560px){ .res-grid{ grid-template-columns:1fr; } }

.res-card{
  background:#fff;
  border:1px solid var(--line);
  padding: 28px 26px 24px;
  display:flex; flex-direction:column;
  min-height: 360px;
  transition: border-color .3s ease, transform .3s ease, box-shadow .3s ease;
}
.res-card:hover{
  border-color: var(--ink-l);
  transform: translateY(-2px);
  box-shadow: 0 24px 48px -28px rgba(14,15,17,.12);
}
.res-card-feature{
  background:var(--ink-l); color:#EAEAE8; border-color:var(--ink-l);
}
.res-card-feature .res-id{ color:var(--fam-red); }
.res-card-feature .res-name{ color:#F2EFEA; }
.res-card-feature .res-specs dt{ color:#888A8E; border-color:var(--line-d-2); }
.res-card-feature .res-specs dd{ color:#EAEAE8; }
.res-card-feature .res-link{ color:#fff; }
.res-card-feature .res-tag{ background: rgba(232,34,46,.2); color:#fff; border-color:transparent; }

.res-card-top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; }
.res-id{ font-family:var(--font-mono); font-size:.78rem; color:var(--muted); }
.res-tag{
  font-family:var(--font-mono); font-size:.62rem; letter-spacing:.14em; text-transform:uppercase;
  padding: 4px 8px; border:1px solid var(--line-2); color: var(--ink-l-2);
}
.res-name{
  font-family:var(--font-display); font-size: 1.4rem; font-weight:500;
  line-height:1.15; margin: 4px 0 18px;
  color:var(--ink-l);
}
.res-specs{ flex:1; margin:0 0 18px; display:flex; flex-direction:column; gap:0; }
.res-specs div{
  display:grid; grid-template-columns: 1fr auto; gap:12px;
  padding: 10px 0;
  border-bottom: 1px dashed var(--line);
  align-items:baseline;
}
.res-specs dt{
  font-family:var(--font-mono); font-size:.64rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--muted);
  margin:0;
}
.res-specs dd{ margin:0; font-size:.92rem; color:var(--ink-l); text-align:right; }
.res-specs dd.onreq{ color:var(--fam-red); font-weight:500; }
.res-link{
  align-self:flex-start;
  font-size:.86rem; font-weight:500; color:var(--ink-l);
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
  transition: color .2s ease;
}
.res-link:hover{ color:var(--fam-red); }

.res-foot{
  max-width: 80ch; margin: 36px auto 0;
  text-align:center;
  font-size:.7rem !important;
  color:var(--muted);
}

/* ====================================================================
   Data block
   ==================================================================== */
.data-head{
  display:grid; grid-template-columns: 1.5fr 1fr; gap: 60px;
  align-items:end; margin-bottom: 56px;
}
@media (max-width:960px){ .data-head{ grid-template-columns:1fr; gap:28px; align-items:start; } }
.data-eyebrow{
  display:inline-block; color: var(--fam-red); font-size:.72rem; letter-spacing:.18em;
  margin-bottom:18px;
}
.data-eyebrow.on-dark{ color: var(--fam-red); }
.data-lead{ font-size:1.06rem; color:var(--ink-l-2); max-width:60ch; line-height:1.6; }
.data-head-r{ display:flex; flex-direction:column; gap:12px; align-items:flex-start; }
.data-foot{ font-size:.66rem; color:var(--muted); }

.data-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}
@media (max-width:1100px){ .data-grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width:640px){ .data-grid{ grid-template-columns: 1fr; } }
.data-card{
  background:#fff;
  border:1px solid var(--line);
  padding: 24px;
  display:flex; flex-direction:column;
}
.data-card-wide{ grid-column: span 2; }
@media (max-width:640px){ .data-card-wide{ grid-column: span 1; } }
.data-card-h{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom: 18px; gap:12px; }
.data-card-t{ font-size:.86rem; font-weight:500; color:var(--ink-l); }
.data-card-r{ font-size:.7rem; color:var(--muted); }
.trend-up{ color: #0A8A4A; }
.trend-down{ color: var(--fam-red); }
.data-card-f{
  margin-top: auto; padding-top: 16px; border-top: 1px solid var(--line);
  display:grid; grid-template-columns: repeat(3, 1fr); gap:12px;
}
.data-card-f > div{ display:flex; flex-direction:column; gap:4px; }
.data-card-f .mono{ color: var(--ink-l); font-size:.94rem; font-weight:500; text-transform:none; letter-spacing:0; }
.data-card-f .lbl{ font-family:var(--font-mono); font-size:.6rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }

.chart-wrap{ position:relative; }
.line-chart{ width:100%; height: 180px; }
.line-chart .grid line{ stroke: var(--line); stroke-width:.5; stroke-dasharray:2 4; }
.chart-x{ display:flex; justify-content:space-between; padding-top:8px; font-size:.6rem; color:var(--muted); }

.bar-chart{
  display:grid; grid-template-columns: repeat(8, 1fr); gap: 6px;
  height: 160px;
  align-items:end;
  margin-bottom: 12px;
}
.bar{ display:flex; flex-direction:column; align-items:center; justify-content:flex-end; gap:8px; height:100%; }
.bar span{
  width: 100%;
  height: var(--h);
  background: var(--ink-l);
  transition: height .8s ease;
}
.bar em{ font-size:.55rem; letter-spacing:.04em; color: var(--muted); font-style:normal; }
.bar-now span{ background: var(--fam-red); }

.mix-rows{ display:flex; flex-direction:column; gap:10px; }
.mix-row{
  display:grid;
  grid-template-columns: 130px 1fr 48px;
  gap: 12px; align-items:center;
}
.mix-lbl{ font-size:.82rem; color: var(--ink-l-2); }
.mix-bar{ height: 6px; background: var(--line); position:relative; overflow:hidden; }
.mix-bar em{ display:block; height:100%; width: var(--w); background: var(--fam-red); transition: width 1s ease; }
.mix-pct{ font-size:.78rem; color:var(--ink-l); text-align:right; letter-spacing:0; text-transform:none; }

.dial{ position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center; padding: 8px 0; flex:1; }
.dial svg{ width:100%; max-width: 220px; }
.dial-num{
  position:absolute; left:0; right:0; top:50px;
  text-align:center;
  font-size:2rem; font-weight:600;
  color:var(--ink-l); letter-spacing:0; text-transform:none;
}
.dial-lbl{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color: var(--muted); margin-top: 6px; }
@keyframes dial{ to{ stroke-dasharray: 130 200; } }

/* ====================================================================
   Gallery
   ==================================================================== */
.gal-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 220px;
  gap: 16px;
  margin-top: 56px;
}
@media (max-width:960px){ .gal-grid{ grid-template-columns: repeat(2, 1fr); grid-auto-rows: 180px; } }
.gal-cell{
  position:relative; overflow:hidden; background: var(--paper-2);
  cursor: zoom-in; padding:0;
  transition: transform .4s ease;
}
.gal-cell:hover{ transform: scale(.992); }
.gal-cell img{ width:100%; height:100%; object-fit:cover; transition: transform .8s ease; }
.gal-cell:hover img{ transform: scale(1.05); }
.gal-tall{ grid-row: span 2; }
.gal-wide{ grid-column: span 2; }
.gal-cap{
  position:absolute; left:14px; bottom:12px;
  color:#fff;
  background: rgba(14,15,17,.5);
  padding: 4px 8px;
  font-size:.6rem !important;
  letter-spacing:.08em !important;
  backdrop-filter: blur(4px);
}

/* ====================================================================
   Awards
   ==================================================================== */
.awards-row{
  display:grid; grid-template-columns: 1fr 2fr;
  gap: 56px;
  align-items:center;
}
@media (max-width:880px){ .awards-row{ grid-template-columns:1fr; gap:24px; } }
.awards-l p{ color:var(--ink-l-2); }
.awards-list{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top:1px solid var(--line-2);
}
.awards-list li{
  padding: 22px 24px;
  border-bottom:1px solid var(--line-2);
  border-right:1px solid var(--line-2);
  display:flex; flex-direction:column; gap:6px;
}
.awards-list li:last-child{ border-right:0; }
.aw-year{ color:var(--fam-red); font-size:.72rem; font-weight:600; }
.aw-name{ font-family:var(--font-display); font-size:1.3rem; font-weight:500; line-height:1.15; }
.aw-iss{ font-size:.82rem; color: var(--muted); }
@media (max-width:780px){
  .awards-list{ grid-template-columns:1fr; }
  .awards-list li{ border-right:0; }
}

/* ====================================================================
   Enquire
   ==================================================================== */
.enquire-shell{
  display:grid;
  grid-template-columns: 1fr 1.05fr;
  gap: 80px;
  align-items:start;
}
@media (max-width:1024px){ .enquire-shell{ grid-template-columns:1fr; gap:48px; } }
.enquire-l .enquire-lead{
  font-size: 1.06rem; color: #C9C7C3;
  max-width: 52ch; margin-bottom: 28px;
}
.enquire-checks{ margin-bottom: 36px; display:flex; flex-direction:column; gap:10px; max-width:50ch; }
.enquire-checks li{
  position:relative; padding-left:22px;
  color:#B6B4B0; font-size:.92rem; line-height:1.5;
}
.enquire-checks li::before{
  content:""; position:absolute; left:0; top:.55em;
  width: 8px; height:8px; background: var(--fam-red);
}
body[dir="rtl"] .enquire-checks li{ padding-left:0; padding-right:22px; }
body[dir="rtl"] .enquire-checks li::before{ left:auto; right:0; }

.enquire-contact{ display:flex; flex-direction:column; gap:0; border-top:1px solid var(--line-d); }
.ec-row{
  display:flex; gap:16px; align-items:center;
  padding: 18px 0;
  border-bottom:1px solid var(--line-d);
  transition: padding .2s ease;
}
.ec-row:hover{ padding-left:6px; }
body[dir="rtl"] .ec-row:hover{ padding-left:0; padding-right:6px; }
.ec-icon{
  width:40px; height:40px; border:1px solid var(--line-d-2);
  display:flex; align-items:center; justify-content:center;
  color: var(--fam-red);
}
.ec-text{ display:flex; flex-direction:column; gap:2px; }
.ec-lbl{ color: #82828A; font-size:.6rem; }
.ec-val{ color:#F2EFEA; font-size:1rem; }

/* form */
.enquire-form{
  background: #fff;
  color: var(--ink-l);
  padding: 36px;
  position:relative;
}
@media (max-width:560px){ .enquire-form{ padding:24px; } }
.form-tabs{ display:flex; gap:0; margin-bottom: 28px; border-bottom: 1px solid var(--line); }
.ft-btn{
  padding: 12px 4px; margin-right: 22px;
  font-size:.84rem; font-weight:500;
  color: var(--muted);
  border-bottom: 2px solid transparent;
  transition: color .2s, border-color .2s;
}
.ft-btn.is-active{ color: var(--ink-l); border-color: var(--fam-red); }
.ft-btn:hover{ color: var(--ink-l); }

.form-row{ display:grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom:16px; }
@media (max-width: 560px){ .form-row{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
.form-row .field{ margin-bottom:0; }
.f-lbl{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color: var(--muted); }
.field input, .field select, .field textarea{
  font-family:var(--font-body);
  font-size:1rem;
  padding: 12px 14px;
  border:1px solid var(--line);
  background:#fff;
  color: var(--ink-l);
  border-radius: 0;
  transition: border-color .2s ease;
  width:100%;
}
.field textarea{ resize:vertical; }
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none;
  border-color: var(--ink-l);
}
.field.is-invalid input, .field.is-invalid select, .field.is-invalid textarea{
  border-color: var(--fam-red);
}
.f-err{ display:none; color: var(--fam-red); font-size:.78rem; }
.field.is-invalid .f-err{ display:block; }

.checkrow{
  display:flex; gap:10px; align-items:flex-start;
  font-size:.82rem; color: var(--ink-l-2); line-height:1.5;
  margin: 4px 0 24px;
}
.checkrow input{ margin-top:3px; accent-color: var(--fam-red); }

.form-foot{
  display:flex; align-items:center; gap:18px; flex-wrap:wrap;
  border-top: 1px solid var(--line); padding-top: 22px;
}
.form-foot-note{ font-size:.6rem; color:var(--muted); max-width: 30ch; }
.form-success{
  position:absolute; inset:0;
  background: #fff;
  padding: 36px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; gap:14px;
  animation: fadeUp .4s ease forwards;
}
.form-success[hidden]{ display:none !important; }
.fs-mark{
  width: 64px; height:64px; border-radius:50%;
  background: var(--fam-red-soft); color: var(--fam-red);
  display:flex; align-items:center; justify-content:center;
}
.form-success h4{
  font-family:var(--font-display); font-size:1.8rem; font-weight:500; margin:0;
}
.form-success p{ max-width: 40ch; color: var(--ink-l-2); }
@keyframes fadeUp{ from{ opacity:0; transform: translateY(10px);} to{opacity:1; transform:none;} }

/* ====================================================================
   More launches
   ==================================================================== */
.more-strip{
  display:grid; grid-template-columns: repeat(4, 1fr); gap: 22px;
  margin-top: 48px;
}
@media (max-width: 1100px){ .more-strip{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px){ .more-strip{ grid-template-columns: 1fr; } }
.more-card{ display:flex; flex-direction:column; gap:0; cursor:pointer; }
.more-img{ aspect-ratio: 4/3; overflow:hidden; background: var(--paper-2); }
.more-img img{ width:100%; height:100%; object-fit:cover; transition: transform .8s ease; }
.more-card:hover .more-img img{ transform: scale(1.05); }
.more-body{ padding: 18px 4px 0; }
.more-loc{ color: var(--fam-red); font-size:.66rem; }
.more-body h4{
  font-family:var(--font-display); font-weight:500;
  font-size: 1.4rem; line-height:1.15;
  margin: 6px 0 10px;
}
.more-body p{ font-size:.92rem; color:var(--ink-l-2); margin-bottom:12px; }
.more-link{
  font-size:.82rem; font-weight:500; border-bottom: 1px solid currentColor; padding-bottom:1px;
}

/* ====================================================================
   Footer
   ==================================================================== */
.footer{ background: var(--noir); color:#A9A8A4; padding: 88px 0 0; }
.footer-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid var(--line-d);
}
@media (max-width: 1024px){
  .footer-grid{ grid-template-columns: 1fr 1fr; gap:36px; }
}
@media (max-width: 560px){
  .footer-grid{ grid-template-columns: 1fr; }
}
.footer-brand .footer-mark{ height: 40px; margin-bottom: 18px; }
.footer-mark-text{
  display:inline-flex; align-items:center; gap:14px;
  margin-bottom: 22px;
  color:#fff;
}
.fb-fam{
  font-family:var(--font-body);
  font-weight:800; font-size:1.7rem; letter-spacing:-0.02em; line-height:1;
  display:inline-flex; align-items:flex-start; gap:1px;
}
.fb-fam sup{ font-size:.42em; font-weight:600; line-height:1; margin-top:.2em; opacity:.65; }
.fb-divider{ width:1px; height:22px; background:#fff; opacity:.32; }
.fb-suffix{ font-family:var(--font-display); font-size:1.3rem; font-weight:500; letter-spacing:.02em; }
.footer-tag{
  font-family: var(--font-display); font-size: 1.4rem; font-weight:400; line-height:1.2;
  color: #EAEAE8; max-width: 22ch; margin-bottom: 16px;
}
.footer-leg{ color:#65676B; }
.footer h6{
  font-family:var(--font-mono); font-size:.68rem; letter-spacing:.12em; text-transform:uppercase;
  color: #E2DFD9; margin: 0 0 14px; font-weight:500;
}
.footer p, .footer a{ color:#A9A8A4; font-size:.9rem; line-height:1.7; }
.footer a:hover{ color:#fff; }
.branch-list{ columns: 2; column-gap: 14px; font-size:.86rem; }
.branch-list li{ padding: 3px 0; color:#A9A8A4; }
.social-list li{ padding: 4px 0; font-size:.86rem; }
.footer-base{ background:#0A0B0D; padding: 18px 0; color:#65676B; }
.footer-base-row{
  display:flex; gap:24px; justify-content:space-between; flex-wrap:wrap;
}
.footer-base .mono{ font-size:.62rem; color:#65676B; }

/* ====================================================================
   FAB + Lightbox
   ==================================================================== */
.fab{
  position:fixed; right: 22px; bottom: 22px; z-index:40;
  width:54px; height:54px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background: #25D366; color:#fff;
  box-shadow: 0 12px 28px -8px rgba(37, 211, 102, .55);
  transition: transform .2s ease;
}
.fab:hover{ transform: scale(1.06); }
@media (max-width: 640px){ .fab{ right:14px; bottom:14px; } }

.lightbox{
  position:fixed; inset:0; z-index:60;
  background: rgba(14,15,17,.96);
  display:flex; align-items:center; justify-content:center;
  animation: fadeIn .2s ease;
}
.lightbox[hidden]{ display:none !important; }
.lightbox img{ max-width: 92vw; max-height: 88vh; object-fit:contain; }
.lb-close, .lb-prev, .lb-next{
  position:absolute; color:#fff; font-size: 2.4rem; line-height:1;
  width: 52px; height:52px;
  display:flex; align-items:center; justify-content:center;
  opacity:.7; transition: opacity .2s ease;
}
.lb-close:hover, .lb-prev:hover, .lb-next:hover{ opacity:1; }
.lb-close{ top: 18px; right: 18px; }
.lb-prev{ left: 12px; top: 50%; transform: translateY(-50%); }
.lb-next{ right: 12px; top: 50%; transform: translateY(-50%); }
@keyframes fadeIn{ from{ opacity:0; } to{ opacity:1; } }

/* ====================================================================
   Reveal animation
   ==================================================================== */
.reveal{ opacity:0; transform: translateY(20px); transition: opacity .8s ease, transform .8s ease; }
.reveal.is-in{ opacity:1; transform: none; }

/* ====================================================================
   RTL fixes
   ==================================================================== */
body[dir="rtl"] .hero-cta .btn svg{ transform: scaleX(-1); }
body[dir="rtl"] .topnav a::after{ transform-origin: right; }
body[dir="rtl"] .res-specs dd{ text-align:left; }
body[dir="rtl"] .res-link::after{ content:" ←"; }

/* Tweaks panel positioning hook (set by tweaks-panel.jsx) */
