/* ============================================================
   GANGA COUNTY · Premium Luxury · v3
   Plus Jakarta Sans · DM Serif Display (accents only)
   Saffron · Forest Green · Champagne · Ivory
   ============================================================ */

/* ─── Tokens ─────────────────────────────────────────────── */
:root{
  /* Brand */
  --saffron: #d97a1a;
  --saffron-deep: #a35a0d;
  --saffron-glow: #f5b878;
  --forest: #0e3326;
  --forest-2: #163f30;
  --forest-deep: #061e16;
  --gold: #c9a35b;
  --gold-2: #e6c98a;
  --gold-deep: #8a6a3a;

  /* Surfaces */
  --ivory: #faf6ec;
  --ivory-2: #f3ead5;
  --cream: #f7eed8;
  --paper: #fffdf5;
  --line: #d9cdb0;
  --line-2: #c5b491;

  /* Ink */
  --ink: #14130f;
  --ink-2: #322e26;
  --muted: #6b6357;
  --muted-2: #948b7c;

  /* Shadows */
  --shadow-sm: 0 1px 2px rgba(20,19,15,.06), 0 4px 14px rgba(20,19,15,.05);
  --shadow-md: 0 10px 30px rgba(20,19,15,.08), 0 30px 60px rgba(20,19,15,.06);
  --shadow-lg: 0 30px 80px rgba(14,51,38,.18), 0 60px 120px rgba(14,51,38,.1);
  --shadow-card: 0 1px 0 #fffdf5 inset, 0 1px 2px rgba(0,0,0,.04), 0 18px 40px rgba(20,19,15,.08);

  /* Type */
  --display: 'Plus Jakarta Sans', -apple-system, 'Segoe UI', system-ui, sans-serif;
  --serif: 'DM Serif Display', Georgia, serif;
  --sans: 'Plus Jakarta Sans', -apple-system, 'Segoe UI', system-ui, sans-serif;

  /* Motion */
  --ease: cubic-bezier(.2,.7,.2,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --ease-elastic: cubic-bezier(.34,1.5,.64,1);

  /* Layout */
  --pad: 28px;
  --container: 1280px;
}

/* ─── Reset & Overflow Lockdown ──────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html,body{
  width:100%;max-width:100vw;
  overflow-x:hidden;overflow-x:clip;
  scroll-behavior:smooth;
}
body{
  font-family:var(--sans);font-size:15px;line-height:1.65;color:var(--ink);
  background:var(--ivory);
  -webkit-font-smoothing:antialiased;
  font-feature-settings:'ss01' on, 'cv11' on;
  position:relative;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.02;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;
}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{background:none;border:0;cursor:pointer;font:inherit;color:inherit}
ul{list-style:none}
input,textarea,select{font:inherit;color:inherit;border:0;background:none;outline:none}
::selection{background:var(--saffron);color:#fff}

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--pad);
  position:relative;z-index:2;
  width:100%;
}

section{padding:120px 0;position:relative;overflow:hidden}

/* ─── Preloader (Enhanced) ───────────────────────────────── */
.preloader{
  position:fixed;inset:0;z-index:10000;
  background:var(--forest-deep);color:var(--ivory-2);
  display:grid;place-items:center;overflow:hidden;
  transition:transform 1.2s var(--ease-out) .3s, visibility 1.5s;
}
.preloader.is-out{transform:translateY(-101%)}

/* layered background */
.pl-bg{
  position:absolute;inset:0;opacity:.9;
  background:
    radial-gradient(60% 50% at 50% 45%, rgba(217,122,26,.18), transparent 60%),
    radial-gradient(80% 60% at 50% 100%, rgba(201,163,91,.1), transparent 70%);
  animation:plBgPulse 5s ease-in-out infinite;
}
@keyframes plBgPulse{0%,100%{opacity:.9}50%{opacity:1}}
.pl-pattern{
  position:absolute;inset:0;opacity:.08;
  background-image:
    radial-gradient(rgba(201,163,91,.55) 1px, transparent 1px),
    radial-gradient(rgba(201,163,91,.4) 1px, transparent 1px);
  background-size:36px 36px, 36px 36px;
  background-position:0 0, 18px 18px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
}
.pl-vignette{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at center, transparent 30%, rgba(6,30,22,.6) 100%);
}

.preloader-inner{
  position:relative;z-index:2;
  text-align:center;width:min(520px,92vw);padding:0 24px;
  display:flex;flex-direction:column;align-items:center;
}

/* Welcome line */
.pl-welcome{
  display:inline-flex;align-items:center;gap:14px;
  font-size:11px;letter-spacing:.36em;text-transform:uppercase;font-weight:600;
  color:var(--gold-2);opacity:0;transform:translateY(-10px);
  animation:plFadeDown .9s var(--ease-out) .1s forwards;
  margin-bottom:36px;
}
.pl-welcome i{
  display:inline-block;width:40px;height:1px;background:var(--gold-2);
  position:relative;transform:scaleX(0);transform-origin:right;
  animation:plRule 1s var(--ease-out) .25s forwards;
}
.pl-welcome i:last-child{transform-origin:left;animation-delay:.25s}
@keyframes plFadeDown{to{opacity:1;transform:translateY(0)}}
@keyframes plRule{to{transform:scaleX(1)}}

/* Logo + ornaments wrapper */
.pl-logo-wrap{
  position:relative;
  width:min(320px,72vw);
  padding:46px;
  opacity:0;transform:scale(.92);
  animation:plPop 1.1s var(--ease-out) .35s forwards;
}
@keyframes plPop{to{opacity:1;transform:scale(1)}}

/* Rotating rings */
.pl-ring{
  position:absolute;border-radius:50%;border:1px solid rgba(201,163,91,.28);
  pointer-events:none;
}
.pl-ring-1{
  inset:0;
  border-style:dashed;
  animation:plRot 22s linear infinite;
}
.pl-ring-2{
  inset:14px;
  border:1px solid rgba(201,163,91,.18);
  animation:plRot 30s linear infinite reverse;
}
.pl-ring-2::after{
  content:"";position:absolute;top:-3px;left:50%;
  width:6px;height:6px;border-radius:50%;background:var(--saffron);
  box-shadow:0 0 12px rgba(217,122,26,.7);
  transform:translateX(-50%);
}
@keyframes plRot{to{transform:rotate(360deg)}}

/* Gold corner brackets */
.pl-corner{
  position:absolute;width:22px;height:22px;border:1.5px solid var(--gold-2);
  z-index:2;opacity:0;
  animation:plFade .8s var(--ease-out) 1s forwards;
}
.pl-corner.tl{top:14px;left:14px;border-right:0;border-bottom:0}
.pl-corner.tr{top:14px;right:14px;border-left:0;border-bottom:0}
.pl-corner.bl{bottom:14px;left:14px;border-right:0;border-top:0}
.pl-corner.br{bottom:14px;right:14px;border-left:0;border-top:0}
@keyframes plFade{to{opacity:1}}

/* Logo with soft halo (no plate) */
.pl-logo{
  position:relative;padding:24px 28px;
  display:flex;align-items:center;justify-content:center;
}
.pl-logo::before{
  content:"";position:absolute;
  inset:-10% -8%;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse at center, rgba(255,253,245,.32) 0%, rgba(255,253,245,.12) 45%, transparent 75%);
}
.pl-logo img{width:100%;height:auto;display:block;position:relative;z-index:1}
.pl-shine{display:none}

/* Meta + tagline */
.pl-meta{
  margin-top:30px;font-size:11px;letter-spacing:.26em;text-transform:uppercase;
  color:rgba(245,239,230,.55);font-weight:500;
  opacity:0;animation:plFadeDown .8s var(--ease-out) 1.1s forwards;
}
.pl-meta .pl-tag{display:inline-block}

/* Progress */
.pl-progress{
  margin-top:28px;display:flex;align-items:center;gap:18px;width:100%;justify-content:center;
  opacity:0;animation:plFadeDown .8s var(--ease-out) 1.3s forwards;
}
.pl-bar{
  width:220px;height:1px;background:rgba(245,239,230,.12);
  overflow:hidden;position:relative;border-radius:1px;
}
.pl-bar i{
  position:absolute;inset:0;
  background:linear-gradient(90deg, var(--saffron), var(--gold-2));
  transform-origin:left;transform:scaleX(0);
  animation:plBar 1.6s var(--ease-out) 1.4s forwards;
  box-shadow:0 0 12px rgba(217,122,26,.6);
}
@keyframes plBar{to{transform:scaleX(1)}}
.pl-percent{
  font-size:12px;font-weight:700;letter-spacing:.06em;color:var(--gold-2);
  min-width:42px;display:inline-flex;align-items:baseline;
}
.pl-percent em{font-style:normal;font-size:9px;opacity:.6;margin-left:1px}

/* ─── Custom Cursor ──────────────────────────────────────── */
.cur{
  position:fixed;top:0;left:0;width:14px;height:14px;border-radius:50%;
  border:1px solid var(--saffron);background:transparent;pointer-events:none;
  z-index:9000;
  opacity:0;
  transition:opacity .25s var(--ease), width .35s var(--ease), height .35s var(--ease), background .25s, border-color .25s;
  mix-blend-mode:difference;
  will-change:transform, opacity;
}
.cur.is-on{opacity:1}
.cur::after{
  content:"";position:absolute;inset:50%;width:3px;height:3px;
  background:var(--saffron);border-radius:50%;transform:translate(-50%,-50%);
}
.cur.is-hover{width:48px;height:48px;background:rgba(217,122,26,.12);border-color:var(--saffron)}
.cur.is-hover::after{opacity:0}
.cur.is-img{width:78px;height:78px;background:var(--saffron);border-color:var(--saffron);mix-blend-mode:normal}
.cur.is-img::after{display:none}
.cur-label{
  font-size:12px;color:var(--ivory);font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  position:absolute;inset:0;display:grid;place-items:center;opacity:0;transition:opacity .25s;
}
.cur.is-img .cur-label{opacity:1}
@media (hover:none), (pointer:coarse), (max-width:1024px){.cur{display:none!important}}

/* ─── Header ─────────────────────────────────────────────── */
.hdr{
  position:fixed;top:0;left:0;right:0;z-index:500;
  padding:22px var(--pad);
  transition:padding .5s var(--ease), background .5s var(--ease);
}
.hdr-inner{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:center;
  min-width:0;
}
.hdr.is-scrolled{
  padding:14px var(--pad);
  background:rgba(250,246,236,.88);
  backdrop-filter:saturate(1.4) blur(20px);
  -webkit-backdrop-filter:saturate(1.4) blur(20px);
  box-shadow:0 1px 0 rgba(20,19,15,.06);
}
.logo{display:flex;align-items:center;flex-shrink:0;transition:transform .4s var(--ease)}
.logo:hover{transform:translateY(-1px)}
.logo-img{
  height:54px;width:auto;display:block;
  transition:transform .4s, filter .4s;
}
.hdr.is-scrolled .logo-img{filter:none}
.ft-brand{position:relative;display:inline-flex}
.ft-brand::before{
  content:"";position:absolute;
  inset:-30% -18%;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse at center, rgba(255,253,245,.22) 0%, rgba(255,253,245,.08) 45%, transparent 75%);
}
.logo-img-ft{height:64px;position:relative;z-index:1}
.logo-text{display:flex;flex-direction:column;line-height:1.05;min-width:0}
.logo-text strong{font-weight:600;font-size:18px;letter-spacing:.01em}
.logo-text em{font-style:normal;font-size:11px;letter-spacing:.16em;opacity:.7;text-transform:uppercase;font-weight:500}

.hdr-nav{display:flex;justify-content:center;gap:4px;min-width:0;flex-wrap:nowrap;overflow:hidden}
.hdr-nav a{
  position:relative;padding:10px 12px;
  font-size:13px;color:#ffffff;
  letter-spacing:.02em;font-weight:600;transition:color .35s, text-shadow .35s;white-space:nowrap;
  text-shadow:0 1px 2px rgba(0,0,0,.6), 0 2px 8px rgba(0,0,0,.45);
}
.hdr.is-scrolled .hdr-nav a{color:var(--ink-2);text-shadow:none;font-weight:500}
.hdr-nav a::after{
  content:"";position:absolute;left:10px;right:10px;bottom:4px;height:1px;
  background:var(--saffron);transform:scaleX(0);transform-origin:left;
  transition:transform .5s var(--ease-out);
}
.hdr-nav a:hover::after,.hdr-nav a.is-active::after{transform:scaleX(1)}
.hdr-nav a:hover,.hdr-nav a.is-active{color:var(--saffron)}

.hdr-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.hdr-call{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 12px 7px 7px;border-radius:60px;
  border:1px solid rgba(245,239,230,.28);
  background:rgba(255,253,245,.06);
  color:var(--ivory);font-weight:600;font-size:12px;letter-spacing:.02em;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  white-space:nowrap;
  transition:background .35s var(--ease), border-color .35s, color .35s, transform .35s;
}
.hdr-call-ico{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg, var(--saffron) 0%, var(--saffron-deep) 100%);
  color:#fff;
  box-shadow:0 3px 8px rgba(217,122,26,.4);
}
.hdr-call-ico svg{width:11px;height:11px}
.hdr-call:hover{
  background:rgba(217,122,26,.15);border-color:var(--saffron);
  transform:translateY(-1px);
}
.hdr.is-scrolled .hdr-call{
  color:var(--ink);border-color:rgba(201,163,91,.35);background:rgba(255,253,245,.65);
}
.hdr.is-scrolled .hdr-call:hover{background:rgba(217,122,26,.12);border-color:var(--saffron);color:var(--saffron-deep)}

.hdr-cta{
  position:relative;
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 14px;border-radius:60px;
  background:linear-gradient(135deg, var(--saffron) 0%, var(--saffron-deep) 100%);
  color:#fff;border:0;cursor:pointer;font:inherit;
  font-weight:700;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  box-shadow:0 8px 22px -8px rgba(217,122,26,.6), 0 0 0 1px rgba(255,255,255,.08) inset;
  overflow:hidden;flex-shrink:0;
  transition:transform .35s var(--ease), box-shadow .35s, filter .35s;
}
.hdr-cta::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(135deg, rgba(255,255,255,.2), transparent 60%);
  pointer-events:none;
}
.hdr-cta-label{position:relative;z-index:1}
.hdr-cta svg{width:12px;height:12px;position:relative;z-index:1;transition:transform .35s var(--ease)}
.hdr-cta:hover{transform:translateY(-1px);box-shadow:0 14px 30px -8px rgba(217,122,26,.85), 0 0 0 1px rgba(255,255,255,.12) inset;filter:brightness(1.07)}
.hdr-cta:hover svg{transform:translateX(3px)}

