/* ============ CLEAN EFFORTLESSLY v3 — cream · green · gold ============ */
@font-face{font-family:'Editorial';src:url('assets/serif-regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Editorial';src:url('assets/serif-italic.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}

:root{
  --cream:#f9f4e8; --cream2:#f1e9d7; --card:#fffdf6;
  --green:#1a4d3a; --green2:#0f3226; --ink:#22332b; --ink2:#41544a; --mut:#6f7d72;
  --gold:#c9a227; --gold2:#e3b23c;
  --line:rgba(26,77,58,.14); --lineL:rgba(249,244,232,.16);
  --serif:'Editorial',Georgia,serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
  --r:22px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}
body{background:var(--cream);color:var(--ink);font-family:var(--sans);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:clip}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:rgba(201,162,39,.35)}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}
.wrap{max-width:1240px;margin:0 auto;padding:0 28px}
.wrap-m{max-width:980px;margin:0 auto;padding:0 28px}
.wrap-n{max-width:780px;margin:0 auto;padding:0 28px}
.center{text-align:center}

/* type */
.h2{font-family:var(--serif);font-weight:400;font-size:clamp(2.1rem,4.6vw,3.6rem);line-height:1.06;letter-spacing:-.015em;color:var(--ink)}
.accent{font-style:italic;background:linear-gradient(95deg,var(--green),#2e7a55);-webkit-background-clip:text;background-clip:text;color:transparent}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.74rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.eyebrow.center{display:flex;justify-content:center}
.pulse-dot{width:7px;height:7px;border-radius:50%;background:var(--gold2);box-shadow:0 0 0 0 rgba(201,162,39,.55);animation:pulse 2.2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 10px rgba(201,162,39,0)}100%{box-shadow:0 0 0 0 rgba(201,162,39,0)}}
.link-green{color:var(--green);font-weight:700;border-bottom:1.5px solid rgba(26,77,58,.35);transition:border-color .25s}
.link-green:hover{border-color:var(--green)}
.stars-inline{color:var(--gold2);letter-spacing:2px;font-weight:400;margin-right:6px}

/* ambient glow */
.glow{position:absolute;border-radius:50%;filter:blur(90px);opacity:.6;pointer-events:none;animation:glowDrift 14s ease-in-out infinite alternate}
.glow-a{width:560px;height:560px;top:-160px;right:-120px;background:radial-gradient(circle,rgba(201,162,39,.14),transparent 65%)}
@keyframes glowDrift{to{transform:translate(40px,30px) scale(1.1)}}

/* reveals */
.rv{opacity:0;transform:translateY(28px);transition:opacity .95s var(--ease),transform .95s var(--ease)}
.rv.d1{transition-delay:.12s}.rv.d2{transition-delay:.24s}.rv.d3{transition-delay:.36s}.rv.d4{transition-delay:.48s}
.rv.in{opacity:1;transform:none}

/* buttons */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:700;border-radius:999px;overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease);white-space:nowrap}
.btn .btn-l{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;white-space:nowrap}
.btn-green{background:linear-gradient(120deg,var(--green),#256b4c);color:var(--cream);padding:15px 28px;box-shadow:0 10px 30px rgba(26,77,58,.3)}
.btn-green:hover{transform:translateY(-2px);box-shadow:0 16px 44px rgba(26,77,58,.42)}
.btn-gold{background:linear-gradient(120deg,var(--gold2),var(--gold));color:var(--green2);padding:15px 28px;box-shadow:0 12px 36px rgba(201,162,39,.4)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 18px 50px rgba(201,162,39,.55)}
.btn-line{padding:16px 28px;color:var(--cream);border:1.5px solid rgba(249,244,232,.4)}
.btn-line:hover{border-color:var(--gold2);color:var(--gold2);transform:translateY(-2px)}
.btn-lg{padding:17px 32px;font-size:1.03rem}
.btn-sm{padding:10px 20px;font-size:.9rem}
.btn-block{width:100%;padding:15px}
.btn-shine::before{content:"";position:absolute;top:0;bottom:0;width:46px;background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);transform:skewX(-20deg);left:-70px;animation:shine 3.2s var(--ease) infinite;z-index:1}
@keyframes shine{0%,55%{left:-70px}85%,100%{left:calc(100% + 30px)}}

/* animated call buttons */
.call-btn{position:relative;display:inline-flex;align-items:center;gap:10px;font-weight:700;border-radius:999px;padding:12px 22px;color:var(--green2);border:1.5px solid rgba(26,77,58,.35);background:var(--card);transition:transform .3s var(--ease),background .3s,border-color .3s,box-shadow .3s;white-space:nowrap}
.call-btn:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:0 12px 36px rgba(26,77,58,.18)}
.call-btn .btn-l{display:inline-flex;align-items:center;font-variant-numeric:tabular-nums;white-space:nowrap}
.call-btn-lg{padding:15px 26px;font-size:1.02rem}
.call-btn-hero{background:rgba(255,253,246,.92);backdrop-filter:blur(8px)}
.call-ic{position:relative;display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:linear-gradient(120deg,var(--green),#2e7a55);color:var(--cream);animation:ring 2.6s ease-in-out infinite;flex-shrink:0}
.call-ic::after{content:"";position:absolute;inset:-3px;border-radius:50%;border:2px solid rgba(26,77,58,.4);animation:ringPulse 2.6s ease-out infinite}
@keyframes ring{0%,12%,24%,100%{transform:rotate(0)}3%,9%,15%,21%{transform:rotate(-13deg)}6%,12%,18%{transform:rotate(13deg)}}
@keyframes ringPulse{0%{transform:scale(.9);opacity:.9}55%{transform:scale(1.7);opacity:0}100%{transform:scale(1.7);opacity:0}}
.g-mark{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:#fff;box-shadow:0 2px 10px rgba(0,0,0,.12);flex-shrink:0}
.g-mark.big{width:64px;height:64px}

/* ============ promo bar ============ */
.promo{position:relative;z-index:95;background:linear-gradient(120deg,var(--green2),var(--green));color:#efe9d8;text-align:center;font-size:.85rem;padding:9px 16px;letter-spacing:.02em}
.promo b{color:var(--gold2)}
.promo-code{background:rgba(227,178,60,.18);border:1px dashed rgba(227,178,60,.6);border-radius:8px;padding:1px 8px;margin-left:2px}
.promo-spark{color:var(--gold2)}
.promo-dim{color:#b9c4b2;font-size:.78rem}
@media(max-width:560px){.promo-dim{display:none}}

/* ============ cursor ============ */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:200;border-radius:50%;transform:translate(-50%,-50%)}
.cursor-dot{width:7px;height:7px;background:var(--green)}
.cursor-ring{width:38px;height:38px;border:1.5px solid rgba(26,77,58,.4);display:flex;align-items:center;justify-content:center;transition:width .35s var(--ease),height .35s var(--ease),background .35s,border-color .35s}
.cursor-ring span{font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--green2);opacity:0;transition:opacity .25s}
.cursor-ring.big{width:86px;height:86px;background:rgba(227,178,60,.92);border-color:transparent}
.cursor-ring.big span{opacity:1}
@media (hover:none),(pointer:coarse){.cursor-dot,.cursor-ring{display:none}}
@media (hover:hover) and (pointer:fine){body.has-cursor,body.has-cursor a,body.has-cursor button{cursor:none}}

/* ============ loader ============ */
.loader{position:fixed;inset:0;z-index:300;background:var(--cream);display:flex;align-items:center;justify-content:center;transition:clip-path .9s var(--ease);clip-path:inset(0)}
.loader.done{clip-path:inset(0 0 100% 0)}
.loader.gone{display:none}
.loader-inner{text-align:center}
.loader-brand{font-family:var(--serif);font-size:clamp(2.4rem,7vw,4.6rem);color:var(--green);display:flex;align-items:baseline;gap:14px;overflow:hidden}
.loader-brand span,.loader-brand b{display:inline-block;transform:translateY(115%);animation:lUp .8s var(--ease) forwards}
.loader-brand .lb-2{font-style:italic;animation-delay:.12s}
.loader-brand b{color:var(--gold2);font-size:.5em;animation-delay:.3s}
@keyframes lUp{to{transform:none}}
.loader-pct{margin-top:16px;font-size:.8rem;letter-spacing:.32em;color:var(--gold);font-variant-numeric:tabular-nums}

/* ============ nav ============ */
.nav{position:sticky;top:0;z-index:90;background:rgba(249,244,232,.88);backdrop-filter:blur(18px);border-bottom:1px solid transparent;transition:border-color .4s,box-shadow .4s}
.nav.solid{border-color:var(--line);box-shadow:0 10px 40px rgba(26,77,58,.08)}
.nav-inner{max-width:1240px;margin:0 auto;padding:13px 28px;display:flex;align-items:center;gap:26px}
.logo{font-family:var(--serif);font-size:1.35rem;color:var(--green);white-space:nowrap}
.logo em{font-style:italic}
.logo-spark{color:var(--gold2);font-size:.7em;vertical-align:super;margin-left:2px}
.nav-links{display:flex;gap:22px;font-size:.92rem;color:var(--ink2)}
.nav-links a{position:relative;transition:color .25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-4px;height:1.5px;width:100%;background:var(--gold2);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:12px}
.nav .call-btn{padding:9px 16px;font-size:.9rem}
.nav .call-ic{width:26px;height:26px}
@media(max-width:1020px){.nav-links{display:none}}
@media(max-width:560px){.nav .call-btn .btn-l{display:none}.nav .call-btn{padding:9px 11px}.nav .btn-sm{padding:9px 14px;font-size:.84rem}.logo{font-size:1.15rem}}

/* ============ hero (full-bleed wipe) ============ */
.hero{position:relative;min-height:calc(100svh - 92px);display:flex;flex-direction:column;justify-content:flex-end;overflow:clip}
.hero-media{position:absolute;inset:0;cursor:ew-resize;touch-action:pan-y;outline:none}
.hero-media:focus-visible{box-shadow:inset 0 0 0 3px var(--gold2)}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-before-wrap{position:absolute;inset:0;overflow:hidden;transform:translateX(-50%);will-change:transform}
.hero-before-wrap .hero-img{transform:translateX(50%);will-change:transform;filter:saturate(.82) brightness(.94)}
.hero-divider{position:absolute;top:0;bottom:0;left:0;width:0;z-index:3;will-change:transform;pointer-events:none}
.divider-line{position:absolute;top:0;bottom:0;left:-1px;width:2px;background:linear-gradient(180deg,transparent,var(--gold2) 18%,#fff 50%,var(--gold2) 82%,transparent);box-shadow:0 0 18px rgba(227,178,60,.85),0 0 60px rgba(227,178,60,.4)}
.divider-handle{position:absolute;top:42%;left:0;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--green2);background:linear-gradient(135deg,#fff,var(--gold2));box-shadow:0 8px 28px rgba(0,0,0,.35);animation:handleFloat 3s ease-in-out infinite}
@keyframes handleFloat{50%{transform:translate(-50%,-56%)}}
#sparkle{position:absolute;inset:0;pointer-events:none;z-index:4}
.ba-tag{position:absolute;top:22px;z-index:4;font-size:.64rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;padding:8px 15px;border-radius:999px;color:#fff;background:rgba(18,40,30,.5);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);transition:opacity .4s}
.tag-before{left:24px}
.tag-after{right:24px;color:#ffe9b0}
.hero-shade{position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(180deg,rgba(15,40,30,.35) 0%,rgba(15,40,30,0) 24%,rgba(15,40,30,0) 46%,rgba(15,40,30,.78) 82%,rgba(15,40,30,.9) 100%)}
.hero-content{position:relative;z-index:5;max-width:1240px;width:100%;margin:0 auto;padding:80px 28px 56px;color:#fff;pointer-events:none}
.hero-content a{pointer-events:auto}
.hero-h1{font-family:var(--serif);font-weight:400;font-size:clamp(2.9rem,7.6vw,6rem);line-height:1.02;letter-spacing:-.01em;margin:8px 0 20px;text-shadow:0 2px 40px rgba(0,0,0,.3)}
.hero-h1 .line{display:block;overflow:hidden}
.hero-h1 .word{display:inline-block;transform:translateY(112%);animation:wordUp .95s var(--ease) forwards}
.w2{animation-delay:.08s}.w3{animation-delay:.16s}.w4{animation-delay:.28s}
.hero-h1 .accent{font-style:italic;background:linear-gradient(95deg,#ffe9b0,var(--gold2));-webkit-background-clip:text;background-clip:text;color:transparent}
@keyframes wordUp{to{transform:translateY(0)}}
.hero-sub{max-width:600px;color:#f0ead9;font-size:clamp(1rem,1.4vw,1.16rem)}
.hero-sub strong{color:#fff}
.hero-ctas{display:flex;gap:14px;margin:26px 0 18px;flex-wrap:wrap;align-items:center}
.hero-proof{font-size:.9rem;color:#d9d2bd}
.hero .eyebrow{color:#ffd97a}
.float-layer{position:absolute;inset:0;z-index:6;pointer-events:none;will-change:transform}
.float-card{position:absolute;padding:15px 19px;border-radius:18px;background:rgba(255,253,246,.92);backdrop-filter:blur(12px);box-shadow:0 20px 55px rgba(15,40,30,.35);color:var(--ink);animation:floaty 6s ease-in-out infinite;opacity:0}
.float-card.show{opacity:1;transition:opacity .8s .9s}
@keyframes floaty{50%{transform:translateY(-9px)}}
.fc1{top:14%;right:5%}
.fc2{top:38%;right:11%;animation-delay:-3s}
.fc-row{display:flex;gap:11px;align-items:center}
.fc-stars{color:var(--gold);letter-spacing:2px;font-size:.95rem}
.fc-sub{font-size:.78rem;color:var(--mut)}
.fc-sub b{color:var(--ink);font-weight:800}
.fc-label-strong{font-weight:800;font-size:.92rem;color:var(--green)}
.fc-check{width:32px;height:32px;border-radius:50%;background:rgba(26,77,58,.12);color:var(--green);display:flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0}
@media(max-width:900px){
  .fc2{display:none}
  .fc1{top:11%;right:14px;padding:11px 14px}
  .divider-handle{top:22%;width:46px;height:46px}
  .ba-tag{top:14px;font-size:.56rem;padding:6px 11px}
  .hero-shade{background:linear-gradient(180deg,rgba(15,40,30,.45) 0%,rgba(15,40,30,.1) 22%,rgba(15,40,30,.42) 48%,rgba(15,40,30,.88) 74%,rgba(15,40,30,.96) 100%)}
}

/* ============ quote (simple form) ============ */
.quote{position:relative;padding:110px 0;background:var(--cream);overflow:hidden}
.quote-grid{position:relative;display:grid;grid-template-columns:.95fr 1.05fr;gap:56px;align-items:start}
.q-sub{color:var(--ink2);max-width:480px;margin-top:14px}
.q-trust{list-style:none;display:grid;gap:12px;margin-top:26px;color:var(--ink2)}
.q-trust li{position:relative;padding-left:30px}
.q-trust li::before{content:"✓";position:absolute;left:0;top:0;width:20px;height:20px;border-radius:50%;background:rgba(201,162,39,.16);color:var(--gold);font-size:.72rem;font-weight:800;display:flex;align-items:center;justify-content:center}
.q-call-card{margin-top:30px;padding:20px 22px;border-radius:var(--r);background:var(--card);border:1px solid var(--line);display:inline-flex;flex-direction:column;gap:12px;box-shadow:0 14px 40px rgba(26,77,58,.08)}
.q-call-k{font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--mut)}
.q-form{padding:34px;border-radius:26px;background:var(--card);border:1.5px solid var(--line);box-shadow:0 36px 90px rgba(26,77,58,.14)}
.q-form-main.hidden,.q-success.hidden,.q-error.hidden{display:none}
.q-label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--mut);margin:18px 0 9px}
.q-label:first-child{margin-top:0}
.q-input{width:100%;padding:15px 17px;border-radius:13px;border:1.5px solid var(--line);background:#fff;color:var(--ink);font-size:1rem;font-family:inherit;transition:border-color .25s,box-shadow .25s}
.q-input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(26,77,58,.12)}
.q-input::placeholder{color:#a7b0a5}
.q-textarea{resize:vertical;min-height:88px}
.q-form .btn{margin-top:24px}
.q-error{margin-top:14px;text-align:center;font-size:.88rem;color:#b0483a;padding:12px;border-radius:12px;background:rgba(176,72,58,.08);border:1px solid rgba(176,72,58,.25)}
.q-fine{margin-top:13px;text-align:center;font-size:.78rem;color:var(--mut)}
.q-success{text-align:center;padding:26px 0}
.q-tick{width:66px;height:66px;margin:0 auto 18px;border-radius:50%;background:linear-gradient(135deg,var(--green),#2e7a55);color:var(--cream);font-size:1.85rem;font-weight:800;display:flex;align-items:center;justify-content:center;animation:pop .5s var(--ease)}
@keyframes pop{0%{transform:scale(0)}80%{transform:scale(1.15)}100%{transform:scale(1)}}
.q-success h3{font-family:var(--serif);font-size:1.8rem;font-weight:400}
.q-success p{color:var(--mut);margin:8px 0 20px}
@media(max-width:940px){.quote-grid{grid-template-columns:1fr;gap:40px}.q-form{padding:26px 20px}}

/* ============ marquee ============ */
.marquee-band{background:var(--cream2);padding:52px 0;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.mq{display:flex;width:max-content;will-change:transform}
.mq-chunk{display:flex;align-items:center;gap:38px;padding-right:38px}
.mq-chunk span{font-family:var(--serif);font-size:clamp(2.4rem,5.6vw,4.4rem);line-height:1;white-space:nowrap;color:transparent;-webkit-text-stroke:1.3px rgba(26,77,58,.45)}
.mq-chunk span.mq-fill{font-style:italic;color:var(--green);-webkit-text-stroke:0}
.mq-chunk i{font-style:normal;color:var(--gold2);font-size:1.5rem}

/* ============ manifesto ============ */
.manifesto{padding:130px 0 100px}
.manifesto-t{font-family:var(--serif);font-size:clamp(1.7rem,3.5vw,2.9rem);line-height:1.32}
.manifesto-t .mw{color:rgba(26,77,58,.16);transition:color .45s linear}
.manifesto-t .mw.on{color:var(--ink)}

/* ============ stats ============ */
.stats{padding:0 0 110px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.stat{padding-top:22px;border-top:1.5px solid rgba(201,162,39,.6)}
.stat-n{display:block;font-family:var(--serif);font-size:clamp(2rem,3.8vw,3.2rem);line-height:1.05;color:var(--green);font-variant-numeric:tabular-nums}
.stat-n b{font-weight:400}
.stat-l{display:block;margin-top:7px;color:var(--mut);font-size:.9rem}
@media(max-width:820px){.stats-grid{grid-template-columns:repeat(2,1fr)}}

/* ============ before/after gallery (3-up) ============ */
.transform{padding:110px 0 90px;background:var(--cream2)}
.tf-sub{color:var(--ink2);max-width:560px;margin-top:14px}
.tf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:1240px;margin:52px auto 0;padding:0 28px}
.tf-card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:0 24px 60px rgba(26,77,58,.12)}
.tf-stage{position:relative;aspect-ratio:16/10;overflow:hidden;cursor:ew-resize;touch-action:pan-y;user-select:none}
.tf-stage img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.tf-after{z-index:0}
.tf-before{position:absolute;inset:0;overflow:hidden;width:50%;z-index:1;will-change:width}
.tf-before img{width:auto;height:100%;max-width:none}
.tf-div{position:absolute;top:0;bottom:0;left:50%;width:2px;z-index:2;background:linear-gradient(180deg,transparent,#fff 12%,#fff 88%,transparent);box-shadow:0 0 16px rgba(227,178,60,.7);will-change:left;transform:translateX(-1px)}
.tf-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--green2);background:linear-gradient(135deg,#fff,var(--gold2));box-shadow:0 6px 20px rgba(0,0,0,.35)}
.tf-tagb,.tf-taga{position:absolute;top:12px;z-index:2;font-size:.6rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;padding:5px 10px;border-radius:999px;color:#fff;background:rgba(18,40,30,.55);backdrop-filter:blur(6px);transition:opacity .3s}
.tf-tagb{left:12px}
.tf-taga{right:12px;color:#ffe9b0}
.tf-card figcaption{padding:20px 22px 24px;font-size:.92rem;color:var(--mut)}
.tf-card figcaption b{display:block;font-family:var(--serif);color:var(--green);font-size:1.25rem;margin-bottom:5px}
.reveal-cap{max-width:1240px;margin:0 auto;padding:0 28px;color:var(--mut);font-size:.95rem}
.reveal-cap.center{text-align:center;margin-top:40px}
@media(max-width:1000px){.tf-grid{grid-template-columns:1fr;max-width:560px}}

/* ============ cleaner band ============ */
.crew{position:relative;min-height:84svh;display:flex;align-items:flex-end;overflow:clip;padding:0 0 64px}
.crew-media{position:absolute;inset:0;z-index:0;overflow:hidden}
.crew-media img{width:100%;height:118%;object-fit:cover;object-position:50% 30%}
.crew-scrim{position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,40,30,.85) 0%,rgba(15,40,30,.5) 42%,rgba(15,40,30,.1) 72%,transparent 100%),linear-gradient(0deg,var(--cream),transparent 42%)}
.crew-copy{position:relative;z-index:1;color:#fff}
.crew-copy .h2{color:#fff}
.crew-copy .accent{background:linear-gradient(95deg,#ffe9b0,var(--gold2));-webkit-background-clip:text;background-clip:text;color:transparent}
.crew-copy .eyebrow{color:#ffd97a}
.crew-sub{max-width:480px;margin-top:16px;color:#efe9d8}
@media(max-width:700px){.crew{min-height:70svh}.crew-media img{object-position:62% 30%}}

/* ============ cursor reveal ============ */
.reveal-sec{padding:110px 0 50px}
.reveal-stage-wrap{padding:46px 28px 24px;max-width:1240px;margin:0 auto}
.reveal-stage{position:relative;border-radius:26px;overflow:hidden;aspect-ratio:16/9;box-shadow:0 40px 100px rgba(26,77,58,.2),0 0 0 1px var(--line);transform:translateZ(0)}
.reveal-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.reveal-clip{position:absolute;inset:0;clip-path:circle(0px at 50% 50%);will-change:clip-path}
.reveal-hint{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;transition:opacity .5s}
.reveal-hint.off{opacity:0}
.reveal-hint span{font-family:var(--serif);font-style:italic;font-size:clamp(1.1rem,2.2vw,1.6rem);color:#fff;background:rgba(18,40,30,.55);backdrop-filter:blur(8px);padding:13px 28px;border-radius:999px}
@media(max-width:820px){.reveal-stage{aspect-ratio:4/3}.reveal-stage-wrap{padding:34px 16px 18px}}

/* ============ stack cards ============ */
.rooms{padding:110px 0 70px;background:var(--cream)}
.stack{max-width:1240px;margin:50px auto 0;padding:0 28px}
.stack-card{position:sticky;top:calc(84px + var(--i)*16px);display:grid;grid-template-columns:1.05fr .95fr;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:32px;box-shadow:0 26px 70px rgba(26,77,58,.13);will-change:transform;transform-origin:top center}
.sc-body{padding:clamp(26px,4vw,54px);display:flex;flex-direction:column;justify-content:center}
.sc-n{font-size:.76rem;font-weight:800;letter-spacing:.24em;color:var(--gold);margin-bottom:14px}
.sc-t{font-family:var(--serif);font-weight:400;font-size:clamp(1.7rem,3.1vw,2.6rem);line-height:1.06;margin-bottom:20px;color:var(--green)}
.sc-t em{font-style:italic}
.sc-list{list-style:none;display:grid;gap:10px}
.sc-list li{position:relative;padding-left:28px;color:var(--ink2);font-size:.97rem}
.sc-list li::before{content:"✦";position:absolute;left:0;color:var(--gold2);font-size:.8rem}
.sc-media{position:relative;min-height:320px;overflow:hidden}
.sc-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
@media(max-width:860px){.stack-card{grid-template-columns:1fr}.sc-media{min-height:225px;order:-1}}

/* ============ pricing ============ */
.pricing{padding:110px 0;background:var(--cream2)}
.price-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:50px}
.p-card{position:relative;display:flex;flex-direction:column;gap:6px;padding:26px 20px 20px;border-radius:22px;background:var(--card);border:1.5px solid var(--line);box-shadow:0 18px 50px rgba(26,77,58,.09);transition:transform .35s var(--ease),box-shadow .35s,border-color .35s}
.p-card:hover{transform:translateY(-6px);box-shadow:0 30px 70px rgba(26,77,58,.16);border-color:rgba(26,77,58,.3)}
.p-card.popular{border-color:var(--gold);box-shadow:0 26px 66px rgba(201,162,39,.22)}
.p-pop{position:absolute;top:-12px;left:50%;transform:translateX(-50%);font-size:.62rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;background:linear-gradient(120deg,var(--gold2),var(--gold));color:var(--green2);padding:5px 13px;border-radius:999px;white-space:nowrap}
.p-beds{font-size:.86rem;font-weight:700;color:var(--ink2)}
.p-amt{font-family:var(--serif);font-size:2.5rem;line-height:1.05;color:var(--green)}
.p-amt i{font-style:normal;font-size:1rem;color:var(--gold);vertical-align:super}
.p-inc{font-size:.76rem;color:var(--mut);margin-bottom:12px}
.p-card .btn{margin-top:auto;padding:12px}
.addons{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:36px;padding-top:24px;border-top:1px solid var(--line);color:var(--mut);font-size:.92rem;justify-content:center}
.addon b{color:var(--green)}
.price-fine{text-align:center;margin-top:18px;color:var(--mut);font-size:.85rem}
.price-fine b{color:var(--green)}
@media(max-width:1080px){.price-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.price-grid{grid-template-columns:repeat(2,1fr)}.p-amt{font-size:2rem}}

/* ============ guarantee (deep green band) ============ */
.guarantee{padding:120px 0;background:linear-gradient(160deg,var(--green2),var(--green));color:#f2edde;border-radius:48px 48px 0 0}
.guarantee .eyebrow{color:var(--gold2)}
.guarantee .h2{color:#fdf9ee}
.guarantee .h2 .accent{background:linear-gradient(95deg,#ffe9b0,var(--gold2));-webkit-background-clip:text;background-clip:text;color:transparent}
.g-grid{display:grid;grid-template-columns:.62fr 1.38fr;gap:60px;align-items:center}
.g-shield{position:relative}
.shield-svg{width:min(225px,56vw);margin:0 auto;display:block}
.shield-path{fill:rgba(227,178,60,.07);stroke:var(--gold2);stroke-width:2.5;stroke-dasharray:460;stroke-dashoffset:460;filter:drop-shadow(0 0 14px rgba(227,178,60,.35))}
.shield-tick{fill:none;stroke:#fff;stroke-width:7;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:90;stroke-dashoffset:90}
.g-shield.in .shield-path{animation:draw 1.6s var(--ease) forwards}
.g-shield.in .shield-tick{animation:draw .7s var(--ease) 1.2s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.g-badge{position:absolute;left:50%;bottom:-14px;transform:translateX(-50%);text-align:center;background:rgba(15,50,38,.85);border:1px solid rgba(227,178,60,.45);border-radius:14px;padding:8px 18px;white-space:nowrap}
.g-badge span{font-family:var(--serif);font-size:1.15rem;color:var(--gold2)}
.g-badge em{display:block;font-style:normal;font-size:.6rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#cfc6ac}
.g-points{display:grid;gap:15px;margin-top:30px}
.g-point{padding:21px 23px;border-radius:18px;background:rgba(249,244,232,.06);border:1px solid var(--lineL);color:#d8d2bf;font-size:.96rem}
.g-point strong{display:block;color:#fdf9ee;margin-bottom:3px}
@media(max-width:860px){.g-grid{grid-template-columns:1fr;gap:48px}.guarantee{border-radius:32px 32px 0 0}}

/* ============ reviews ============ */
.reviews{padding:120px 0 110px;background:var(--cream);overflow:hidden}
.g-card{display:flex;align-items:center;gap:22px;max-width:760px;margin:44px auto 0;padding:26px 30px;border-radius:24px;background:var(--card);border:1.5px solid var(--line);box-shadow:0 26px 70px rgba(26,77,58,.14);transition:transform .3s var(--ease),box-shadow .3s}
.g-card:hover{transform:translateY(-3px);box-shadow:0 34px 90px rgba(26,77,58,.2)}
.g-card-mid{flex:1;display:flex;flex-direction:column;gap:2px}
.g-stars{color:var(--gold);letter-spacing:4px;font-size:1.3rem}
.g-count{font-family:var(--serif);font-size:1.5rem;color:var(--green)}
.g-count b{font-weight:400}
.g-sub{font-size:.82rem;color:var(--mut)}
.g-go{font-weight:700;color:var(--green);white-space:nowrap;border-bottom:1.5px solid rgba(26,77,58,.3)}
@media(max-width:680px){.g-card{flex-direction:column;text-align:center;gap:12px}.g-go{border:none}}
.r-marquee{margin-top:46px;mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.r-track{display:flex;gap:20px;width:max-content;will-change:transform}
.review{width:320px;flex-shrink:0;padding:26px 28px;border-radius:var(--r);background:var(--card);border:1px solid var(--line);box-shadow:0 14px 40px rgba(26,77,58,.07)}
.r-stars{color:var(--gold);letter-spacing:3px;margin-bottom:12px;font-size:.85rem}
.review p{font-family:var(--serif);font-size:1.25rem;line-height:1.35;color:var(--green)}
.r-who{margin-top:12px;font-size:.82rem;color:var(--mut)}

/* ============ areas map ============ */
.areas{padding:110px 0;background:var(--cream2)}
.area-map{max-width:880px;margin:44px auto 0;border-radius:24px;border:1px solid var(--line);background:linear-gradient(180deg,#fffdf6,#faf5e9);box-shadow:0 30px 80px rgba(26,77,58,.12);overflow:hidden}
.area-map svg{display:block;width:100%;height:auto}
.coast{fill:rgba(26,77,58,.04);stroke:rgba(26,77,58,.4);stroke-width:1.6;stroke-dasharray:3400;stroke-dashoffset:3400}
.area-map.in .coast{animation:coastDraw 2.6s var(--ease) .2s forwards}
@keyframes coastDraw{to{stroke-dashoffset:0}}
.river{fill:none;stroke:rgba(78,131,180,.4);stroke-width:1.4;stroke-dasharray:160;stroke-dashoffset:160}
.area-map.in .river{animation:coastDraw 1.4s var(--ease) 1.4s forwards}
.dotg{opacity:0;transform:scale(0);transform-box:fill-box;transform-origin:center;transition:opacity .5s var(--ease),transform .65s cubic-bezier(.34,1.56,.64,1);transition-delay:calc(var(--d) + .9s)}
.area-map.in .dotg{opacity:1;transform:scale(1)}
.dot{fill:var(--green);filter:drop-shadow(0 0 6px rgba(26,77,58,.5))}
.dotg.home .dot{fill:var(--gold);filter:drop-shadow(0 0 8px rgba(201,162,39,.8))}
.dot-pulse{fill:none;stroke:rgba(26,77,58,.5);stroke-width:1.5;transform-box:fill-box;transform-origin:center;animation:mapPulse 3s ease-out infinite;animation-delay:var(--d)}
.dotg.home .dot-pulse{stroke:rgba(201,162,39,.7)}
@keyframes mapPulse{0%{transform:scale(.4);opacity:.9}70%,100%{transform:scale(2.3);opacity:0}}
.dot-label{fill:var(--ink2);font-size:13.5px;font-weight:700;letter-spacing:.02em;paint-order:stroke;stroke:rgba(249,244,232,.9);stroke-width:3px}
.dotg.home .dot-label{fill:var(--green);font-weight:800}
.lbl-l{text-anchor:end}
.lbl-c{text-anchor:middle}
.radar{fill:none;stroke:rgba(201,162,39,.45);stroke-width:1.2;transform-box:fill-box;transform-origin:center;animation:radarSweep 4.5s linear infinite}
.radar.r2{animation-delay:2.25s}
@keyframes radarSweep{0%{transform:scale(.25);opacity:.85}100%{transform:scale(12);opacity:0}}
.map-word{fill:rgba(26,77,58,.08);font-family:var(--serif);font-size:54px;letter-spacing:.14em}
.map-sea{fill:rgba(78,131,180,.35);font-size:13px;font-weight:700;letter-spacing:.5em}
.areas-note{text-align:center;color:var(--mut);margin-top:26px;font-size:.95rem}
@media(max-width:640px){.dot-label{font-size:19px}.map-word{font-size:64px}}

/* ============ faq ============ */
.faq{padding:110px 0;background:var(--cream)}
.faq .h2{margin-bottom:30px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{padding:22px 44px 22px 0;font-weight:700;font-size:1.06rem;cursor:pointer;list-style:none;position:relative;color:var(--green2)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);color:var(--gold);font-size:1.5rem;font-weight:300;transition:transform .35s var(--ease)}
.faq-item[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq-item p{padding:0 0 22px;color:var(--mut);max-width:640px}

/* ============ footer ============ */
.footer{position:relative;background:linear-gradient(170deg,var(--green),var(--green2));color:#efe9d8;padding:110px 0 0;overflow:hidden;border-radius:48px 48px 0 0}
.f-cta{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-bottom:64px;border-bottom:1px solid var(--lineL)}
.f-h{font-family:var(--serif);font-weight:400;font-size:clamp(2.5rem,5.8vw,4.8rem);line-height:1.04;color:#fdf9ee}
.f-h .accent{background:linear-gradient(95deg,#ffe9b0,var(--gold2));-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic}
.f-btns{display:flex;gap:14px;flex-wrap:wrap}
.f-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;padding:50px 0 26px}
.f-k{font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#a8b5a3;margin-bottom:8px}
.f-link{color:#e3ddc9;font-size:.95rem;line-height:1.5}
a.f-link:hover{color:var(--gold2)}
.f-wordmark{font-family:var(--serif);font-style:italic;font-size:clamp(4.2rem,14vw,12.5rem);line-height:.85;text-align:center;color:transparent;-webkit-text-stroke:1px rgba(249,244,232,.16);user-select:none;transform:translateY(12%)}
.f-wordmark b{-webkit-text-stroke:0;color:rgba(227,178,60,.4);font-size:.4em;font-style:normal;vertical-align:super}
.f-fine{position:relative;text-align:center;color:#8d9b89;font-size:.76rem;padding:12px 28px 26px}
@media(max-width:820px){.f-grid{grid-template-columns:repeat(2,1fr)}.footer{border-radius:32px 32px 0 0}}

/* ============ sticky cta (mobile) ============ */
.sticky-cta{position:fixed;left:12px;right:12px;bottom:12px;z-index:80;display:none;align-items:stretch;gap:10px;transform:translateY(140%);transition:transform .55s var(--ease)}
.sticky-cta.show{transform:none}
.call-fab{flex-shrink:0;width:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;color:var(--cream);background:linear-gradient(135deg,var(--green),#2e7a55);box-shadow:0 14px 40px rgba(26,77,58,.4)}
.call-fab svg{animation:ring 2.6s ease-in-out infinite}
.sc-quote{flex:1;border-radius:16px;box-shadow:0 16px 50px rgba(26,77,58,.4)}
@media(max-width:760px){.sticky-cta{display:flex}}

/* ============ reduced motion ============ */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .rv,.hero-h1 .word{opacity:1!important;transform:none!important}
  .float-card{opacity:1}
  .manifesto-t .mw{color:var(--ink)}
  .loader{display:none}
  .reveal-clip{clip-path:circle(34% at 62% 50%)!important}
  .dotg{opacity:1!important;transform:none!important}
  .coast,.river{stroke-dashoffset:0!important}
}
