/* ═══════════════════════════════════════════════════════════════════
   GULSHAN EMPIRE — Editorial Ivory design system
   "An architecture magazine that happens to sell a home."
   Palette: ivory paper · deep-forest ink · antique-gold hairlines ·
   oxblood signature accent (graft from Imperial direction)
   Rules: gold #B08D3A = hairlines/decoration ONLY (3.1:1 — fails AA as text);
   gold-as-text uses #8A6D27 (4.7:1). Motion = transform/opacity only.
   ═══════════════════════════════════════════════════════════════════ */

:root{
  --ivory:#FBF9F4;
  --stone:#F2EDE3;
  --sand:#E7DFD0;
  --forest:#13352A;
  --forest-700:#1C4A3A;
  --ink:#1F1B16;
  --taupe:#5B5347;
  --gold:#B08D3A;        /* hairlines only */
  --gold-text:#8A6D27;   /* AA-safe gold text */
  --oxblood:#6E1423;     /* signature accent: price ribbon, numerals */
  --white:#FFFFFF;
  --brick:#9A2A2A;
  --ok:#1B6E4B;
  --max:1240px;
  --r:2px;               /* sharp = editorial */
  --shadow:0 18px 50px -24px rgba(31,27,22,.22);
  --pad-y:clamp(72px,11vw,150px);
  --hairline:1px solid var(--gold);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;background:var(--ivory);color:var(--ink);
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',Arial,sans-serif;
  font-size:16.5px;line-height:1.62;letter-spacing:-.011em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:clip;
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--forest);text-decoration:none}
a:hover{color:var(--forest-700)}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:var(--r)}
::selection{background:var(--forest);color:var(--ivory)}

h1,h2,h3,.display{
  font-family:'Fraunces',Georgia,'Times New Roman',serif;
  font-weight:600;line-height:1.12;letter-spacing:-.015em;color:var(--forest);
  margin:0 0 .45em;font-variation-settings:"opsz" 80;
}
h1{font-size:clamp(2.45rem,5.6vw,4.4rem)}
h2{font-size:clamp(1.85rem,3.4vw,2.7rem)}
h3{font-size:clamp(1.25rem,2vw,1.5rem)}
h4{font-family:'Inter',sans-serif;font-weight:600;font-size:1.05rem;color:var(--forest);margin:0 0 .4em}
p{margin:0 0 1.1em}
.lede{font-size:clamp(1.06rem,1.6vw,1.24rem);color:var(--taupe);line-height:1.65;max-width:62ch}
em.gild{font-style:italic;color:var(--gold-text)}
.num,.fact-bar b,td.num,.price-fig{font-variant-numeric:tabular-nums lining-nums}
small,.fine{font-size:.84rem;color:var(--taupe)}
hr{border:0;border-top:var(--hairline);margin:2.4rem auto;max-width:160px}

/* ── layout ─────────────────────────────────────────────── */
.wrap{max-width:var(--max);margin:0 auto;padding:0 clamp(20px,4vw,44px)}
section{padding:var(--pad-y) 0;position:relative}
section.band{background:var(--stone)}
section.band-forest{background:var(--forest);color:var(--ivory)}
section.band-forest h2,section.band-forest h3{color:var(--ivory)}
section.band-forest .lede,section.band-forest p{color:#CFD8D0}
.grid{display:grid;gap:clamp(24px,3.4vw,52px)}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.g2,.g3,.g4{grid-template-columns:1fr}.g4{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.g4{grid-template-columns:1fr}}

/* eyebrow: gold rule + roman-numeral kicker — the magazine "department" mark */
.eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:1.5rem}
.eyebrow::before{content:"";width:44px;border-top:var(--hairline)}
.eyebrow span{
  font-size:.74rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--taupe);
}
.eyebrow .roman{color:var(--oxblood);font-weight:700;margin-right:.5em}
.center .eyebrow{justify-content:center}
.center .eyebrow::after{content:"";width:44px;border-top:var(--hairline)}
.center{text-align:center}
.center .lede{margin-inline:auto}