.hdr-burger{
  width:48px;height:48px;display:none;flex-direction:column;gap:5px;align-items:center;justify-content:center;
  border:1px solid rgba(245,239,230,.3);border-radius:14px;color:var(--ivory);flex-shrink:0;
  background:rgba(255,253,245,.06);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  transition:background .35s, border-color .35s, color .35s, transform .35s var(--ease);
  position:relative;overflow:hidden;
}
.hdr-burger::before{
  content:"";position:absolute;inset:0;background:var(--saffron);
  transform:translateY(101%);transition:transform .4s var(--ease-out);
}
.hdr-burger:hover{transform:scale(1.05)}
.hdr-burger:hover::before{transform:translateY(0)}
.hdr-burger:hover{color:#fff;border-color:var(--saffron)}
.hdr.is-scrolled .hdr-burger{
  color:var(--ink);border-color:rgba(201,163,91,.4);background:rgba(255,253,245,.6);
}
.hdr-burger span{
  width:18px;height:1.5px;background:currentColor;border-radius:2px;
  transition:transform .35s var(--ease), width .35s;
  position:relative;z-index:1;
}
.hdr-burger span:nth-child(2){width:12px;align-self:flex-end;margin-right:15px}
.hdr-burger:hover span:nth-child(2){width:18px;margin-right:15px}
.hdr-burger.is-open span:nth-child(1){transform:translateY(3.5px) rotate(45deg);width:18px}
.hdr-burger.is-open span:nth-child(2){transform:translateY(-3px) rotate(-45deg);width:18px;margin-right:15px}

/* ─── Drawer ─────────────────────────────────────────────── */
.drawer{
  position:fixed;inset:0;background:var(--forest);color:var(--ivory);
  z-index:480;opacity:0;visibility:hidden;transition:opacity .5s, visibility .5s;
  overflow-y:auto;
}
.drawer.is-open{opacity:1;visibility:visible}
.drawer-inner{padding:90px 28px 32px;min-height:100%;display:flex;flex-direction:column;justify-content:space-between;gap:40px}
.drawer nav{display:flex;flex-direction:column;gap:2px}
.drawer nav a{
  font-weight:500;font-size:20px;letter-spacing:.01em;
  border-bottom:1px solid rgba(245,239,230,.08);padding:14px 0;
  display:flex;align-items:center;gap:14px;transform:translateX(-30px);opacity:0;
  transition:transform .6s var(--ease-out), opacity .6s, color .3s, padding .3s;
}
.drawer nav a::before{
  content:"";width:18px;height:1px;background:var(--saffron);
  opacity:0;transition:opacity .3s, width .35s;flex-shrink:0;
}
.drawer nav a:hover{padding-left:8px}
.drawer nav a:hover::before{opacity:1;width:24px}
.drawer.is-open nav a{transform:translateX(0);opacity:1}
.drawer.is-open nav a:nth-child(1){transition-delay:.15s}
.drawer.is-open nav a:nth-child(2){transition-delay:.20s}
.drawer.is-open nav a:nth-child(3){transition-delay:.25s}
.drawer.is-open nav a:nth-child(4){transition-delay:.30s}
.drawer.is-open nav a:nth-child(5){transition-delay:.35s}
.drawer.is-open nav a:nth-child(6){transition-delay:.40s}
.drawer.is-open nav a:nth-child(7){transition-delay:.45s}
.drawer nav a:hover{color:var(--saffron-glow)}
.drawer nav a:hover::before{opacity:1}
.drawer-foot{display:flex;flex-direction:column;gap:8px;font-size:14px;color:var(--gold-2);font-weight:500;padding-top:24px;border-top:1px solid rgba(245,239,230,.08)}
.drawer-foot a{transition:color .3s}
.drawer-foot a:hover{color:var(--saffron-glow)}

/* ─── HERO ───────────────────────────────────────────────── */
.hero{
  position:relative;min-height:100vh;color:var(--ivory);
  display:flex;flex-direction:column;
  padding:0;
}
.hero-stage{position:absolute;inset:0;z-index:0;overflow:hidden;background:#0c1a14}
.hero-video{
  position:absolute;inset:0;pointer-events:none;
  overflow:hidden;
  isolation:isolate;  /* scope inner z-indexes (poster, iframe, masks) so the veil can sit on top */
}
.hero-video iframe{
  position:absolute!important;top:50%!important;left:50%!important;
  width:100vw!important;height:56.25vw!important;          /* 16:9 scaled to viewport width  */
  min-width:177.78vh;min-height:100vh; /* …or scaled to viewport height, whichever covers */
  transform:translate(-50%,-50%) scale(1.05);
  border:0;pointer-events:none;
}
.hero-yt-anchor{position:absolute;inset:0}
.hero-poster{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;
  display:block;z-index:2;
  transition:opacity .8s ease;
}
.hero-video.is-playing .hero-poster{opacity:0;pointer-events:none}
/* Mask the iframe's top/bottom edges so YouTube's title flash & end-card thumbnails never appear */
.hero-video::before,
.hero-video::after{
  content:"";position:absolute;left:0;right:0;height:120px;z-index:2;pointer-events:none;
}
.hero-video::before{
  top:0;
  background:linear-gradient(180deg, var(--forest-deep) 0%, rgba(6,30,22,.85) 45%, transparent 100%);
}
.hero-video::after{
  bottom:0;
  background:linear-gradient(0deg, var(--forest-deep) 0%, rgba(6,30,22,.85) 45%, transparent 100%);
}
.hero-veil{
  position:absolute;inset:0;
  background:
    /* Forest-green wash */
    linear-gradient(180deg, rgba(6,30,22,.42) 0%, rgba(6,30,22,.42) 100%),
    /* Soft anchoring at top and bottom */
    linear-gradient(180deg,
      rgba(0,0,0,.45) 0%,
      rgba(0,0,0,.08) 25%,
      rgba(0,0,0,.1) 70%,
      rgba(0,0,0,.55) 100%
    );
}
@media (max-width:1024px){
  .hero-veil{
    background:
      /* Stronger base on mobile (text occupies more of the screen) */
      linear-gradient(180deg, rgba(6,20,16,.55) 0%, rgba(6,20,16,.55) 100%),
      /* Header anchor */
      linear-gradient(180deg, rgba(0,0,0,.45) 0%, transparent 22%),
      /* Mid anchor for description/CTAs */
      linear-gradient(180deg, transparent 25%, rgba(0,0,0,.12) 50%, rgba(0,0,0,.18) 70%),
      /* Bottom anchor for plaque + scroll */
      linear-gradient(180deg, transparent 70%, rgba(0,0,0,.6) 100%) !important;
  }
}
.hero-noise{
  position:absolute;inset:0;opacity:.07;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

.hero-content{
  position:relative;z-index:2;flex:1;
  max-width:var(--container);margin:0 auto;width:100%;
  padding:140px var(--pad) 80px;
  display:grid;grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);gap:60px;align-items:center;
}
.hero-row{padding-right:0;min-width:0}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-2);
  margin-bottom:30px;font-weight:600;
  text-shadow:0 1px 3px rgba(0,0,0,.5);
}
.hero-eyebrow .rule{display:inline-block;width:42px;height:1px;background:var(--gold-2);opacity:.9}

.hero-title{
  font-weight:300;font-size:clamp(54px, 9vw, 130px);
  line-height:.95;letter-spacing:-.025em;color:var(--ivory);
  text-shadow:0 2px 14px rgba(0,0,0,.45), 0 1px 2px rgba(0,0,0,.4);
}
.hero-title .line{
  display:block;overflow:hidden;line-height:1.18;
  padding:0 .6em .05em 0;margin:0 -.6em -.18em 0;
}
.hero-title .word{display:inline-block;transform:translateY(120%);line-height:1.18}
.hero-title .word.ital{
  padding-right:.08em;
  color:transparent;
  background:linear-gradient(120deg, var(--gold-2) 0%, var(--saffron) 60%, var(--gold-deep) 100%);
  -webkit-background-clip:text;background-clip:text;
  text-shadow:none;
  filter:drop-shadow(0 2px 10px rgba(0,0,0,.35));
}
.is-anim .hero-title .word{animation:slideUpIn 1.4s var(--ease-out) forwards}
.is-anim .hero-title .word[data-delay="400"]{animation-delay:.4s}
.is-anim .hero-title .word[data-delay="550"]{animation-delay:.6s}
@keyframes slideUpIn{
  0%{transform:translateY(110%) rotate(2deg);opacity:.6}
  100%{transform:translateY(0) rotate(0);opacity:1}
}

.hero-deck{
  font-size:clamp(17px,1.6vw,22px);font-weight:400;
  margin-top:30px;line-height:1.55;color:rgba(250,246,236,.92);
  max-width:600px;
  text-shadow:0 1px 3px rgba(0,0,0,.5), 0 2px 12px rgba(0,0,0,.35);
}
.hero-cta{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap}

.split-up{opacity:0;transform:translateY(20px)}
.is-anim .split-up{animation:fadeUp 1s var(--ease-out) forwards}
.is-anim .split-up[data-delay="200"]{animation-delay:.2s}
.is-anim .split-up[data-delay="900"]{animation-delay:.95s}
.is-anim .split-up[data-delay="1100"]{animation-delay:1.15s}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}

/* Buttons */
.btn-gold{
  position:relative;display:inline-flex;align-items:center;gap:12px;
  padding:16px 26px;background:var(--saffron);color:#fff;
  border-radius:60px;font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  overflow:hidden;isolation:isolate;
  box-shadow:0 18px 40px rgba(217,122,26,.4), inset 0 1px 0 rgba(255,255,255,.2);
  transition:transform .4s var(--ease), box-shadow .4s, color .4s;
}
.btn-gold::before{
  content:"";position:absolute;inset:0;background:var(--ink);z-index:-1;
  transform:translateY(101%);transition:transform .55s var(--ease-out);
}
.btn-gold:hover{box-shadow:0 24px 50px rgba(14,51,38,.4)}
.btn-gold:hover::before{transform:translateY(0)}
.btn-gold .btn-arrow{
  width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.18);
  display:grid;place-items:center;transition:transform .5s var(--ease), background .3s;
}
.btn-gold .btn-arrow svg{width:14px;height:14px}
.btn-gold:hover .btn-arrow{transform:rotate(-45deg);background:var(--saffron)}

.btn-line{
  display:inline-flex;align-items:center;gap:14px;padding:16px 24px;
  border:1px solid rgba(245,239,230,.45);border-radius:60px;
  color:var(--ivory);font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  position:relative;overflow:hidden;
  transition:color .4s;
}
.btn-line::before{
  content:"";position:absolute;inset:0;background:var(--ivory);transform:translateX(-101%);
  transition:transform .55s var(--ease-out);z-index:-1;
}
.btn-line:hover{color:var(--ink);border-color:var(--ivory)}
.btn-line:hover::before{transform:translateX(0)}

/* Hero Plaque */
.hero-plaque{
  position:relative;
  background:linear-gradient(180deg, rgba(255,253,245,.97), rgba(247,238,216,.95));
  color:var(--ink);
  border-radius:18px;
  padding:24px 26px;
  box-shadow:var(--shadow-lg);
  border:1px solid rgba(201,163,91,.22);
  min-width:0;
}
.hero-plaque::before{
  content:"";position:absolute;inset:8px;border:1px solid rgba(201,163,91,.22);
  border-radius:10px;pointer-events:none;
}
.plaque-corner{
  position:absolute;width:18px;height:18px;
  border:1.5px solid var(--gold);z-index:2;pointer-events:none;
  opacity:.7;
}
.plaque-corner.tl{top:16px;left:16px;border-right:0;border-bottom:0;border-top-left-radius:3px}
.plaque-corner.tr{top:16px;right:16px;border-left:0;border-bottom:0;border-top-right-radius:3px}
.plaque-corner.bl{bottom:16px;left:16px;border-right:0;border-top:0;border-bottom-left-radius:3px}
.plaque-corner.br{bottom:16px;right:16px;border-left:0;border-top:0;border-bottom-right-radius:3px}
.plaque-pattern{
  position:absolute;inset:8px;border-radius:10px;pointer-events:none;
  opacity:.04;
  background-image:radial-gradient(rgba(31,58,42,.9) 1px, transparent 1px);
  background-size:14px 14px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
}
.plaque-stamp{
  position:absolute;top:-18px;right:-12px;z-index:3;
  width:140px;height:140px;border-radius:50%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  padding:8px;
  background:radial-gradient(circle at 35% 30%, #f4ecd6 0%, #ead7ad 70%, #d9bf86 100%);
  color:#1f3a2a;
  border:2px solid currentColor;
  box-shadow:inset 0 0 0 4px rgba(244,236,214,.95), inset 0 0 0 5px currentColor, 0 8px 22px rgba(31,58,42,.22);
  transform:rotate(-14deg);
  font-family:var(--serif, Georgia, serif);
  text-transform:uppercase;letter-spacing:.14em;
  opacity:.96;
  pointer-events:none;
  text-align:center;
}
.plaque-stamp::before{
  content:"";position:absolute;inset:10px;border-radius:50%;
  border:1px dashed rgba(31,58,42,.4);
}
.plaque-stamp .ps-top,.plaque-stamp .ps-bot{
  font-size:13px;font-weight:700;line-height:1;
}
.plaque-stamp .ps-sub{
  font-size:9.5px;font-weight:700;letter-spacing:.1em;line-height:1;
  margin-top:5px;padding-top:5px;
  border-top:1px solid rgba(31,58,42,.4);
  color:rgba(31,58,42,.88);
}
.plaque-stamp .ps-icon{
  display:flex;align-items:center;justify-content:center;
  width:26px;height:26px;margin:2px 0;
}
.plaque-stamp .ps-icon svg{width:100%;height:100%}
.plaque-head{
  display:flex;align-items:center;gap:12px;
  font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--saffron-deep);font-weight:700;
  margin-bottom:14px;
}
.plaque-mark{width:8px;height:8px;background:var(--saffron);border-radius:50%;box-shadow:0 0 0 4px rgba(217,122,26,.16)}
.plaque-price{position:relative;padding-bottom:0;border-bottom:0;text-align:left}
.plaque-price small{
  font-size:10px;color:var(--saffron-deep);letter-spacing:.22em;text-transform:uppercase;
  display:block;font-weight:700;
}
.plaque-price strong{
  font-weight:300;font-size:48px;line-height:1;color:var(--forest);
  display:flex;align-items:baseline;gap:5px;margin:6px 0 4px;letter-spacing:-.035em;
  text-shadow:0 1px 0 rgba(255,255,255,.7);
}
.plaque-price strong i{
  font-family:var(--serif, Georgia, serif);font-style:italic;
  font-size:16px;color:var(--saffron);font-weight:400;letter-spacing:.01em;
}
.plaque-price p{font-size:12px;color:var(--muted);letter-spacing:.01em;font-weight:500}

