:root{
  /* ---- ELEVATION: higher = lighter (this IS the depth cue) ---- */
  --bg:        #0A0F0C;
  --surface-1: #121813;
  --surface-2: #18211B;
  --surface-3: #202B23;
  /* slime-tinted deep gradient for the "spotlight" dark panels */
  --panel-a:   #15231A;
  --panel-b:   #0C140F;

  /* ---- HAIRLINES / BORDERS ---- */
  --line:    rgba(255,255,255,.08);
  --line-2:  rgba(255,255,255,.14);
  --line-ui: #5A6857;                 /* SOLID control borders = 3.0:1 min */
  --line-slime: rgba(123,191,42,.40);
  --hi-inset: inset 0 1px 0 rgba(255,255,255,.06);

  /* ---- TEXT ---- */
  --text:  #F2F6F0;
  --body:  #C2CBBE;
  --muted: #8B9686;

  /* ---- BRAND GREENS ---- */
  --slime:        #7BBF2A;
  --slime-bright: #8FE04A;
  --slime-deep:   #5D9E16;
  --on-slime:     #0A0F0C;   /* DARK INK on any green fill */

  /* ---- SEMANTIC ---- */
  --mint:  #3FD37D;
  --amber: #F2B33D;
  --on-amber: #1A1400;
  --error: #FF6B5E;

  /* ---- GLOWS (the only "shadow" that reads on dark) ---- */
  --glow-cta:   0 10px 28px -8px rgba(123,191,42,.55);
  --glow-soft:  0 24px 60px -30px rgba(0,0,0,.8);
  --glow-slime: 0 0 40px rgba(123,191,42,.28);
  --ring:       0 0 0 3px rgba(123,191,42,.25);

  --font-display:'Sora',sans-serif;
  --font-body:'Spline Sans',sans-serif;
  --font-mono:'JetBrains Mono',monospace;
  --ease:cubic-bezier(.16,1,.3,1);
  --maxw:1140px;

  /* radii */
  --r-sm:10px; --r:16px; --r-lg:22px; --r-pill:999px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;color-scheme:dark}
body{
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(123,191,42,.06), transparent 60%),
    var(--bg);
  background-attachment:fixed;
  color:var(--body);
  font-family:var(--font-body);
  line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.5rem)}
