/* ============================================================
   Marlin Bay Yacht Club — The Founders' 30
   Editorial coastal luxury · light theme
   ============================================================ */

:root{
  /* palette */
  --ink:        #15303A;   /* deep marina ink — body text */
  --ink-soft:   #43606B;   /* muted text */
  --navy:       #0C2A37;   /* deepest water */
  --teal:       #2C7A86;   /* marina teal */
  --sand:       #F4EDE1;   /* warm sand panel */
  --sand-deep:  #EBE0CE;
  --cream:      #FBF7EF;   /* page background */
  --paper:      #FFFFFF;
  --gold:       #BE9A4E;   /* sunset gold accent */
  --gold-deep:  #9C7C34;
  --coral:      #C8553D;   /* lounger coral, used sparingly */
  --line:       #E2D8C6;

  --shadow-sm: 0 2px 10px rgba(20,48,58,.06);
  --shadow-md: 0 18px 50px rgba(12,42,55,.14);
  --shadow-lg: 0 40px 90px rgba(12,42,55,.22);

  --maxw: 1180px;
  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Jost", "Helvetica Neue", Arial, sans-serif;
  --ease:  cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--sans);
  font-weight:300;
  color:var(--ink);
  background:var(--cream);
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:28px; }

/* ---------- type primitives ---------- */
.display{
  font-family:var(--serif);
  font-weight:500;
  line-height:1.04;
  letter-spacing:.005em;
  margin:0 0 .5em;
  font-size:clamp(2.1rem, 5vw, 3.6rem);
  color:var(--navy);
}
.eyebrow{
  font-family:var(--sans);
  font-weight:500;
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin:0 0 1.1rem;
}
.eyebrow--light{ color:var(--gold); }
.eyebrow--gold{ color:var(--gold); }