.plaque-divider{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin:14px 0 12px;color:var(--gold);
}
.plaque-divider .pd-line{
  flex:1;max-width:80px;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
}
.plaque-divider .pd-mark{
  width:11px;height:11px;color:var(--saffron);
  filter:drop-shadow(0 0 4px rgba(217,122,26,.35));
}

.plaque-sizes{
  padding:10px 0 14px;border-bottom:1px solid var(--line);margin-bottom:14px;
}
.plaque-sizes .ps-head{
  display:flex;align-items:center;gap:8px;margin-bottom:9px;
}
.plaque-sizes .ps-label{
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);font-weight:700;
}
.plaque-sizes .ps-ico{margin-bottom:0}
.ps-pills{
  display:flex;align-items:center;gap:6px;flex-wrap:nowrap;min-width:0;
}
.ps-pill{
  flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  padding:6px 11px;border-radius:60px;
  background:linear-gradient(135deg, rgba(247,238,216,.95) 0%, rgba(230,201,138,.55) 100%);
  border:1px solid rgba(201,163,91,.5);
  color:var(--forest);font-weight:600;font-size:14px;letter-spacing:-.01em;
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 2px 6px rgba(201,163,91,.2);
  transition:transform .35s var(--ease), box-shadow .35s, background .35s;
}
.ps-pill:hover{
  transform:translateY(-1px);
  background:linear-gradient(135deg, var(--saffron) 0%, var(--saffron-deep) 100%);
  color:#fff;border-color:var(--saffron);
  box-shadow:0 6px 14px rgba(217,122,26,.4);
}
.ps-unit{
  font-size:11px;color:var(--saffron);font-weight:600;letter-spacing:.02em;
  margin-left:auto;flex-shrink:0;
}

.plaque-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;margin:0 0 16px;border-bottom:1px solid var(--line);padding-bottom:14px}
.plaque-stats li{display:flex;flex-direction:column;align-items:flex-start;padding:0 14px;border-right:1px solid var(--line);min-width:0;position:relative}
.plaque-stats li:first-child{padding-left:0}.plaque-stats li:last-child{border-right:0;padding-right:0}
.ps-ico{
  display:inline-flex;align-items:center;justify-content:center;
  width:24px;height:24px;border-radius:7px;
  background:linear-gradient(135deg, rgba(217,122,26,.13) 0%, rgba(201,163,91,.18) 100%);
  color:var(--saffron-deep);margin-bottom:7px;flex-shrink:0;
}
.ps-ico svg{width:13px;height:13px}
.plaque-stats b{font-weight:300;font-size:28px;color:var(--forest);line-height:1;display:flex;align-items:baseline;gap:3px;letter-spacing:-.02em}
.plaque-stats i{font-style:normal;font-size:12px;color:var(--saffron);font-weight:500}
.plaque-stats span{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:5px;font-weight:600}
.plaque-cta{
  display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  padding:13px;background:linear-gradient(135deg, var(--forest) 0%, var(--forest-2, #163f30) 100%);
  color:var(--ivory);
  border-radius:60px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;
  position:relative;overflow:hidden;
  box-shadow:0 10px 24px -10px rgba(14,51,38,.5), 0 0 0 1px rgba(255,255,255,.05) inset;
  transition:color .35s, box-shadow .4s, transform .4s var(--ease);
}
.plaque-cta::before{
  content:"";position:absolute;inset:0;background:linear-gradient(135deg, var(--saffron) 0%, var(--saffron-deep) 100%);
  transform:translateX(-101%);transition:transform .55s var(--ease-out);
}
.plaque-cta:hover::before{transform:translateX(0)}
.plaque-cta span,.plaque-cta svg{position:relative;z-index:1;transition:transform .4s var(--ease)}
.plaque-cta svg{width:16px;height:16px}
.plaque-cta:hover{color:#fff;box-shadow:0 16px 32px -8px rgba(217,122,26,.5), 0 0 0 1px rgba(255,255,255,.12) inset;transform:translateY(-1px)}
.plaque-cta:hover svg{transform:translateX(4px)}

/* Hero Foot */
.hero-foot{
  position:relative;z-index:2;display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;padding:16px var(--pad);
  max-width:var(--container);width:100%;margin:0 auto;
  border-top:1px solid rgba(245,239,230,.14);
  gap:16px;
}
.hero-side-mark{
  justify-self:start;
  font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(245,239,230,.55);font-weight:600;
  display:inline-flex;align-items:center;gap:10px;
}
.hero-side-mark::before{
  content:"";display:inline-block;width:18px;height:1px;background:var(--gold-2);opacity:.6;
}
.scroll-mark{
  position:relative;
  display:flex;flex-direction:column;align-items:center;gap:9px;
  color:rgba(245,239,230,.75);font-size:10px;letter-spacing:.24em;
  text-transform:uppercase;font-weight:600;text-decoration:none;
  padding:6px 14px 2px;
  transition:color .4s var(--ease), transform .5s var(--ease);
}
.scroll-mark::before{
  content:"";position:absolute;inset:-6px -10px;border-radius:32px;
  background:radial-gradient(closest-side, rgba(201,163,91,.18), transparent 75%);
  opacity:0;transition:opacity .5s var(--ease);pointer-events:none;
}
.scroll-mark:hover{color:var(--saffron-glow);transform:translateY(-2px)}
.scroll-mark:hover::before{opacity:1}

.scroll-mark .sm-cap{
  position:relative;width:6px;height:6px;border-radius:50%;
  background:var(--gold-2);
  box-shadow:0 0 0 1px rgba(201,163,91,.35), 0 0 12px rgba(201,163,91,.55);
}
.scroll-mark .sm-cap::before,
.scroll-mark .sm-cap::after{
  content:"";position:absolute;top:50%;left:50%;
  width:6px;height:6px;border-radius:50%;
  border:1px solid var(--gold-2);
  transform:translate(-50%,-50%);
  animation:smCapRing 2.6s ease-out infinite;
}
.scroll-mark .sm-cap::after{animation-delay:1.3s}
@keyframes smCapRing{
  0%{width:6px;height:6px;opacity:.65}
  100%{width:22px;height:22px;opacity:0}
}

.scroll-mark .line{
  display:block;width:1px;height:54px;position:relative;overflow:hidden;
  background:linear-gradient(180deg,
    rgba(245,239,230,.06),
    rgba(245,239,230,.28) 30%,
    rgba(245,239,230,.28) 70%,
    rgba(245,239,230,.06));
}
.scroll-mark .line i{
  position:absolute;inset:auto 0 100% 0;height:18px;border-radius:2px;
  background:linear-gradient(180deg, transparent, var(--saffron) 45%, var(--saffron-glow));
  box-shadow:0 0 8px rgba(255,166,0,.65), 0 0 16px rgba(201,163,91,.35);
  animation:smDrop 2.6s cubic-bezier(.55,.05,.45,.95) infinite;
}
@keyframes smDrop{
  0%  {inset:-30% 0 100% 0;opacity:0}
  12% {opacity:1}
  88% {opacity:1}
  100%{inset:100% 0 -30% 0;opacity:0}
}

.scroll-mark .sm-chev{
  display:flex;align-items:center;justify-content:center;
  width:14px;height:8px;color:var(--gold-2);
  animation:smChev 2.6s ease-in-out infinite;
}
.scroll-mark .sm-chev svg{width:100%;height:auto;display:block;filter:drop-shadow(0 0 4px rgba(201,163,91,.45))}
@keyframes smChev{
  0%,100%{transform:translateY(-2px);opacity:.55}
  50%    {transform:translateY(2px);opacity:1}
}

.scroll-mark small{
  display:inline-block;
  transition:letter-spacing .4s var(--ease), opacity .4s var(--ease);
}
.scroll-mark:hover small{letter-spacing:.36em}
.scroll-mark:hover .sm-cap::before,
.scroll-mark:hover .sm-cap::after{animation-duration:1.6s}
.scroll-mark:hover .line i{animation-duration:1.6s}
.scroll-mark:hover .sm-chev{animation-duration:1.4s}

@media (prefers-reduced-motion: reduce){
  .scroll-mark .sm-cap::before,
  .scroll-mark .sm-cap::after,
  .scroll-mark .line i,
  .scroll-mark .sm-chev{animation:none}
}
.hero-meta{justify-self:end;display:flex;gap:10px;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(245,239,230,.55);font-weight:500;flex-wrap:wrap}
.hero-meta .sep{opacity:.4}

/* ─── Marquee Strip ──────────────────────────────────────── */
.strip{
  background:var(--forest);color:var(--ivory);padding:28px 0;overflow:hidden;
  border-block:1px solid rgba(201,163,91,.2);
  width:100%;max-width:100vw;
}
.strip-track{
  display:flex;gap:40px;width:max-content;
  animation:marquee 40s linear infinite;
  align-items:center;font-size:24px;font-weight:300;letter-spacing:-.01em;
}
.strip-track span{display:inline-flex;align-items:center;gap:14px;white-space:nowrap}
.strip-track em{font-family:var(--serif);font-style:italic;color:var(--gold-2);font-weight:400}
.strip-ital{font-family:var(--serif);font-style:italic;color:var(--gold-2);font-weight:400}
.strip-dot{color:var(--saffron);font-size:16px}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ─── Section Primitives ─────────────────────────────────── */
.kicker{
  display:inline-flex;align-items:center;gap:12px;
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--saffron-deep);
  font-weight:700;margin-bottom:26px;
}
.kicker i{display:inline-block;width:32px;height:1px;background:var(--saffron)}
.kicker.on-dark{color:var(--gold-2)}
.kicker.on-dark i{background:var(--gold-2)}

.display{
  font-weight:300;
  font-size:clamp(36px,5vw,72px);
  line-height:1.02;letter-spacing:-.03em;color:var(--ink);
}
.display em{
  font-family:var(--serif);font-style:italic;font-weight:400;
  color:transparent;
  background:linear-gradient(120deg, var(--saffron) 0%, var(--gold-deep) 80%);
  -webkit-background-clip:text;background-clip:text;letter-spacing:-.02em;
}
.display.on-dark{color:var(--ivory)}
.display.on-dark em{background:linear-gradient(120deg, var(--gold-2) 0%, var(--saffron) 80%);-webkit-background-clip:text;background-clip:text}

.lede{font-size:18px;line-height:1.6;color:var(--ink-2);max-width:540px;font-weight:400}
.lede.on-dark{color:rgba(245,239,230,.78)}
.body-text{font-size:15px;line-height:1.75;color:var(--muted);max-width:520px}

.section-head{margin-bottom:70px;max-width:100%}
.section-head.center{text-align:center;margin-inline:auto;max-width:720px}
.section-head.center .kicker{justify-content:center}
.section-head.center .lede{margin-inline:auto;margin-top:20px}
.section-head.split{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:60px;align-items:end}
.section-head.split .lede{margin-bottom:6px}

/* Reveal */
[data-reveal]{opacity:0;transform:translateY(40px);transition:opacity 1s var(--ease-out), transform 1s var(--ease-out)}
[data-reveal].is-in{opacity:1;transform:translateY(0)}

/* ─── CHAPTER ONE ────────────────────────────────────────── */
.chapter{background:var(--ivory);padding-bottom:50px}
.chapter-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:60px;align-items:start;margin-bottom:80px}
.chapter-left .display{padding-right:30px}
.chapter-right{padding-top:14px}
.chapter-right .body-text{margin-top:22px}
.chapter-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-top:40px;padding-top:32px;border-top:1px solid var(--line)}
.chapter-stats div{display:flex;flex-direction:column;gap:6px;min-width:0}
.chapter-stats b{font-weight:300;font-size:40px;color:var(--forest);line-height:1;letter-spacing:-.02em;display:inline-flex;align-items:baseline;gap:4px}
.chapter-stats b i{font-style:normal;font-size:16px;color:var(--saffron);font-weight:500;letter-spacing:.02em}
.chapter-stats span{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600}

.chapter-media{
  display:grid;
  grid-template-columns:minmax(0,1.3fr) minmax(0,1fr) minmax(0,1.15fr);
  gap:20px;
}
.chapter-media figure{
  position:relative;border-radius:16px;min-width:0;height:480px;
  padding:5px;background:linear-gradient(135deg, rgba(201,163,91,.45) 0%, rgba(201,163,91,.06) 60%, rgba(201,163,91,.25) 100%);
  box-shadow:0 18px 40px rgba(20,19,15,.08), 0 2px 6px rgba(20,19,15,.04);
  transition:transform .6s var(--ease-out), box-shadow .6s, padding .4s;
  overflow:hidden;
}
.chapter-media figure:hover{
  transform:translateY(-8px);
  box-shadow:0 40px 90px rgba(14,51,38,.18), 0 4px 12px rgba(20,19,15,.06);
}
.media-mask{
  position:relative;overflow:hidden;width:100%;height:100%;
  border-radius:12px;
  clip-path:inset(0 100% 0 0);
  transition:clip-path 1.3s var(--ease-out);
}
.chapter-media figure.is-in .media-mask{clip-path:inset(0 0 0 0)}
.media-mask::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg, transparent 35%, rgba(6,30,22,.4) 70%, rgba(6,30,22,.88) 100%);
  transition:background .6s;
}
.chapter-media figure:hover .media-mask::after{
  background:linear-gradient(180deg, transparent 20%, rgba(6,30,22,.5) 55%, rgba(6,30,22,.92) 100%);
}
.media-mask img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.8s var(--ease), filter 1s;
  filter:saturate(.95);
}
.chapter-media figure:hover img{transform:scale(1.08);filter:saturate(1.08)}

/* Gold corner brackets */
.cm-corner{
  position:absolute;width:26px;height:26px;border:1.5px solid var(--gold-2);z-index:4;pointer-events:none;
  opacity:0;transition:opacity .5s, transform .55s var(--ease-out);
}
.cm-corner.tl{top:18px;left:18px;border-right:0;border-bottom:0;transform:translate(-10px,-10px)}
.cm-corner.br{bottom:18px;right:18px;border-left:0;border-top:0;transform:translate(10px,10px)}
.chapter-media figure:hover .cm-corner{opacity:1;transform:translate(0,0)}

/* Caption pill */
.chapter-media figcaption{
  position:absolute;left:16px;right:16px;bottom:16px;z-index:3;
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;
  background:rgba(6,30,22,.6);
  backdrop-filter:blur(14px) saturate(1.4);
  -webkit-backdrop-filter:blur(14px) saturate(1.4);
  border:1px solid rgba(245,239,230,.16);
  border-radius:60px;color:var(--ivory);
  transform:translateY(8px);opacity:0;
  transition:transform .7s var(--ease-out), opacity .6s, background .4s, border-color .4s;
}
.chapter-media figure.is-in figcaption{opacity:1;transform:translateY(0);transition-delay:.6s}
.chapter-media figure:hover figcaption{background:rgba(6,30,22,.78);border-color:rgba(201,163,91,.4)}