/* ── header ─────────────────────────────────────────────── */
.site-head{
  position:sticky;top:0;z-index:60;background:rgba(251,249,244,.94);
  backdrop-filter:saturate(140%) blur(10px);border-bottom:var(--hairline);
}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;height:74px}
.brand{display:flex;align-items:center;gap:12px;color:var(--forest)}
.brand svg{width:38px;height:38px;flex:none}
.brand .word{font-family:'Fraunces',serif;font-weight:700;font-size:1.18rem;letter-spacing:.02em;line-height:1.05}
.brand .word small{display:block;font-family:'Inter',sans-serif;font-weight:500;font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--taupe)}
nav.primary{display:flex;gap:clamp(14px,2vw,28px);align-items:center}
nav.primary a{font-size:.92rem;font-weight:500;color:var(--ink);padding:6px 2px;border-bottom:1px solid transparent}
nav.primary a:hover{border-bottom-color:var(--gold);color:var(--forest)}
.head-cta{display:flex;align-items:center;gap:12px}
.tel-link{font-weight:600;font-size:.95rem;color:var(--forest);white-space:nowrap}
@media(max-width:1020px){nav.primary{display:none}}
@media(max-width:720px){
  .site-head .wrap{height:62px;gap:10px}
  .tel-link{display:none}
  .head-cta .btn{min-height:40px;padding:9px 14px;font-size:.84rem}
  .brand svg,.brand img{width:32px;height:32px}
  .brand .word{font-size:1rem}
  .brand .word small{letter-spacing:.22em}
}

/* ── buttons ────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:48px;padding:13px 26px;border-radius:var(--r);cursor:pointer;
  font:600 .97rem/1 'Inter',sans-serif;letter-spacing:.01em;border:1px solid transparent;
  transition:background .18s ease,color .18s ease,border-color .18s ease,transform .18s ease;
  -webkit-tap-highlight-color:transparent;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--forest);color:var(--ivory)}
.btn-primary:hover{background:var(--forest-700);color:var(--ivory)}
.btn-ghost{background:transparent;color:var(--forest);border-color:var(--forest)}
.btn-ghost:hover{background:var(--forest);color:var(--ivory)}
.btn-gold{background:transparent;color:var(--gold-text);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold);color:var(--white)}
.btn-oxblood{background:var(--oxblood);color:var(--ivory)}
.btn-oxblood:hover{background:#581021;color:var(--ivory)}
.btn-block{width:100%}

/* ── hero: "The Cover Story" ────────────────────────────── */
.hero{padding:clamp(48px,7vw,96px) 0 clamp(56px,7vw,104px);overflow:clip}
.hero .wrap{display:grid;grid-template-columns:minmax(0,11fr) minmax(0,9fr);gap:clamp(32px,5vw,72px);align-items:center}
@media(max-width:920px){.hero .wrap{grid-template-columns:1fr}.hero .plate-col{order:-1;max-width:520px}}
.kicker{display:flex;align-items:center;gap:14px;margin-bottom:1.4rem}
.kicker::before{content:"";width:44px;border-top:var(--hairline)}
.kicker span{font-size:.74rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--taupe)}
.hero h1{margin-bottom:.5em}
.hero .sub{font-size:clamp(1.02rem,1.5vw,1.18rem);color:var(--taupe);max-width:56ch;margin-bottom:1.9rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin:1.9rem 0 1.5rem}
.micro-trust{font-size:.8rem;color:var(--taupe);line-height:1.7}
.micro-trust a{color:var(--gold-text);border-bottom:1px solid var(--gold)}

/* fact bar — tabular figures with gold hairline separators (LLM-extractable) */
.fact-bar{
  display:grid;grid-template-columns:repeat(4,auto);gap:0;justify-content:start;
  border-block:var(--hairline);margin:1.7rem 0 0;
}
.fact-bar>div{padding:14px clamp(14px,2vw,28px)}
.fact-bar>div+div{border-left:var(--hairline)}
.fact-bar b{display:block;font-family:'Fraunces',serif;font-weight:600;font-size:clamp(1.12rem,1.8vw,1.42rem);color:var(--forest)}
.fact-bar i{font-style:normal;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--taupe)}
.fact-bar .ox b{color:var(--oxblood)}
@media(max-width:700px){.fact-bar{grid-template-columns:1fr 1fr}.fact-bar>div{border-left:0!important;border-top:var(--hairline)}.fact-bar>div:nth-child(-n+2){border-top:0}.fact-bar>div:nth-child(2n){border-left:var(--hairline)!important}}