p{ margin:0 0 1.1rem; max-width:64ch; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--sans); font-weight:500; font-size:.8rem;
  letter-spacing:.16em; text-transform:uppercase;
  padding:1.02em 1.9em; border-radius:2px; cursor:pointer;
  border:1px solid transparent; transition:background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease);
  white-space:nowrap;
}
.btn--gold{ background:var(--gold); color:#fff; box-shadow:var(--shadow-sm); }
.btn--gold:hover{ background:var(--gold-deep); }
.btn--gold:focus-visible{ outline:3px solid rgba(190,154,78,.45); outline-offset:3px; }
.btn--ghost{ background:transparent; color:#fff; border-color:rgba(255,255,255,.65); }
.btn--ghost:hover{ background:rgba(255,255,255,.12); border-color:#fff; }
.btn--block{ width:100%; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  transition:background .35s var(--ease), box-shadow .35s var(--ease), padding .35s var(--ease);
  padding:18px 0;
}
.nav__inner{
  max-width:var(--maxw); margin-inline:auto; padding-inline:28px;
  display:flex; align-items:center; gap:24px;
}
.brand{ display:inline-flex; align-items:center; gap:11px; color:#fff; transition:color .35s var(--ease); }
.brand__mark{ display:inline-flex; color:var(--gold); }
.brand__text{
  font-family:var(--serif); font-weight:600; font-size:1.32rem; line-height:1;
  letter-spacing:.02em; display:flex; flex-direction:column;
}
.brand__text small{
  font-family:var(--sans); font-weight:500; font-size:.52rem; letter-spacing:.42em;
  margin-top:3px; opacity:.85;
}
.nav__links{ display:flex; gap:30px; margin-left:auto; }
.nav__links a{
  font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.9);
  font-weight:400; position:relative; padding:4px 0; transition:color .2s var(--ease);
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px; background:var(--gold);
  transition:width .25s var(--ease);
}
.nav__links a:hover{ color:#fff; }
.nav__links a:hover::after{ width:100%; }
.nav__cta{ padding:.7em 1.3em; font-size:.7rem; }
.nav__toggle{ display:none; }

/* scrolled state */
.nav.is-scrolled{
  background:rgba(251,247,239,.92);
  backdrop-filter:saturate(140%) blur(12px);
  box-shadow:0 1px 0 var(--line), var(--shadow-sm);
  padding:12px 0;
}
.nav.is-scrolled .brand{ color:var(--navy); }
.nav.is-scrolled .brand__mark{ color:var(--gold-deep); }
.nav.is-scrolled .nav__links a{ color:var(--ink-soft); }
.nav.is-scrolled .nav__links a:hover{ color:var(--navy); }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh; display:flex; flex-direction:column;
  justify-content:center; color:#fff; overflow:hidden;
}
.hero__media{ position:absolute; inset:0; z-index:-1; }
.hero__media img{ width:100%; height:100%; object-fit:cover; }
.hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(105deg, rgba(8,28,38,.74) 0%, rgba(8,28,38,.42) 42%, rgba(8,28,38,.08) 70%),
    linear-gradient(to bottom, rgba(8,28,38,.45) 0%, rgba(8,28,38,.05) 32%, rgba(8,28,38,.28) 62%, rgba(8,28,38,.72) 100%);
}
.hero__content{
  max-width:var(--maxw); width:100%; margin-inline:auto; padding:0 28px;
  margin-top:6vh;
}
.hero__title{
  font-family:var(--serif); font-weight:500; line-height:.98;
  font-size:clamp(3rem, 9vw, 6.6rem); letter-spacing:.005em;
  margin:.1em 0 .35em; text-shadow:0 4px 40px rgba(0,0,0,.35);
}
.hero__lede{ font-size:clamp(1.05rem,1.8vw,1.35rem); max-width:46ch; color:rgba(255,255,255,.92); margin-bottom:1.7rem; }
.hero__offer{
  display:inline-flex; align-items:center; gap:18px; flex-wrap:wrap;
  padding:14px 22px; margin-bottom:2rem; border:1px solid rgba(255,255,255,.28);
  border-radius:3px; background:rgba(8,28,38,.28); backdrop-filter:blur(4px);
  font-size:.95rem; letter-spacing:.02em;
}
.hero__offer strong{ font-family:var(--serif); font-size:1.5rem; font-weight:600; color:var(--gold); margin-right:.25em; }
.hero__arrow{ color:rgba(255,255,255,.6); }
.hero__cta{ display:flex; gap:14px; flex-wrap:wrap; }
.hero__foot{
  position:absolute; bottom:26px; left:0; right:0;
  max-width:var(--maxw); margin-inline:auto; padding:0 28px;
  display:flex; align-items:center; justify-content:space-between;
  font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.72);
}
.hero__scroll{ width:24px; height:40px; border:1px solid rgba(255,255,255,.5); border-radius:14px; position:relative; }
.hero__scroll span{
  position:absolute; left:50%; top:8px; width:3px; height:7px; border-radius:2px; background:#fff;
  transform:translateX(-50%); animation:scrolldot 1.8s var(--ease) infinite;
}
@keyframes scrolldot{ 0%{opacity:0;transform:translate(-50%,0)} 30%{opacity:1} 70%{opacity:1} 100%{opacity:0;transform:translate(-50%,12px)} }

/* ============================================================
   OFFER BAND
   ============================================================ */
.offer{ background:var(--navy); color:#fff; padding:clamp(64px,9vw,120px) 0; }
.offer__grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:48px; align-items:end; }
.offer .display{ color:#fff; }
.offer__body{ font-size:1.12rem; color:rgba(255,255,255,.82); }
.offer__body strong{ color:var(--gold); font-weight:500; }

/* ============================================================
   STATS
   ============================================================ */
.stats{ background:var(--cream); padding:clamp(48px,6vw,80px) 0; }
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.stat{ text-align:center; padding:18px 12px; border-right:1px solid var(--line); }
.stat:last-child{ border-right:none; }
.stat__num{
  display:block; font-family:var(--serif); font-weight:600;
  font-size:clamp(2.6rem,5vw,3.8rem); line-height:1; color:var(--teal); margin-bottom:.35rem;
}
.stat__label{ font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-soft); }
.stat--ink .stat__num{ color:var(--gold-deep); }

/* ============================================================
   SPLIT (image + text)
   ============================================================ */
.split{ display:grid; grid-template-columns:1fr 1fr; align-items:center; }
.split__media{ height:100%; min-height:520px; }
.split__media img{ width:100%; height:100%; object-fit:cover; min-height:520px; }
.split__text{ padding:clamp(48px,7vw,108px) clamp(28px,6vw,90px); }
.split--reverse .split__media{ order:2; }
.split--reverse .split__text{ order:1; }

.ticklist{ list-style:none; padding:0; margin:1.6rem 0 0; }
.ticklist li{ position:relative; padding-left:30px; margin-bottom:.85rem; color:var(--ink-soft); }
.ticklist li::before{
  content:""; position:absolute; left:0; top:.55em; width:14px; height:8px;
  border-left:2px solid var(--gold); border-bottom:2px solid var(--gold); transform:rotate(-45deg);
}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{ padding:clamp(64px,9vw,128px) 0; }
.section--sand{ background:var(--sand); }
.section--deep{ background:var(--navy); color:#fff; }
.section--deep .display{ color:#fff; }
.section__head{ max-width:760px; margin-bottom:clamp(36px,5vw,64px); }
.section__intro{ font-size:1.08rem; color:var(--ink-soft); }
.section__intro--light{ color:rgba(255,255,255,.8); }

/* ---------- gallery ---------- */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:240px; gap:18px; }
.gallery__item{ position:relative; margin:0; overflow:hidden; border-radius:4px; box-shadow:var(--shadow-sm); }
.gallery__item img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease); }
.gallery__item:hover img{ transform:scale(1.05); }
.gallery__item--tall{ grid-row:span 2; }
.gallery__item--wide{ grid-column:span 2; }
.gallery__item figcaption{
  position:absolute; left:0; right:0; bottom:0; padding:16px 18px;
  font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:#fff;
  background:linear-gradient(to top, rgba(8,28,38,.78), transparent);
}
.gallery--three{ grid-template-columns:repeat(3,1fr); grid-auto-rows:340px; }