.cm-no{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:24px;line-height:1;color:var(--gold-2);letter-spacing:-.02em;
  flex-shrink:0;
}
.cm-divider{
  width:1px;height:22px;background:rgba(245,239,230,.25);flex-shrink:0;
}
.cm-meta{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.cm-meta h4{
  font-weight:600;font-size:14px;letter-spacing:.01em;color:var(--ivory);line-height:1.2;
}
.cm-meta small{
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(245,239,230,.6);font-weight:500;
}
.cm-arrow{
  width:32px;height:32px;border-radius:50%;
  display:grid;place-items:center;flex-shrink:0;
  padding:0;font:inherit;cursor:pointer;
  background:rgba(245,239,230,.1);
  border:1px solid rgba(245,239,230,.18);color:var(--ivory);
  transition:background .4s, border-color .4s, transform .4s var(--ease);
}
.cm-arrow:hover{background:var(--saffron);border-color:var(--saffron);transform:rotate(-45deg)}
.cm-arrow svg{width:14px;height:14px;transition:transform .4s var(--ease)}
.chapter-media figure:hover .cm-arrow{
  background:var(--saffron);border-color:var(--saffron);transform:rotate(-45deg);
}
.chapter-media figure:hover .cm-arrow svg{transform:translateX(0)}

/* ─── WHY (Editorial Rows) ───────────────────────────────── */
.why{
  background:var(--paper);padding-top:50px;
  position:relative;
}
.why::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:140px;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold-2), transparent);
  opacity:.55;
}
.why-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.4fr);gap:40px;align-items:end;margin-bottom:60px}
.why-list{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;
}
.why-row{
  position:relative;display:flex;flex-direction:column;
  background:var(--paper);
  border-radius:16px;overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 18px 40px rgba(20,19,15,.06), 0 2px 6px rgba(20,19,15,.03);
  transition:transform .6s var(--ease-out), box-shadow .6s, border-color .4s;
  min-width:0;
}
.why-row:hover{
  transform:translateY(-8px);
  box-shadow:0 40px 90px rgba(14,51,38,.18), 0 4px 12px rgba(20,19,15,.06);
  border-color:rgba(201,163,91,.4);
}
.wr-media{
  position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;
  clip-path:inset(0 100% 0 0);
  transition:clip-path 1.3s var(--ease-out);
  background:#0c1a14;
}
.why-row.is-in .wr-media{clip-path:inset(0 0 0 0)}
.wr-media img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.8s var(--ease), filter 1s;
  filter:saturate(.95);
}
.why-row:hover .wr-media img{transform:scale(1.08);filter:saturate(1.08)}
.wr-media::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg, transparent 45%, rgba(6,30,22,.55) 100%);
  transition:background .6s;
}
.why-row:hover .wr-media::after{
  background:linear-gradient(180deg, transparent 30%, rgba(6,30,22,.75) 100%);
}
.why-row .cm-corner{
  position:absolute;width:24px;height:24px;border:1.5px solid var(--gold-2);z-index:4;pointer-events:none;
  opacity:0;transition:opacity .5s, transform .55s var(--ease-out);
}
.why-row .cm-corner.tl{top:16px;left:16px;border-right:0;border-bottom:0;transform:translate(-10px,-10px)}
.why-row .cm-corner.br{bottom:16px;right:16px;border-left:0;border-top:0;transform:translate(10px,10px)}
.why-row:hover .cm-corner{opacity:1;transform:translate(0,0)}
.why-num{
  position:absolute;top:14px;right:18px;z-index:3;
  font-family:var(--serif);font-style:italic;font-weight:400;font-size:48px;
  color:var(--gold-2);line-height:1;letter-spacing:-.02em;
  text-shadow:0 2px 14px rgba(0,0,0,.45);
  transition:transform .5s var(--ease), color .4s;
}
.why-row:hover .why-num{transform:scale(1.05) rotate(-3deg);color:var(--saffron)}
.why-body{
  padding:24px 24px 26px;display:flex;flex-direction:column;gap:12px;flex:1;min-width:0;
}
.why-body h3{font-weight:600;font-size:20px;color:var(--ink);letter-spacing:-.01em;line-height:1.3}
.why-body p{color:var(--muted);font-size:14.5px;line-height:1.65;flex:1}
.why-tag{
  align-self:flex-start;font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:700;padding:7px 14px;border:1px solid var(--line);border-radius:60px;
  transition:all .4s;white-space:nowrap;background:var(--ivory);
}
.why-row:hover .why-tag{border-color:var(--saffron);color:var(--saffron);background:var(--paper)}

/* ─── PLOT CARDS · WOW DESIGN ────────────────────────────── */
.plots{
  background:var(--forest-deep);color:var(--ivory);position:relative;overflow:hidden;
}
.plots::before{
  content:"";position:absolute;inset:0;opacity:.45;
  background-image:
    radial-gradient(50% 50% at 0% 0%, rgba(217,122,26,.22), transparent 70%),
    radial-gradient(50% 50% at 100% 100%, rgba(201,163,91,.18), transparent 70%);
}
.plots::after{
  content:"";position:absolute;left:0;right:0;top:0;height:160px;
  background:linear-gradient(180deg, rgba(243,234,213,.10), transparent);
  pointer-events:none;z-index:1;
}
.plots{
  background:
    linear-gradient(180deg, transparent 75%, rgba(250,246,236,.06) 100%),
    var(--forest-deep);
}
.plots .container{position:relative;z-index:2}
.plots .section-head{text-align:center;margin-inline:auto;max-width:760px}
.plots .section-head .kicker{justify-content:center}
.plots .lede{margin-inline:auto;margin-top:20px}

.plot-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px;
  align-items:stretch;
}

.plot-card{
  position:relative;
  background:linear-gradient(180deg, #fffdf5 0%, #fcf5e3 100%);
  border-radius:18px;overflow:hidden;
  box-shadow:0 1px 0 rgba(255,255,255,.7) inset, 0 1px 2px rgba(0,0,0,.04), 0 20px 50px rgba(0,0,0,.25);
  display:flex;flex-direction:column;
  border:1px solid rgba(201,163,91,.25);
  transition:transform .6s var(--ease-out), box-shadow .6s;
  min-width:0;
}
.plot-card::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:48%;height:2px;border-radius:0 0 4px 4px;
  background:linear-gradient(90deg, transparent, var(--gold-2) 30%, var(--saffron-glow) 50%, var(--gold-2) 70%, transparent);
  opacity:.5;transition:opacity .5s, width .7s var(--ease-out);
  z-index:6;pointer-events:none;
}
.plot-card:hover::before{opacity:1;width:88%}
.plot-card:hover{transform:translateY(-14px);box-shadow:0 1px 0 rgba(255,255,255,.7) inset, 0 1px 2px rgba(0,0,0,.04), 0 50px 90px rgba(0,0,0,.35), 0 0 0 1px var(--gold) inset}

.pc-ribbon{
  position:absolute;top:18px;right:-44px;transform:rotate(45deg);z-index:5;
  background:linear-gradient(135deg, var(--saffron) 0%, var(--saffron-deep) 100%);
  color:#fff;padding:6px 50px;font-size:10px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  box-shadow:0 6px 16px rgba(217,122,26,.4);
}
.pc-ribbon::before,.pc-ribbon::after{
  content:"";position:absolute;top:100%;border:4px solid var(--saffron-deep);
}
.pc-ribbon::before{left:0;border-right-color:transparent;border-bottom-color:transparent}
.pc-ribbon::after{right:0;border-left-color:transparent;border-bottom-color:transparent}
.is-signature .pc-ribbon{background:linear-gradient(135deg, var(--gold) 0%, var(--gold-deep) 100%);box-shadow:0 6px 16px rgba(201,163,91,.4)}
.is-signature .pc-ribbon::before,.is-signature .pc-ribbon::after{border-color:var(--gold-deep);}
.is-signature .pc-ribbon::before{border-right-color:transparent;border-bottom-color:transparent}
.is-signature .pc-ribbon::after{border-left-color:transparent;border-bottom-color:transparent}

/* Card Header — editorial, no images */
.pc-header{
  position:relative;
  padding:54px 24px 36px;
  background:linear-gradient(160deg, var(--forest) 0%, var(--forest-deep) 100%);
  color:var(--ivory);
  overflow:hidden;
  text-align:center;
}
.is-featured .pc-header{
  background:linear-gradient(160deg, #1a4d35 0%, #0b2a1e 100%);
}
.is-featured .pc-header::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 60% at 50% 30%, rgba(217,122,26,.32), transparent 70%);
  pointer-events:none;
}
.is-signature .pc-header{
  background:linear-gradient(160deg, #2a2418 0%, #0e0a04 100%);
}
.is-signature .pc-header::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 60% at 50% 30%, rgba(201,163,91,.3), transparent 70%);
  pointer-events:none;
}

/* Subtle gold dot pattern */
.pc-pattern{
  position:absolute;inset:0;opacity:.18;pointer-events:none;
  background-image:radial-gradient(rgba(201,163,91,.6) 1px, transparent 1px);
  background-size:22px 22px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 80%);
}

/* Gold corner brackets */
.pc-corner{
  position:absolute;width:20px;height:20px;border:1px solid var(--gold-2);
  z-index:2;opacity:.5;transition:opacity .5s, transform .5s var(--ease-out);
}
.pc-corner.tl{top:14px;left:14px;border-right:0;border-bottom:0}
.pc-corner.tr{top:14px;right:14px;border-left:0;border-bottom:0}
.pc-corner.bl{bottom:14px;left:14px;border-right:0;border-top:0}
.pc-corner.br{bottom:14px;right:14px;border-left:0;border-top:0}
.plot-card:hover .pc-corner{opacity:1}

/* Tags */
.pc-no{
  position:absolute;top:18px;left:50%;transform:translateX(-50%);z-index:3;
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;font-weight:700;
  color:var(--gold-2);
}
.pc-tag{
  position:absolute;bottom:18px;left:50%;transform:translateX(-50%);z-index:3;
  font-size:9px;letter-spacing:.28em;text-transform:uppercase;font-weight:700;
  color:var(--saffron-glow);
  padding:5px 14px;border:1px solid rgba(245,184,120,.4);border-radius:30px;
  background:rgba(6,30,22,.4);backdrop-filter:blur(4px);
}
.is-featured .pc-tag{color:#fff;border-color:rgba(255,255,255,.5);background:rgba(217,122,26,.5)}
.is-signature .pc-tag{color:var(--gold-2);border-color:rgba(201,163,91,.55);background:rgba(0,0,0,.35)}

/* Size — the hero element */
.pc-size{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;
  margin:8px 0;
}
.pc-size b{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:96px;line-height:.95;letter-spacing:-.04em;
  background:linear-gradient(120deg, var(--gold-2) 0%, var(--saffron-glow) 50%, var(--gold-deep) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  transition:transform .55s var(--ease-elastic);
  display:inline-block;
  padding-right:.12em;
  transform-origin:center;
}
.plot-card:hover .pc-size b{transform:scale(1.04)}
.pc-size span{
  font-size:11px;letter-spacing:.36em;text-transform:uppercase;
  color:rgba(245,239,230,.6);font-weight:600;
  margin-top:8px;
}

.pc-body{
  padding:28px 24px 24px;flex:1;display:flex;flex-direction:column;gap:22px;
  justify-content:space-between;
  color:var(--ink);
}
.pc-deco{
  display:flex;align-items:center;justify-content:center;gap:12px;
}
.pc-deco .pc-dot{
  width:6px;height:6px;border-radius:50%;background:var(--saffron);
  box-shadow:0 0 0 4px rgba(217,122,26,.12);
  flex-shrink:0;
}
.pc-deco .pc-line{
  flex:1;max-width:64px;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
}
.pc-deco .pc-mark-svg{
  width:14px;height:14px;color:var(--saffron);
  filter:drop-shadow(0 0 6px rgba(217,122,26,.35));
  transition:transform .7s var(--ease-out);
}
.plot-card:hover .pc-deco .pc-mark-svg{transform:rotate(180deg)}
.is-featured .pc-deco .pc-line{background:linear-gradient(90deg, transparent, var(--saffron), transparent)}
.is-signature .pc-deco .pc-mark-svg{color:var(--gold)}
.is-signature .pc-deco .pc-dot{background:var(--gold);box-shadow:0 0 0 4px rgba(201,163,91,.14)}
.is-signature .pc-deco .pc-line{background:linear-gradient(90deg, transparent, var(--gold), transparent)}
.pc-title{
  font-weight:600;font-size:18px;color:var(--ink);
  letter-spacing:-.01em;
}
.pc-rule{
  display:block;width:32px;height:2px;background:var(--saffron);
  margin:14px 0 18px;border-radius:2px;
}
.pc-feat{display:flex;flex-direction:column;gap:9px;margin-bottom:22px;flex:1}
.pc-feat li{
  display:flex;align-items:center;gap:10px;
  font-size:13px;color:var(--ink-2);line-height:1.4;
}
.pc-feat .check{
  width:18px;height:18px;border-radius:50%;background:rgba(217,122,26,.12);
  display:grid;place-items:center;flex-shrink:0;position:relative;
}
.pc-feat .check::after{
  content:"";width:8px;height:4px;border-left:1.5px solid var(--saffron-deep);border-bottom:1.5px solid var(--saffron-deep);
  transform:rotate(-45deg) translate(1px,-1px);
}

.pc-foot{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding-top:18px;border-top:1px dashed var(--line);
}
.pc-price{display:flex;flex-direction:column;gap:2px;min-width:0}
.pc-price small{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600}
.pc-price strong{
  font-weight:600;font-size:18px;color:var(--forest);
  display:flex;align-items:baseline;gap:3px;letter-spacing:-.01em;
}
.pc-price i{font-style:normal;font-size:11px;color:var(--saffron);font-weight:500;letter-spacing:.04em}

.pc-cta{
  flex-shrink:0;
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 18px 12px 20px;border-radius:60px;
  background:var(--forest);color:var(--ivory);
  border:0;cursor:pointer;font:inherit;
  position:relative;overflow:hidden;
  transition:box-shadow .4s var(--ease), transform .4s var(--ease);
}
.pc-cta::before{
  content:"";position:absolute;inset:0;background:linear-gradient(90deg, var(--saffron) 0%, var(--saffron-deep) 100%);
  transform:translateX(-101%);
  transition:transform .55s var(--ease-out);
}
.pc-cta:hover::before{transform:translateX(0)}
.pc-cta-label{
  position:relative;z-index:1;
  font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
}
.pc-cta svg{width:14px;height:14px;position:relative;z-index:1;transition:transform .4s}
.pc-cta:hover{box-shadow:0 14px 28px rgba(217,122,26,.35)}
.pc-cta:hover svg{transform:translateX(4px)}
.is-signature .pc-cta::before{background:linear-gradient(90deg, var(--gold) 0%, var(--gold-deep) 100%)}
.is-signature .pc-cta:hover{box-shadow:0 14px 28px rgba(201,163,91,.4)}

.is-featured{box-shadow:0 1px 0 rgba(255,255,255,.7) inset, 0 1px 2px rgba(0,0,0,.04), 0 30px 70px rgba(217,122,26,.25), 0 0 0 1px var(--saffron) inset}
.is-featured .pc-rule{background:var(--saffron);height:3px}
.is-signature{box-shadow:0 1px 0 rgba(255,255,255,.7) inset, 0 1px 2px rgba(0,0,0,.04), 0 30px 70px rgba(201,163,91,.25), 0 0 0 1px var(--gold) inset}
.is-signature .pc-rule{background:var(--gold);height:3px}

.plots-foot{text-align:center;margin-top:48px;color:rgba(245,239,230,.55);font-size:14px;font-weight:500}

/* ─── AMENITIES (INTERACTIVE SHOWCASE) ───────────────────── */
.amen{
  background:var(--ivory-2);
  position:relative;
}
.amen::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:140px;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold-2), transparent);
  opacity:.55;
}
.amen::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:120px;
  background:linear-gradient(180deg, transparent, rgba(6,30,22,.10));
  pointer-events:none;z-index:1;
}
.amen > .container{position:relative;z-index:2}
.amen-showcase{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);
  gap:18px;
  background:var(--paper);
  border-radius:20px;
  border:1px solid rgba(201,163,91,.3);
  padding:18px;
  box-shadow:0 1px 0 #fffdf5 inset, 0 30px 70px rgba(14,51,38,.1);
  position:relative;
}
.amen-showcase::before{
  content:"";position:absolute;inset:10px;border:1px solid rgba(201,163,91,.16);
  border-radius:12px;pointer-events:none;
}