h1,h2,h3{font-family:var(--font-display);line-height:1.05;letter-spacing:-.02em;color:var(--text);text-wrap:balance}
.mono{font-family:var(--font-mono)}
a{color:inherit}
a,button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.out-big,.out-row .v,.amt,.launch-spots b,.launch-booked b{font-variant-numeric:tabular-nums}
section[id]{scroll-margin-top:84px}
img{max-width:100%}
::selection{background:var(--slime);color:var(--on-slime)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* skip link */
.skip{position:absolute;left:-9999px;top:0;z-index:200;background:var(--slime);color:var(--on-slime);
  font-family:var(--font-mono);font-weight:700;padding:.7rem 1.1rem;border-radius:0 0 12px 0}
.skip:focus{left:0}

/* universal visible focus */
:where(a,button,input,select,textarea,summary,[tabindex]):focus-visible{
  outline:2px solid var(--slime-bright);outline-offset:2px;border-radius:6px}

/* reveal gated on JS so no-JS = visible */
.reveal{opacity:1;transform:none}
.js .reveal{opacity:0;transform:translateY(28px) scale(.99);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal.in{opacity:1;transform:none}

/* ===== NAV ===== */
nav{position:sticky;top:0;z-index:50;background:rgba(10,15,12,.72);backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:padding .18s var(--ease),border-color .18s}
.navin{display:flex;align-items:center;justify-content:space-between;padding:.7rem 0;gap:1rem}
nav.scrolled .navin{padding:.5rem 0}
nav.scrolled{border-bottom-color:var(--line-2)}
.navlogo{display:flex;align-items:center;gap:.55rem;font-family:var(--font-display);font-weight:800;font-size:1.15rem;text-decoration:none}
.navlogo img{height:34px;width:auto;display:block;filter:drop-shadow(0 0 10px rgba(123,191,42,.45))}
.navlinks{display:flex;gap:1.4rem;align-items:center}
.navlinks a{font-family:var(--font-mono);font-size:.76rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;text-decoration:none;color:var(--muted);transition:color .2s}
.navlinks a:hover{color:var(--text)}
@media(max-width:820px){.navlinks{display:none}}
.navcta{display:inline-flex;align-items:center;justify-content:center;min-height:44px;font-family:var(--font-mono);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;background:var(--slime);color:var(--on-slime);padding:.5rem 1.05rem;border-radius:var(--r-pill);text-decoration:none;transition:transform .2s var(--ease),box-shadow .2s var(--ease);white-space:nowrap}
.navcta:hover{transform:translateY(-2px);box-shadow:var(--glow-cta)}

/* ===== HERO ===== */
header{position:relative;overflow:hidden;text-align:center;
  padding:clamp(2.4rem,6vw,4rem) 0 clamp(1.5rem,4vw,2.5rem);
  background:radial-gradient(60% 50% at 50% 22%, rgba(123,191,42,.18), transparent 70%), var(--bg)}
header::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:
    linear-gradient(rgba(123,191,42,.045) 1px,transparent 1px) 0 0/48px 48px,
    linear-gradient(90deg,rgba(123,191,42,.045) 1px,transparent 1px) 0 0/48px 48px;
  -webkit-mask:radial-gradient(70% 60% at 50% 30%,#000,transparent 75%);
          mask:radial-gradient(70% 60% at 50% 30%,#000,transparent 75%)}
header .wrap{position:relative;z-index:1}
.hero-logo{max-width:min(360px,60vw);height:auto;margin:0 auto;display:block;will-change:transform;transition:transform .3s var(--ease);
  filter:drop-shadow(0 0 30px rgba(123,191,42,.45)) drop-shadow(0 8px 20px rgba(0,0,0,.55));
  animation:logo-breathe 6s var(--ease) infinite}
header::before{animation:gridDrift 18s linear infinite}
@keyframes gridDrift{to{background-position:48px 48px,48px 48px}}
@media(max-width:480px){.hero-logo{max-width:64vw}}
@keyframes logo-breathe{0%,100%{filter:drop-shadow(0 0 30px rgba(123,191,42,.34)) drop-shadow(0 10px 26px rgba(0,0,0,.55))}50%{filter:drop-shadow(0 0 46px rgba(123,191,42,.52)) drop-shadow(0 10px 26px rgba(0,0,0,.55))}}
.local-eyebrow{display:inline-block;margin-top:1.2rem;font-family:var(--font-mono);font-size:.76rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.local-eyebrow b{color:var(--slime-bright);font-weight:700}
.promise{display:inline-flex;align-items:center;gap:.6rem;margin-top:1rem;background:rgba(123,191,42,.10);border:1px solid var(--line-slime);border-radius:var(--r-pill);padding:.55rem 1.2rem;font-family:var(--font-mono);font-size:.82rem;font-weight:700;letter-spacing:.02em;color:var(--slime-bright);text-transform:uppercase;box-shadow:var(--hi-inset)}
.promise svg{width:16px;height:16px;stroke:var(--slime);fill:none;stroke-width:2.4}
h1.hero{margin-top:1.2rem;font-size:clamp(2.1rem,5.5vw,3.6rem);font-weight:800;line-height:1.03;max-width:20ch;margin-left:auto;margin-right:auto}
h1.hero .hl{color:var(--slime-bright)}
.lede{margin:1rem auto 0;font-size:clamp(1.02rem,2vw,1.22rem);color:var(--body);max-width:54ch}
.herocta{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap;margin-top:1.4rem}
@media(max-width:480px){.herocta{flex-direction:column}.herocta .btn{width:100%}}
.trustrow{margin-top:1rem;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
/* hide phone affordances until Chris's number is wired in (remove .no-phone on <html>) */
.no-phone .needs-phone{display:none !important}

/* ===== CALCULATOR ===== */
#calc{scroll-margin-top:80px}
.calc-shell{margin:clamp(1.8rem,4vw,2.6rem) auto 0;max-width:920px;background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.3rem,3vw,2.2rem);text-align:left;box-shadow:var(--hi-inset),var(--glow-soft)}
.calc-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.4rem}
.calc-head h2{font-size:clamp(1.3rem,3vw,1.9rem);font-weight:800}
.calc-head .tag{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--slime-bright)}
.calc-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:1.2rem}
@media(max-width:760px){.calc-grid{grid-template-columns:1fr}}
.calc-input{background:var(--surface-2);border:1px solid var(--line-2);border-radius:var(--r);padding:1.4rem;box-shadow:var(--hi-inset)}
.field{margin-bottom:1.3rem}
.field:last-child{margin-bottom:0}
.field label{display:block;font-family:var(--font-mono);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.billrow{display:flex;align-items:center;gap:.5rem;background:var(--bg);border:1.5px solid var(--line-ui);border-radius:12px;padding:.45rem .85rem;transition:border-color .2s,box-shadow .2s}
.billrow:focus-within{border-color:var(--slime);box-shadow:var(--ring)}
.billrow .cur{font-family:var(--font-mono);color:var(--slime-bright);font-weight:700;font-size:1.2rem}
.billrow input{flex:1;background:none;border:none;color:var(--text);font-family:var(--font-display);font-weight:800;font-size:1.6rem;outline:none;width:100%;-moz-appearance:textfield;appearance:textfield}
.billrow input::-webkit-outer-spin-button,.billrow input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.seg{display:flex;gap:.45rem;flex-wrap:wrap}
.seg button{flex:1;min-width:68px;min-height:44px;font-family:var(--font-mono);font-size:.8rem;font-weight:700;padding:.6rem .3rem;border-radius:var(--r-sm);border:1px solid var(--line-ui);background:var(--bg);color:var(--body);cursor:pointer;transition:all .2s var(--ease)}
.seg button[aria-pressed="true"]{background:var(--slime);color:var(--on-slime);border-color:var(--slime)}
.slider{width:100%;-webkit-appearance:none;appearance:none;height:8px;border-radius:var(--r-pill);background:linear-gradient(90deg,#3a5236,var(--slime));outline:none;margin:.8rem 0 .2rem;cursor:pointer}
.slider::-webkit-slider-runnable-track{height:8px;border-radius:var(--r-pill);background:transparent}
.slider::-webkit-slider-thumb{-webkit-appearance:none;width:26px;height:26px;margin-top:-9px;border-radius:50%;background:var(--bg);border:2px solid var(--slime);cursor:pointer;box-shadow:0 0 10px rgba(123,191,42,.6)}
.slider::-moz-range-track{height:8px;border-radius:var(--r-pill);background:transparent}
.slider::-moz-range-thumb{width:26px;height:26px;border:2px solid var(--slime);border-radius:50%;background:var(--bg);cursor:pointer;box-shadow:0 0 10px rgba(123,191,42,.6)}
.slidertags{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.7rem;color:var(--muted);margin-top:.1rem}
.calc-out{background:linear-gradient(155deg,var(--panel-a),var(--panel-b));border:1px solid var(--line-slime);border-radius:var(--r);padding:1.5rem;color:var(--text);position:relative;overflow:hidden;box-shadow:var(--hi-inset)}
.calc-out::after{content:"";position:absolute;width:300px;height:300px;right:-110px;top:-110px;border-radius:50%;background:radial-gradient(circle,rgba(123,191,42,.35),transparent 65%)}
.out-label{font-family:var(--font-mono);font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);position:relative;z-index:1}
.out-big{font-family:var(--font-display);font-weight:800;font-size:clamp(2.6rem,7vw,3.9rem);color:var(--slime-bright);line-height:1;margin:.35rem 0 .2rem;position:relative;z-index:1;text-shadow:0 0 24px rgba(143,224,74,.35);transition:transform .25s var(--ease)}
.out-big.bump{transform:scale(1.04)}
.out-sub{color:var(--body);font-size:.95rem;position:relative;z-index:1}
.out-divider{height:1px;background:rgba(255,255,255,.14);margin:1.3rem 0;position:relative;z-index:1}
.out-rows{position:relative;z-index:1;display:flex;flex-direction:column;gap:.7rem}
.out-row{display:flex;justify-content:space-between;align-items:baseline;font-size:.95rem;gap:1rem}
.out-row .k{color:var(--muted)}
.out-row .v{font-family:var(--font-display);font-weight:700;color:var(--text)}
.out-row .v.mint{color:var(--mint)}
.out-payback{position:relative;z-index:1;margin-top:1rem;font-size:.9rem;color:var(--body)}
.out-payback b{color:var(--slime-bright)}
.out-cta{margin-top:1.2rem;position:relative;z-index:1;display:block}

/* ===== BUTTONS ===== */
.btn{position:relative;overflow:hidden;isolation:isolate;font-family:var(--font-mono);font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.04em;padding:1rem 1.5rem;border-radius:var(--r-pill);text-decoration:none;cursor:pointer;border:none;transition:transform .22s var(--ease),box-shadow .22s var(--ease),background .2s,border-color .2s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:48px}
/* liquid shine sweep on hover */
.btn::after{content:"";position:absolute;top:0;left:0;height:100%;width:55%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.5),transparent);transform:translateX(-200%) skewX(-18deg);pointer-events:none}
.btn:hover::after,.btn:focus-visible::after{animation:btnshine .8s var(--ease)}
@keyframes btnshine{0%{transform:translateX(-200%) skewX(-18deg)}100%{transform:translateX(260%) skewX(-18deg)}}
.btn-slime{background:var(--slime);color:var(--on-slime);box-shadow:var(--glow-cta)}
.btn-slime:hover{transform:translateY(-3px);background:#6FAE25;box-shadow:0 18px 44px -10px rgba(123,191,42,.85),var(--glow-slime)}
.btn-slime:active{transform:translateY(-1px) scale(.985)}
.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--line-ui)}
.btn-ghost:hover{background:var(--surface-3);border-color:var(--line-slime);transform:translateY(-2px)}
.btn-ghost:active{transform:scale(.985)}

/* ===== SECTIONS ===== */
section{padding:clamp(3.4rem,8vw,6rem) 0}
.eyebrow{font-family:var(--font-mono);font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slime-bright);margin-bottom:.8rem}
h2.sec{font-size:clamp(1.7rem,4vw,2.7rem);font-weight:800;max-width:20ch}
.sec-lede{margin-top:.9rem;color:var(--body);max-width:54ch;font-size:1.05rem}