/* framed image plate — every image sits in a gold-hairline frame on ivory */
.plate{background:var(--white);border:var(--hairline);padding:clamp(10px,1.4vw,16px);box-shadow:var(--shadow)}
.plate img,.plate svg{width:100%;height:auto}
.plate figcaption{padding:10px 4px 2px;font-size:.78rem;letter-spacing:.06em;color:var(--taupe);text-transform:uppercase}
.plate--art{background:linear-gradient(168deg,var(--stone),var(--sand))}

/* ── ribbons & chips ────────────────────────────────────── */
.ribbon{
  display:inline-flex;align-items:center;gap:10px;background:var(--oxblood);color:var(--ivory);
  font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  padding:9px 16px;border-radius:var(--r);
}
.chip-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:1.2rem}
.chip{
  display:inline-flex;align-items:center;gap:8px;border:var(--hairline);border-radius:var(--r);
  background:var(--white);padding:9px 14px;font-size:.8rem;font-weight:500;color:var(--ink);
}
.chip b{color:var(--forest);font-weight:600}
.chip svg{width:15px;height:15px;stroke:var(--gold-text)}

/* GEO answer block — first-200-words direct answer */
.answer-block{
  border-left:3px solid var(--gold);background:var(--white);
  padding:clamp(20px,2.6vw,30px) clamp(22px,3vw,36px);box-shadow:var(--shadow);margin:2rem 0;
}
.answer-block p{margin:0;font-size:1.02rem;line-height:1.7}
.answer-block .q{font-family:'Fraunces',serif;font-weight:600;color:var(--forest);display:block;margin-bottom:.5em;font-size:1.12rem}

/* ── cards & tables ─────────────────────────────────────── */
.card{background:var(--white);border:var(--hairline);border-radius:var(--r);padding:clamp(24px,3vw,38px);box-shadow:var(--shadow)}
.card.on-stone{background:var(--ivory)}
.card .price-fig{font-family:'Fraunces',serif;font-size:clamp(1.7rem,3vw,2.3rem);font-weight:600;color:var(--oxblood)}
.spec-table{width:100%;border-collapse:collapse;font-size:.95rem}
.spec-table th{font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--taupe);text-align:left;padding:12px 14px;border-bottom:1.5px solid var(--gold)}
.spec-table td{padding:13px 14px;border-bottom:1px solid var(--sand);vertical-align:top}
.spec-table tr:last-child td{border-bottom:var(--hairline)}
.spec-table td.num{text-align:right;font-weight:600;color:var(--forest)}
.spec-table .hl td{background:var(--stone)}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* amenity tile */
.amen{display:flex;gap:14px;align-items:flex-start;padding:18px;border:var(--hairline);background:var(--white);border-radius:var(--r)}
.amen svg{width:26px;height:26px;flex:none;stroke:var(--gold-text);fill:none;stroke-width:1.5}
.amen b{display:block;font-weight:600;color:var(--forest);margin-bottom:2px}
.amen span{font-size:.86rem;color:var(--taupe)}

/* steps / timeline */
.steps{counter-reset:st;display:grid;gap:18px}
.step{display:grid;grid-template-columns:52px 1fr;gap:16px;padding:18px;background:var(--white);border:var(--hairline);border-radius:var(--r)}
.step::before{
  counter-increment:st;content:counter(st,upper-roman);
  font-family:'Fraunces',serif;font-weight:700;font-size:1.25rem;color:var(--oxblood);
  display:flex;align-items:flex-start;justify-content:center;padding-top:2px;border-right:var(--hairline);
}