/* Featured Panel */
.af{
  position:relative;display:flex;flex-direction:column;
  border-radius:12px;overflow:hidden;background:var(--forest-deep);
  min-height:560px;
}
.af-stage{position:relative;flex:1;overflow:hidden;min-height:340px}
.af-img{
  position:absolute;inset:0;
  background-image:var(--bg);background-size:cover;background-position:center;
  opacity:0;transform:scale(1.06);
  transition:opacity .9s var(--ease), transform 6s linear;
}
.af-img.is-on{opacity:1;transform:scale(1)}
.af-veil{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(6,30,22,.15) 0%, rgba(6,30,22,.05) 40%, rgba(6,30,22,.8) 100%);
}
.af-corner{position:absolute;width:24px;height:24px;border:1.5px solid var(--gold-2);z-index:2;pointer-events:none}
.af-corner.tl{top:18px;left:18px;border-right:0;border-bottom:0}
.af-corner.tr{top:18px;right:18px;border-left:0;border-bottom:0}
.af-corner.bl{bottom:18px;left:18px;border-right:0;border-top:0}
.af-corner.br{bottom:18px;right:18px;border-left:0;border-top:0}

.af-badge{
  position:absolute;top:32px;left:32px;z-index:3;
  display:inline-flex;align-items:center;gap:14px;
  padding:10px 18px;
  background:rgba(6,30,22,.55);backdrop-filter:blur(10px);
  border:1px solid rgba(245,239,230,.16);
  border-radius:60px;color:var(--ivory);
}
.af-no{font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;color:var(--gold-2)}
.af-bar{display:inline-block;width:14px;height:1px;background:rgba(245,239,230,.4)}
.af-cat{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(245,239,230,.85);font-weight:600}

.af-info{
  padding:32px 32px 28px;background:linear-gradient(180deg, var(--forest-deep) 0%, var(--forest) 100%);
  color:var(--ivory);position:relative;
}
.af-title{
  font-weight:300;font-size:34px;letter-spacing:-.02em;color:var(--ivory);
  margin-bottom:12px;line-height:1.1;
}
.af-desc{font-size:15px;line-height:1.7;color:rgba(245,239,230,.78);max-width:580px}
.af-progress{
  position:absolute;left:0;right:0;bottom:0;height:2px;
  background:rgba(245,239,230,.08);overflow:hidden;
}
.af-progress i{
  display:block;height:100%;width:0;
  background:linear-gradient(90deg, var(--saffron), var(--gold-2));
  transition:width 5s linear;
}

/* Tile Grid */
.amen-tiles{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  grid-template-rows:repeat(5,minmax(0,1fr));
  gap:8px;
}
.amen-tiles .at:nth-child(14){grid-column:span 2}
.at{
  position:relative;background:var(--ivory);
  border:1px solid rgba(201,163,91,.22);
  border-radius:10px;padding:18px 12px 14px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  text-align:center;cursor:pointer;
  transition:transform .4s var(--ease), border-color .35s, background .4s, color .35s, box-shadow .4s;
  min-height:0;overflow:hidden;isolation:isolate;
}
.at::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(160deg, var(--saffron) 0%, var(--saffron-deep) 100%);
  opacity:0;transition:opacity .4s var(--ease);
}
.at:hover{transform:translateY(-3px);border-color:var(--saffron-glow)}
.at.is-on{
  border-color:var(--saffron);color:#fff;
  box-shadow:0 14px 30px rgba(217,122,26,.35);
}
.at.is-on::before{opacity:1}

.at-no,.af-no,.af-bar{display:none}

.at-ico{
  width:38px;height:38px;display:grid;place-items:center;
  color:var(--saffron-deep);
  transition:transform .45s var(--ease-elastic), color .35s;
}
.at:hover .at-ico{transform:scale(1.1) rotate(-4deg)}
.at.is-on .at-ico{color:#fff;transform:scale(1.05)}
.at-ico svg{width:28px;height:28px}

.at-name{
  font-size:11px;font-weight:600;color:var(--ink-2);
  letter-spacing:.02em;line-height:1.25;
  transition:color .35s;
}
.at.is-on .at-name{color:#fff}

/* ─── MASTER PLAN ────────────────────────────────────────── */
.master{
  background:
    linear-gradient(180deg, rgba(250,246,236,.06) 0%, transparent 25%, transparent 75%, rgba(250,246,236,.06) 100%),
    var(--forest);
  color:var(--ivory);position:relative;overflow:hidden;
  padding:110px 0;
}
.master .section-head{margin-bottom:56px}
.master::before{
  content:"";position:absolute;inset:0;opacity:.55;
  background:
    radial-gradient(60% 50% at 100% 0%, rgba(201,163,91,.22), transparent 60%),
    radial-gradient(40% 40% at 0% 100%, rgba(217,122,26,.18), transparent 70%);
}
.master::after{
  content:"";position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:linear-gradient(rgba(201,163,91,.4) 1px, transparent 1px),
                   linear-gradient(90deg, rgba(201,163,91,.4) 1px, transparent 1px);
  background-size:60px 60px;
}
.master .container{position:relative;z-index:1}
.master-frame{
  position:relative;margin-top:40px;border-radius:14px;overflow:hidden;
  box-shadow:0 50px 120px rgba(0,0,0,.5), 0 0 0 1px rgba(201,163,91,.25) inset;
  transform:scale(.96);opacity:.7;transition:transform 1.2s var(--ease-out), opacity 1s;
  padding:4px;
  background:linear-gradient(135deg, rgba(201,163,91,.4), rgba(201,163,91,.05));
}
.master-frame.is-in{transform:scale(1);opacity:1}
.master-foot{
  text-align:center;margin-top:28px;
  color:rgba(245,239,230,.6);font-size:14px;line-height:1.6;font-weight:500;
  max-width:680px;margin-inline:auto;
  position:relative;z-index:2;
}
.master-frame img{
  width:100%;height:auto;display:block;border-radius:10px;
  transition:transform 1.6s var(--ease);
  object-fit:contain;
}
.master-frame:hover img{transform:scale(1.02)}
.master-corner{position:absolute;width:42px;height:42px;border:2px solid var(--gold-2);z-index:3;pointer-events:none}
.master-corner.tl{top:18px;left:18px;border-right:0;border-bottom:0}
.master-corner.tr{top:18px;right:18px;border-left:0;border-bottom:0}
.master-corner.bl{bottom:18px;left:18px;border-right:0;border-top:0}
.master-corner.br{bottom:18px;right:18px;border-left:0;border-top:0}
.master-overlay{position:absolute;inset:0;display:grid;place-items:end center;padding-bottom:36px;z-index:2}
.master-btn{
  display:inline-flex;align-items:center;gap:12px;padding:14px 24px;
  background:var(--saffron);color:#fff;border-radius:60px;
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  box-shadow:0 24px 50px rgba(217,122,26,.45);
  position:relative;overflow:hidden;transition:all .4s;
}
.master-btn::before{content:"";position:absolute;inset:0;background:var(--forest);transform:translateY(101%);transition:transform .55s var(--ease-out)}
.master-btn span,.master-btn svg{position:relative;z-index:1}
.master-btn:hover::before{transform:translateY(0)}
.master-btn svg{width:18px;height:18px}

.master-pin{position:absolute;display:flex;align-items:center;gap:10px;z-index:2;font-size:12px;color:var(--ivory);opacity:0;transition:opacity .8s var(--ease-out);font-weight:500}
.master-frame.is-in .master-pin{opacity:1}
.master-frame.is-in .pin-1{transition-delay:.6s}
.master-frame.is-in .pin-2{transition-delay:.8s}
.master-frame.is-in .pin-3{transition-delay:1s}
.master-frame.is-in .pin-4{transition-delay:1.2s}
.master-pin span{width:14px;height:14px;border-radius:50%;background:var(--saffron);position:relative}
.master-pin span::before{content:"";position:absolute;inset:-6px;border-radius:50%;border:1px solid var(--saffron);animation:pinPulse 2.4s ease-out infinite}
@keyframes pinPulse{0%{transform:scale(.5);opacity:1}100%{transform:scale(2);opacity:0}}
.master-pin b{padding:6px 12px;background:rgba(6,30,22,.7);border:1px solid rgba(201,163,91,.3);border-radius:30px;backdrop-filter:blur(8px);font-weight:500;font-size:11px;letter-spacing:.06em;color:var(--gold-2)}
.pin-1{top:25%;left:18%}.pin-2{top:60%;left:42%}.pin-3{top:78%;left:25%}.pin-4{top:30%;right:18%}

/* ─── LOCATION ───────────────────────────────────────────── */
.loc{background:var(--ivory)}
.loc-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.3fr);gap:50px;align-items:start}
.loc-cols{display:flex;flex-direction:column;gap:36px;min-width:0}
.loc-group{min-width:0}
.loc-subhead{
  display:flex;align-items:center;gap:14px;margin-bottom:8px;
  padding-bottom:14px;border-bottom:1px solid rgba(217,122,26,.22);
}
.ls-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg, var(--saffron) 0%, var(--saffron-deep) 100%);
  color:#fff;flex-shrink:0;
  font-family:var(--serif);font-style:italic;font-weight:400;font-size:15px;
  box-shadow:0 6px 14px rgba(217,122,26,.28), inset 0 0 0 1px rgba(255,255,255,.2);
}
.loc-subhead h4{
  font-weight:700;font-size:12px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--forest);line-height:1;
}
.loc-list{min-width:0}
.loc-list li{
  position:relative;display:grid;grid-template-columns:130px minmax(0,1fr);gap:18px;align-items:center;
  padding:20px 0;border-bottom:1px solid var(--line);
  transition:padding .5s var(--ease);
}
.loc-bar{position:absolute;left:0;top:50%;width:0;height:1px;background:var(--saffron);transform:translateY(-50%);transition:width .8s var(--ease-out)}
.loc-list li:hover{padding-left:20px}
.loc-list li:hover .loc-bar{width:12px}
.loc-list b{font-weight:300;font-size:32px;color:var(--forest);line-height:1;display:flex;align-items:baseline;gap:5px;letter-spacing:-.02em}
.loc-list b i{font-style:normal;font-size:13px;color:var(--saffron);font-weight:500}
.loc-place{font-size:14px;color:var(--ink-2);letter-spacing:.01em;font-weight:500}

.loc-map{
  position:relative;height:560px;border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-md);border:1px solid var(--line);
  align-self:center;
}
.loc-map iframe{width:100%;height:100%;border:0;filter:saturate(.92) contrast(1.03)}
.loc-pin{
  position:absolute;top:20px;left:20px;display:inline-flex;align-items:center;gap:10px;
  padding:11px 18px;background:rgba(255,253,245,.96);border-radius:60px;
  font-size:12px;letter-spacing:.04em;color:var(--forest);font-weight:700;
  box-shadow:0 10px 30px rgba(20,19,15,.18);
}
.pin-dot{width:10px;height:10px;border-radius:50%;background:var(--saffron);position:relative}
.pin-dot::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:1px solid var(--saffron);animation:pinPulse 2s ease-out infinite}
.loc-corner{position:absolute;width:28px;height:28px;border:1.5px solid var(--gold-2);pointer-events:none;z-index:1}
.loc-corner.tl{top:12px;left:12px;border-right:0;border-bottom:0}
.loc-corner.tr{top:12px;right:12px;border-left:0;border-bottom:0}
.loc-corner.bl{bottom:12px;left:12px;border-right:0;border-top:0}
.loc-corner.br{bottom:12px;right:12px;border-left:0;border-top:0}

/* ─── GALLERY (PREMIUM WITH FILTER) ──────────────────────── */
.gal{background:linear-gradient(180deg, var(--ivory) 0%, var(--ivory-2) 100%)}
.gal-head{
  display:grid;grid-template-columns:minmax(0,1fr) auto;gap:40px;align-items:end;
  margin-bottom:50px;
}
.gal-tabs{
  display:flex;gap:6px;flex-wrap:wrap;
  background:var(--paper);padding:6px;border-radius:60px;
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}
.gal-tab{
  position:relative;padding:11px 22px;border-radius:60px;
  font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);
  transition:color .35s, background .35s;display:inline-flex;align-items:center;gap:8px;
}
.gal-tab span{
  font-size:10px;padding:2px 8px;background:var(--ivory-2);
  border-radius:30px;color:var(--muted-2);font-weight:600;letter-spacing:.04em;
  transition:background .35s, color .35s;
}
.gal-tab:hover{color:var(--ink)}
.gal-tab.is-on{background:var(--forest);color:var(--ivory);box-shadow:0 8px 22px rgba(14,51,38,.25)}
.gal-tab.is-on span{background:var(--saffron);color:#fff}

.gal-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  grid-auto-rows:260px;gap:14px;
  grid-auto-flow:dense;
}
.gal-it{
  position:relative;overflow:hidden;border-radius:14px;cursor:pointer;background:var(--forest-deep);
  opacity:0;transform:translateY(30px) scale(.97);
  transition:opacity .8s var(--ease-out), transform .8s var(--ease-out), box-shadow .5s;
  min-width:0;
}
.gal-it.is-in{opacity:1;transform:translateY(0) scale(1)}
.gal-it:hover{box-shadow:0 30px 60px rgba(14,51,38,.25)}
.gal-it.is-hidden{opacity:0;transform:scale(.85);pointer-events:none;width:0;height:0;padding:0;margin:0;grid-column:span 0;grid-row:span 0;border:0;overflow:hidden;position:absolute;visibility:hidden}
.gal-it img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.6s var(--ease), filter 1s;
  filter:saturate(.92);
}
.gal-tall{grid-row:span 2}
.gal-lg{grid-column:span 2;grid-row:span 2}