/* price promise band */
.band{position:relative;background:linear-gradient(150deg,var(--panel-a),var(--panel-b));border:1px solid var(--line-slime);border-radius:var(--r-lg);box-shadow:var(--hi-inset);padding:clamp(1.8rem,4vw,2.8rem);text-align:center}
.band::after{content:"";position:absolute;left:24px;right:24px;bottom:-20px;height:44px;background:url("slime-drip.svg") repeat-x top center/240px 44px;filter:drop-shadow(0 6px 12px rgba(123,191,42,.3));pointer-events:none;opacity:.92}
.band h2{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;max-width:22ch;margin:0 auto}
.band h2 .hl{color:var(--slime-bright)}
.band p{color:var(--body);margin:1rem auto 0;max-width:48ch}

/* dirty-truth cards */
.cards3{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1rem;margin-top:2.2rem}
.pcard{background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r);padding:1.5rem;box-shadow:var(--hi-inset);transition:transform .2s var(--ease),border-color .2s}
.pcard:hover{transform:translateY(-3px);border-color:var(--line-2)}
.pcard .ic{width:44px;height:44px;border-radius:12px;background:rgba(123,191,42,.12);display:grid;place-items:center;margin-bottom:1rem}
.pcard .ic svg{width:23px;height:23px;stroke:var(--slime);fill:none;stroke-width:1.9}
.pcard h3{font-size:1.15rem;margin-bottom:.4rem}
.pcard p{color:var(--body);font-size:.95rem}