/* ---------- feature grid ---------- */
.feature-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.12); border-radius:4px; overflow:hidden; }
.feature{ background:var(--navy); padding:34px 30px; }
.feature__icon{ display:inline-flex; width:42px; height:42px; color:var(--gold); margin-bottom:16px; }
.feature__icon svg{ width:100%; height:100%; }
.feature h3{ font-family:var(--serif); font-weight:600; font-size:1.4rem; margin:0 0 .4rem; color:#fff; }
.feature p{ color:rgba(255,255,255,.72); font-size:.96rem; margin:0; }
.jv-line{ text-align:center; margin-top:42px; font-size:.74rem; letter-spacing:.26em; text-transform:uppercase; color:var(--gold); }

/* ============================================================
   DINING (G7)
   ============================================================ */
.dining{ display:grid; grid-template-columns:0.85fr 1.15fr; background:#0a0c0f; color:#fff; }
.dining__media{ min-height:560px; }
.dining__media img{ width:100%; height:100%; object-fit:cover; }
.dining__text{ padding:clamp(48px,7vw,110px) clamp(28px,6vw,84px); }
.dining__text .display{ color:#fff; }
.dining__text p{ color:rgba(255,255,255,.74); }
.dining__text strong{ color:var(--gold); font-weight:500; }
.dining__tags{ display:flex; flex-wrap:wrap; gap:10px; margin:1.5rem 0; }
.dining__tags span{
  font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.85);
  border:1px solid rgba(255,255,255,.22); border-radius:2px; padding:.55em 1em;
}
.dining__dish{ margin:2rem 0 0; }
.dining__dish img{ width:100%; height:220px; object-fit:cover; border-radius:4px; }
.dining__dish figcaption{ font-size:.72rem; letter-spacing:.08em; color:rgba(255,255,255,.5); margin-top:10px; text-transform:uppercase; }

/* ============================================================
   SITE PLAN
   ============================================================ */
.siteplan__figure{ margin:0; border-radius:6px; overflow:hidden; box-shadow:var(--shadow-md); background:#cfe6ef; }
.siteplan__figure img{ width:100%; }

/* ============================================================
   NUMBERS / METRICS
   ============================================================ */
.metric-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:16px; margin-bottom:56px; }
.metric{
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.14); border-radius:5px;
  padding:28px 22px; text-align:left;
}
.metric--gold{ background:rgba(190,154,78,.16); border-color:rgba(190,154,78,.5); }
.metric__num{ display:block; font-family:var(--serif); font-weight:600; font-size:2.1rem; line-height:1; color:var(--gold); margin-bottom:.3rem; }
.metric__unit{ display:inline-block; font-size:.8rem; color:rgba(255,255,255,.6); margin-bottom:.6rem; letter-spacing:.04em; }
.metric__label{ display:block; font-size:.82rem; letter-spacing:.04em; color:rgba(255,255,255,.82); line-height:1.5; }
.metric__label small{ display:block; font-size:.72rem; color:rgba(255,255,255,.5); margin-top:3px; letter-spacing:.02em; }

/* tables */
.comps__title, .pricetable__head h3{ font-family:var(--serif); font-weight:600; font-size:1.5rem; margin:0 0 1.2rem; }
.section--deep .comps__title{ color:#fff; }
.comps__scroll{ overflow-x:auto; -webkit-overflow-scrolling:touch; border-radius:5px; }
.comps__table{ width:100%; border-collapse:collapse; min-width:620px; font-size:.92rem; }
.comps__table thead th{
  text-align:left; font-weight:500; font-size:.7rem; letter-spacing:.14em; text-transform:uppercase;
  padding:14px 16px; color:rgba(255,255,255,.55); border-bottom:1px solid rgba(255,255,255,.18);
}
.comps__table tbody td{ padding:15px 16px; border-bottom:1px solid rgba(255,255,255,.1); color:rgba(255,255,255,.82); }
.comps__table tbody tr.is-highlight{ background:rgba(190,154,78,.14); }
.comps__table tbody tr.is-highlight td{ color:#fff; font-weight:400; }
.comps__table tbody tr.is-highlight td:first-child{ font-family:var(--serif); font-weight:600; font-size:1.02rem; color:var(--gold); }
.comps__note{ font-size:.84rem; color:rgba(255,255,255,.6); margin-top:18px; max-width:88ch; line-height:1.6; }
.comps__note em{ font-style:italic; color:rgba(255,255,255,.5); }

/* ============================================================
   HOW IT WORKS
   ============================================================ */
.how .section__head{ text-align:center; margin-inline:auto; }
.how .section__intro{ margin-inline:auto; }
.steps__list{ list-style:none; counter-reset:s; padding:0; margin:0 0 clamp(48px,7vw,90px);
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.step{ position:relative; padding-top:18px; border-top:2px solid var(--line); }
.step__n{
  display:inline-flex; align-items:center; justify-content:center; width:44px; height:44px;
  border-radius:50%; background:var(--navy); color:var(--gold); font-family:var(--serif);
  font-weight:600; font-size:1.3rem; margin-bottom:16px;
}
.step h3{ font-family:var(--serif); font-weight:600; font-size:1.3rem; margin:0 0 .5rem; color:var(--navy); }
.step p{ font-size:.95rem; color:var(--ink-soft); margin:0; }

.pricetable{ background:var(--navy); color:#fff; border-radius:8px; padding:clamp(32px,5vw,56px); margin-bottom:56px; }
.pricetable__head{ max-width:760px; margin-bottom:28px; }
.pricetable__head h3{ color:#fff; font-size:1.7rem; }
.pricetable__head p{ color:rgba(255,255,255,.72); }
.pricetable__table tbody td:nth-child(3){ color:var(--gold); }
.pricetable__table tbody tr.is-highlight td:nth-child(3){ color:var(--gold); font-weight:500; }

.how-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.how-stats .stat{ border-right:1px solid var(--line); }
.how-stats .stat:last-child{ border-right:none; }

/* ============================================================
   EMOTIVE CLOSE
   ============================================================ */
.close{ position:relative; min-height:78vh; display:flex; align-items:center; color:#fff; overflow:hidden; }
.close__media{ position:absolute; inset:0; z-index:-1; }
.close__media img{ width:100%; height:100%; object-fit:cover; }
.close__scrim{ position:absolute; inset:0; background:linear-gradient(to right, rgba(6,20,28,.82) 0%, rgba(6,20,28,.5) 55%, rgba(6,20,28,.3) 100%); }
.close__content{ max-width:var(--maxw); margin-inline:auto; padding:0 28px; }
.close__title{ font-family:var(--serif); font-weight:500; font-size:clamp(1.9rem,4.2vw,3.4rem); line-height:1.1; max-width:20ch; margin:0 0 1rem; text-shadow:0 4px 30px rgba(0,0,0,.4); }
.close__content p{ color:rgba(255,255,255,.85); max-width:54ch; margin-bottom:1.8rem; font-size:1.05rem; }

/* ============================================================
   RESERVE / FORM
   ============================================================ */
.reserve{ background:var(--sand); padding:clamp(64px,9vw,128px) 0; }
.reserve__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,84px); align-items:start; }
.reserve__intro .display{ color:var(--navy); }
.reserve__timeline{ list-style:none; padding:0; margin:2.2rem 0 0; }
.reserve__timeline li{ display:flex; gap:18px; padding:16px 0; border-top:1px solid var(--line); align-items:baseline; }
.reserve__timeline li:last-child{ border-bottom:1px solid var(--line); }
.reserve__timeline span{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); min-width:92px; }
.reserve__timeline strong{ font-family:var(--serif); font-weight:600; font-size:1.18rem; color:var(--navy); }

.reserve__form{ background:var(--paper); border-radius:8px; padding:clamp(28px,4vw,46px); box-shadow:var(--shadow-md); }
.reserve__form h3{ font-family:var(--serif); font-weight:600; font-size:1.6rem; margin:0 0 1.4rem; color:var(--navy); }
.field{ margin-bottom:18px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field label{ display:block; font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:7px; }
.field .opt{ text-transform:none; letter-spacing:0; opacity:.6; }
.field input, .field select, .field textarea{
  width:100%; font-family:var(--sans); font-size:1rem; font-weight:300; color:var(--ink);
  padding:13px 15px; border:1px solid var(--line); border-radius:4px; background:#fcfaf6;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(190,154,78,.18);
}
.field textarea{ resize:vertical; }
.reserve__success{ background:rgba(44,122,134,.1); border:1px solid rgba(44,122,134,.35); color:var(--teal); padding:14px 16px; border-radius:4px; margin-top:16px; font-size:.92rem; }
.reserve__fineprint{ font-size:.76rem; color:var(--ink-soft); margin-top:16px; line-height:1.5; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--navy); color:rgba(255,255,255,.72); padding:clamp(54px,7vw,84px) 0 40px; }
.footer__top{ display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; padding-bottom:36px; border-bottom:1px solid rgba(255,255,255,.12); }
.brand--footer{ color:#fff; }
.footer__brand p{ margin-top:14px; font-size:.85rem; line-height:1.7; color:rgba(255,255,255,.6); }
.footer__nav{ display:flex; flex-wrap:wrap; gap:14px 26px; align-content:start; }
.footer__nav a{ font-size:.76rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.7); transition:color .2s var(--ease); }
.footer__nav a:hover{ color:var(--gold); }
.footer__disclosure{ padding-top:28px; }
.footer__disclosure p{ font-size:.73rem; line-height:1.7; color:rgba(255,255,255,.46); max-width:none; }
.footer__disclosure strong{ color:rgba(255,255,255,.7); }
.footer__copy{ margin-top:20px; letter-spacing:.1em; text-transform:uppercase; font-size:.68rem; }

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.is-visible{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .hero__scroll span{ animation:none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .nav__links{ display:none; }
  .nav__toggle{ display:inline-flex; }
  .metric-grid{ grid-template-columns:repeat(2,1fr); }
  .feature-grid{ grid-template-columns:repeat(2,1fr); }
}

@media (max-width:860px){
  body{ font-size:16px; }
  .offer__grid{ grid-template-columns:1fr; gap:24px; }
  .split{ grid-template-columns:1fr; }
  .split__media, .split__media img{ min-height:340px; }
  .split--reverse .split__media{ order:1; }
  .split--reverse .split__text{ order:2; }
  .dining{ grid-template-columns:1fr; }
  .dining__media{ min-height:320px; }
  .gallery, .gallery--three{ grid-template-columns:repeat(2,1fr); grid-auto-rows:200px; }
  .gallery__item--tall{ grid-row:span 1; }
  .gallery__item--wide{ grid-column:span 2; }
  .steps__list{ grid-template-columns:repeat(2,1fr); }
  .reserve__grid{ grid-template-columns:1fr; }
  .stats__grid{ grid-template-columns:repeat(2,1fr); gap:28px 12px; }
  .stat:nth-child(2){ border-right:none; }
  .how-stats{ grid-template-columns:repeat(2,1fr); gap:28px 12px; }
  .how-stats .stat:nth-child(2){ border-right:none; }
}

@media (max-width:560px){
  .container{ padding-inline:20px; }
  .nav__inner{ padding-inline:20px; }
  .nav__cta{ display:none; }
  .hero__foot{ font-size:.6rem; }
  .hero__foot span{ max-width:40%; }
  .metric-grid{ grid-template-columns:1fr; }
  .feature-grid{ grid-template-columns:1fr; }
  .stats__grid{ grid-template-columns:1fr; }
  .stat{ border-right:none !important; border-bottom:1px solid var(--line); padding-bottom:24px; }
  .stats__grid .stat:last-child{ border-bottom:none; }
  .how-stats{ grid-template-columns:1fr; }
  .how-stats .stat{ border-right:none !important; border-bottom:1px solid var(--line); padding-bottom:24px; }
  .steps__list{ grid-template-columns:1fr; }
  .gallery, .gallery--three{ grid-template-columns:1fr; }
  .gallery__item--wide{ grid-column:span 1; }
  .field-row{ grid-template-columns:1fr; }
  .hero__offer{ font-size:.85rem; gap:12px; }
}

/* mobile menu panel */
.nav__toggle{ flex-direction:column; gap:5px; width:44px; height:44px; align-items:center; justify-content:center; background:transparent; border:none; cursor:pointer; margin-left:auto; }
.nav__toggle span{ width:24px; height:2px; background:#fff; transition:.3s var(--ease); }
.nav.is-scrolled .nav__toggle span{ background:var(--navy); }
.nav.menu-open .nav__toggle span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav.menu-open .nav__toggle span:nth-child(2){ opacity:0; }
.nav.menu-open .nav__toggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
.mobile-menu{
  position:fixed; inset:0; z-index:45; background:var(--navy); display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:8px; opacity:0; visibility:hidden;
  transition:opacity .35s var(--ease), visibility .35s var(--ease);
}
.mobile-menu.is-open{ opacity:1; visibility:visible; }
.mobile-menu a{ font-family:var(--serif); font-size:1.8rem; color:#fff; padding:10px; }
.mobile-menu a:hover{ color:var(--gold); }
.mobile-menu .btn{ margin-top:20px; }
