/* ═══════════════════════════════════════════════════════════════════
   ARTANA — stylesheet
   Structure:  tokens · base · nav · pages · components · responsive · themes
   Theming:    every surface/border/shadow reads a CSS variable, so the
               four themes at the bottom of this file fully reskin the site.
═══════════════════════════════════════════════════════════════════ */

/* ── Design tokens (default = WARM theme) ──────────────────────────── */
:root{
  /* text */
  --ink:#1e1d1b;
  --muted:#746d64;
  /* surfaces */
  --bg:#fbfaf6;            /* page background — crisp warm-white */
  --bg-alt:#f0ece3;        /* page-hero / alt sections   */
  --card:#ffffff;          /* card + panel surface       */
  --card-edge:#f6f3ed;     /* card gradient end stop     */
  --field-bg:#ffffff;      /* form inputs                */
  --nav-bg:rgba(251,250,246,.82);
  --nav-solid:rgba(251,250,246,.96);
  /* accents */
  --walnut:#6f5842;        /* heading accent + primary button */
  --walnut-dark:#403226;   /* button hover               */
  --brass:#a9823f;         /* gold accent                */
  --brass-light:rgba(169,130,63,.15);
  --glow:rgba(169,130,63,.16);   /* soft hero/section glow */
  --btn-text:#ffffff;      /* text on the primary button */
  /* lines + shadow */
  --line:rgba(30,29,27,.10);
  --line-strong:rgba(30,29,27,.20);
  --shadow:30,29,27;       /* rgb tuple, used as rgba(var(--shadow),a) */
  /* footer (dark in every theme) */
  --dark:#221d18;
  --on-dark:#f8f4ec;
  --on-dark-muted:rgba(248,244,236,.72);
  /* metrics */
  --content:1240px;
  --gutter:clamp(24px, 6vw, 88px);
  --ease:cubic-bezier(.25,.1,.25,1);
  --ease-out:cubic-bezier(0,0,.2,1);
  --radius-card:20px;
  --radius-sm:10px;
  color-scheme:light;
}

/* ── Base ──────────────────────────────────────────────────────────── */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:"Inter",system-ui,sans-serif;
  font-size:15px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  transition:background .3s var(--ease),color .3s var(--ease);
}
a{color:inherit;text-decoration:none;transition:color .2s var(--ease)}
button,input,select,textarea{font:inherit}
img{display:block}

h1,h2,h3{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-weight:500;
  letter-spacing:0;
}
h1{font-size:clamp(48px, 7vw, 92px);line-height:1.02;margin:0}
h2{font-size:clamp(34px, 4.5vw, 58px);line-height:1.08;margin:0}
h3{font-size:clamp(24px, 2.7vw, 34px);line-height:1.15;margin:0}
p{margin:0}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--walnut);
  font-size:11px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.eyebrow::before{
  content:"";
  display:inline-block;
  width:24px;
  height:1px;
  background:var(--brass);
  flex-shrink:0;
}
.arrow{
  font-size:14px;
  display:inline-block;
  transition:transform .25s var(--ease);
}

::selection{background:var(--walnut);color:var(--btn-text)}
:focus-visible{outline:2px solid var(--walnut);outline-offset:3px}

/* ── Nav ───────────────────────────────────────────────────────────── */
.nav{
  position:sticky;
  top:0;
  z-index:20;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  padding:16px var(--gutter);
  background:var(--nav-bg);
  border-bottom:1px solid transparent;
  backdrop-filter:saturate(160%) blur(20px);
  -webkit-backdrop-filter:saturate(160%) blur(20px);
  transition:background .25s var(--ease),border-color .25s var(--ease),box-shadow .25s var(--ease);
}
.nav.scrolled{
  border-bottom-color:var(--line);
  background:var(--nav-solid);
  box-shadow:0 4px 30px rgba(var(--shadow),.06);
}
.wm{display:inline-flex;align-items:center}
.wm-text{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-style:italic;
  font-weight:500;
  font-size:26px;
  letter-spacing:.005em;
  color:var(--walnut);
  line-height:1;
}
.nav-links{display:flex;gap:30px;font-size:12px;font-weight:700;letter-spacing:.15em;text-transform:uppercase}
.nav-links a{position:relative;color:var(--muted);padding:8px 0}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:2px;
  height:1px;
  background:var(--walnut);
}
.nav-divider{
  width:1px;
  height:18px;
  background:var(--line-strong);
  flex-shrink:0;
}

/* ── Buttons + links ───────────────────────────────────────────────── */
.cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:44px;
  padding:13px 26px;
  border:1px solid var(--walnut);
  border-radius:var(--radius-sm);
  background:var(--walnut);
  color:var(--btn-text);
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  cursor:pointer;
  position:relative;
  overflow:hidden;
  transition:background .22s var(--ease),border-color .22s var(--ease),box-shadow .22s var(--ease),transform .22s var(--ease);
}
.cta::after{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(255,255,255,.08);
  opacity:0;
  transition:opacity .2s var(--ease);
}
.cta:hover{
  background:var(--walnut-dark);
  border-color:var(--walnut-dark);
  box-shadow:0 8px 26px rgba(var(--shadow),.26);
  transform:translateY(-1px);
}
.cta:hover::after{opacity:1}
.cta:hover .arrow{transform:translateX(4px)}
.cta.whatsapp{background:#1f7a4d;border-color:#1f7a4d;color:#fff}
.cta.whatsapp:hover{
  background:#17613d;
  border-color:#17613d;
  box-shadow:0 8px 28px rgba(31,122,77,.3);
}
.text-link{
  display:inline-flex;
  align-items:center;
  min-height:44px;
  color:var(--walnut);
  font-size:12px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  border-bottom:1px solid currentColor;
  transition:color .2s var(--ease);
}
.text-link:hover{color:var(--walnut-dark)}
.text-link:hover .arrow{transform:translateX(4px)}

/* ── Page transitions + scroll reveal ──────────────────────────────── */
.page{display:block;animation:pageFadeIn .42s var(--ease-out) both}
.page[hidden]{display:none;animation:none}
@keyframes pageFadeIn{
  from{opacity:0;transform:translateY(16px)}
  to{opacity:1;transform:translateY(0)}
}
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .65s var(--ease-out),transform .65s var(--ease-out);
}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.12s}
.reveal-delay-2{transition-delay:.24s}
.reveal-delay-3{transition-delay:.36s}

/* ═══════════════════════════════════════════════════════════════════
   HOME
═══════════════════════════════════════════════════════════════════ */
.hero{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(320px,.85fr);
  gap:clamp(36px, 6vw, 88px);
  align-items:center;
  max-width:calc(var(--content) + var(--gutter) * 2);
  margin:0 auto;
  padding:clamp(56px, 7vw, 100px) var(--gutter) clamp(28px, 4vw, 48px);
  background:
    radial-gradient(ellipse 70% 55% at 80% 22%, var(--glow), transparent 72%),
    radial-gradient(ellipse 50% 50% at 12% 88%, var(--glow), transparent 70%),
    var(--bg);
}
.hero-copy{max-width:760px}
.hero h1{margin:22px 0 26px;max-width:760px}
.hero .sub{
  max-width:620px;
  color:var(--muted);
  font-size:clamp(17px, 1.6vw, 21px);
  line-height:1.65;
}
.hero-actions{display:flex;align-items:center;gap:24px;flex-wrap:wrap;margin-top:38px}
.hero-panel{position:relative}
.hero-figure{
  margin:0;
  position:relative;
  aspect-ratio:1/1;
  border-radius:var(--radius-card);
  overflow:hidden;
  box-shadow:0 20px 60px rgba(var(--shadow),.18),0 4px 16px rgba(var(--shadow),.08);
}
.hero-figure img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .6s var(--ease);
}
.hero-figure:hover img{transform:scale(1.03)}
.hero-figcap{
  position:absolute;
  left:16px;
  bottom:16px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 15px;
  background:rgba(20,17,13,.58);
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  border-radius:40px;
  color:#fff;
  font-size:10px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.hero-figcap::before{
  content:"";
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--brass);
  flex-shrink:0;
}