/* ===== JOURNEY ===== */
.journey{margin-top:2.4rem;background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1rem,3vw,2rem);box-shadow:var(--hi-inset)}
.jscene{width:100%;height:auto;display:block;border-radius:var(--r);background:var(--surface-1);border:1px solid var(--line)}
.jproof{margin-top:1rem;text-align:center;color:var(--body);font-size:1rem;display:none}
.jproof b{color:var(--slime-bright)}
.jcaps{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem;margin-top:1.2rem}
@media(max-width:760px){.jcaps{grid-template-columns:1fr 1fr}}
.jcap{font-family:var(--font-mono);font-size:.82rem;color:var(--body);padding:.7rem .8rem;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--surface-2);transition:all .35s var(--ease);cursor:pointer}
.jcap .jn{display:block;font-weight:700;color:var(--slime-bright);margin-bottom:.2rem}
.jcap.on{background:var(--slime);color:var(--on-slime);border-color:var(--slime);transform:translateY(-3px)}
.jcap.on .jn{color:var(--on-slime)}
@media(max-width:600px){.jscene{min-height:200px}.j-txt{display:none}.jproof{display:block}}

/* journey: one panel, dirty -> clean, with an output gauge that fills */
.j-sun{transform-box:fill-box;transform-origin:center;animation:jspin 60s linear infinite}
@keyframes jspin{to{transform:rotate(360deg)}}
.j-grime{transition:opacity 1s var(--ease)}
.j-squeegee{transform:translateX(-90px);opacity:0;transition:transform 1.2s var(--ease),opacity .35s}
.j-gaugefill{transform-box:fill-box;transform-origin:bottom;transform:scaleY(.42);transition:transform 1s var(--ease)}
.j-sparkle{opacity:0;transition:opacity .6s var(--ease)}
.j-glow{opacity:0;transition:opacity 1s var(--ease)}
.j-badge{opacity:0;transform:translateY(12px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
#journey.s1 .j-squeegee{transform:translateX(330px);opacity:1}
#journey.s1 .j-grime{opacity:.3}
#journey.s1 .j-gaugefill{transform:scaleY(.68)}
#journey.s2 .j-squeegee{transform:translateX(380px);opacity:0}
#journey.s2 .j-grime{opacity:0}
#journey.s2 .j-gaugefill{transform:scaleY(1)}
#journey.s2 .j-glow{opacity:1}
#journey.s2 .j-sparkle{opacity:1;animation:twinkle 1.6s var(--ease) infinite}
#journey.s3 .j-squeegee{transform:translateX(380px);opacity:0}
#journey.s3 .j-grime{opacity:0}
#journey.s3 .j-gaugefill{transform:scaleY(1)}
#journey.s3 .j-glow{opacity:1}
#journey.s3 .j-sparkle{opacity:.85}
#journey.s3 .j-badge{opacity:1;transform:none}
@keyframes twinkle{0%,100%{opacity:.4}50%{opacity:1}}

/* ===== MEET CHRIS ===== */
.chris{margin-top:2.4rem;display:grid;grid-template-columns:.82fr 1.18fr;gap:1.8rem;align-items:center}
@media(max-width:760px){.chris{grid-template-columns:1fr}}
.chris-photo{aspect-ratio:4/5;border-radius:var(--r-lg);background:linear-gradient(160deg,var(--surface-2),var(--panel-b));border:1.5px dashed var(--line-slime);display:grid;place-items:center;text-align:center;padding:1.6rem;color:var(--muted);font-family:var(--font-mono);font-size:.82rem;line-height:1.5}
.chris-photo span{display:block}
.chris-body h2{font-size:clamp(1.5rem,4vw,2.2rem);font-weight:800;margin-bottom:.4rem}
.chris-list{display:flex;flex-direction:column;gap:.85rem;margin:1.2rem 0 0}
.chris-quote{margin-top:1.4rem;padding:1.1rem 1.3rem;border-left:3px solid var(--slime);background:var(--surface-2);border-radius:0 12px 12px 0;font-style:italic;color:var(--body)}
.chris-quote .ph{color:var(--amber)}

/* draft / placeholder system — AMBER = unconfirmed (distinct from brand green = fact) */
.draft{position:relative;border:1.5px dashed var(--amber);background:rgba(242,179,61,.07);border-radius:14px;padding:1.1rem 1.2rem}
.draft-tag{display:inline-block;background:var(--amber);color:var(--on-amber);font-family:var(--font-mono);font-weight:700;font-size:.62rem;text-transform:uppercase;letter-spacing:.06em;padding:.2rem .6rem;border-radius:var(--r-pill);margin-bottom:.5rem}
.draft .ph{color:var(--body)}
.draft .ph b{color:var(--text)}
.draft-note{margin-top:1rem;font-family:var(--font-mono);font-size:.78rem;color:var(--amber)}

/* ===== PRICING ===== */
.price3{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.1rem;margin-top:2.2rem}
.ptier{background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r);padding:1.7rem;display:flex;flex-direction:column;box-shadow:var(--hi-inset)}
.ptier.feature{background:var(--surface-3);border:1px solid var(--slime);box-shadow:var(--hi-inset),var(--glow-slime);position:relative}
.ptier.feature::before{content:"";position:absolute;inset:-1px 20% auto 20%;height:2px;background:var(--slime-bright);border-radius:2px;box-shadow:0 0 16px 2px rgba(143,224,74,.6)}
@media(min-width:761px){.ptier.feature{transform:translateY(-8px)}}
.ptier.feature .badge{position:absolute;top:-12px;left:1.7rem;background:var(--slime);color:var(--on-slime);font-family:var(--font-mono);font-weight:700;font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;padding:.25rem .7rem;border-radius:var(--r-pill)}
.ptier h3{font-size:1.2rem;margin-bottom:.2rem}
.ptier .who{color:var(--muted);font-size:.86rem;margin-bottom:.7rem;min-height:2.4em}
.ptier .from{color:var(--muted);font-size:.8rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em}
.ptier .amt{font-family:var(--font-display);font-weight:800;font-size:2.5rem;color:var(--text);margin:.2rem 0 1rem}
.ptier .amt .per{font-size:.95rem;color:var(--muted);font-weight:500}
.ptier.feature .amt{color:var(--slime-bright)}
.ptier ul{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.5rem}
.ptier li{display:flex;gap:.55rem;align-items:flex-start;font-size:.94rem;color:var(--body)}
.ptier li svg{width:17px;height:17px;stroke:var(--mint);fill:none;stroke-width:2.6;flex:0 0 auto;margin-top:.2rem}
.ptier .btn{margin-top:auto}
.pricenote{margin-top:1.3rem;font-family:var(--font-mono);font-size:.8rem;color:var(--muted);text-align:center}

/* recurring band */
.recur{margin-top:2.4rem;display:grid;grid-template-columns:1.3fr 1fr;gap:1.6rem;align-items:center;background:linear-gradient(150deg,var(--panel-a),var(--panel-b));border:1px solid var(--line-slime);border-radius:var(--r-lg);box-shadow:var(--hi-inset);padding:clamp(1.6rem,4vw,2.6rem)}
@media(max-width:740px){.recur{grid-template-columns:1fr}}
.recur .eyebrow{color:var(--slime-bright)}
.recur h3{font-size:clamp(1.5rem,3.5vw,2.1rem);font-weight:800;margin-bottom:.5rem}
.recur p{color:var(--body);font-size:1rem}
.recur-plans{display:flex;flex-direction:column;gap:.7rem}
.recur-plan{display:flex;justify-content:space-between;align-items:center;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:.9rem 1.1rem}
.recur-plan.feature{border-color:var(--line-slime);background:rgba(123,191,42,.12)}
.recur-plan .rp-k{font-family:var(--font-display);font-weight:800;font-size:1.1rem;color:var(--text)}
.recur-plan .rp-v{font-family:var(--font-mono);font-size:.78rem;color:var(--body);text-transform:uppercase;letter-spacing:.04em}

/* also offers strip */
.also{margin-top:1.8rem}
.also .also-in{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}

/* ===== LAUNCH OFFER ===== */
.launch{margin:0 auto;max-width:920px;background:linear-gradient(150deg,var(--panel-a),var(--panel-b));border:1px solid var(--line-slime);border-radius:var(--r-lg);box-shadow:var(--hi-inset),var(--glow-slime);padding:clamp(1.3rem,3vw,1.9rem);text-align:left}
.launch-top{display:flex;align-items:center;justify-content:space-between;gap:.8rem;flex-wrap:wrap;margin-bottom:.7rem}
.launch-tag{font-family:var(--font-mono);font-weight:700;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--amber);background:rgba(242,179,61,.12);border:1px solid rgba(242,179,61,.4);padding:.32rem .75rem;border-radius:var(--r-pill)}
.launch-spots{font-family:var(--font-mono);font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.launch-spots b{color:var(--slime-bright)}
.launch-h{font-size:clamp(1.4rem,3.5vw,2.05rem);font-weight:800;color:var(--text);margin-bottom:.3rem;line-height:1.1}
.launch-h .hl{color:var(--slime-bright)}
.launch-p{color:var(--body);font-size:.98rem;max-width:62ch;margin-bottom:1rem}
.launch-bar{height:10px;border-radius:var(--r-pill);background:var(--surface-2);border:1px solid var(--line);overflow:hidden}
.launch-fill{height:100%;width:0;border-radius:var(--r-pill);background:linear-gradient(90deg,var(--slime-deep),var(--slime-bright));box-shadow:0 0 14px rgba(143,224,74,.5);transition:width 1.2s var(--ease)}
.launch-foot{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:.9rem}
.launch-booked{font-family:var(--font-mono);font-size:.82rem;color:var(--body)}
.launch-booked b{color:var(--text)}
@media(max-width:520px){.launch-foot{flex-direction:column;align-items:stretch}.launch-foot .btn{width:100%}}

/* ===== SERVICE AREA ===== */
.area-chips{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.6rem}
.chip{font-family:var(--font-mono);font-size:.82rem;font-weight:600;padding:.5rem .9rem;border-radius:var(--r-pill);border:1px solid var(--line);background:var(--surface-2);color:var(--body)}
.chip.core{background:var(--slime);color:var(--on-slime);border-color:var(--slime);font-weight:700}
.chip.core::before{content:"\25cf  ";}
.area-links{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem}
.area-links a{font-family:var(--font-mono);font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--slime-bright);text-decoration:none;border:1px solid var(--line-slime);border-radius:var(--r-pill);padding:.7rem 1rem;transition:all .2s var(--ease)}
.area-links a:hover{background:var(--slime);color:var(--on-slime);border-color:var(--slime)}

