/* =========================================================
   SoulFire Farm — Island homestead landing page
   Editorial "sustainable luxury" — cream + forest green
   ========================================================= */

:root{
  --cream:#F4F1E8;
  --cream-deep:#ECE6D6;
  --paper:#FBFAF5;
  --forest:#2E3A23;
  --forest-2:#38462B;
  --olive:#5F6B3E;
  --olive-soft:#8A9A5B;
  --ink:#23231C;
  --muted:#595849;
  --line:rgba(46,58,35,.14);
  --line-strong:rgba(46,58,35,.22);
  --shadow:0 18px 50px -28px rgba(46,58,35,.45);
  --shadow-sm:0 8px 26px -18px rgba(46,58,35,.5);

  --font-display:"Fraunces",Georgia,"Times New Roman",serif;
  --font-sans:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  --container:1180px;
  --radius:22px;
  --radius-lg:34px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--cream);
  font-size:clamp(1rem,.97rem + .2vw,1.075rem);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--font-display);font-weight:500;line-height:1.05;letter-spacing:-.01em;margin:0}
h2{font-size:clamp(2rem,1.3rem + 2.6vw,3.25rem)}
h3{font-size:1.3rem;line-height:1.2;letter-spacing:0}
p{margin:0 0 1rem}
:focus-visible{outline:2.5px solid var(--olive);outline-offset:3px;border-radius:4px}

.skip-link{position:absolute;left:-999px;top:0;background:var(--forest);color:var(--cream);padding:.7rem 1.1rem;border-radius:0 0 10px 0;z-index:200}
.skip-link:focus{left:0}

/* ---------- layout helpers ---------- */
.section{padding:clamp(4rem,3rem + 6vw,7.5rem) clamp(1.25rem,5vw,2rem)}
.section--paper{background:var(--paper)}
.section__head{max-width:var(--container);margin:0 auto clamp(2.5rem,4vw,4rem)}
.section__head h2{max-width:16ch}
.section__lead{color:var(--muted);max-width:54ch;margin-top:1rem;font-size:1.1rem}

.eyebrow{
  font-family:var(--font-sans);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.72rem;
  font-weight:600;
  color:var(--olive);
  margin:0 0 1.1rem;
  display:flex;align-items:center;gap:.7rem;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--olive-soft)}
.eyebrow--light{color:#C8D2A6}
.eyebrow--light::before{background:rgba(200,210,166,.6)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--font-sans);font-weight:500;font-size:.98rem;
  padding:.92rem 1.6rem;border-radius:100px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .25s var(--ease),background .25s,color .25s,border-color .25s,box-shadow .25s;
  white-space:nowrap;line-height:1;
}
.btn--sm{padding:.62rem 1.15rem;font-size:.9rem}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--forest);color:var(--cream)}
.btn--primary:hover{background:var(--forest-2);box-shadow:var(--shadow-sm)}
.btn--ghost{border-color:var(--line-strong);color:var(--forest)}
.btn--ghost:hover{background:var(--forest);color:var(--cream);border-color:var(--forest)}
.btn--light{background:var(--cream);color:var(--forest)}
.btn--light:hover{background:#fff;box-shadow:0 12px 30px -16px rgba(0,0,0,.5)}
.btn--outline-light{border-color:rgba(244,241,232,.45);color:var(--cream)}
.btn--outline-light:hover{background:rgba(244,241,232,.12);border-color:var(--cream)}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s,box-shadow .3s,padding .3s}
.nav__inner{
  max-width:1280px;margin:0 auto;padding:1.15rem clamp(1.25rem,5vw,2rem);
  display:flex;align-items:center;gap:1.5rem;transition:padding .3s;
}
.nav.scrolled{background:rgba(244,241,232,.85);backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2);box-shadow:0 1px 0 var(--line)}
.nav.scrolled .nav__inner{padding-top:.75rem;padding-bottom:.75rem}