.gal-it::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 40%, rgba(6,30,22,.85) 100%);
  opacity:0;transition:opacity .5s;
}
.gal-overlay{
  position:absolute;inset:0;padding:24px;z-index:3;
  display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;
  color:var(--ivory);transform:translateY(20px);opacity:0;
  transition:transform .6s var(--ease-out), opacity .5s;
}
.gal-cat{
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--saffron-glow);font-weight:700;
  padding:5px 11px;background:rgba(6,30,22,.5);
  border:1px solid rgba(245,184,120,.3);border-radius:30px;
  margin-bottom:14px;backdrop-filter:blur(6px);
}
.gal-overlay h4{font-weight:600;font-size:22px;letter-spacing:-.01em;margin-bottom:6px}
.gal-no{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--gold-2);font-weight:400}

.gal-corner{
  position:absolute;width:22px;height:22px;border:1.5px solid var(--gold-2);
  opacity:0;transition:opacity .5s, transform .5s var(--ease-out);z-index:4;
}
.gal-corner.tl{top:14px;left:14px;border-right:0;border-bottom:0;transform:translate(-8px,-8px)}
.gal-corner.br{bottom:14px;right:14px;border-left:0;border-top:0;transform:translate(8px,8px)}

.gal-it:hover img{transform:scale(1.1);filter:saturate(1.08)}
.gal-it:hover::after{opacity:1}
.gal-it:hover .gal-overlay{opacity:1;transform:translateY(0)}
.gal-it:hover .gal-corner{opacity:1;transform:translate(0,0)}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:1100;
  background:rgba(6,30,22,.96);backdrop-filter:blur(8px);
  display:none;flex-direction:column;
  padding:32px;
}
.lightbox.is-on{display:flex;animation:fadeIn .5s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.lb-stage{flex:1;display:grid;place-items:center;min-height:0}
.lb-stage img{max-width:90%;max-height:80vh;object-fit:contain;border-radius:8px;box-shadow:0 40px 100px rgba(0,0,0,.5);animation:zoomIn .55s var(--ease-out)}
@keyframes zoomIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
.lb-x,.lb-prev,.lb-next{
  position:absolute;width:54px;height:54px;border-radius:50%;
  background:rgba(255,253,245,.1);color:var(--ivory);
  border:1px solid rgba(255,253,245,.18);
  display:grid;place-items:center;transition:all .35s;
  z-index:2;
}
.lb-x svg,.lb-prev svg,.lb-next svg{width:20px;height:20px}
.lb-x{top:24px;right:24px}
.lb-prev{top:50%;left:32px;transform:translateY(-50%)}
.lb-next{top:50%;right:32px;transform:translateY(-50%)}
.lb-x:hover,.lb-prev:hover,.lb-next:hover{background:var(--saffron);border-color:var(--saffron)}
.lb-prev:hover{transform:translateY(-50%) translateX(-4px)}
.lb-next:hover{transform:translateY(-50%) translateX(4px)}

.lb-info{
  display:flex;justify-content:space-between;align-items:center;
  color:var(--ivory);padding:0 32px;margin-top:18px;
}
.lb-counter{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2);font-weight:600}
.lb-counter b{color:var(--saffron-glow);font-weight:700}
.lb-counter i{font-style:normal;color:rgba(245,239,230,.5)}
.lb-info h5{font-family:var(--serif);font-style:italic;font-weight:400;font-size:22px;color:var(--ivory)}

/* ─── FILMS / VIDEO SHOWCASE ─────────────────────────────── */
.films{
  position:relative;padding:80px 0 70px;overflow:hidden;
  background:linear-gradient(180deg, var(--forest-deep) 0%, var(--forest) 55%, var(--forest-deep) 100%);
  color:var(--ivory);
}
.films-bg{
  position:absolute;inset:0;pointer-events:none;opacity:.55;
  background:
    radial-gradient(60% 50% at 15% 20%, rgba(217,122,26,.16), transparent 60%),
    radial-gradient(50% 40% at 85% 80%, rgba(201,163,91,.12), transparent 60%);
}
.films .section-head{position:relative;z-index:1;margin-bottom:36px}
.films-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.6fr 1fr;grid-auto-rows:1fr;
  gap:16px;
  max-width:1080px;margin:0 auto;
}
.film{
  position:relative;border-radius:6px;overflow:hidden;
  background:#0c0b09;cursor:pointer;
  box-shadow:0 20px 40px -22px rgba(0,0,0,.55);
  transition:transform .45s var(--ease-out), box-shadow .45s var(--ease-out);
  aspect-ratio:16/10;
}
.film-short{
  grid-column:2;grid-row:1 / span 2;
  aspect-ratio:auto;
}
.film:hover{transform:translateY(-4px);box-shadow:0 38px 80px -28px rgba(217,122,26,.35)}
.film-poster{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  display:block;background:#0c0b09;
  transition:transform 1.2s var(--ease-out), filter .6s var(--ease);
}
.film:hover .film-poster{transform:scale(1.04);filter:brightness(1.05)}
.film-short .film-poster{object-position:center}

/* Inline YouTube embed (replaces poster on click) */
.film-iframe{
  position:absolute;inset:0;width:100%;height:100%;border:0;z-index:3;
  background:#000;
}
.film.is-playing{cursor:default}
.film.is-playing .film-poster,
.film.is-playing .film-overlay{opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
.film.is-playing:hover .film-poster{transform:none;filter:none}

.film-overlay{
  position:absolute;inset:0;z-index:2;
  display:flex;align-items:flex-end;justify-content:flex-start;
  padding:28px;
  background:
    linear-gradient(180deg, rgba(0,0,0,.1) 0%, rgba(0,0,0,0) 35%, rgba(0,0,0,.55) 75%, rgba(0,0,0,.85) 100%);
  transition:opacity .35s var(--ease);
}
.film.is-playing .film-overlay{opacity:0;pointer-events:none}

.film-corner{
  position:absolute;width:22px;height:22px;
  border:1.5px solid var(--gold-2);opacity:.7;
  transition:all .5s var(--ease-out);
}
.film-corner.tl{top:14px;left:14px;border-right:none;border-bottom:none}
.film-corner.tr{top:14px;right:14px;border-left:none;border-bottom:none}
.film-corner.bl{bottom:14px;left:14px;border-right:none;border-top:none}
.film-corner.br{bottom:14px;right:14px;border-left:none;border-top:none}
.film:hover .film-corner{width:30px;height:30px;opacity:1;border-color:var(--saffron-glow)}

.film-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:64px;height:64px;border-radius:50%;
  background:linear-gradient(135deg, var(--saffron) 0%, var(--gold-deep) 100%);
  color:#fff;border:none;cursor:pointer;display:grid;place-items:center;
  box-shadow:0 10px 28px -6px rgba(217,122,26,.55);
  transition:transform .45s var(--ease-elastic), box-shadow .45s var(--ease);
}
.film-short .film-play{width:74px;height:74px}
.film-play svg{width:26px;height:26px;margin-left:4px;position:relative;z-index:2;filter:drop-shadow(0 1px 2px rgba(0,0,0,.25))}
.film-short .film-play svg{width:30px;height:30px;margin-left:5px}
.film-play-ring,.film-play-ring-2{
  position:absolute;inset:-10px;border-radius:50%;
  border:1.5px solid rgba(245,184,120,.4);
  animation:filmRing 2.6s ease-out infinite;
}
.film-play-ring-2{animation-delay:1.3s}
@keyframes filmRing{
  0%{transform:scale(.9);opacity:.7}
  100%{transform:scale(1.45);opacity:0}
}
.film:hover .film-play{transform:translate(-50%,-50%) scale(1.08);box-shadow:0 20px 50px -8px rgba(217,122,26,.85)}
.film-play:focus-visible{outline:2px solid var(--gold-2);outline-offset:6px}

.film-cap{
  position:relative;z-index:1;color:var(--ivory);max-width:80%;
}
.film-cap .film-tag{
  display:inline-block;font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-2);font-weight:600;margin-bottom:10px;
  padding:5px 11px;border:1px solid rgba(230,201,138,.4);border-radius:60px;
  background:rgba(20,19,15,.4);backdrop-filter:blur(6px);
}
.film-cap h3{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:24px;line-height:1.1;letter-spacing:-.01em;color:var(--ivory);
  margin-bottom:4px;
}
.film-cap p{
  font-size:13px;color:rgba(245,239,230,.78);line-height:1.55;max-width:380px;margin-top:3px;
}
.film-dur{
  position:absolute;top:14px;right:14px;
  font-size:11px;letter-spacing:.18em;font-weight:600;
  color:var(--ivory);background:rgba(0,0,0,.55);backdrop-filter:blur(6px);
  padding:5px 10px;border-radius:4px;border:1px solid rgba(245,239,230,.12);
}

@media (max-width:960px){
  .films{padding:64px 0 56px}
  .films .section-head{margin-bottom:24px;padding:0 var(--pad)}

  /* Magazine grid: 1 featured (full-width) + 2 thumbnails side-by-side */
  .films-grid{
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto auto;
    gap:10px;
    padding:0 var(--pad);
    max-width:none;
  }
  .film{aspect-ratio:16/10;border-radius:6px}
  /* First film = featured, spans both columns */
  .films-grid > .film:nth-child(1){
    grid-column:1 / span 2;
    aspect-ratio:16/10;
  }
  /* Second film = bottom-left thumbnail */
  .films-grid > .film:nth-child(2){
    grid-column:1;grid-row:2;
    aspect-ratio:4/5;
  }
  /* Short = bottom-right thumbnail */
  .film-short{
    grid-column:2;grid-row:2;
    aspect-ratio:4/5;
    max-width:none;margin:0;
  }

  /* Quiet overlay — let the YouTube thumbnail breathe */
  .film-overlay{
    padding:10px;
    background:linear-gradient(180deg, rgba(0,0,0,.35) 0%, rgba(0,0,0,0) 30%, rgba(0,0,0,0) 65%, rgba(0,0,0,.4) 100%);
    align-items:flex-start;
  }
  .film-corner{width:10px;height:10px;opacity:.5}
  .film-corner.tl,.film-corner.tr{top:6px}
  .film-corner.bl,.film-corner.br{bottom:6px}
  .film-corner.tl,.film-corner.bl{left:6px}
  .film-corner.tr,.film-corner.br{right:6px}

  /* Play buttons — featured gets the larger one */
  .film-play{width:44px;height:44px}
  .films-grid > .film:nth-child(1) .film-play{width:60px;height:60px}
  .film-play svg{width:18px;height:18px;margin-left:3px}
  .films-grid > .film:nth-child(1) .film-play svg{width:24px;height:24px;margin-left:4px}
  .film-play-ring-2{display:none}

  /* Tag pill — small, top-left */
  .film-cap{position:absolute;top:10px;left:10px;max-width:none}
  .film-cap .film-tag{
    font-size:8.5px;letter-spacing:.2em;padding:3px 7px;margin:0;
    background:rgba(20,19,15,.7);backdrop-filter:blur(4px);
  }
  .film-cap h3,
  .film-cap p{display:none}
}

@media (max-width:480px){
  .films{padding:48px 0 40px}
  .films-grid{gap:8px}
  .films-grid > .film:nth-child(1) .film-play{width:54px;height:54px}
  .films-grid > .film:nth-child(1) .film-play svg{width:22px;height:22px}
}

/* ─── TESTIMONIAL ────────────────────────────────────────── */
.testi{background:var(--cream);position:relative;overflow:hidden;padding:110px 0}
.testi::before,.testi::after{
  content:"";position:absolute;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(50% 50% at 50% 50%, rgba(217,122,26,.06), transparent 70%);
  pointer-events:none;
}
.testi::before{top:-180px;left:-180px}
.testi::after{bottom:-180px;right:-180px;background:radial-gradient(50% 50% at 50% 50%, rgba(14,51,38,.05), transparent 70%)}
.testi-head{
  position:relative;text-align:center;max-width:760px;
  margin:0 auto 56px;padding:0 var(--pad);
}
.testi-head .kicker{justify-content:center;margin-bottom:18px}
.testi-head .display{margin-bottom:0}
.testi-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
  padding:0 var(--pad);
  max-width:var(--container);margin:0 auto;
}
.testi-card{
  position:relative;
  background:var(--paper);
  border:1px solid rgba(201,163,91,.25);
  border-radius:16px;
  padding:30px 26px 26px;
  box-shadow:0 1px 0 rgba(255,255,255,.7) inset, 0 18px 40px rgba(20,19,15,.06);
  transition:transform .55s var(--ease-out), box-shadow .55s, border-color .35s;
  display:flex;flex-direction:column;
}
.testi-card:hover{
  transform:translateY(-6px);
  box-shadow:0 1px 0 rgba(255,255,255,.7) inset, 0 30px 60px rgba(14,51,38,.14);
  border-color:rgba(217,122,26,.45);
}
.testi-card .quote-mark{width:36px;height:36px;color:var(--saffron);margin:0 0 16px;opacity:.55;flex-shrink:0}
.testi-quote{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:17px;line-height:1.55;color:var(--ink);letter-spacing:-.005em;
  flex:1;
}
.testi-author{margin-top:22px;display:flex;flex-direction:column;align-items:flex-start;gap:10px}
.testi-divider{width:36px;height:1px;background:var(--saffron)}
.testi-author p{display:flex;flex-direction:column;gap:4px}
.testi-author b{font-weight:700;font-size:15px;color:var(--forest);letter-spacing:.01em}
.testi-author span{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600}

/* ─── PRESS ──────────────────────────────────────────────── */
.press{background:var(--ivory)}
.press-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  grid-auto-rows:210px;
  gap:18px;
  grid-auto-flow:dense;
}
.press-card{
  position:relative;border-radius:14px;overflow:visible;cursor:pointer;
  padding:5px;
  background:linear-gradient(135deg, rgba(201,163,91,.45) 0%, rgba(201,163,91,.08) 55%, rgba(201,163,91,.3) 100%);
  box-shadow:0 14px 30px rgba(20,19,15,.08), 0 2px 6px rgba(20,19,15,.04);
  transition:transform .55s var(--ease-out), box-shadow .55s;
  min-width:0;
}
.press-card.press-lg{grid-column:span 2;grid-row:span 2}
.press-card:hover{transform:translateY(-8px) rotate(.3deg);box-shadow:0 36px 70px rgba(14,51,38,.22)}
.press-card.press-lg:hover{transform:translateY(-10px) rotate(-.3deg)}