/* Full-bleed image marquee — sits between hero and quick-facts */
.marquee{padding:clamp(16px, 2.5vw, 34px) 0}
.marquee-head{
  display:flex;
  justify-content:center;
  margin-bottom:clamp(18px, 2.6vw, 30px);
}
.marquee-viewport{
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%);
}
.marquee-track{
  display:flex;
  width:max-content;
  animation:marquee-scroll 60s linear infinite;
}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{
  flex:0 0 auto;
  width:clamp(264px, 30vw, 420px);
  aspect-ratio:3/2;
  margin-right:clamp(14px, 1.6vw, 22px);
  border-radius:16px;
  overflow:hidden;
  background:var(--bg-alt);
  box-shadow:0 6px 26px rgba(var(--shadow),.10),0 1px 4px rgba(var(--shadow),.05);
}
.marquee-item img{width:100%;height:100%;object-fit:cover}
.marquee-item.crop-a img{object-position:46% 72%;transform:scale(1.85)}
.marquee-item.crop-b img{object-position:62% 60%;transform:scale(1.7)}
.marquee-item.crop-c img{object-position:40% 54%;transform:scale(1.9)}
.marquee-item.crop-d img{object-position:30% 56%;transform:scale(1.8)}
@keyframes marquee-scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
@media (prefers-reduced-motion:reduce){
  .marquee-track{animation:none}
  .marquee-viewport{overflow-x:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .page{animation:none}
  html{scroll-behavior:auto}
}

.quick-facts{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  max-width:var(--content);
  margin:0 auto;
  padding:clamp(24px, 3vw, 44px) var(--gutter) clamp(56px, 7vw, 88px);
}
.fact{
  background:linear-gradient(150deg, var(--card) 0%, var(--card-edge) 100%);
  border:1px solid var(--line);
  border-radius:16px;
  padding:28px 24px;
  box-shadow:0 1px 3px rgba(var(--shadow),.04),0 6px 20px rgba(var(--shadow),.05);
  transition:border-color .28s var(--ease),box-shadow .28s var(--ease),transform .28s var(--ease);
}
.fact:hover{
  border-color:var(--brass-light);
  box-shadow:0 10px 32px rgba(var(--shadow),.10);
  transform:translateY(-2px);
}
.fact span{
  display:block;
  color:var(--muted);
  font-size:10px;
  letter-spacing:.2em;
  text-transform:uppercase;
  font-weight:800;
  margin-bottom:10px;
}
.fact strong{
  font-family:"Cormorant Garamond",serif;
  font-size:30px;
  font-weight:500;
  display:block;
}

/* Shared editorial split sections */
.intro,.story-grid,.space-detail,.contact-body{
  padding:clamp(56px, 7.5vw, 100px) var(--gutter);
}
.intro,.story-grid,.space-detail{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:clamp(36px, 6vw, 88px);
  max-width:var(--content);
  margin:0 auto;
}
.intro{
  background:
    radial-gradient(ellipse 60% 50% at 90% 82%, var(--glow), transparent 72%),
    var(--bg);
}
.section-head h2,.story-grid h2,.space-detail h2{margin-top:18px}
.intro-copy,.story-copy,.space-copy p{
  color:var(--muted);
  font-size:17px;
  line-height:1.78;
}
.intro-copy,.story-copy{display:flex;flex-direction:column;gap:22px}

/* Card grids — preview / values / pricing */
.preview-grid,.values,.option-list{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  max-width:var(--content);
  margin:0 auto;
  padding:0 var(--gutter) clamp(60px, 7.5vw, 100px);
}
.preview-card,.values article,.price-card{
  background:linear-gradient(150deg, var(--card) 0%, var(--card-edge) 100%);
  border:1px solid var(--line);
  border-radius:var(--radius-card);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  box-shadow:0 1px 3px rgba(var(--shadow),.04),0 8px 28px rgba(var(--shadow),.06);
  transition:box-shadow .32s var(--ease),border-color .32s var(--ease),transform .32s var(--ease);
}
.preview-card:hover,.values article:hover,.price-card:hover{
  box-shadow:0 16px 48px rgba(var(--shadow),.12);
  border-color:var(--brass-light);
  transform:translateY(-5px);
}
.values article{padding:32px;gap:14px;min-height:218px}

/* Card media — image header shared by preview + pricing cards */
.card-media{
  position:relative;
  aspect-ratio:16/10;
  overflow:hidden;
  background:var(--bg-alt);
}
.card-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .55s var(--ease);
}
.preview-card:hover .card-media img,
.price-card:hover .card-media img{transform:scale(1.04)}
.card-num{
  position:absolute;
  top:13px;
  left:16px;
  font-family:"Cormorant Garamond",serif;
  font-size:25px;
  font-weight:600;
  line-height:1;
  color:#fff;
  text-shadow:0 1px 10px rgba(0,0,0,.55);
}
.card-body{
  display:flex;
  flex-direction:column;
  gap:15px;
  flex:1;
  padding:clamp(24px, 2.4vw, 32px);
}
.preview-card p,.values p,.price-card p{color:var(--muted);line-height:1.7}
.card-from{
  color:var(--walnut);
  font-size:13px;
  font-weight:700;
  letter-spacing:.02em;
  margin:-2px 0 4px;
}
.preview-card a{
  margin-top:auto;
  align-self:flex-start;
  color:var(--walnut);
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  border-bottom:1px solid currentColor;
}
.preview-card a:hover .arrow{transform:translateX(4px)}

/* ═══════════════════════════════════════════════════════════════════
   PAGE HEADERS (about / space / contact)
═══════════════════════════════════════════════════════════════════ */
.page-hero{
  padding:clamp(48px, 6.5vw, 88px) var(--gutter);
  background:var(--bg-alt);
}
.page-hero.soft{
  background:
    radial-gradient(ellipse 65% 55% at 85% 16%, var(--glow), transparent 72%),
    var(--bg-alt);
}
.page-hero.split{
  display:grid;
  grid-template-columns:1fr .72fr;
  gap:clamp(32px, 6vw, 78px);
  align-items:center;
  background:
    radial-gradient(ellipse 55% 60% at 92% 25%, var(--glow), transparent 72%),
    var(--bg-alt);
}
.page-hero-inner,.page-hero-image{max-width:var(--content);margin:0 auto;width:100%}
.page-hero .crumbs{
  display:flex;
  gap:10px;
  margin-bottom:28px;
  color:var(--muted);
  font-size:10px;
  font-weight:800;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.page-hero .current{color:var(--walnut)}
.page-hero h1{max-width:830px}
.page-hero p{
  max-width:650px;
  color:var(--muted);
  font-size:18px;
  line-height:1.72;
  margin-top:24px;
}

/* ═══════════════════════════════════════════════════════════════════
   ABOUT
═══════════════════════════════════════════════════════════════════ */
.values article{min-height:230px}

/* ═══════════════════════════════════════════════════════════════════
   SPACE — detail · gallery · pricing
═══════════════════════════════════════════════════════════════════ */
.space-detail{
  align-items:start;
  border-bottom:1px solid var(--line);
}
.space-copy p{margin-top:24px;max-width:560px}
.stat-list{margin:0;padding:0}
.stat-list div{
  display:grid;
  grid-template-columns:150px 1fr;
  gap:24px;
  padding:18px 0;
  border-bottom:1px solid var(--line);
  transition:border-color .2s var(--ease);
}
.stat-list div:first-child{border-top:1px solid var(--line)}
.stat-list div:hover{border-bottom-color:var(--brass-light)}
.stat-list dt{
  color:var(--walnut);
  font-family:"Cormorant Garamond",serif;
  font-size:28px;
  font-weight:600;
}
.stat-list dd{
  margin:0;
  color:var(--muted);
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  align-self:center;
}

/* Renders gallery */
.renders-gallery{
  max-width:var(--content);
  margin:0 auto;
  padding:clamp(64px, 8vw, 110px) var(--gutter);
}
.renders-head{margin-bottom:clamp(28px, 3.5vw, 48px)}
.renders-head h2{margin-top:18px}
.renders-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(14px, 1.8vw, 22px);
}
.render-item{
  margin:0;
  position:relative;
  border-radius:18px;
  aspect-ratio:4/3;
  overflow:hidden;
  aspect-ratio:4/3;
  box-shadow:0 4px 26px rgba(var(--shadow),.10);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.render-item:hover{
  transform:translateY(-4px) scale(1.01);
  box-shadow:0 16px 52px rgba(var(--shadow),.16);
}
.render-item--large{grid-column:1 / -1;aspect-ratio:21/9}
.render-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .55s var(--ease);
}
.render-item:hover img{transform:scale(1.04)}
.render-item figcaption{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  padding:18px 22px;
  background:linear-gradient(to top, rgba(22,17,12,.72) 0%, transparent 100%);
  color:rgba(255,255,255,.9);
  font-size:11px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
}

/* Pricing */
.pricing{
  max-width:var(--content);
  margin:0 auto;
  padding:clamp(56px, 7vw, 96px) var(--gutter) clamp(60px, 7.5vw, 100px);
}
.pricing-head{
  display:grid;
  grid-template-columns:1fr auto;
  gap:clamp(28px, 4vw, 56px);
  align-items:end;
  padding-bottom:clamp(28px, 3.5vw, 40px);
  border-bottom:1px solid var(--line);
  margin-bottom:clamp(36px, 5vw, 56px);
}
.pricing-intro h2{margin-top:16px;max-width:520px}
.pricing-controls{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:14px;
}
.pricing-note{
  color:var(--muted);
  font-size:13px;
  line-height:1.6;
  max-width:300px;
  text-align:right;
}
.billing-toggle{
  display:inline-grid;
  grid-template-columns:1fr 1fr;
  border:1px solid var(--line-strong);
  border-radius:40px;
  background:var(--card);
  padding:4px;
  min-width:236px;
}
.billing-toggle button{
  border:0;
  background:transparent;
  color:var(--muted);
  min-height:36px;
  padding:6px 14px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  cursor:pointer;
  border-radius:40px;
  transition:background .2s var(--ease),color .2s var(--ease);
}
.billing-toggle button.active{
  background:var(--walnut);
  color:var(--btn-text);
  box-shadow:0 2px 10px rgba(var(--shadow),.20);
}
.pricing .option-list{padding:0;max-width:none}
.price-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:24px;
  padding-bottom:22px;
  border-bottom:1px solid var(--line);
}
.price-top h3{max-width:170px}
.price{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:5px;
  margin:0;
  text-align:right;
}
.price strong{
  color:var(--walnut);
  font-family:"Cormorant Garamond",serif;
  font-size:42px;
  font-weight:600;
  line-height:1;
  white-space:nowrap;
}
.price span{
  color:var(--muted);
  font-size:11px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  line-height:1.35;
  max-width:150px;
}
.price-list{
  list-style:none;
  margin:auto 0 0;
  padding:18px 0 0;
  border-top:1px solid var(--line);
  display:flex;
  flex-direction:column;
  gap:9px;
  color:var(--muted);
}
.price-list li::before{
  content:"-";
  color:var(--brass);
  margin-right:8px;
  font-weight:800;
}