.brand{display:flex;align-items:center;gap:.55rem;color:var(--forest);margin-right:auto}
.brand__mark{flex:none}
.brand__name{font-family:var(--font-display);font-weight:600;font-size:1.22rem;letter-spacing:-.01em}

.nav__links{display:flex;gap:1.9rem}
.nav__links a{font-size:.94rem;font-weight:500;color:var(--ink);opacity:.82;position:relative;padding:.25rem 0;transition:opacity .2s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--olive);transition:width .25s var(--ease)}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after,.nav__links a.active::after{width:100%}

.nav__cta{display:flex;align-items:center;gap:.85rem}
.price-pill{
  font-family:var(--font-display);font-weight:600;font-size:.92rem;
  color:var(--forest);background:rgba(138,154,91,.22);
  padding:.45rem .85rem;border-radius:100px;border:1px solid rgba(95,107,62,.25);
}

.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:.4rem}
.nav__toggle span{width:24px;height:2px;background:var(--forest);border-radius:2px;transition:transform .3s,opacity .3s}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- hero (wide) ---------- */
.hero{padding:clamp(7.5rem,7rem + 5vw,10rem) clamp(1.25rem,5vw,2rem) clamp(3rem,4vw,4.5rem);max-width:1320px;margin:0 auto;text-align:center}
.hero .eyebrow{justify-content:center}
.hero__head{max-width:900px;margin:0 auto}
.hero__title{font-size:clamp(2.5rem,1.3rem + 5vw,5.4rem);letter-spacing:-.02em;margin-bottom:1.3rem}
.hero__lead{font-size:clamp(1.08rem,1rem + .45vw,1.3rem);color:var(--muted);max-width:62ch;margin:0 auto}

.hero__wide{position:relative;max-width:1240px;margin:clamp(2.2rem,3vw,3.4rem) auto 0}
.hero__wide img{
  width:100%;aspect-ratio:16/9;object-fit:cover;display:block;
  clip-path:polygon(0% 3.8%,4.17% 4.74%,8.33% 7%,12.5% 9.26%,16.67% 10.2%,20.83% 9.26%,25% 7%,29.17% 4.74%,33.33% 3.8%,37.5% 4.74%,41.67% 7%,45.83% 9.26%,50% 10.2%,54.17% 9.26%,58.33% 7%,62.5% 4.74%,66.67% 3.8%,70.83% 4.74%,75% 7%,79.17% 9.26%,83.33% 10.2%,87.5% 9.26%,91.67% 7%,95.83% 4.74%,100% 3.8%,100% 96.2%,95.83% 95.26%,91.67% 93%,87.5% 90.74%,83.33% 89.8%,79.17% 90.74%,75% 93%,70.83% 95.26%,66.67% 96.2%,62.5% 95.26%,58.33% 93%,54.17% 90.74%,50% 89.8%,45.83% 90.74%,41.67% 93%,37.5% 95.26%,33.33% 96.2%,29.17% 95.26%,25% 93%,20.83% 90.74%,16.67% 89.8%,12.5% 90.74%,8.33% 93%,4.17% 95.26%,0% 96.2%);
  filter:drop-shadow(0 26px 48px rgba(46,58,35,.32));
}
.hero__actions{
  position:absolute;top:9%;left:50%;transform:translate(-50%,-50%);z-index:3;
  display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center;
}
.hero__actions .btn{box-shadow:0 12px 30px -12px rgba(0,0,0,.5)}

.hero__stats{
  list-style:none;margin:clamp(2.5rem,4vw,4rem) auto 0;max-width:960px;padding:1.6rem 0 0;
  border-top:1px solid var(--line);
  display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
}
.hero__stats li{display:flex;flex-direction:column;gap:.15rem;align-items:center}
.hero__stats strong{font-family:var(--font-display);font-size:clamp(1.6rem,1.2rem + 1.4vw,2.4rem);color:var(--forest);font-weight:500;line-height:1}
.hero__stats span{font-size:.85rem;color:var(--muted)}