/* Index sticker — premium gold seal */
.press-num{
  position:absolute;top:-12px;left:-12px;z-index:5;
  width:46px;height:46px;border-radius:50%;
  display:grid;place-items:center;
  background:linear-gradient(160deg, var(--ivory) 0%, var(--cream) 100%);
  color:var(--forest);font-weight:700;font-size:14px;letter-spacing:.05em;
  border:1.5px solid var(--gold-2);
  box-shadow:0 8px 18px rgba(0,0,0,.18), 0 0 0 4px var(--paper);
  transition:transform .5s var(--ease-elastic), background .35s, color .35s;
}
.press-lg .press-num{
  width:56px;height:56px;font-size:17px;
  background:linear-gradient(160deg, var(--saffron) 0%, var(--saffron-deep) 100%);
  color:#fff;border-color:var(--gold-2);
}
.press-card:hover .press-num{transform:scale(1.08) rotate(-6deg)}

.press-img{
  position:relative;overflow:hidden;border-radius:10px;
  background:var(--ivory-2);width:100%;height:100%;
}
.press-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.6s var(--ease), filter 1s;
  filter:saturate(.96);
}
.press-card:hover .press-img img{transform:scale(1.08);filter:saturate(1.08)}

.press-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 55%, rgba(6,30,22,.55) 100%);
  opacity:0;transition:opacity .5s;
}
.press-card:hover .press-img::after{opacity:1}

/* Corner brackets */
.press-corner{
  position:absolute;width:22px;height:22px;border:1.5px solid var(--gold-2);z-index:3;
  opacity:0;transition:opacity .5s, transform .55s var(--ease-out);
}
.press-corner.tl{top:14px;left:14px;border-right:0;border-bottom:0;transform:translate(-10px,-10px)}
.press-corner.br{bottom:14px;right:14px;border-left:0;border-top:0;transform:translate(10px,10px)}
.press-card:hover .press-corner{opacity:1;transform:translate(0,0)}

/* Zoom icon on hover */
.press-zoom{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.6);
  width:56px;height:56px;border-radius:50%;
  background:rgba(217,122,26,.95);color:#fff;
  display:grid;place-items:center;z-index:3;
  opacity:0;pointer-events:none;
  box-shadow:0 14px 32px rgba(217,122,26,.5);
  transition:opacity .4s, transform .55s var(--ease-out);
}
.press-zoom svg{width:22px;height:22px}
.press-card:hover .press-zoom{opacity:1;transform:translate(-50%,-50%) scale(1)}

/* ─── CONTACT ────────────────────────────────────────────── */
.contact{background:var(--forest);color:var(--ivory);position:relative;overflow:hidden}
.contact::before{
  content:"";position:absolute;inset:0;opacity:.5;
  background:
    radial-gradient(50% 50% at 100% 0%, rgba(217,122,26,.2), transparent 60%),
    radial-gradient(50% 60% at 0% 100%, rgba(201,163,91,.15), transparent 70%);
}
.contact .container{position:relative;z-index:1}
.contact-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:60px;align-items:start}

.contact-info{display:flex;flex-direction:column;gap:0;margin-top:36px;border-top:1px solid rgba(245,239,230,.12)}
.contact-info li{display:grid;grid-template-columns:auto minmax(0,1fr);gap:18px;align-items:flex-start;padding:22px 0;border-bottom:1px solid rgba(245,239,230,.12)}
.ci-icon{width:46px;height:46px;display:grid;place-items:center;border-radius:50%;border:1px solid rgba(201,163,91,.3);color:var(--gold-2);flex-shrink:0}
.ci-icon svg{width:20px;height:20px}
.contact-info small{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(245,239,230,.55);display:block;margin-bottom:6px;font-weight:600}
.contact-info b{font-weight:500;font-size:16px;color:var(--ivory);line-height:1.5;letter-spacing:-.01em}
.contact-info b a{transition:color .3s}
.contact-info b a:hover{color:var(--saffron-glow)}

.atomoney{margin-top:32px;padding:24px;background:rgba(255,255,255,.04);border-radius:12px;border:1px solid rgba(245,239,230,.08)}
.atomoney h5{font-weight:600;font-size:16px;color:var(--gold-2);margin-bottom:8px;letter-spacing:.01em}
.atomoney p{font-size:14px;color:rgba(245,239,230,.72);line-height:1.7}

/* Form */
.contact-form{
  background:var(--paper);color:var(--ink);
  padding:44px 38px;border-radius:20px;
  box-shadow:var(--shadow-lg);
  border:1px solid rgba(201,163,91,.28);
  position:relative;align-self:center;
}
.contact-form::before{
  content:"";position:absolute;inset:10px;border:1px solid rgba(201,163,91,.16);
  border-radius:12px;pointer-events:none;
}

.cf-head{
  position:relative;margin-bottom:30px;padding-bottom:22px;
  border-bottom:1px solid var(--line);
}
.cf-pip{
  display:inline-block;width:32px;height:2px;background:var(--saffron);
  margin-bottom:14px;border-radius:2px;
}
.cf-head h3{font-weight:600;font-size:26px;color:var(--forest);letter-spacing:-.015em;margin-bottom:8px;line-height:1.2}
.cf-head p{font-size:14px;color:var(--muted);line-height:1.55}

.cf-body{display:flex;flex-direction:column;gap:18px;margin-bottom:24px}

.contact-form label,.modal-form label{
  display:flex;flex-direction:column;gap:8px;margin-bottom:0;
  position:relative;
}
.modal-form label{margin-bottom:14px}
.contact-form label span,.modal-form label span{
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:700;
  display:flex;align-items:baseline;gap:8px;
}
.contact-form label span em,.modal-form label span em{
  font-style:italic;text-transform:none;letter-spacing:.04em;color:var(--muted-2);font-weight:500;font-size:11px;
}

.contact-form input,.contact-form select,.contact-form textarea,
.modal-form input,.modal-form select{
  padding:14px 16px;background:var(--ivory);border:1px solid var(--line);
  border-radius:8px;font-size:14px;color:var(--ink);font-weight:500;
  transition:border-color .3s, background .3s, box-shadow .3s;
  width:100%;font-family:inherit;
}
.contact-form input::placeholder,.contact-form textarea::placeholder,
.modal-form input::placeholder{color:var(--muted-2);font-weight:400}
.contact-form input:hover,.contact-form select:hover,.contact-form textarea:hover,
.modal-form input:hover,.modal-form select:hover{border-color:var(--line-2);background:var(--paper)}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus,
.modal-form input:focus,.modal-form select:focus{
  border-color:var(--saffron);background:var(--paper);
  box-shadow:0 0 0 4px rgba(217,122,26,.1);
}
.contact-form textarea{resize:vertical;min-height:90px;line-height:1.5}

/* Custom select */
.cf-select{position:relative}
.cf-select select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:42px;cursor:pointer}
.cf-select::after{
  content:"";position:absolute;right:18px;bottom:18px;
  width:8px;height:8px;border-right:1.5px solid var(--saffron);border-bottom:1.5px solid var(--saffron);
  transform:rotate(45deg);pointer-events:none;transition:transform .3s;
}
.cf-select:focus-within::after{transform:rotate(225deg) translate(2px,2px)}

.cf-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px}

.cf-submit{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:12px;
  padding:17px 24px;background:var(--forest);color:var(--ivory);
  border-radius:60px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;
  overflow:hidden;transition:color .4s, box-shadow .4s, transform .4s;width:100%;
  box-shadow:0 8px 24px rgba(14,51,38,.18);
}
.cf-submit-fill{
  position:absolute;inset:0;
  background:linear-gradient(120deg, var(--saffron) 0%, var(--saffron-deep) 100%);
  transform:translateX(-101%);transition:transform .55s var(--ease-out);
}
.cf-submit:hover{box-shadow:0 16px 36px rgba(217,122,26,.32)}
.cf-submit:hover .cf-submit-fill{transform:translateX(0)}
.cf-submit-label,.cf-submit svg{position:relative;z-index:1}
.cf-submit svg{width:16px;height:16px;transition:transform .4s}
.cf-submit:hover svg{transform:translateX(4px)}

.cf-foot{
  margin-top:14px;font-size:11px;color:var(--muted);text-align:center;
  letter-spacing:.02em;line-height:1.55;font-weight:500;
}
.cf-success{
  padding:14px;background:rgba(14,51,38,.06);color:var(--forest);border-radius:8px;
  text-align:center;font-size:13px;font-weight:600;margin-top:12px;
  border:1px dashed rgba(14,51,38,.35);
}

/* ─── FOOTER ─────────────────────────────────────────────── */
.ft{background:#06180f;color:rgba(245,239,230,.7);padding:96px 0 28px;position:relative;overflow:hidden}
.ft::before{content:"";position:absolute;inset:0;opacity:.5;background:
  radial-gradient(45% 60% at 50% 0%, rgba(201,163,91,.12), transparent 70%),
  radial-gradient(30% 40% at 100% 100%, rgba(217,122,26,.08), transparent 70%);
}
.ft::after{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(201,163,91,.5), transparent);
}
.ft .container{position:relative;z-index:1}
.ft-top{display:flex;justify-content:space-between;align-items:flex-start;gap:50px;padding-bottom:50px;border-bottom:1px solid rgba(245,239,230,.08);margin-bottom:54px;flex-wrap:wrap}
.ft-brand{display:flex;align-items:center;gap:14px;color:var(--ivory)}
.ft-blurb{max-width:480px;font-size:15px;line-height:1.65;color:rgba(245,239,230,.55);text-align:right;font-weight:400;font-style:italic;font-family:var(--serif)}
.ft-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:36px;margin-bottom:48px}
.ft h6{font-weight:700;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-2);margin-bottom:22px;position:relative;padding-bottom:14px}
.ft h6::after{content:"";position:absolute;bottom:0;left:0;width:24px;height:1px;background:var(--saffron)}
.ft .ft-grid div a{display:block;padding:7px 0;font-size:14px;color:rgba(245,239,230,.65);transition:color .3s, transform .3s, padding .3s;font-weight:500;position:relative}
.ft .ft-grid div a::before{
  content:"";position:absolute;left:0;top:50%;width:0;height:1px;
  background:var(--saffron);transform:translateY(-50%);transition:width .4s var(--ease-out);
}
.ft .ft-grid div a:hover{color:var(--saffron-glow);padding-left:16px}
.ft .ft-grid div a:hover::before{width:10px}
.ft div p{font-size:14px;line-height:1.7;color:rgba(245,239,230,.55)}
.socials{display:flex;gap:18px;margin-top:18px}
.socials a{
  display:inline-grid;place-items:center;
  color:rgba(245,239,230,.55);
  transition:color .3s, transform .3s;
  padding:0!important;
}
.socials a svg{width:20px;height:20px;transition:transform .35s var(--ease-elastic)}
.socials a:hover{color:var(--saffron-glow);transform:translateY(-3px)!important}
.socials a:hover svg{transform:scale(1.15)}

.ft-disclaimer{
  margin-top:40px;padding:22px 0 20px;
  border-top:1px solid rgba(245,239,230,.08);
}
.ft-disclaimer h6{
  font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(245,239,230,.55);font-weight:600;margin-bottom:10px;
}
.ft-disclaimer p{
  font-size:12px;line-height:1.7;
  color:rgba(245,239,230,.42);
  max-width:none;
}

.ft-base{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding-top:22px;border-top:1px solid rgba(245,239,230,.08);font-size:12px;color:rgba(245,239,230,.4);gap:16px;flex-wrap:wrap}
.ft-base small{display:inline}
.ft-base small a{display:inline-block;transition:color .3s;color:inherit;font-weight:500;padding:0 2px}
.ft-base small a:hover{color:var(--saffron-glow)}