/* ── FAQ accordion ──────────────────────────────────────── */
.faq details{border-bottom:var(--hairline);padding:6px 0}
.faq summary{
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:18px;align-items:center;
  font-family:'Fraunces',serif;font-weight:600;font-size:1.08rem;color:var(--forest);padding:16px 2px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:'Inter';font-weight:400;font-size:1.5rem;color:var(--gold-text);transition:transform .2s ease}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .a{padding:0 2px 18px;color:var(--ink);max-width:72ch}

/* ── lead form (the money component) ────────────────────── */
.lead-card{background:var(--white);border:var(--hairline);border-radius:var(--r);padding:clamp(26px,3.4vw,40px);box-shadow:var(--shadow)}
.lead-card h3{margin-bottom:.3em}
.lead-card .sub{color:var(--taupe);font-size:.95rem;margin-bottom:1.3rem}
.fg{margin-bottom:14px}
.fg input{
  width:100%;min-height:50px;padding:13px 15px;border:1px solid var(--sand);border-radius:var(--r);
  background:var(--ivory);font:500 1rem 'Inter',sans-serif;color:var(--ink);
  transition:border-color .15s ease;
}
.fg input:focus{outline:none;border-color:var(--gold);background:var(--white)}
.fg input[aria-invalid="true"]{border-color:var(--brick)}
.form-err{display:none;color:var(--brick);font-size:.84rem;margin:-6px 0 10px}
.form-err.show{display:block}
.form-note{font-size:.78rem;color:var(--taupe);margin-top:12px;line-height:1.6}
.form-thankyou{display:none;text-align:center;padding:26px 8px}
.form-thankyou.show{display:block}
.form-thankyou .check{font-size:2rem;margin-bottom:8px}
.form-thankyou h4{font-family:'Fraunces',serif;font-size:1.25rem;color:var(--forest)}

/* ── modals ─────────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;z-index:90;display:none;align-items:center;justify-content:center;
  background:rgba(31,27,22,.55);backdrop-filter:blur(7px);padding:20px;
}
.modal-overlay.show{display:flex}
.modal{
  position:relative;width:min(460px,100%);background:var(--white);border:var(--hairline);
  border-radius:var(--r);padding:clamp(26px,4vw,38px);box-shadow:0 30px 80px -20px rgba(31,27,22,.45);
  max-height:92vh;overflow:auto;
}
.modal h3{padding-right:30px}
.modal-sub{color:var(--taupe);font-size:.93rem;margin-bottom:1.2rem}
.modal-close{
  position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;
  border:var(--hairline);background:var(--ivory);color:var(--taupe);font-size:1.25rem;cursor:pointer;
}
.modal-close:hover{background:var(--stone);color:var(--ink)}
.modal-icon{font-size:1.7rem;margin-bottom:10px}
.fp-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:1.2rem}
.fp-tags span{border:var(--hairline);border-radius:var(--r);background:var(--ivory);padding:6px 11px;font-size:.78rem;font-weight:500;color:var(--forest)}

/* ── sticky CTAs ────────────────────────────────────────── */
.side-sticky{
  position:fixed;right:0;top:46%;z-index:55;display:flex;align-items:center;gap:10px;
  background:var(--forest);color:var(--ivory);border:0;border-radius:var(--r) 0 0 var(--r);
  padding:13px 16px;cursor:pointer;font:600 .85rem 'Inter';box-shadow:var(--shadow);
  writing-mode:vertical-rl;letter-spacing:.12em;text-transform:uppercase;
}
.side-sticky:hover{background:var(--forest-700)}
@media(max-width:920px){.side-sticky{display:none}}
.fab-mini{
  position:fixed;left:18px;bottom:86px;z-index:55;display:none;align-items:center;gap:8px;
  background:var(--white);border:var(--hairline);border-radius:999px;padding:11px 16px;
  font:600 .83rem 'Inter';color:var(--forest);cursor:pointer;box-shadow:var(--shadow);
}
.fab-mini.show{display:inline-flex}
.wa-float{
  position:fixed;right:18px;bottom:86px;z-index:55;width:54px;height:54px;border-radius:50%;
  background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);
}
.wa-float svg{width:28px;height:28px;fill:#fff}
@media(min-width:921px){.wa-float{bottom:24px}}
.mobile-dock{
  position:fixed;left:0;right:0;bottom:0;z-index:60;display:none;grid-template-columns:1fr 1fr 1.3fr;
  background:var(--forest);border-top:var(--hairline);
}
.mobile-dock a,.mobile-dock button{
  display:flex;align-items:center;justify-content:center;gap:8px;min-height:56px;
  font:600 .88rem 'Inter';color:var(--ivory);background:none;border:0;cursor:pointer;
}
.mobile-dock a+a,.mobile-dock button{border-left:1px solid rgba(176,141,58,.45)}
.mobile-dock .enq{background:var(--oxblood)}
@media(max-width:920px){.mobile-dock{display:grid}body{padding-bottom:56px}}

/* scroll progress — thin gold strand */
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--gold);z-index:99}