/* ---------- shared media shapes ---------- */
.leaf img{border-radius:8px 64px 8px 64px;box-shadow:var(--shadow)}

/* ---------- story ---------- */
.story__grid{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,4vw,4.5rem);align-items:center}
.story__media{margin:0}
.story__media img{width:100%;aspect-ratio:4/3;object-fit:cover}
.story__copy p{color:var(--muted);max-width:52ch}
.story__copy h2{margin-bottom:1.4rem;max-width:14ch}
.pull-quote{
  font-family:var(--font-display);font-style:italic;font-size:clamp(1.3rem,1.1rem + 1vw,1.7rem);
  line-height:1.3;color:var(--forest);margin:1.8rem 0 0;padding-left:1.4rem;
  border-left:3px solid var(--olive-soft);
}

/* ---------- features cards ---------- */
.cards{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.card{
  background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .35s var(--ease),box-shadow .35s;
}
.section--paper .card{background:#fff}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card__media{aspect-ratio:4/3;overflow:hidden}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover .card__media img{transform:scale(1.05)}
.card__body{padding:1.5rem 1.5rem 1.7rem}
.card__body h3{color:var(--forest);margin-bottom:.55rem}
.card__body p{color:var(--muted);font-size:.96rem;margin-bottom:.9rem}
.card__stat{
  display:inline-block;font-family:var(--font-display);font-weight:600;font-size:.92rem;
  color:var(--forest);background:rgba(138,154,91,.2);padding:.32rem .8rem;border-radius:100px;margin:0;
}

/* ---------- systems ---------- */
.systems__grid{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.systems__intro{position:sticky;top:7rem}
.systems__list{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}
.sys{display:flex;gap:1.3rem;padding:1.7rem 0;border-bottom:1px solid var(--line)}
.sys:first-child{padding-top:0}
.sys:last-child{border-bottom:0}
.sys__icon{flex:none;width:54px;height:54px;border-radius:50%;display:grid;place-items:center;background:rgba(138,154,91,.18);color:var(--forest)}
.sys h3{color:var(--forest);margin-bottom:.4rem}
.sys p{color:var(--muted);margin:0;font-size:1rem}

/* ---------- facts ---------- */
.facts__grid{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:0 clamp(2rem,5vw,5rem)}
.fact{display:flex;justify-content:space-between;gap:1.5rem;padding:1.05rem 0;border-bottom:1px solid var(--line);align-items:baseline}
.fact dt{font-weight:600;color:var(--forest);flex:none}
.fact dd{margin:0;text-align:right;color:var(--muted)}

/* ---------- business ---------- */
.business{padding-left:clamp(1.25rem,5vw,2rem);padding-right:clamp(1.25rem,5vw,2rem)}
.business__panel{
  max-width:var(--container);margin:0 auto;background:var(--forest);color:var(--cream);
  border-radius:var(--radius-lg);padding:clamp(2.2rem,4vw,4rem);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;
  background-image:radial-gradient(circle at 100% 0,rgba(138,154,91,.28),transparent 55%);
}
.business__copy h2{color:var(--cream);max-width:15ch;margin-bottom:1rem}
.business__copy p{color:rgba(244,241,232,.78);max-width:42ch;margin:0}
.business__list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:.85rem 1.5rem}
.business__list li{position:relative;padding-left:1.7rem;font-size:.97rem;color:rgba(244,241,232,.92)}
.business__list li::before{
  content:"";position:absolute;left:0;top:.36em;width:11px;height:7px;
  border-left:2px solid var(--olive-soft);border-bottom:2px solid var(--olive-soft);transform:rotate(-45deg);
}

/* ---------- location ---------- */
.location__grid{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,4vw,4rem);align-items:start}
.proximity{list-style:none;margin:0 0 1.5rem;padding:0;display:grid;gap:.7rem}
.proximity li{padding:.5rem 0;border-bottom:1px solid var(--line);color:var(--muted)}
.proximity strong{color:var(--forest);font-family:var(--font-display);font-weight:600;margin-right:.5rem;display:inline-block;min-width:3.6em}
.location__info > p{color:var(--muted);font-size:.98rem}
.location__plan{margin:1.8rem 0 0}
.location__plan img{width:100%;aspect-ratio:3/2;object-fit:cover}
.location__map{position:relative}
.location__map iframe{width:100%;aspect-ratio:4/3;border:0;border-radius:var(--radius);box-shadow:var(--shadow);filter:saturate(.92)}
.map__link{display:inline-block;margin-top:1rem;color:var(--forest);font-weight:500;font-size:.95rem}
.map__link:hover{color:var(--olive)}

/* ---------- lifestyle ---------- */
.lifestyle__grid{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:center}
.lifestyle__copy h2{max-width:13ch;margin-bottom:1.3rem}
.lifestyle__copy p{color:var(--muted);max-width:46ch}
.lifestyle__sub{font-weight:600;color:var(--forest);margin:1.5rem 0 .8rem}
.chips{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.55rem}
.chips li{font-size:.88rem;padding:.45rem .95rem;border:1px solid var(--line-strong);border-radius:100px;color:var(--forest)}
.lifestyle__media{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.lifestyle__media figure{margin:0}
.lifestyle__media figure:first-child{grid-row:span 2}
.lifestyle__media img{width:100%;height:100%;object-fit:cover;border-radius:16px;box-shadow:var(--shadow-sm)}

.ideal{max-width:var(--container);margin:clamp(3rem,5vw,5rem) auto 0;padding-top:clamp(2.5rem,4vw,4rem);border-top:1px solid var(--line)}
.ideal__list{list-style:none;margin:1.4rem 0 0;padding:0;display:flex;flex-wrap:wrap;gap:.7rem}
.ideal__list li{
  font-family:var(--font-display);font-size:1.02rem;color:var(--forest);
  padding:.55rem 1.15rem;background:var(--paper);border:1px solid var(--line);border-radius:100px;
}
.section--paper .ideal__list li{background:var(--cream)}

/* ---------- gallery ---------- */
.gallery__grid{max-width:var(--container);margin:0 auto;columns:3;column-gap:1.1rem}
.shot{
  display:block;width:100%;margin:0 0 1.1rem;padding:0;border:0;background:none;cursor:pointer;
  border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);break-inside:avoid;line-height:0;
}
.shot img{width:100%;height:auto;transition:transform .6s var(--ease)}
.shot:hover img{transform:scale(1.05)}

/* ---------- cta ---------- */
.cta{padding:clamp(1.25rem,5vw,2rem)}
.cta__inner{
  max-width:1280px;margin:0 auto;background:var(--forest);color:var(--cream);
  border-radius:var(--radius-lg);text-align:center;
  padding:clamp(3.5rem,5vw,6rem) clamp(1.5rem,5vw,3rem);
  background-image:radial-gradient(circle at 50% -10%,rgba(138,154,91,.35),transparent 60%);
}
.cta .eyebrow{justify-content:center}
.cta__title{font-size:clamp(2.2rem,1.5rem + 3vw,4rem);color:var(--cream);max-width:18ch;margin:0 auto 1.2rem}
.cta__lead{color:rgba(244,241,232,.82);max-width:48ch;margin:0 auto 2.2rem;font-size:1.12rem}
.cta__actions{display:flex;flex-wrap:wrap;gap:.85rem;justify-content:center}
.cta__note{margin:2.2rem 0 0;font-size:.9rem;color:rgba(244,241,232,.65)}

/* ---------- footer ---------- */
.footer{background:var(--cream-deep);padding:clamp(2.5rem,4vw,3.5rem) clamp(1.25rem,5vw,2rem) 1.5rem}
.footer__inner{max-width:var(--container);margin:0 auto;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;align-items:flex-start}
.footer__brand .brand__name{font-size:1.3rem;color:var(--forest)}
.footer__brand p{color:var(--muted);font-size:.9rem;margin:.5rem 0 0;line-height:1.5}
.footer__links{display:flex;flex-wrap:wrap;gap:1.2rem}
.footer__links a{color:var(--muted);font-size:.92rem;transition:color .2s}
.footer__links a:hover{color:var(--forest)}
.footer__social{display:flex;gap:.9rem}
.footer__social a{color:var(--forest);opacity:.7;transition:opacity .2s,transform .2s}
.footer__social a:hover{opacity:1;transform:translateY(-2px)}
.footer__copy{max-width:var(--container);margin:2.5rem auto 0;padding-top:1.5rem;border-top:1px solid var(--line);color:var(--muted);font-size:.82rem;text-align:center}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(20,24,16,.92);display:grid;place-items:center;padding:4vw}
.lightbox[hidden]{display:none}
.lightbox__img{max-width:92vw;max-height:88vh;width:auto;border-radius:10px;box-shadow:0 30px 80px -20px rgba(0,0,0,.7);animation:lbin .35s var(--ease)}
@keyframes lbin{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}
.lightbox__close,.lightbox__nav{position:absolute;background:rgba(244,241,232,.12);color:var(--cream);border:0;cursor:pointer;border-radius:50%;display:grid;place-items:center;transition:background .2s}
.lightbox__close:hover,.lightbox__nav:hover{background:rgba(244,241,232,.28)}
.lightbox__close{top:3vh;right:3vw;width:48px;height:48px;font-size:2rem;line-height:1}
.lightbox__nav{top:50%;transform:translateY(-50%);width:54px;height:54px;font-size:2.2rem;line-height:1}
.lightbox__prev{left:3vw}
.lightbox__next{right:3vw}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in-view{opacity:1;transform:none}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:980px){
  .story__grid,.systems__grid,.location__grid,.lifestyle__grid,.business__panel{grid-template-columns:1fr}
  .story__media{order:-1}
  .systems__intro{position:static}
  .cards{grid-template-columns:repeat(2,1fr)}
  .business__panel{text-align:left}
  .gallery__grid{columns:2}
  .lifestyle__media{margin-top:.5rem}
}
@media (max-width:760px){
  .nav__links{
    position:fixed;inset:0 0 auto;top:0;flex-direction:column;gap:0;
    background:var(--cream);padding:5.5rem 1.5rem 2rem;
    box-shadow:0 20px 40px -20px rgba(46,58,35,.4);
    transform:translateY(-100%);transition:transform .4s var(--ease);
    border-bottom:1px solid var(--line);
  }
  .nav__links.open{transform:translateY(0)}
  .nav__links a{padding:1rem 0;font-size:1.1rem;border-bottom:1px solid var(--line);width:100%}
  .nav__links a::after{display:none}
  .nav__toggle{display:flex;order:3}
  .nav__cta .btn{display:none}
  .price-pill{display:none}
  .nav.scrolled{background:rgba(244,241,232,.92)}
  .hero__actions{position:static;transform:none;flex-direction:column;align-items:center;margin:1.4rem auto 0;max-width:340px}
  .hero__actions .btn{width:100%}
  .hero__wide{margin-top:1.6rem}
  .hero__stats{grid-template-columns:repeat(2,1fr);gap:1.5rem 1rem}
  .facts__grid{grid-template-columns:1fr;gap:0}
  .business__list{grid-template-columns:1fr}
  .lifestyle__media{grid-template-columns:1fr 1fr}
}
@media (max-width:520px){
  .cards{grid-template-columns:1fr}
  .gallery__grid{columns:1}
  .fact{flex-direction:column;gap:.15rem}
  .fact dd{text-align:left}
  .btn{width:100%;justify-content:center}
  .hero__actions,.cta__actions{flex-direction:column}
  .nav__cta{margin-left:auto}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
}