/* ═══════════════════════════════════════════════════════════════════
   CONTACT
═══════════════════════════════════════════════════════════════════ */
.contact-grid{
  display:grid;
  grid-template-columns:.82fr 1.18fr;
  gap:clamp(40px, 6vw, 88px);
  max-width:var(--content);
  margin:0 auto;
  align-items:start;
}
.editorial h2{margin:18px 0 24px}
.editorial p{color:var(--muted);font-size:17px;line-height:1.76;max-width:520px}
.contact-actions{
  display:flex;
  align-items:center;
  gap:22px;
  flex-wrap:wrap;
  margin-top:30px;
}
.editorial-figure{
  margin:34px 0 0;
  border-radius:var(--radius-card);
  overflow:hidden;
  aspect-ratio:16/10;
  box-shadow:0 10px 40px rgba(var(--shadow),.12),0 2px 10px rgba(var(--shadow),.05);
}
.editorial-figure img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.editorial-figure:hover img{transform:scale(1.03)}
.meta-block{
  margin:40px 0 0;
  padding:0;
  border-top:1px solid var(--line);
}
.meta-block div{
  display:grid;
  grid-template-columns:110px 1fr;
  gap:22px;
  padding:16px 0;
  border-bottom:1px solid var(--line);
}
.meta-block dt{
  color:var(--muted);
  font-size:10px;
  font-weight:800;
  letter-spacing:.2em;
  text-transform:uppercase;
}
.meta-block dd{margin:0;font-weight:600;line-height:1.55}
.meta-block a:hover{color:var(--walnut)}

.form-card{
  background:linear-gradient(150deg, var(--card) 0%, var(--card-edge) 100%);
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:0 4px 40px rgba(var(--shadow),.08),0 1px 8px rgba(var(--shadow),.04);
  padding:clamp(28px, 4vw, 52px);
}
.form-head{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:18px;
  padding-bottom:18px;
  margin-bottom:30px;
  border-bottom:1px solid var(--line);
}
.form-head h3{font-size:30px}
.form-meta,.legal{color:var(--muted);font-size:11px;line-height:1.5}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.field{display:flex;flex-direction:column}
.field.full{grid-column:1 / -1}
.field label{
  color:var(--muted);
  font-size:10px;
  font-weight:800;
  letter-spacing:.2em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.field input,.field select,.field textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:8px;
  background:var(--field-bg);
  color:var(--ink);
  padding:13px 14px;
  outline:none;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease);
}
.field textarea{min-height:120px;resize:vertical;line-height:1.6}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--walnut);
  box-shadow:0 0 0 3px var(--brass-light);
}
.field input::placeholder,.field textarea::placeholder{color:var(--muted);opacity:.65}
.form-foot{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  margin-top:30px;
  padding-top:24px;
  border-top:1px solid var(--line);
}
.legal{max-width:340px;font-style:italic}

/* Honeypot — kept out of sight and the tab order */
.hp{
  position:absolute !important;
  width:1px;
  height:1px;
  overflow:hidden;
  clip:rect(0 0 0 0);
  white-space:nowrap;
}
/* Form submission feedback */
.form-status{
  margin-top:24px;
  padding:14px 18px;
  border-radius:10px;
  font-size:13px;
  font-weight:600;
  line-height:1.5;
}
.form-status.sending{background:var(--brass-light);color:var(--walnut)}
.form-status.success{background:rgba(31,122,77,.13);color:#1f7a4d}
.form-status.error{background:rgba(192,57,43,.12);color:#c0392b}

/* ═══════════════════════════════════════════════════════════════════
   IMAGE SLOTS
═══════════════════════════════════════════════════════════════════ */
.img-slot{
  position:relative;
  width:100%;
  background:linear-gradient(160deg, #ede3d4 0%, #dfd3c0 50%, #d0c4b0 100%);
  border-radius:20px;
  overflow:hidden;
  min-height:280px;
  box-shadow:0 8px 44px rgba(var(--shadow),.14),0 2px 12px rgba(var(--shadow),.06);
}
.img-slot img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .6s var(--ease);
}
.img-slot:hover img{transform:scale(1.03)}
.ratio-4-3{aspect-ratio:4/3}

/* ═══════════════════════════════════════════════════════════════════
   FEATURE VIDEO — full-bleed 16:9 placement on the home page
═══════════════════════════════════════════════════════════════════ */
.feature-video{
  max-width:var(--content);
  margin:0 auto;
  padding:0 var(--gutter) clamp(40px, 5vw, 68px);
}
.feature-video-frame{
  position:relative;
  aspect-ratio:16/9;
  border-radius:var(--radius-card);
  overflow:hidden;
  background:var(--bg-alt);
  box-shadow:0 14px 48px rgba(var(--shadow),.14), 0 2px 8px rgba(var(--shadow),.05);
}
.feature-video-frame video,
.feature-video-frame img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.feature-video-cap{
  position:absolute;
  left:18px;
  bottom:18px;
  z-index:2;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 15px;
  background:rgba(20,17,13,.55);
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  border-radius:40px;
  color:#fff;
  font-size:10px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.feature-video-cap::before{
  content:"";
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--brass);
  flex-shrink:0;
}

/* Play / pause toggle — sits opposite the caption */
.feature-video-toggle{
  position:absolute;
  right:18px;
  bottom:18px;
  z-index:3;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:46px;
  height:46px;
  padding:0;
  border:0;
  border-radius:50%;
  cursor:pointer;
  color:#fff;
  background:rgba(20,17,13,.55);
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  transition:transform .2s ease, background .2s ease, opacity .2s ease;
  opacity:.85;
}
.feature-video-toggle:hover,
.feature-video-toggle:focus-visible{
  background:rgba(20,17,13,.72);
  opacity:1;
  transform:scale(1.06);
  outline:none;
}
.feature-video-toggle svg{ width:18px; height:18px; display:block; }
.feature-video-toggle .icon-play{ display:none; margin-left:2px; }
.feature-video-frame[data-state="paused"] .feature-video-toggle .icon-play{ display:block; }
.feature-video-frame[data-state="paused"] .feature-video-toggle .icon-pause{ display:none; }
@media (max-width:520px){
  .feature-video-toggle{ width:42px; height:42px; right:14px; bottom:14px; }
  .feature-video-toggle svg{ width:16px; height:16px; }
}
@media (prefers-reduced-motion: reduce){
  .feature-video-toggle{ transition:none; }
}

/* ═══════════════════════════════════════════════════════════════════
   LOCATIONS — city grid, building cards, status pills
═══════════════════════════════════════════════════════════════════ */

/* Locations grid (cities on /spaces) — compact 4-up */
.locations-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:clamp(14px, 1.6vw, 22px);
  max-width:var(--content);
  margin:0 auto;
  padding:clamp(56px, 6vw, 88px) var(--gutter) clamp(60px, 7.5vw, 100px);
}
.locations-grid .loc-card{aspect-ratio:4/5}
.locations-grid .loc-city{font-size:clamp(22px, 2.4vw, 32px)}
.locations-grid .loc-meta{padding:clamp(18px, 2vw, 26px);gap:10px}
.locations-grid .loc-arrow{
  width:34px;height:34px;font-size:14px;
  top:clamp(14px, 1.6vw, 20px);
  right:clamp(14px, 1.6vw, 20px);
}

/* Compact preview row on the home page */
.spaces-preview{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:clamp(14px, 1.6vw, 22px);
  max-width:var(--content);
  margin:0 auto;
  padding:0 var(--gutter) clamp(40px, 5vw, 68px);
}
.spaces-preview .loc-card{aspect-ratio:3/4}
.spaces-preview .loc-city{font-size:clamp(22px, 2.4vw, 32px)}
.spaces-preview .loc-meta{padding:clamp(18px, 2vw, 24px);gap:10px}
.spaces-preview .loc-arrow{
  width:34px;height:34px;font-size:14px;
  top:clamp(14px, 1.6vw, 20px);
  right:clamp(14px, 1.6vw, 20px);
}

/* Section heading row with a side link (used on home + others) */
.spaces-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:24px;
  max-width:var(--content);
  margin:0 auto;
  padding:clamp(40px, 5vw, 68px) var(--gutter) clamp(20px, 2.5vw, 36px);
}
.spaces-head .spaces-intro h2{margin-top:14px;max-width:520px}
.spaces-head .text-link{flex-shrink:0}