/* ── author / E-E-A-T card ──────────────────────────────── */
.author-card{display:grid;grid-template-columns:84px 1fr;gap:18px;align-items:center}
.author-card .avatar{
  width:84px;height:84px;border-radius:50%;border:var(--hairline);background:var(--stone);
  display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;
  font-size:1.6rem;font-weight:700;color:var(--forest);
}
.author-card b{display:block;font-size:1.05rem;color:var(--forest)}
.author-card span{font-size:.86rem;color:var(--taupe);display:block;line-height:1.55}

/* breadcrumbs */
.crumbs{font-size:.8rem;color:var(--taupe);padding:18px 0 0}
.crumbs a{color:var(--taupe)}
.crumbs a:hover{color:var(--forest)}
.crumbs .sep{color:var(--gold-text);margin:0 7px}

/* prose (blog/long-form) */
.prose{max-width:74ch}
.prose h2{margin-top:2.2em}
.prose h3{margin-top:1.7em}
.prose ul,.prose ol{padding-left:1.3em;margin:0 0 1.2em}
.prose li{margin-bottom:.45em}
.prose blockquote{border-left:3px solid var(--gold);margin:1.6em 0;padding:.4em 0 .4em 1.2em;color:var(--taupe);font-style:italic}
.prose table{width:100%;border-collapse:collapse;font-size:.92rem;margin:1.4em 0}
.prose th{border-bottom:1.5px solid var(--gold);text-align:left;padding:10px;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--taupe)}
.prose td{border-bottom:1px solid var(--sand);padding:10px;vertical-align:top}
.updated{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;color:var(--taupe);border:var(--hairline);border-radius:var(--r);padding:7px 12px;background:var(--white)}