/* ===== QUOTE FORM ===== */
#quote{scroll-margin-top:80px}
.quotecard{margin-top:2.2rem;background:var(--surface-1);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:clamp(1.5rem,4vw,2.8rem);box-shadow:var(--hi-inset),var(--glow-soft)}
.qgrid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:640px){.qgrid{grid-template-columns:1fr}}
.qfield{display:flex;flex-direction:column}
.qfield.full{grid-column:1/-1}
.qfield label{font-family:var(--font-mono);font-size:.73rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem}
.qfield input,.qfield select,.qfield textarea{background:var(--bg);border:1.5px solid var(--line-ui);border-radius:11px;padding:.85rem 1rem;color:var(--text);font-family:var(--font-body);font-size:1rem;outline:none;transition:border-color .2s,box-shadow .2s}
.qfield input::placeholder,.qfield textarea::placeholder{color:var(--muted)}
.qfield input:focus,.qfield select:focus,.qfield textarea:focus{border-color:var(--slime);box-shadow:var(--ring)}
.qfield select option{background:#0A0F0C;color:#F2F6F0}
.qfield input[aria-invalid="true"],.qfield select[aria-invalid="true"]{border-color:var(--error)}
.qerr{color:var(--error);font-size:.78rem;margin-top:.35rem;font-family:var(--font-mono);display:none}
.qerr.show{display:block}
.qhp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
input:-webkit-autofill,textarea:-webkit-autofill,select:-webkit-autofill{-webkit-text-fill-color:var(--text);-webkit-box-shadow:0 0 0 100px var(--bg) inset;caret-color:var(--text)}
.qnote{margin-top:1rem;font-size:.8rem;color:var(--muted)}
.qnote b{color:var(--body)}
.qok{display:none;margin-top:1.2rem;background:rgba(63,211,125,.12);border:1px solid rgba(63,211,125,.4);color:var(--mint);border-radius:12px;padding:1.3rem;font-weight:600}
.qok.show{display:block;animation:rise .4s var(--ease)}
.qok h3{color:var(--mint);font-size:1.3rem;margin-bottom:.4rem}
.qok p{color:var(--body);font-size:.95rem;font-weight:400}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ===== FAQ ===== */
.faq{margin-top:2rem;display:flex;flex-direction:column;gap:.6rem}
details{background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r);padding:1.05rem 1.25rem}
details[open]{border-color:var(--line-2)}
details summary{cursor:pointer;font-family:var(--font-display);font-weight:700;font-size:1.02rem;color:var(--text);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
details summary::-webkit-details-marker{display:none}
details summary::after{content:"+";font-family:var(--font-mono);color:var(--slime-bright);font-size:1.4rem;transition:transform .25s;flex:0 0 auto}
details[open] summary::after{transform:rotate(45deg)}
details p{margin-top:.7rem;color:var(--body);font-size:.95rem}
details .ph{color:var(--amber)}

/* ===== FOOTER ===== */
footer{position:relative;overflow:hidden;border-top:1px solid var(--line-slime);background:var(--bg);padding:4rem 0 2.2rem;margin-top:1.5rem}
footer::before{content:"";position:absolute;left:0;right:0;top:-1px;height:50px;background:url("slime-drip.svg") repeat-x top left/280px 50px;filter:drop-shadow(0 5px 12px rgba(123,191,42,.35));pointer-events:none;opacity:.9}
.footgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem}
@media(max-width:720px){.footgrid{grid-template-columns:1fr}}
.footgrid img{width:clamp(130px,40vw,156px);height:auto;margin-bottom:1.1rem;filter:drop-shadow(0 0 16px rgba(123,191,42,.5))}
.footcol h4{font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.8rem}
.footcol p,.footcol a{color:var(--body);font-size:.9rem;display:block;text-decoration:none;margin-bottom:.4rem}
.footcol a{text-decoration:underline;text-decoration-color:var(--line-2);text-underline-offset:3px}
.footcol a:hover{color:var(--text)}
.footcol p b{color:var(--text)}
.foot-suburbs{color:var(--muted);font-size:.86rem;line-height:1.7;text-decoration:none}
.footbar{margin-top:2rem;padding-top:1.4rem;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;align-items:center}
.footbar .small{color:var(--muted);font-size:.8rem;font-family:var(--font-mono)}