/* ─── FAB ────────────────────────────────────────────────── */
.fab{position:fixed;right:22px;bottom:22px;z-index:600;display:flex;flex-direction:column;gap:12px}
.fab-btn{
  width:50px;height:50px;border-radius:50%;display:grid;place-items:center;
  color:#fff;box-shadow:0 12px 30px rgba(0,0,0,.25);position:relative;
  transition:transform .35s var(--ease-elastic), box-shadow .3s;
}
.fab-btn svg{width:20px;height:20px}
.fab-call{background:var(--saffron)}
.fab-call::after{content:"";position:absolute;inset:-2px;border-radius:50%;border:1.5px solid var(--saffron);animation:fabPulse 2.2s ease-out infinite}
@keyframes fabPulse{0%{transform:scale(1);opacity:1}100%{transform:scale(1.6);opacity:0}}
.fab-wa{background:#25d366}
.fab-up{background:var(--forest);opacity:0;pointer-events:none;transform:translateY(20px);transition:opacity .4s, transform .4s}
.fab-up.is-on{opacity:1;pointer-events:auto;transform:translateY(0)}
.fab-btn:hover{transform:translateY(-4px) scale(1.06)}

/* ─── MODAL ──────────────────────────────────────────────── */
.modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.modal.is-on{display:flex}
.modal-back{position:absolute;inset:0;background:rgba(6,30,22,.75);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:fadeIn .4s}
.modal-card{
  position:relative;background:var(--paper);border-radius:16px;
  width:100%;max-width:440px;overflow:hidden;
  box-shadow:0 50px 130px rgba(0,0,0,.5);
  animation:modalIn .6s var(--ease-out);
  border:1px solid rgba(201,163,91,.3);
}
.modal-card::before{content:"";position:absolute;inset:8px;border:1px solid rgba(201,163,91,.18);border-radius:10px;pointer-events:none}
@keyframes modalIn{from{opacity:0;transform:translateY(40px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.modal-x{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:rgba(20,19,15,.06);color:var(--ink);z-index:2;display:grid;place-items:center;transition:background .3s, transform .3s}
.modal-x svg{width:14px;height:14px}
.modal-x:hover{background:var(--saffron);color:#fff;transform:rotate(90deg)}
.modal-head{padding:28px 30px 18px;text-align:center;border-bottom:1px solid var(--line)}
.modal-mark{display:inline-block;width:32px;height:1px;background:var(--saffron);margin-bottom:14px}
.modal-head h3{font-weight:600;font-size:26px;color:var(--forest);letter-spacing:-.01em}
.modal-head p{font-size:13px;color:var(--muted);margin-top:6px}
.modal-form{padding:22px 30px 28px}

/* ─── Responsive ─────────────────────────────────────────── */
@media (max-width:1380px){
  .hdr-call-text{display:none}
  .hdr-call{padding:7px;border-radius:50%}
}
@media (max-width:1180px){
  .hdr{padding:14px var(--pad)}
  .hdr.is-scrolled{padding:10px var(--pad)}
  .hdr-nav{display:none}
  .hdr-burger{display:flex;width:42px;height:42px;border-radius:12px}
  .hdr-inner{display:flex;justify-content:space-between;align-items:center;gap:14px}
  .hdr-call,.hdr-cta{display:none}
  .logo-img{height:40px}
  .logo-img-ft{height:52px}
  .hero-content{grid-template-columns:1fr;gap:40px;padding-top:130px;padding-bottom:60px}
  .hero-plaque{max-width:480px;margin:0 auto;width:100%}
  .chapter-grid,.contact-grid,.loc-grid,.why-head{grid-template-columns:1fr;gap:36px}
  .chapter-media{grid-template-columns:1fr 1fr;gap:14px}
  .chapter-media figure{height:300px}
  .media-a{grid-column:span 2;height:340px}
  .media-b,.media-c{grid-column:auto}
  .why-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
  .plot-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .press-grid{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:200px;gap:18px}
  .press-card.press-lg{grid-column:span 2}
  .amen-showcase{grid-template-columns:1fr;gap:14px}
  .af{min-height:auto}
  .af-stage{min-height:300px;height:380px}
  .amen-tiles{grid-template-columns:repeat(4,minmax(0,1fr));grid-template-rows:repeat(4,1fr)}
  .amen-tiles .at:nth-child(14){grid-column:span 3}
  .at{padding:18px 10px 12px;min-height:90px}
  .ft-top{flex-direction:column;align-items:flex-start;gap:24px}
  .ft-blurb{text-align:left}
  .ft-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .section-head.split{grid-template-columns:1fr;gap:24px}
  .gal-head{grid-template-columns:1fr;gap:30px}
  .gal-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .gal-lg{grid-column:span 2}
  .testi-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
}
.mobile-only{display:none}
@media (max-width:760px){
  :root{--pad:18px}
  section{padding:64px 0}
  .mobile-only{display:flex}

  /* Section heads — tighter */
  .section-head{margin-bottom:36px}
  .display{font-size:clamp(28px,7.5vw,42px)}
  .lede{font-size:15px}
  .kicker{font-size:10px;letter-spacing:.24em;margin-bottom:18px}

  /* Header */
  .hdr{padding:12px var(--pad)}
  .hdr.is-scrolled{padding:8px var(--pad)}
  .hdr-inner{gap:14px}
  .hdr-burger{width:38px;height:38px}
  .logo-img{height:36px}

  /* Hero — refined for small screens */
  .hero-content{padding:110px var(--pad) 48px;gap:30px}
  .hero-eyebrow{font-size:10px;letter-spacing:.28em;margin-bottom:22px;gap:10px}
  .hero-eyebrow .rule{width:24px}
  .hero-title{font-size:clamp(46px,12vw,76px);font-weight:400}
  .hero-deck{font-size:15px;margin-top:22px;max-width:none;line-height:1.55}
  .hero-cta{gap:10px;margin-top:28px}
  .btn-gold,.btn-line{padding:14px 22px;font-size:12px;letter-spacing:.1em}
  .btn-gold .btn-arrow{width:28px;height:28px}
  .hero-stats{gap:14px;margin-top:24px}
  .hero-foot{grid-template-columns:1fr;gap:12px;text-align:center;padding:18px var(--pad)}
  .hero-side-mark,.hero-meta{justify-self:center;justify-content:center}
  .scroll-mark{display:none}
  .hero-plaque{padding:24px 20px;border-radius:14px}
  .plaque-stamp{width:112px;height:112px;top:-12px;right:-6px;padding:6px}
  .plaque-stamp .ps-top,.plaque-stamp .ps-bot{font-size:10.5px;letter-spacing:.12em}
  .plaque-stamp .ps-sub{font-size:8px;margin-top:3px;padding-top:3px;letter-spacing:.08em}
  .plaque-stamp .ps-icon{width:20px;height:20px}
  .plaque-head{margin-bottom:16px;font-size:10px;letter-spacing:.2em}
  .plaque-price strong{font-size:40px}
  .plaque-price strong i{font-size:14px}
  .plaque-corner{width:14px;height:14px;top:12px;left:12px}
  .plaque-corner.tr{left:auto;right:12px}
  .plaque-corner.bl{top:auto;bottom:12px}
  .plaque-corner.br{top:auto;bottom:12px;left:auto;right:12px}
  .plaque-divider{margin:18px 0 14px}
  .plaque-divider .pd-line{max-width:60px}
  .plaque-sizes{padding:12px 0 14px;margin-bottom:14px}
  .plaque-sizes .ps-head{margin-bottom:10px;gap:7px}
  .plaque-sizes .ps-label{font-size:9px;letter-spacing:.14em}
  .ps-pills{gap:5px}
  .ps-pill{padding:5px 9px;font-size:12.5px}
  .ps-unit{font-size:10px}
  .plaque-stats{margin:0 0 18px;padding-bottom:18px}
  .plaque-stats li{padding:0 10px}
  .ps-ico{width:22px;height:22px;border-radius:6px;margin-bottom:8px}
  .ps-ico svg{width:12px;height:12px}
  .plaque-stats b{font-size:24px}
  .plaque-stats span{font-size:9px;letter-spacing:.12em}
  .plaque-stats i{font-size:12px}

  /* Strip marquee */
  .strip{padding:22px 0}
  .strip-track{gap:30px;font-size:18px}

  /* Chapter media */
  .chapter-media{grid-template-columns:1fr;gap:14px}
  .chapter-media figure,.chapter-media .media-a{grid-column:auto;height:280px}
  .chapter-stats{gap:10px}
  .chapter-stats b{font-size:22px;gap:2px;flex-wrap:nowrap}
  .chapter-stats b i{font-size:11px}
  .chapter-stats span{font-size:9.5px;letter-spacing:.12em}

  /* Why cards */
  .why-list{grid-template-columns:1fr;gap:14px}
  .why-num{font-size:34px;top:10px;right:14px}
  .why-body{padding:20px 20px 22px;gap:10px}
  .why-body h3{font-size:18px}
  .why-body p{font-size:14px}

  /* ─── PLOT CARDS → HORIZONTAL SLIDER ─── */
  .plot-grid{
    display:flex;grid-template-columns:none;
    overflow-x:auto;overflow-y:visible;
    scroll-snap-type:x mandatory;
    gap:14px;padding:24px 18px 32px;
    margin:0 calc(var(--pad) * -1);
    scrollbar-width:none;-webkit-overflow-scrolling:touch;
  }
  .plot-grid::-webkit-scrollbar{display:none}
  .plot-card{flex:0 0 82%;scroll-snap-align:center;min-width:0}
  .plot-card:hover{transform:none}
  .pc-header{padding:42px 20px 30px}
  .pc-size b{font-size:78px}
  .pc-no{top:14px;font-size:9px;letter-spacing:.28em}
  .pc-tag{bottom:14px;font-size:8px;padding:4px 11px}
  .pc-body{padding:26px 22px 22px}
  .pc-title{font-size:17px}
  .pc-feat li{font-size:12.5px}
  .plots-foot{margin-top:24px;font-size:13px}

  /* ─── PRESS → HORIZONTAL SLIDER ─── */
  .press-grid{
    display:flex;grid-template-columns:none;
    overflow-x:auto;overflow-y:visible;
    scroll-snap-type:x mandatory;
    gap:14px;padding:24px 18px 32px;
    margin:0 calc(var(--pad) * -1);
    scrollbar-width:none;-webkit-overflow-scrolling:touch;
  }
  .press-grid::-webkit-scrollbar{display:none}
  .press-card{flex:0 0 82%;scroll-snap-align:center;min-width:0;height:240px;grid-column:auto!important;grid-row:auto!important}
  .press-card.press-lg{grid-column:auto;grid-row:auto;height:240px}
  .press-num{width:40px;height:40px;font-size:13px;top:-10px;left:-10px}
  .press-lg .press-num{width:46px;height:46px;font-size:14px;background:linear-gradient(160deg, var(--saffron) 0%, var(--saffron-deep) 100%);color:#fff}

  /* Slider hint cue */
  .slider-hint{
    display:flex;align-items:center;justify-content:center;gap:12px;
    margin-top:10px;font-size:10px;letter-spacing:.22em;text-transform:uppercase;
    color:var(--muted);font-weight:700;
  }
  .slider-hint::before,.slider-hint::after{
    content:"";width:18px;height:1px;background:currentColor;opacity:.45;
  }

  /* ─── AMENITIES SHOWCASE — Mobile ─── */
  .amen-showcase{padding:10px;gap:10px}
  .af{min-height:auto}
  .af-stage{height:260px;min-height:220px}
  .af-info{padding:22px 20px 22px}
  .af-title{font-size:22px}
  .af-desc{font-size:13px}
  .af-badge{top:16px;left:16px;padding:7px 12px}
  .af-cat{font-size:9px;letter-spacing:.18em}
  .af-corner{width:18px;height:18px;border-width:1px}
  .af-corner.tl,.af-corner.tr{top:12px}
  .af-corner.bl,.af-corner.br{bottom:12px}
  .af-corner.tl,.af-corner.bl{left:12px}
  .af-corner.tr,.af-corner.br{right:12px}

  /* Tiles as horizontal swipeable strip */
  .amen-tiles{
    display:flex;grid-template-columns:none;grid-template-rows:none;
    overflow-x:auto;scroll-snap-type:x mandatory;
    gap:8px;padding:2px 2px 6px;
    scrollbar-width:none;-webkit-overflow-scrolling:touch;
  }
  .amen-tiles::-webkit-scrollbar{display:none}
  .at{
    flex:0 0 96px;scroll-snap-align:center;
    min-height:96px;padding:14px 8px;
    border-radius:10px;
  }
  .at-ico{width:32px;height:32px}
  .at-ico svg{width:22px;height:22px}
  .at-name{font-size:10px;line-height:1.2}

  /* Master plan */
  .master{padding:80px 0}
  .master-frame{margin-top:24px}
  .master-frame img{height:auto}
  .master-foot{margin-top:20px;font-size:13px}
  .master-corner{width:28px;height:28px}
  .master-pin b{font-size:10px;padding:5px 10px}
  .master-btn{padding:12px 20px;font-size:11px}

  /* Location */
  .loc-list li{grid-template-columns:80px minmax(0,1fr);padding:18px 0}
  .loc-list b{font-size:24px}
  .loc-list b i{font-size:11px}
  .loc-place{font-size:13px}
  .loc-map{height:380px}

  /* Gallery */
  .gal-grid{grid-template-columns:1fr 1fr;grid-auto-rows:170px;gap:10px}
  .gal-tall{grid-row:span 2}
  .gal-lg{grid-column:span 2;grid-row:span 1}
  .gal-wide{grid-column:span 2}
  .gal-tabs{padding:5px;gap:4px;width:100%;justify-content:space-between}
  .gal-tab{padding:9px 12px;font-size:10px;letter-spacing:.04em;flex:1;justify-content:center}
  .gal-tab span{display:none}
  .gal-overlay{padding:14px}
  .gal-overlay h4{font-size:15px}
  .gal-cat{font-size:8px;padding:3px 8px;margin-bottom:6px}
  .gal-no{font-size:12px}

  /* Lightbox */
  .lightbox{padding:16px}
  .lb-prev,.lb-next{width:42px;height:42px}
  .lb-prev{left:10px}.lb-next{right:10px}
  .lb-x{top:10px;right:10px;width:42px;height:42px}
  .lb-info{padding:0 8px;margin-top:14px}
  .lb-info h5{font-size:16px}
  .lb-counter{font-size:11px}

  /* Testimonial — horizontal swiper on mobile */
  .testi{padding:64px 0}
  .testi-head{margin-bottom:30px}
  .testi-grid{
    display:flex;grid-template-columns:none;
    overflow-x:auto;overflow-y:visible;
    scroll-snap-type:x mandatory;
    gap:14px;padding:6px var(--pad) 22px;
    margin:0 calc(var(--pad) * -1);
    scrollbar-width:none;-webkit-overflow-scrolling:touch;
  }
  .testi-grid::-webkit-scrollbar{display:none}
  .testi-card{
    flex:0 0 85%;scroll-snap-align:center;min-width:0;
    padding:24px 22px;
  }
  .testi-card .quote-mark{width:32px;height:32px;margin-bottom:14px}
  .testi-quote{font-size:15.5px;line-height:1.55}
  .testi-author{margin-top:18px}
  .testi + section,.testi .slider-hint{position:relative;z-index:1}

  /* Contact */
  .contact-grid{gap:32px}
  .cf-row{grid-template-columns:1fr}
  .contact-form{padding:26px 20px}
  .cf-head h3{font-size:20px}
  .ci-icon{width:42px;height:42px}
  .contact-info b{font-size:14px}
  .atomoney{padding:20px}

  /* Footer */
  .ft{padding:64px 0 24px}
  .ft-grid{grid-template-columns:1fr 1fr;gap:28px}
  .ft-base{justify-content:center;text-align:center;gap:8px;font-size:11px}
  .ft-blurb{font-size:14px}
  .ft-disclaimer{margin-top:30px;padding:18px 0 16px}
  .ft-disclaimer p{font-size:11.5px;line-height:1.65}

  /* FAB */
  .fab{right:14px;bottom:14px;gap:10px}
  .fab-btn{width:48px;height:48px}
  .fab-btn svg{width:18px;height:18px}

  /* Modal */
  .modal-head{padding:24px 22px 14px}
  .modal-head h3{font-size:22px}
  .modal-form{padding:18px 22px 22px}

  /* Loader — fits small screens */
  .pl-welcome{font-size:10px;letter-spacing:.3em;gap:10px;margin-bottom:24px}
  .pl-welcome i{width:28px}
  .pl-logo-wrap{width:min(280px,80vw);padding:38px}
  .pl-logo{padding:18px 22px}
  .pl-meta{font-size:10px;letter-spacing:.22em;margin-top:24px}
  .pl-progress{margin-top:20px;gap:14px}
  .pl-bar{width:160px}
  .pl-percent{font-size:11px}
}

@media (max-width:420px){
  .hero-title{font-size:46px}
  .display{font-size:30px}
  .chapter-stats b{font-size:19px}
  .chapter-stats b i{font-size:10px}
  .plot-card{flex:0 0 86%}
  .press-card{flex:0 0 86%}
  .testi-card{flex:0 0 88%;padding:22px 20px}
  .testi-quote{font-size:14.5px}
  .ft-grid{grid-template-columns:1fr;gap:24px}
}