/* The card itself — shared between /spaces and the home preview */
.loc-card{
  position:relative;
  display:block;
  aspect-ratio:4/5;
  border-radius:var(--radius-card);
  overflow:hidden;
  background:var(--bg-alt);
  box-shadow:0 8px 36px rgba(var(--shadow),.10);
  transition:box-shadow .35s var(--ease),transform .35s var(--ease);
  color:#fff;
  text-decoration:none;
}
.loc-card.is-open:hover{
  box-shadow:0 20px 60px rgba(var(--shadow),.18);
  transform:translateY(-4px);
}
.loc-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .8s var(--ease),filter .4s var(--ease);
}
.loc-card.is-open:hover .loc-img{transform:scale(1.05)}
.loc-card.is-comingsoon .loc-img{
  filter:blur(1px) saturate(.9) brightness(.97);
  transform:scale(1.02);
}
/* Reframe Podgorica so the city sits in view (default crop went too far left) */
.loc-card .loc-img[src*="city-podgorica"]{ object-position:72% center; }
.loc-veil{
  position:absolute;
  inset:0;
  background:linear-gradient(170deg, rgba(20,17,13,.08) 0%, rgba(20,17,13,.72) 100%);
}
.loc-card.is-comingsoon .loc-veil{
  background:linear-gradient(180deg, rgba(20,17,13,.10) 0%, rgba(20,17,13,.42) 100%);
}
.loc-meta{
  position:absolute;
  inset:auto 0 0 0;
  padding:clamp(22px, 2.8vw, 34px);
  display:flex;
  flex-direction:column;
  gap:12px;
  z-index:2;
}
.loc-country{
  font-size:10px;
  letter-spacing:.22em;
  font-weight:800;
  text-transform:uppercase;
  color:rgba(255,255,255,.72);
  margin:0;
}
.loc-city{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(34px, 4.5vw, 56px);
  font-weight:500;
  line-height:1.02;
  margin:0;
  color:#fff;
}
.loc-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  align-self:flex-start;
  padding:8px 14px;
  border-radius:40px;
  background:rgba(255,255,255,.16);
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  color:#fff;
  font-size:10px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.loc-pill::before{
  content:"";
  width:6px;
  height:6px;
  border-radius:50%;
  background:currentColor;
  flex-shrink:0;
}
.loc-pill.is-open{
  background:var(--brass);
  color:#1f1a14;
}
.loc-pill.is-open::before{background:#1f7a4d}
.loc-arrow{
  position:absolute;
  top:clamp(18px, 2.2vw, 28px);
  right:clamp(18px, 2.2vw, 28px);
  width:42px;
  height:42px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:rgba(255,255,255,.14);
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  color:#fff;
  font-size:16px;
  z-index:2;
  transition:transform .25s var(--ease),background .25s var(--ease);
}
.loc-card.is-open:hover .loc-arrow{
  transform:translate(3px,-3px);
  background:rgba(255,255,255,.26);
}
.loc-card.is-comingsoon{cursor:default}
.loc-card.is-comingsoon .loc-arrow{display:none}

/* Buildings grid (on /pristina) */
.building-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:clamp(20px, 2.4vw, 32px);
  max-width:var(--content);
  margin:0 auto;
  padding:0 var(--gutter) clamp(60px, 7.5vw, 100px);
}
.building-grid .card-media{aspect-ratio:5/4}
.card-meta-line{
  color:var(--muted);
  font-size:11px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin:-2px 0 4px;
}