/* ===== MOBILE ACTION BAR ===== */
.mobilebar{display:none}
@media(max-width:820px){
  .mobilebar{display:grid;grid-template-columns:auto 1fr;gap:.6rem;position:fixed;left:0;right:0;bottom:0;z-index:60;padding:.6rem .9rem calc(.6rem + env(safe-area-inset-bottom));background:rgba(10,15,12,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid var(--line)}
  .mobilebar.solo{grid-template-columns:1fr}
  .mb-call,.mb-quote{display:flex;align-items:center;justify-content:center;min-height:48px;border-radius:var(--r-pill);font-family:var(--font-mono);font-weight:700;text-decoration:none;font-size:.85rem;letter-spacing:.03em}
  .mb-call{padding:0 1.1rem;border:1.5px solid var(--slime);color:var(--slime)}
  .mb-quote{background:var(--slime);color:var(--on-slime);box-shadow:var(--glow-cta)}
  body{padding-bottom:76px}
  .no-phone .mobilebar{grid-template-columns:1fr}
}

/* ===== SCROLL PROGRESS ===== */
.scrollprog{position:fixed;top:0;left:0;height:3px;width:0;z-index:70;background:linear-gradient(90deg,var(--slime-deep),var(--slime-bright));box-shadow:0 0 10px rgba(143,224,74,.6);transition:width .1s linear;pointer-events:none}

/* ===== BEFORE / AFTER (drag to clean) ===== */
.ba-wrap{margin:2.2rem auto 0;max-width:760px}
.ba{position:relative;aspect-ratio:16/10;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line-2);box-shadow:var(--hi-inset),var(--glow-soft);user-select:none;background:var(--surface-1)}
.ba-layer{position:absolute;inset:0}
.ba-layer svg{width:100%;height:100%;display:block}
.ba-dirty{clip-path:inset(0 calc(100% - var(--pos,50%)) 0 0)}
.ba-tag{position:absolute;top:.7rem;font-family:var(--font-mono);font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.28rem .6rem;border-radius:var(--r-pill);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2}
.ba-tag-before{left:.7rem;background:rgba(242,179,61,.18);color:var(--amber);border:1px solid rgba(242,179,61,.4)}
.ba-tag-after{right:.7rem;background:rgba(123,191,42,.16);color:var(--slime-bright);border:1px solid var(--line-slime)}
.ba-divider{position:absolute;top:0;bottom:0;left:var(--pos,50%);width:2px;background:var(--slime-bright);box-shadow:0 0 12px rgba(143,224,74,.7);transform:translateX(-1px);pointer-events:none;z-index:3}
.ba-grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:var(--slime);color:var(--on-slime);display:grid;place-items:center;box-shadow:var(--glow-cta)}
.ba-grip svg{width:20px;height:20px;stroke:var(--on-slime);fill:none;stroke-width:2.4}
.ba-range{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;-webkit-appearance:none;appearance:none;background:transparent;z-index:4}
.ba-range::-webkit-slider-thumb{-webkit-appearance:none;width:64px;height:300px;cursor:ew-resize}
.ba-range::-moz-range-thumb{width:64px;height:300px;border:0;background:transparent;cursor:ew-resize}
.ba-hint{margin-top:.9rem;font-family:var(--font-mono);font-size:.76rem;color:var(--muted);text-align:center}

/* ===== STICKY ESTIMATE CHIP ===== */
.estchip{position:fixed;right:20px;bottom:20px;z-index:55;display:none;align-items:center;gap:.9rem;background:var(--surface-2);border:1px solid var(--line-slime);border-radius:var(--r-pill);padding:.55rem .6rem .55rem 1.1rem;box-shadow:var(--hi-inset),var(--glow-soft);transform:translateY(20px);opacity:0;transition:transform .35s var(--ease),opacity .35s var(--ease)}
.estchip.show{display:flex;transform:none;opacity:1}
.estchip .ec-txt{font-family:var(--font-mono);font-size:.78rem;color:var(--body);line-height:1.25}
.estchip .ec-txt b{color:var(--slime-bright);font-variant-numeric:tabular-nums}
.estchip .ec-btn{font-family:var(--font-mono);font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.03em;background:var(--slime);color:var(--on-slime);padding:.55rem .95rem;border-radius:var(--r-pill);text-decoration:none;white-space:nowrap;min-height:40px;display:inline-flex;align-items:center}
@media(max-width:820px){.estchip{display:none!important}}

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