/* ── footer ─────────────────────────────────────────────── */
footer.site-foot{background:var(--forest);color:#CFD8D0;padding:64px 0 110px;font-size:.88rem}
footer.site-foot .grid{gap:36px}
footer.site-foot h6{
  font:600 .72rem 'Inter';letter-spacing:.2em;text-transform:uppercase;color:var(--gold);
  margin:0 0 14px;
}
footer.site-foot a{color:#E8E4DA}
footer.site-foot a:hover{color:var(--white)}
footer.site-foot ul{list-style:none;margin:0;padding:0}
footer.site-foot li{margin-bottom:9px}
.foot-disclaimer{border-top:1px solid rgba(176,141,58,.4);margin-top:42px;padding-top:26px;font-size:.78rem;line-height:1.7;color:#ADBBB0}
.foot-disclaimer strong{color:#E8E4DA}
.foot-legal{margin-top:18px;font-size:.78rem;color:#8FA396}

/* ── reveal animations (transform/opacity only; reduced-motion safe) ── */
.reveal,.reveal-left,.reveal-right{opacity:0;transition:opacity .7s ease,transform .7s ease;will-change:transform}
.reveal{transform:translateY(26px)}
.reveal-left{transform:translateX(-26px)}
.reveal-right{transform:translateX(26px)}
.reveal.in,.reveal-left.in,.reveal-right.in{opacity:1;transform:none}
.stagger>*{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.stagger.in>*{opacity:1;transform:none}
.stagger.in>*:nth-child(2){transition-delay:.08s}
.stagger.in>*:nth-child(3){transition-delay:.16s}
.stagger.in>*:nth-child(4){transition-delay:.24s}
.stagger.in>*:nth-child(5){transition-delay:.32s}
.stagger.in>*:nth-child(6){transition-delay:.4s}
@media (prefers-reduced-motion:reduce){
  .reveal,.reveal-left,.reveal-right,.stagger>*{opacity:1!important;transform:none!important;transition:none!important}
}

/* utility */
.mt-0{margin-top:0}.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}
.mb-1{margin-bottom:1rem}.mb-2{margin-bottom:2rem}
.tac{text-align:center}
.gold-rule{border:0;border-top:var(--hairline);max-width:160px;margin:2.2rem auto}
.sr-only{position:absolute;width:1px;height:1px;margin:-1px;clip:rect(0 0 0 0);overflow:hidden}

/* ── mobile upgrade: hamburger nav, sheet modals, footer mark ── */
.menu-btn{display:none;width:44px;height:44px;flex:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;background:none;border:var(--hairline);border-radius:var(--r);cursor:pointer}
.menu-btn span{display:block;width:20px;height:2px;background:var(--forest);transition:transform .2s ease,opacity .2s ease}
body.nav-open .menu-btn span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .menu-btn span:nth-child(2){opacity:0}
body.nav-open .menu-btn span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:1020px){.menu-btn{display:flex}}
.mob-nav{position:fixed;left:0;right:0;top:74px;bottom:0;z-index:58;background:var(--forest);padding:14px 22px calc(96px + env(safe-area-inset-bottom));overflow:auto;display:none}
body.nav-open .mob-nav{display:block}
body.nav-open{overflow:hidden}
.mob-nav a.link{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--ivory);font:500 1.04rem 'Inter',sans-serif;padding:14px 2px;border-bottom:1px solid rgba(176,141,58,.35);min-height:48px}
.mob-nav a.link:hover{color:var(--ivory)}
.mob-nav a.link small{color:#9FB0A4;font-size:.76rem;text-align:right}
.mob-nav .mob-cta{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px}
.mob-nav .mob-cta a{display:flex;align-items:center;justify-content:center;gap:8px;min-height:52px;border-radius:var(--r);font:600 .95rem 'Inter',sans-serif}
.mob-nav .mob-cta a.c1{background:var(--gold);color:#2A1F08}
.mob-nav .mob-cta a.c2{background:var(--oxblood);color:var(--ivory)}
@media(min-width:1021px){.mob-nav{display:none!important}}
@media(max-width:720px){.mob-nav{top:62px}}

/* bottom-sheet modals + full-width hero CTAs on phones */
@media(max-width:720px){
  .modal-overlay{align-items:flex-end;padding:0}
  .modal{width:100%;max-width:none;border-radius:14px 14px 0 0;border-left:0;border-right:0;border-bottom:0;padding-bottom:calc(26px + env(safe-area-inset-bottom));max-height:88vh}
}
@media(max-width:540px){.hero-ctas .btn{width:100%}}

/* dock safe-area (notched phones) */
.mobile-dock{padding-bottom:env(safe-area-inset-bottom)}
@media(max-width:920px){body{padding-bottom:calc(56px + env(safe-area-inset-bottom))}}

/* long-page render perf on mobile */
@media(max-width:720px){
  section{content-visibility:auto;contain-intrinsic-size:auto 720px}
  .hero{content-visibility:visible}
}

/* footer brand mark (official wordmark on forest) */
.foot-mark{border-top:1px solid rgba(176,141,58,.4);margin-top:42px;padding-top:30px}
.foot-mark img{width:208px;height:auto;opacity:.95}
.foot-mark + .foot-disclaimer{border-top:0;margin-top:22px;padding-top:0}

/* ── self-hosted variable fonts (latin subsets) ── */
@font-face{
  font-family:'Fraunces';
  src:url('/assets/fonts/fraunces-var-latin.woff2') format('woff2');
  font-weight:400 700;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Inter';
  src:url('/assets/fonts/inter-var-latin.woff2') format('woff2');
  font-weight:400 600;font-style:normal;font-display:swap;
}