@media (max-width:960px){
  .locations-grid,.spaces-preview{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width:760px){
  .building-grid{grid-template-columns:1fr}
  .spaces-head{flex-direction:column;align-items:flex-start}
}
@media (max-width:520px){
  .locations-grid,.spaces-preview{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════════════════════════
   LEGAL PAGE (privacy policy)
═══════════════════════════════════════════════════════════════════ */
.legal-body{
  max-width:760px;
  margin:0 auto;
  padding:clamp(56px, 8vw, 100px) var(--gutter) clamp(76px, 10vw, 124px);
}
.legal-updated{
  color:var(--muted);
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:8px;
}
.legal-body h2{
  font-size:clamp(20px, 2.3vw, 27px);
  line-height:1.2;
  margin:40px 0 14px;
}
.legal-body h2:first-of-type{margin-top:34px}
.legal-body p{
  color:var(--muted);
  font-size:16px;
  line-height:1.78;
  margin-bottom:14px;
}
.legal-body a{
  color:var(--walnut);
  border-bottom:1px solid var(--line-strong);
}
.legal-body a:hover{color:var(--walnut-dark)}

/* ═══════════════════════════════════════════════════════════════════
   FOOTER (dark in every theme)
═══════════════════════════════════════════════════════════════════ */
.ftr{
  background:
    radial-gradient(ellipse at 80% 0%, rgba(201,163,95,.07) 0%, transparent 50%),
    var(--dark);
  color:var(--on-dark-muted);
  padding:clamp(56px, 7vw, 80px) var(--gutter) 32px;
  border-top:2px solid var(--brass);
}
.ftr-top{
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:48px;
  max-width:var(--content);
  margin:0 auto;
  padding-bottom:42px;
  border-bottom:1px solid rgba(248,244,236,.1);
}
.ftr-wm{
  color:var(--on-dark);
  font-family:"Cormorant Garamond",Georgia,serif;
  font-style:italic;
  font-weight:500;
  font-size:30px;
  letter-spacing:.005em;
  line-height:1;
  margin-bottom:18px;
}
.ftr-brand p{line-height:1.7}
.ftr-social{
  display:flex;
  gap:12px;
  margin-top:24px;
}
.ftr-social a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:50%;
  border:1px solid rgba(248,244,236,.16);
  color:var(--on-dark);
  transition:background .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease),transform .2s var(--ease);
}
.ftr-social a:hover{
  background:var(--brass);
  border-color:var(--brass);
  color:#221d18;
  transform:translateY(-2px);
}
.ftr-social svg{width:18px;height:18px}

.ftr-prefs{
  display:flex;
  align-items:center;
  gap:14px;
  margin-top:20px;
  flex-wrap:wrap;
}
.ftr-prefs-label{
  color:rgba(248,244,236,.48);
  font-size:10px;
  font-weight:800;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.ftr-lang{
  display:flex;
  gap:4px;
  align-items:center;
}
.ftr-lang-btn{
  background:transparent;
  border:1px solid rgba(248,244,236,.18);
  color:var(--on-dark-muted);
  padding:5px 10px;
  border-radius:6px;
  font:inherit;
  font-size:10px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  cursor:pointer;
  transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);
}
.ftr-lang-btn:hover{background:rgba(248,244,236,.08);color:var(--on-dark)}
.ftr-lang-btn.active{
  background:var(--brass);
  border-color:var(--brass);
  color:#1f1a14;
}
.ftr-cols{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.ftr-label{
  display:block;
  color:rgba(248,244,236,.48);
  font-size:10px;
  font-weight:800;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:12px;
}
.ftr ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.ftr a{color:var(--on-dark)}
.ftr a:hover{color:#d2ae68}
.ftr-bot{
  display:flex;
  justify-content:space-between;
  gap:18px;
  max-width:var(--content);
  margin:24px auto 0;
  color:rgba(248,244,236,.4);
  font-size:10px;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.ftr-bot-links{
  display:flex;
  gap:22px;
  align-items:center;
}
.ftr-bot-links a:hover{color:#d2ae68}

/* ═══════════════════════════════════════════════════════════════════
   LANGUAGE DROPDOWN
═══════════════════════════════════════════════════════════════════ */
.lang-dropdown{position:relative;flex-shrink:0}
.lang-trigger{
  display:inline-flex;
  align-items:center;
  gap:7px;
  border:1px solid var(--line-strong);
  border-radius:40px;
  background:var(--card);
  padding:5px 12px 5px 10px;
  min-height:34px;
  color:var(--ink);
  font-size:10px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  cursor:pointer;
  transition:background .2s var(--ease),border-color .2s var(--ease);
}
.lang-trigger:hover{border-color:var(--walnut);background:var(--bg-alt)}
.lang-flag{
  width:18px;
  height:13px;
  border-radius:2px;
  flex-shrink:0;
  display:inline-block;
  object-fit:cover;
  box-shadow:0 0 0 1px rgba(0,0,0,.06);
}
.lang-chevron{
  width:10px;height:6px;
  color:var(--muted);
  flex-shrink:0;
  transition:transform .22s var(--ease);
}
.lang-dropdown.open .lang-chevron{transform:rotate(180deg)}
.lang-menu{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  background:var(--card);
  border:1px solid var(--line-strong);
  border-radius:14px;
  box-shadow:0 10px 36px rgba(var(--shadow),.14),0 2px 8px rgba(var(--shadow),.06);
  list-style:none;
  margin:0;
  padding:6px;
  min-width:168px;
  z-index:100;
  opacity:0;
  transform:translateY(-8px);
  pointer-events:none;
  transition:opacity .18s var(--ease),transform .18s var(--ease);
}
.lang-dropdown.open .lang-menu{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.lang-option{
  display:flex;
  align-items:center;
  gap:10px;
  width:100%;
  padding:9px 13px;
  border:0;
  border-radius:8px;
  background:transparent;
  color:var(--muted);
  font-size:11px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  cursor:pointer;
  text-align:left;
  transition:background .15s var(--ease),color .15s var(--ease);
}
.lang-option:hover{background:var(--bg-alt);color:var(--ink)}
.lang-option.active{color:var(--walnut);background:var(--brass-light)}

/* ═══════════════════════════════════════════════════════════════════
   THEME SWITCHER
═══════════════════════════════════════════════════════════════════ */
.theme-switcher{
  display:inline-flex;
  align-items:center;
  gap:6px;
  flex-shrink:0;
}
.theme-swatch{
  width:13px;
  height:13px;
  border-radius:50%;
  border:1px solid var(--line-strong);
  outline:1.5px solid transparent;
  outline-offset:2px;
  padding:0;
  cursor:pointer;
  transition:transform .22s var(--ease),outline-color .22s var(--ease);
}
.theme-swatch:hover{transform:scale(1.2)}
.theme-swatch.active{outline-color:var(--walnut);transform:scale(1.15)}
.theme-swatch[data-theme="warm"]    {background:#a9823f}
.theme-swatch[data-theme="oak"]     {background:#b48d52}
.theme-swatch[data-theme="sand"]    {background:#8a5a2a}
.theme-swatch[data-theme="pearl"]   {background:#d9cdb6}
.theme-swatch[data-theme="marble"]  {background:#dad8d2}
.theme-swatch[data-theme="linen"]   {background:linear-gradient(135deg,#ffffff 50%,#16161a 50%)}
.theme-swatch[data-theme="onyx"]    {background:#26221e}
.theme-swatch[data-theme="obsidian"]{background:#0e0d0c}

/* ═══════════════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════════════ */
@media (max-width:960px){
  .hero,.page-hero.split,.intro,.story-grid,.space-detail,.contact-grid{grid-template-columns:1fr}
  .hero-figure{aspect-ratio:3/2}
  .pricing-head{grid-template-columns:1fr;align-items:start}
  .pricing-controls{align-items:flex-start}
  .pricing-note{text-align:left}
  .quick-facts,.preview-grid,.values,.option-list{grid-template-columns:1fr 1fr}
  .page-hero-image{max-width:none}
}
@media (max-width:760px){
  .nav{align-items:flex-start;gap:16px;flex-wrap:wrap}
  .nav-links{order:3;width:100%;gap:18px;overflow-x:auto;padding-top:4px}
  .theme-switcher{order:1}
  .nav-divider{order:1}
  .lang-dropdown{order:2}
  .renders-grid{grid-template-columns:1fr 1fr}
  .render-item--large{grid-column:1 / -1;aspect-ratio:16/9}
}
@media (max-width:620px){
  h1{font-size:clamp(42px, 14vw, 58px)}
  .quick-facts,.preview-grid,.values,.option-list{grid-template-columns:1fr}
  .pricing .option-list{padding-left:0;padding-right:0}
  .billing-toggle{width:100%;min-width:0}
  .price-top{flex-direction:column;gap:14px}
  .price{align-items:flex-start;text-align:left}
  .price span{max-width:none}
  .stat-list div,.meta-block div{grid-template-columns:1fr;gap:4px}
  .form-grid{grid-template-columns:1fr}
  .form-head,.form-foot,.ftr-bot{flex-direction:column;align-items:flex-start}
  .ftr-top,.ftr-cols{grid-template-columns:1fr}
  .renders-grid{grid-template-columns:1fr}
  .render-item--large{grid-column:1;aspect-ratio:4/3}
}

/* ═══════════════════════════════════════════════════════════════════
   COLOUR THEMES
   Applied via data-theme="oak|sand|pearl|marble|onyx|obsidian" on <html>.
   Default (warm) = the :root tokens above. All share one warm
   material family — gold, brown, stone, off-white, charcoal.
═══════════════════════════════════════════════════════════════════ */

/* PEARL — bleached, airy, near-white ivory with a soft taupe accent. */
[data-theme="pearl"]{
  --ink:#2b2824;
  --muted:#8a8377;
  --bg:#faf8f3;
  --bg-alt:#f1ede3;
  --card:#ffffff;
  --card-edge:#f7f3ea;
  --field-bg:#ffffff;
  --nav-bg:rgba(250,248,243,.82);
  --nav-solid:rgba(250,248,243,.96);
  --walnut:#7c6e5c;
  --walnut-dark:#5b5042;
  --brass:#b29a73;
  --brass-light:rgba(178,154,115,.16);
  --glow:rgba(178,154,115,.12);
  --btn-text:#ffffff;
  --line:rgba(43,40,36,.09);
  --line-strong:rgba(43,40,36,.17);
  --shadow:43,40,36;
  --dark:#2b2825;
  --on-dark:#f1ede3;
  --on-dark-muted:rgba(241,237,227,.70);
}

/* SAND — deeper, warmer tan; rich brown text and a bronze accent. */
[data-theme="sand"]{
  --ink:#2c2114;
  --muted:#7c6c54;
  --bg:#efe4d0;
  --bg-alt:#e6d6bd;
  --card:#fbf6ea;
  --card-edge:#f1e7d3;
  --field-bg:#fdf9f0;
  --nav-bg:rgba(239,228,208,.85);
  --nav-solid:rgba(239,228,208,.97);
  --walnut:#6a4f2e;
  --walnut-dark:#48351e;
  --brass:#a87b3c;
  --brass-light:rgba(168,123,60,.18);
  --glow:rgba(168,123,60,.20);
  --btn-text:#ffffff;
  --line:rgba(44,33,20,.12);
  --line-strong:rgba(44,33,20,.22);
  --shadow:44,33,20;
  --dark:#241a0d;
  --on-dark:#efe4d0;
  --on-dark-muted:rgba(239,228,208,.70);
}

/* ONYX — warm charcoal dark mode; warm-white text, gold accent. */
[data-theme="onyx"]{
  --ink:#ece6da;
  --muted:#9a9286;
  --bg:#191715;
  --bg-alt:#221f1b;
  --card:#262320;
  --card-edge:#2d2925;
  --field-bg:#2b2723;
  --nav-bg:rgba(25,23,21,.82);
  --nav-solid:rgba(25,23,21,.95);
  --walnut:#caa45f;
  --walnut-dark:#dcbc7e;
  --brass:#caa45f;
  --brass-light:rgba(202,164,95,.15);
  --glow:rgba(202,164,95,.13);
  --btn-text:#191715;
  --line:rgba(236,230,218,.11);
  --line-strong:rgba(236,230,218,.20);
  --shadow:0,0,0;
  --dark:#100f0d;
  --on-dark:#ece6da;
  --on-dark-muted:rgba(236,230,218,.66);
  color-scheme:dark;
}

/* OAK — bright, airy off-white with warm oak-wood tones and soft gold. */
[data-theme="oak"]{
  --ink:#2a241c;
  --muted:#7b7064;
  --bg:#fbf9f4;
  --bg-alt:#f1ebdf;
  --card:#ffffff;
  --card-edge:#f7f3ea;
  --field-bg:#ffffff;
  --nav-bg:rgba(251,249,244,.82);
  --nav-solid:rgba(251,249,244,.96);
  --walnut:#7a5e3c;
  --walnut-dark:#56412a;
  --brass:#b08b4a;
  --brass-light:rgba(176,139,74,.15);
  --glow:rgba(176,139,74,.13);
  --btn-text:#ffffff;
  --line:rgba(42,36,28,.09);
  --line-strong:rgba(42,36,28,.18);
  --shadow:42,36,28;
  --dark:#241f17;
  --on-dark:#f6f1e6;
  --on-dark-muted:rgba(246,241,230,.72);
}

/* MARBLE — crisp, light, architectural; white and warm grey with a
   restrained charcoal accent. Corporate and clean. */
[data-theme="marble"]{
  --ink:#23211f;
  --muted:#7d7b77;
  --bg:#f6f6f3;
  --bg-alt:#eceae4;
  --card:#ffffff;
  --card-edge:#f3f2ee;
  --field-bg:#ffffff;
  --nav-bg:rgba(246,246,243,.82);
  --nav-solid:rgba(246,246,243,.96);
  --walnut:#403b34;
  --walnut-dark:#2a2722;
  --brass:#8c7f6a;
  --brass-light:rgba(140,127,106,.15);
  --glow:rgba(140,127,106,.10);
  --btn-text:#ffffff;
  --line:rgba(35,33,31,.10);
  --line-strong:rgba(35,33,31,.18);
  --shadow:35,33,31;
  --dark:#262420;
  --on-dark:#f0efea;
  --on-dark-muted:rgba(240,239,234,.70);
}

/* OBSIDIAN — the deepest, most dramatic dark; near-black with a
   refined luminous gold. */
[data-theme="obsidian"]{
  --ink:#ece8e0;
  --muted:#928c82;
  --bg:#0e0d0c;
  --bg-alt:#171514;
  --card:#1b1918;
  --card-edge:#232120;
  --field-bg:#1f1d1b;
  --nav-bg:rgba(14,13,12,.85);
  --nav-solid:rgba(14,13,12,.96);
  --walnut:#cda968;
  --walnut-dark:#e0c48d;
  --brass:#cda968;
  --brass-light:rgba(205,169,104,.16);
  --glow:rgba(205,169,104,.12);
  --btn-text:#0e0d0c;
  --line:rgba(236,232,224,.12);
  --line-strong:rgba(236,232,224,.22);
  --shadow:0,0,0;
  --dark:#080808;
  --on-dark:#ece8e0;
  --on-dark-muted:rgba(236,232,224,.64);
  color-scheme:dark;
}

/* LINEN — bright, modern, office-like; pure white with a near-black
   ink accent. Highest contrast of the light themes. */
[data-theme="linen"]{
  --ink:#16161a;
  --muted:#6c6b6b;
  --bg:#ffffff;
  --bg-alt:#f4f3ef;
  --card:#ffffff;
  --card-edge:#f7f6f2;
  --field-bg:#ffffff;
  --nav-bg:rgba(255,255,255,.86);
  --nav-solid:rgba(255,255,255,.98);
  --walnut:#1c1c20;
  --walnut-dark:#000000;
  --brass:#5e5b58;
  --brass-light:rgba(94,91,88,.10);
  --glow:rgba(94,91,88,.06);
  --btn-text:#ffffff;
  --line:rgba(22,22,26,.08);
  --line-strong:rgba(22,22,26,.16);
  --shadow:22,22,26;
  --dark:#16161a;
  --on-dark:#f4f3ef;
  --on-dark-muted:rgba(244,243,239,.68);
}

/* ── Floating WhatsApp FAB ────────────────────────────────────────────────── */
.fab-whatsapp{
  position:fixed;
  right:clamp(16px, 2.4vw, 28px);
  bottom:clamp(16px, 2.4vw, 28px);
  z-index:90;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:58px;
  height:58px;
  border-radius:50%;
  background:#25D366;
  color:#fff;
  box-shadow:0 12px 28px rgba(37,211,102,.35), 0 2px 6px rgba(0,0,0,.18);
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
  text-decoration:none;
}
.fab-whatsapp svg{ width:32px; height:32px; display:block; }
.fab-whatsapp:hover{
  transform:translateY(-2px) scale(1.04);
  background:#1ebe59;
  box-shadow:0 16px 36px rgba(37,211,102,.42), 0 4px 10px rgba(0,0,0,.22);
}
.fab-whatsapp:focus-visible{
  outline:3px solid rgba(255,255,255,.85);
  outline-offset:3px;
}
@media (max-width:520px){
  .fab-whatsapp{ width:52px; height:52px; }
  .fab-whatsapp svg{ width:28px; height:28px; }
}

/* ── Cookie banner ────────────────────────────────────────────────────────── */
.cookie-banner{
  position:fixed;
  left:clamp(16px, 2.4vw, 28px);
  bottom:clamp(16px, 2.4vw, 28px);
  z-index:95;
  width:min(360px, calc(100vw - 32px));
  pointer-events:none;
  transform:translateY(20px);
  opacity:0;
  transition:transform .35s ease, opacity .35s ease;
}
.cookie-banner.is-open{
  transform:translateY(0);
  opacity:1;
  pointer-events:auto;
}
.cookie-banner.is-dismissed{
  transform:translateY(12px);
  opacity:0;
}
.cookie-banner-card{
  background:var(--paper, #ffffff);
  color:var(--ink, #16161a);
  border:1px solid var(--line, rgba(22,22,26,.10));
  border-radius:14px;
  padding:18px 18px 16px;
  box-shadow:0 22px 50px rgba(0,0,0,.18), 0 4px 12px rgba(0,0,0,.08);
}
.cookie-banner-title{
  font-size:15px;
  font-weight:600;
  letter-spacing:.01em;
  margin:0 0 6px;
}
.cookie-banner-body{
  font-size:13px;
  line-height:1.5;
  color:var(--muted, rgba(22,22,26,.66));
  margin:0 0 14px;
}
.cookie-banner-actions{
  display:flex;
  align-items:center;
  gap:14px;
}
.cookie-banner-accept{
  appearance:none;
  border:0;
  cursor:pointer;
  background:var(--walnut, #1c1c20);
  color:var(--btn-text, #ffffff);
  font:inherit;
  font-size:13px;
  font-weight:500;
  letter-spacing:.02em;
  padding:9px 18px;
  border-radius:999px;
  transition:transform .2s ease, background .2s ease;
}
.cookie-banner-accept:hover{
  transform:translateY(-1px);
  background:var(--walnut-dark, #000);
}
.cookie-banner-privacy{
  color:var(--muted, rgba(22,22,26,.66));
  font-size:12px;
  text-decoration:underline;
  text-underline-offset:3px;
  text-decoration-thickness:1px;
}
.cookie-banner-privacy:hover{ color:var(--ink, #16161a); }
@media (max-width:520px){
  .cookie-banner-card{ padding:16px 16px 14px; }
  .cookie-banner-body{ font-size:12.5px; }
}
@media (prefers-reduced-motion: reduce){
  .cookie-banner,
  .fab-whatsapp{ transition:none; }
}

/* ── Back link (calm crumb) ────────────────────────────────────────────────── */
.page-backbar{
  max-width:var(--content);
  margin:0 auto;
  padding:clamp(28px, 3.5vw, 44px) var(--gutter) 0;
}
.back-link{
  display:inline-flex;
  align-items:center;
  gap:9px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  text-decoration:none;
  transition:color .2s ease, gap .2s ease;
}
.back-link::before{
  content:"";
  width:18px;
  height:1px;
  background:currentColor;
  transition:width .2s ease;
}
.back-link:hover{ color:var(--walnut); gap:14px; }
.back-link:hover::before{ width:26px; }

/* ── Pristina lead — three polished, distinct variants ─────────────────────── */
/* Shared base — typography + container */
.pristina-lead{
  max-width:var(--content);
  margin:0 auto;
  padding:clamp(20px, 2.4vw, 32px) var(--gutter) clamp(56px, 7vw, 96px);
}
.pristina-lead .lead-eyebrow{
  display:inline-block;
  color:var(--brass);
  font-size:10px;
  font-weight:800;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.pristina-lead .lead-h{
  margin:14px 0 18px;
  font-family:"Cormorant Garamond",serif;
  font-weight:500;
  font-size:clamp(32px, 4.4vw, 52px);
  line-height:1.04;
  color:var(--walnut);
  letter-spacing:-.005em;
}
.pristina-lead .lead-p{
  color:var(--muted);
  font-size:17px;
  line-height:1.7;
  margin:0;
}

/* Generic stat tile look (Variants A & B) */
.lead-tile{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:12px;
  padding:18px 20px;
}
.lead-tile dt{
  display:block;
  font-family:"Cormorant Garamond",serif;
  font-size:26px;
  font-weight:600;
  color:var(--walnut);
  line-height:1;
}
.lead-tile dd{
  margin:8px 0 0;
  color:var(--muted);
  font-size:10px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  line-height:1.4;
}

/* ─── Variant A: smaller image left · copy right ──────────────────────────── */
.pristina-lead--a{
  display:grid;
  grid-template-columns:0.78fr 1fr;
  gap:clamp(28px, 4vw, 56px);
  align-items:center;
}
.pristina-lead--a .lead-img{
  border-radius:var(--radius-card);
  overflow:hidden;
  aspect-ratio:4/3;
  box-shadow:0 14px 48px rgba(var(--shadow),.12);
}
.pristina-lead--a .lead-img img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.pristina-lead--a .lead-p{ max-width:520px; }
/* Stat tiles still styled for /pristina-preview, but the live page omits them */
.pristina-lead--a .lead-stats{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin:26px 0 0;
  padding:0;
  list-style:none;
}

/* ─── Variant B: centered copy on top · full-width image · 4-up strip ─────── */
.pristina-lead--b .lead-body{
  max-width:720px;
  margin:0 auto;
  text-align:center;
}
.pristina-lead--b .lead-p{ margin:0 auto; }
.pristina-lead--b .lead-img{
  margin-top:32px;
  border-radius:var(--radius-card);
  overflow:hidden;
  aspect-ratio:21/9;
  box-shadow:0 14px 48px rgba(var(--shadow),.12);
}
.pristina-lead--b .lead-img img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.pristina-lead--b .lead-stats{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  margin:24px 0 0;
  padding:0;
  list-style:none;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius-card);
  overflow:hidden;
}
.pristina-lead--b .lead-stats > div{
  padding:22px 24px;
  border-right:1px solid var(--line);
  text-align:center;
}
.pristina-lead--b .lead-stats > div:last-child{ border-right:0; }
.pristina-lead--b .lead-stats dt{
  display:block;
  font-family:"Cormorant Garamond",serif;
  font-size:30px;
  font-weight:600;
  color:var(--walnut);
  line-height:1;
}
.pristina-lead--b .lead-stats dd{
  margin:9px 0 0;
  color:var(--muted);
  font-size:10px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
}

/* ─── Variant C: wide hero with glassy stats overlay · copy below ─────────── */
.pristina-lead--c .lead-img{
  position:relative;
  border-radius:var(--radius-card);
  overflow:hidden;
  aspect-ratio:16/9;
  box-shadow:0 14px 48px rgba(var(--shadow),.14);
}
.pristina-lead--c .lead-img img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.pristina-lead--c .lead-img::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(20,17,13,.0) 45%, rgba(20,17,13,.55) 100%);
  pointer-events:none;
}
.pristina-lead--c .lead-stats{
  position:absolute;
  left:clamp(16px, 2.4vw, 28px);
  right:clamp(16px, 2.4vw, 28px);
  bottom:clamp(16px, 2.4vw, 28px);
  z-index:2;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  margin:0;
  padding:0;
  list-style:none;
  background:rgba(255,255,255,.95);
  -webkit-backdrop-filter:blur(12px);
  backdrop-filter:blur(12px);
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 12px 32px rgba(0,0,0,.18);
}
.pristina-lead--c .lead-stats > div{
  padding:16px 18px;
  border-right:1px solid var(--line);
  text-align:center;
}
.pristina-lead--c .lead-stats > div:last-child{ border-right:0; }
.pristina-lead--c .lead-stats dt{
  display:block;
  font-family:"Cormorant Garamond",serif;
  font-size:24px;
  font-weight:600;
  color:var(--walnut);
  line-height:1;
}
.pristina-lead--c .lead-stats dd{
  margin:7px 0 0;
  color:var(--muted);
  font-size:9.5px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.pristina-lead--c .lead-body{
  margin-top:26px;
  max-width:720px;
}

/* Responsive collapses */
@media (max-width:960px){
  .pristina-lead--a{ grid-template-columns:1fr; gap:24px; }
  .pristina-lead--a .lead-img{ aspect-ratio:16/10; }
  .pristina-lead--c .lead-img{ aspect-ratio:4/3; }
  .pristina-lead--c .lead-stats{ position:static; margin-top:18px; }
  .pristina-lead--c .lead-img::after{ display:none; }
}
@media (max-width:640px){
  .pristina-lead--a .lead-stats{ grid-template-columns:1fr; }
  .pristina-lead--b .lead-stats,
  .pristina-lead--c .lead-stats{ grid-template-columns:1fr 1fr; }
  .pristina-lead--b .lead-stats > div,
  .pristina-lead--c .lead-stats > div{
    border-right:1px solid var(--line);
    border-bottom:1px solid var(--line);
  }
  .pristina-lead--b .lead-stats > div:nth-child(2n),
  .pristina-lead--c .lead-stats > div:nth-child(2n){ border-right:0; }
  .pristina-lead--b .lead-stats > div:nth-last-child(-n+2),
  .pristina-lead--c .lead-stats > div:nth-last-child(-n+2){ border-bottom:0; }
}

/* ── Variant preview labels (only used on /pristina-preview) ───────────────── */
.variant-divider{
  max-width:var(--content);
  margin:64px auto 0;
  padding:0 var(--gutter);
}
.variant-divider-inner{
  display:flex;
  align-items:center;
  gap:18px;
  padding:14px 22px;
  background:var(--brass-light);
  border:1px dashed var(--brass);
  border-radius:12px;
  color:var(--walnut);
}
.variant-divider .tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px; height:30px;
  border-radius:8px;
  background:var(--walnut);
  color:#fff;
  font-weight:700;
  font-family:"JetBrains Mono",monospace;
  font-size:13px;
}
.variant-divider .title{
  font-weight:600;
  font-size:14px;
}
.variant-divider .desc{
  color:var(--muted);
  font-size:12px;
  margin-left:auto;
}
@media (max-width:520px){ .variant-divider .desc{ display:none; } }

/* ── Popup mode switch (only on /spaces) ───────────────────────────────────── */
.popup-mode-switch{
  max-width:var(--content);
  margin:0 auto;
  padding:clamp(20px, 2.4vw, 30px) var(--gutter) 0;
  display:flex;
  align-items:center;
  gap:12px;
}
.popup-mode-switch .label{
  font-size:10px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
}
.popup-mode-switch .pills{
  display:inline-flex;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:999px;
  padding:3px;
}
.popup-mode-switch button{
  appearance:none;
  border:0;
  background:transparent;
  font:inherit;
  font-size:12px;
  font-weight:600;
  padding:7px 14px;
  border-radius:999px;
  cursor:pointer;
  color:var(--muted);
  transition:background .2s ease, color .2s ease;
}
.popup-mode-switch button.active{
  background:var(--walnut);
  color:#fff;
}

/* ── Coming-soon: city MODAL ───────────────────────────────────────────────── */
.city-modal{
  position:fixed;
  inset:0;
  z-index:120;
  display:none;
  align-items:center;
  justify-content:center;
  padding:clamp(16px, 3vw, 32px);
}
.city-modal.is-open{ display:flex; }
.city-modal-backdrop{
  position:absolute; inset:0;
  background:rgba(10,8,6,.62);
  -webkit-backdrop-filter:blur(6px);
  backdrop-filter:blur(6px);
  animation:cityFadeIn .25s ease;
}
.city-modal-card{
  position:relative;
  z-index:1;
  width:min(420px, 100%);
  background:var(--paper);
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,.45);
  animation:cityRise .35s cubic-bezier(.2,.7,.2,1);
}
@keyframes cityFadeIn { from { opacity:0 } to { opacity:1 } }
@keyframes cityRise   { from { opacity:0; transform:translateY(20px) scale(.98) } to { opacity:1; transform:none } }
.city-modal-image{
  position:relative;
  aspect-ratio:16/10;
  overflow:hidden;
  background:#000;
}
.city-modal-image img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; display:block;
  transform:scale(1.02);
  animation:cityImg .8s ease-out both;
}
@keyframes cityImg { from { transform:scale(1.08) } to { transform:scale(1.02) } }
.city-modal-image::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(20,17,13,.05) 30%, rgba(20,17,13,.7) 100%);
}
.city-modal-meta{
  position:absolute;
  left:18px; bottom:16px; right:18px;
  z-index:1;
  color:#fff;
}
.city-modal-meta .country{
  font-size:9.5px;
  font-weight:800;
  letter-spacing:.22em;
  text-transform:uppercase;
  opacity:.85;
}
.city-modal-meta h2{
  margin:4px 0 6px;
  font-family:"Cormorant Garamond",serif;
  font-size:28px;
  font-weight:500;
  line-height:1;
}
.city-modal-meta .pill{
  display:inline-flex;
  align-items:center;
  padding:5px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.06em;
}
.city-modal-close{
  position:absolute;
  top:12px; right:12px;
  z-index:2;
  width:30px; height:30px;
  border-radius:50%;
  border:0;
  cursor:pointer;
  background:rgba(20,17,13,.55);
  color:#fff;
  font-size:16px;
  line-height:1;
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  transition:background .2s ease, transform .2s ease;
}
.city-modal-close:hover{ background:rgba(20,17,13,.78); transform:scale(1.06); }
.city-modal-body{
  padding:18px 20px 20px;
}
.city-modal-body p{
  margin:0 0 14px;
  color:var(--muted);
  font-size:13.5px;
  line-height:1.55;
}
.city-modal-actions{
  display:flex;
  gap:8px;
  align-items:center;
}
.city-modal-actions .btn-primary{
  flex:1;
  text-align:center;
  background:var(--walnut);
  color:#fff;
  padding:10px 14px;
  border-radius:999px;
  font-size:12.5px;
  font-weight:600;
  letter-spacing:.02em;
  text-decoration:none;
  transition:background .2s ease, transform .2s ease;
}
.city-modal-actions .btn-primary:hover{ background:var(--walnut-dark); transform:translateY(-1px); }
.city-modal-actions .btn-secondary{
  appearance:none;
  border:1px solid var(--line-strong);
  background:transparent;
  cursor:pointer;
  font:inherit;
  font-size:12.5px;
  font-weight:600;
  padding:9px 14px;
  border-radius:999px;
  color:var(--walnut);
  transition:background .2s ease, border-color .2s ease;
}
.city-modal-actions .btn-secondary:hover{ background:var(--brass-light); border-color:var(--brass); }
body.no-scroll{ overflow:hidden; }

/* ── Coming-soon: INLINE EXPANSION inside the grid ─────────────────────────── */
.loc-card.is-comingsoon{ cursor:pointer; transition:transform .35s var(--ease); }
.loc-card.is-comingsoon:hover{ transform:translateY(-3px); }
.loc-card.is-comingsoon .loc-arrow{ display:none; }

.locations-grid.is-expanded .loc-card{ transition:opacity .25s ease; }
.loc-card.is-expanded{
  grid-column:1 / -1;
  aspect-ratio:auto;
  display:grid;
  grid-template-columns:1.1fr 1fr;
  cursor:default;
  animation:cityRise .4s cubic-bezier(.2,.7,.2,1);
}
.loc-card.is-expanded .loc-img{
  position:relative;
  filter:none;
  transform:none;
  width:100%;
  height:100%;
  min-height:340px;
}
.loc-card.is-expanded .loc-veil{ display:none; }
.loc-card.is-expanded .loc-meta{
  position:relative;
  inset:auto;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:clamp(24px, 3vw, 36px);
  background:var(--paper);
  color:var(--walnut);
}
.loc-card.is-expanded .loc-country{ color:var(--muted); }
.loc-card.is-expanded .loc-city{ color:var(--walnut); }
.loc-card.is-expanded .loc-pill{
  background:var(--brass-light);
  color:var(--walnut);
}
.expand-body{
  display:none;
  margin-top:18px;
  color:var(--muted);
  font-size:14px;
  line-height:1.6;
}
.expand-actions{
  display:none;
  margin-top:20px;
  gap:10px;
}
.expand-close{
  display:none;
  position:absolute;
  top:14px; right:14px;
  z-index:3;
  width:34px; height:34px;
  border:0;
  border-radius:50%;
  background:rgba(20,17,13,.55);
  color:#fff;
  font-size:18px;
  line-height:1;
  cursor:pointer;
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
}
.loc-card.is-expanded .expand-body,
.loc-card.is-expanded .expand-actions,
.loc-card.is-expanded .expand-close{ display:flex; }
.loc-card.is-expanded .expand-body{ display:block; }
.loc-card.is-expanded .expand-actions .btn-primary{
  flex:1;
  text-align:center;
  background:var(--walnut);
  color:#fff;
  padding:11px 16px;
  border-radius:999px;
  font-size:13px;
  font-weight:600;
  text-decoration:none;
}
.loc-card.is-expanded .expand-actions .btn-primary:hover{ background:var(--walnut-dark); }
.loc-card.is-expanded .expand-actions .btn-secondary{
  appearance:none;
  border:1px solid var(--line-strong);
  background:transparent;
  font:inherit;
  font-size:13px;
  font-weight:600;
  padding:10px 16px;
  border-radius:999px;
  cursor:pointer;
}

@media (max-width:720px){
  .loc-card.is-expanded{ grid-template-columns:1fr; }
}

/* Utility: pull cropped images leftward when there's empty sky / window space
   on the right side of the source (kitchen.jpg, phonebooth.jpg). Use on any
   <img> inside an object-fit:cover container. */
.img-shift-left{ object-position:18% center !important; }

/* ── Tower enquire-only section ───────────────────────────────────────────── */
.tower-enquire{
  max-width:var(--content);
  margin:0 auto;
  padding:clamp(48px, 6.5vw, 96px) var(--gutter) clamp(64px, 8vw, 112px);
}
.tower-enquire-inner{
  max-width:720px;
  margin:0 auto;
  text-align:center;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius-card);
  padding:clamp(36px, 5vw, 64px) clamp(28px, 4vw, 56px);
  box-shadow:0 14px 48px rgba(var(--shadow),.08);
}
.tower-enquire-inner .eyebrow{
  display:block;
  color:var(--brass);
  font-size:10px;
  font-weight:800;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:14px;
}
.tower-enquire-inner h2{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-weight:500;
  font-size:clamp(28px, 3.6vw, 42px);
  line-height:1.1;
  color:var(--walnut);
  margin:0 0 18px;
}
.tower-enquire-intro{
  color:var(--muted);
  font-size:16px;
  line-height:1.7;
  max-width:560px;
  margin:0 auto;
}
.tower-enquire-list{
  list-style:none;
  margin:28px auto 32px;
  padding:0;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px 24px;
  max-width:560px;
  text-align:left;
}
.tower-enquire-list li{
  position:relative;
  padding-left:22px;
  color:var(--ink);
  font-size:14px;
  line-height:1.5;
}
.tower-enquire-list li::before{
  content:"";
  position:absolute;
  left:0; top:8px;
  width:6px; height:6px;
  border-radius:50%;
  background:var(--brass);
}
.tower-enquire-actions{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:24px;
  flex-wrap:wrap;
}
.tower-enquire-actions .cta{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:var(--walnut);
  color:#fff;
  padding:14px 26px;
  border-radius:999px;
  font-size:13px;
  font-weight:600;
  letter-spacing:.04em;
  transition:background .2s ease, transform .2s ease;
}
.tower-enquire-actions .cta:hover{
  background:var(--walnut-dark);
  transform:translateY(-1px);
}
.tower-enquire-actions .text-link{
  color:var(--muted);
  font-size:13px;
  font-weight:600;
  text-decoration:underline;
  text-underline-offset:4px;
  text-decoration-thickness:1px;
  transition:color .2s ease;
}
.tower-enquire-actions .text-link:hover{ color:var(--walnut); }

@media (max-width:560px){
  .tower-enquire-list{ grid-template-columns:1fr; }
}

/* ── Pristina map section ──────────────────────────────────────────────────── */
.pristina-map-section{
  max-width:var(--content);
  margin:0 auto;
  padding:clamp(40px, 5vw, 72px) var(--gutter) clamp(60px, 7vw, 96px);
}
.pristina-map-head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:20px;
  margin-bottom:24px;
}
.pristina-map-head .eyebrow{
  display:block;
  color:var(--brass);
  font-size:10px;
  font-weight:800;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.pristina-map-head h2{
  margin:0;
  font-family:"Cormorant Garamond",serif;
  font-weight:500;
  font-size:clamp(26px, 3vw, 36px);
  line-height:1.1;
  color:var(--walnut);
}
.pristina-map-head p{
  max-width:340px;
  margin:0;
  color:var(--muted);
  font-size:14px;
  line-height:1.6;
  text-align:right;
}
.pristina-map-frame{
  position:relative;
  border-radius:var(--radius-card);
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 14px 48px rgba(var(--shadow),.12);
  height:clamp(320px, 48vh, 480px);
  background:var(--bg-alt);
}
#pristina-map{ position:absolute; inset:0; }
/* Leaflet markers: brand-walnut pin */
.lm-marker{
  position:relative;
  width:34px; height:34px;
  border-radius:50% 50% 50% 0;
  background:var(--walnut);
  transform:rotate(-45deg);
  box-shadow:0 4px 12px rgba(0,0,0,.3);
  border:2px solid #fff;
}
.lm-marker::after{
  content:"";
  position:absolute;
  top:50%; left:50%;
  width:10px; height:10px;
  margin:-5px 0 0 -5px;
  border-radius:50%;
  background:#fff;
}
.leaflet-popup-content-wrapper{
  border-radius:10px !important;
  font-family:"Inter",sans-serif !important;
}
.leaflet-popup-content{
  margin:10px 14px !important;
  font-size:13px !important;
  font-weight:600 !important;
  color:var(--walnut) !important;
}
.leaflet-popup-content small{
  display:block;
  margin-top:2px;
  font-size:10px;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
}

@media (max-width:640px){
  .pristina-map-head{ flex-direction:column; align-items:start; }
  .pristina-map-head p{ text-align:left; max-width:none; }
}


/* ── Mobile polish (added with theme lockdown) ───────────────────────────── */
@media (max-width:760px){
  /* Nav: stack cleanly on phone, hide the language label text inside dropdown */
  .nav{ padding:14px 16px !important; gap:8px; }
  .nav-links{ gap:18px; font-size:11px; }
  .nav-divider{ display:none; }
  .lang-dropdown .lang-flag{ width:16px; height:12px; }

  /* Hero: tighter spacing, smaller h1 */
  .hero{ padding:36px 16px 28px; gap:24px; }
  .hero-copy h1{ font-size:clamp(36px, 9vw, 52px) !important; line-height:1.05; }
  .hero-copy .sub{ font-size:15px; line-height:1.6; }

  /* Section paddings down 20% on phone */
  .intro, .story-grid, .space-detail, .contact-body,
  .marquee, .feature-video, .preview-grid, .building-grid,
  .pristina-lead, .pristina-map-section, .tower-enquire,
  .renders-gallery, .locations-grid, .spaces-preview{
    padding-top: clamp(36px, 8vw, 56px);
    padding-bottom: clamp(36px, 8vw, 56px);
  }

  /* Cards / preview grids stack */
  .preview-grid, .building-grid, .spaces-preview, .locations-grid,
  .renders-grid, .option-list{ grid-template-columns:1fr !important; gap:18px !important; }
  .render-item--large{ grid-column:1 !important; aspect-ratio:16/10 !important; }
  .render-item{ aspect-ratio:16/10 !important; }

  /* Pristina lead — image above copy, smaller image */
  .pristina-lead--a{ grid-template-columns:1fr !important; gap:20px !important; }
  .pristina-lead--a .lead-img{ aspect-ratio:16/10 !important; }

  /* Map: stack head + frame */
  .pristina-map-head{ flex-direction:column !important; align-items:start !important; gap:8px; }
  .pristina-map-head p{ max-width:none !important; text-align:left !important; }
  .pristina-map-frame{ height:clamp(260px, 60vw, 380px) !important; }

  /* Tower enquire — 1-col bullet list, snug padding */
  .tower-enquire-inner{ padding:28px 22px !important; }
  .tower-enquire-list{ grid-template-columns:1fr !important; gap:8px !important; }
  .tower-enquire-actions{ flex-direction:column; gap:14px; }
  .tower-enquire-actions .cta,
  .tower-enquire-actions .text-link{ width:100%; text-align:center; justify-content:center; }

  /* Footer breathing */
  .ftr-top, .ftr-cols{ grid-template-columns:1fr !important; gap:24px; }
  .ftr-wm{ font-size:26px !important; }

  /* Modal: smaller, comfy on phone */
  .city-modal-card{ width:min(360px, calc(100vw - 24px)) !important; }
  .city-modal-meta h2{ font-size:24px !important; }

  /* WhatsApp FAB + cookie banner don't crowd small screens */
  .fab-whatsapp{ width:52px !important; height:52px !important; }
  .cookie-banner{ width:calc(100vw - 24px) !important; }
}
