:root{
  --sand:#faf9f6;
  --sand-dark:#f1eee4;
  --sand-deep:#ebe7d9;
  --ink:#0b0707;
  --ink-soft:#46413e;
  --ink-mute:#6b655f;
  --line:#e7e2d4;
  --line-soft:#efebe0;
  --red:#db4545;
  --green:#16893f;
  --green-bright:#1aa64c;
  --green-light:#34c75f;
  --white:#fff;
  --wrap:75rem;
  --pad:1.5rem;
  --section:9rem;
  --font-body:'Inter',sans-serif;
  --font-head:'Inter Tight',sans-serif;
  --ease:cubic-bezier(.22,.7,.18,1);
  /* Mantine scale (spacing / radius / font-size), ported into the cadre brand */
  --mt-xs:.625rem; --mt-sm:.75rem; --mt-md:1rem; --mt-lg:1.25rem; --mt-xl:2rem;
  --rad-sm:8px; --rad-md:12px; --rad-lg:16px; --rad-xl:24px;
  --fz-xs:.75rem; --fz-sm:.875rem; --fz-md:1rem; --fz-lg:1.125rem; --fz-xl:1.25rem;
  --radius:16px;
  --radius-sm:12px;
  /* Mantine's signature layered soft shadows (contact + ambient + mid), ink-tinted */
  --shadow-xs:0 1px 3px rgba(11,7,7,.05),0 1px 2px rgba(11,7,7,.08);
  --shadow-1:0 1px 3px rgba(11,7,7,.05),0 10px 15px -5px rgba(11,7,7,.05),0 7px 7px -5px rgba(11,7,7,.04);
  --shadow-2:0 1px 3px rgba(11,7,7,.05),0 20px 25px -5px rgba(11,7,7,.06),0 10px 10px -5px rgba(11,7,7,.04);
  --shadow-3:0 1px 3px rgba(11,7,7,.06),0 28px 34px -7px rgba(11,7,7,.10),0 12px 12px -7px rgba(11,7,7,.05);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--sand);color:var(--ink);font-size:1.0625rem;line-height:1.62;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"cv05" 1,"cv08" 1,"ss03" 1,"calt" 1;font-variant-ligatures:common-ligatures contextual}
/* subtle paper grain — a hand-designed signal, not a flat AI canvas */
body::before{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--pad);position:relative;z-index:2}
section{padding:var(--section) 0;position:relative;z-index:2}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:600;line-height:1.06;letter-spacing:-0.028em;font-feature-settings:"ss01" 1,"cv11" 1}
.dot{color:var(--green-bright)}
.eyebrow{display:inline-flex;align-items:center;gap:.7rem;font-size:.75rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--green);margin-bottom:1.4rem}
.eyebrow::before{content:"";width:1.6rem;height:1px;background:currentColor;opacity:.55}
.hero .eyebrow,.cta-band .eyebrow,.stack .eyebrow,.quote .eyebrow{justify-content:center}
.lede{font-size:1.1875rem;color:var(--ink-soft);max-width:38rem;line-height:1.55}
::selection{background:var(--green-light);color:#062512}
:focus-visible{outline:2px solid var(--green-bright);outline-offset:3px;border-radius:4px}
img{max-width:100%}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--font-body);font-weight:600;font-size:.975rem;letter-spacing:-.005em;padding:.82rem 1.55rem;border-radius:11px;text-decoration:none;transition:transform .2s var(--ease),background .2s var(--ease),box-shadow .25s var(--ease),color .2s var(--ease);border:1px solid transparent;cursor:pointer}
.btn:active{transform:translateY(1px)}
.btn-dark{background:var(--ink);color:var(--white);box-shadow:var(--shadow-1)}
.btn-dark:hover{background:#1c1614;box-shadow:var(--shadow-2)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--white);border-color:var(--ink)}
.btn-light{background:var(--white);color:var(--ink);box-shadow:var(--shadow-1)}
.btn-light:hover{box-shadow:var(--shadow-2);transform:translateY(-1px)}
.btn-green{background:linear-gradient(135deg,#5fce2e 0%,#23a64c 52%,#16893f 100%);color:var(--white);box-shadow:0 1px 0 rgba(255,255,255,.22) inset,0 6px 16px rgba(22,137,63,.3)}
.btn-green:hover{background:linear-gradient(135deg,#68d836 0%,#28b454 52%,#1aa64c 100%);box-shadow:0 1px 0 rgba(255,255,255,.26) inset,0 10px 26px rgba(22,137,63,.4);transform:translateY(-1px)}
.btn .ico{transition:transform .22s var(--ease)}
.btn:hover .ico{transform:translateX(3px)}
.hl{color:var(--green);font-weight:inherit}
.stack .hl,.cta-band .hl,.magnet .hl{color:var(--green-light)}
.textlink{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;color:var(--ink);text-decoration:none;transition:color .18s var(--ease)}
.textlink .lbl{position:relative}
.textlink .lbl::after{content:"";position:absolute;left:0;bottom:-3px;height:1.5px;width:100%;background:var(--green-bright);transform-origin:left;transition:transform .28s var(--ease)}
.textlink:hover{color:var(--green)}
.textlink:hover .lbl::after{transform:scaleX(.45)}
.arrow,.ico{display:inline-block;transition:transform .2s var(--ease)}
a:hover .arrow{transform:translateX(4px)}

/* ── Nav (floating pill) ── */
header{position:sticky;top:0;z-index:50;background:#000;border-bottom:1px solid rgba(255,255,255,.08);transition:box-shadow .3s var(--ease)}
header.scrolled{box-shadow:0 8px 30px rgba(0,0,0,.5)}
.nav{display:flex;align-items:center;justify-content:space-between;height:4rem;background:transparent;border:0;border-radius:0;padding:0 var(--pad);box-shadow:none}
.logo{display:inline-flex;align-items:center;font-family:var(--font-head);font-weight:700;font-size:1.22rem;letter-spacing:-.025em;color:var(--ink);text-decoration:none}
.logo .dot{font-size:1.5em;line-height:0}
.logo-img{height:30px;width:auto;display:block;mix-blend-mode:lighten}
.nav-links{display:flex;gap:.3rem;list-style:none}
.nav-links a{position:relative;color:rgba(255,255,255,.82);text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s var(--ease),background .2s var(--ease);padding:.5rem .8rem;border-radius:8px}
.nav-links a:hover{color:#50C215;background:rgba(80,194,21,.1)}
.nav-cta{display:flex;align-items:center;gap:.75rem}
.nav .btn{padding:.58rem 1.15rem;font-size:.875rem}
.nav-meta{font-size:.8rem;color:var(--ink-mute);font-weight:500}
@media (max-width:980px){.nav-meta{display:none}}

/* ── Hero (centered) ── */
.hero{padding:6rem 0 5rem;text-align:center}
.badge{display:inline-flex;align-items:center;gap:.55rem;background:var(--white);border:1px solid var(--line);border-radius:999px;padding:.4rem .4rem .4rem .9rem;font-size:.8125rem;font-weight:500;color:var(--ink-soft);box-shadow:var(--shadow-1);margin-bottom:1.9rem}
.badge .pip{display:inline-flex;align-items:center;gap:.45rem;background:var(--sand-dark);border-radius:999px;padding:.18rem .65rem;font-weight:600;color:var(--green);font-size:.75rem;letter-spacing:.01em}
.badge .pip::before{content:"";width:.45rem;height:.45rem;border-radius:50%;background:var(--green-bright);box-shadow:0 0 0 3px rgba(26,166,76,.18)}
.hero h1{font-size:clamp(2.6rem,6vw,5rem);max-width:58rem;margin:0 auto;letter-spacing:-.035em}
.hero .lede{margin:1.75rem auto 2.5rem;font-size:1.22rem;max-width:40rem}
.hero-ctas{display:flex;gap:1.1rem;align-items:center;justify-content:center;flex-wrap:wrap}
.hero-trust{margin-top:1.6rem;display:flex;gap:1.4rem;justify-content:center;flex-wrap:wrap;font-size:.85rem;color:var(--ink-mute)}
.hero-trust span{display:inline-flex;align-items:center;gap:.45rem}
.hero-trust span::before{content:"";width:1rem;height:1rem;flex-shrink:0;background:var(--green);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9.55 17.6 4.4 12.45l1.4-1.4 3.75 3.75 8.25-8.25 1.4 1.4z'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9.55 17.6 4.4 12.45l1.4-1.4 3.75 3.75 8.25-8.25 1.4 1.4z'/%3E%3C/svg%3E") center/contain no-repeat}
.hero .badge,.hero .eyebrow,.hero h1,.hero .lede,.hero-ctas,.hero-trust,.video-shell{opacity:0;animation:rise .85s var(--ease) forwards}
.hero h1{animation-delay:.06s}
.hero .lede{animation-delay:.14s}
.hero-ctas{animation-delay:.22s}
.hero-trust{animation-delay:.28s}
.video-shell{animation-delay:.38s}
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* ── Video slot ── */
.video-shell{position:relative;max-width:58rem;margin:4rem auto 0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-3);aspect-ratio:16/9;background:var(--sand-dark);cursor:pointer}
.video-shell::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:0 1px 0 rgba(255,255,255,.4) inset;pointer-events:none}
.video-shell img,.video-shell video{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s var(--ease)}
.video-shell.is-video{background:#0b0707;cursor:default}
.video-shell.is-video video{object-fit:contain;background:#0b0707}
.video-shell:hover img{transform:scale(1.03)}
.video-shell.playing .play{opacity:0;pointer-events:none;transform:scale(.6)}
/* tap-for-sound pill */
.vsound{position:absolute;right:1rem;top:1rem;display:none;align-items:center;gap:.45rem;padding:.5rem .85rem;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:rgba(11,7,7,.55);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font:600 .8rem/1 var(--font-body);cursor:pointer;box-shadow:0 6px 18px rgba(0,0,0,.3);transition:transform .2s var(--ease),background .2s var(--ease),opacity .2s var(--ease)}
.video-shell.playing:not(.sound-on) .vsound{display:inline-flex;animation:rise .5s var(--ease) both}
.vsound:hover{transform:translateY(-1px);background:var(--green)}
.vsound-ico{width:.85rem;height:.85rem;border-radius:2px;background:currentColor;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M3 9v6h4l5 5V4L7 9H3zm13.5 3a4.5 4.5 0 00-2.5-4v8a4.5 4.5 0 002.5-4zM14 1.2v2.1a7 7 0 010 17.4v2.1a9 9 0 000-21.6z'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M3 9v6h4l5 5V4L7 9H3zm13.5 3a4.5 4.5 0 00-2.5-4v8a4.5 4.5 0 002.5-4zM14 1.2v2.1a7 7 0 010 17.4v2.1a9 9 0 000-21.6z'/></svg>") center/contain no-repeat}
/* scroll progress bar */
#scrollbar{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--green),var(--green-bright));z-index:200;transition:width .08s linear;box-shadow:0 0 12px rgba(22,137,63,.5)}
/* 3D pointer tilt for cards + pillars */
.cards,.pillars{perspective:1100px}
.card,.pillar{transform-style:preserve-3d;will-change:transform}
.card.tilt,.pillar.tilt{transition:transform .08s linear,box-shadow .3s var(--ease),border-color .3s var(--ease)}
.card .card-art img,.pillar .pillar-art img{transition:transform .6s var(--ease)}
/* process steps */
.step{transition:transform .28s var(--ease)}
.step:hover{transform:translateY(-5px)}
.step:hover .chip-n{background:var(--green);color:#fff;transform:scale(1.08) rotate(-4deg);box-shadow:0 8px 20px rgba(22,137,63,.35)}
.chip-n{transition:transform .28s var(--ease),background .28s var(--ease),color .28s var(--ease),box-shadow .28s var(--ease)}
/* tags */
.tag{transition:transform .2s var(--ease),background .2s var(--ease),color .2s var(--ease)}
.card:hover .tag{transform:translateY(-1px)}
/* feature list rows */
.feat-list li{transition:transform .22s var(--ease),color .22s var(--ease)}
.feat-list li:hover{transform:translateX(5px);color:var(--ink)}
/* footer links */
.foot-col a{display:inline-block;transition:transform .2s var(--ease),color .2s var(--ease)}
.foot-col a:hover{transform:translateX(3px);color:var(--green-bright)}
/* magnetic buttons settle smoothly */
.btn.mag{transition:transform .18s var(--ease),background .2s var(--ease),box-shadow .25s var(--ease),color .2s var(--ease)}
.play{position:absolute;inset:0;margin:auto;width:5.5rem;height:5.5rem;border-radius:50%;background:var(--white);border:none;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 35px rgba(11,7,7,.25);transition:transform .2s ease,background .2s ease;cursor:pointer}
.play::after{content:"";display:block;margin-left:5px;border-left:1.45rem solid var(--ink);border-top:.95rem solid transparent;border-bottom:.95rem solid transparent;transition:border-left-color .2s}
.video-shell:hover .play{transform:scale(1.08);background:var(--green)}
.video-shell:hover .play::after{border-left-color:var(--white)}

/* ── Logo marquee ── */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--sand);padding:2.4rem 0;overflow:hidden;position:relative}
.marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:8rem;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg,var(--sand),transparent)}
.marquee::after{right:0;background:linear-gradient(270deg,var(--sand),transparent)}
.marquee-label{text-align:center;font-size:.78rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:1.6rem}
.marquee-track{display:flex;gap:4.5rem;width:max-content;animation:slide 32s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.mark{font-family:var(--font-head);font-weight:600;font-size:1.2rem;letter-spacing:-.01em;color:#a9a294;white-space:nowrap;transition:color .2s}
.mark:hover{color:var(--ink)}
.mark .dot{color:var(--green)}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── Pillars (feature cards) ── */
.pillars-intro h3{font-size:1.6rem;font-weight:500;color:var(--ink-soft);letter-spacing:-.01em}
.pillars-intro strong{color:var(--ink)}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:4rem}
.pillar{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1rem 2rem;display:flex;flex-direction:column;box-shadow:var(--shadow-1);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease)}
.pillar:hover{transform:translateY(-6px);border-color:#d6cfba;box-shadow:var(--shadow-3);z-index:2;position:relative}
.pillar-art{border-radius:var(--radius-sm);overflow:hidden;background:var(--sand-dark);aspect-ratio:4/3;margin-bottom:1.7rem;border:1px solid var(--line-soft)}
.pillar-art img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.pillar:hover .pillar-art img{transform:scale(1.06)}
.pillar-body{padding:0 1rem;display:flex;flex-direction:column;flex:1}
.pillar h2{font-size:clamp(1.5rem,2vw,1.9rem);margin-bottom:1rem}
.pillar p{color:var(--ink-soft);font-size:.975rem}
.pillar .inc{margin-top:1.5rem;font-size:.75rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute)}
.feat-list{list-style:none;margin:.8rem 0 0}
.feat-list li{font-size:.9375rem;color:var(--ink-soft);padding:.4rem 0 .4rem 1.6rem;position:relative}
.feat-list li::before{content:"";position:absolute;left:0;top:.9rem;width:.55rem;height:.55rem;border-radius:50%;background:var(--green)}

/* ── Capabilities (dark "what we do" showcase) ── */
.cap-panel{position:relative;background:#0d0a09;border:1px solid #221d1a;border-radius:28px;padding:clamp(2rem,4vw,4rem) clamp(1.25rem,3.5vw,3.5rem);overflow:hidden;box-shadow:var(--shadow-3)}
.cap-glow-bg{position:absolute;inset:0;pointer-events:none;background:radial-gradient(60rem 30rem at 82% -12%,rgba(34,197,94,.13),transparent 60%),radial-gradient(42rem 24rem at -5% 120%,rgba(34,197,94,.08),transparent 60%)}
.cap-head{position:relative;max-width:46rem;margin-bottom:clamp(2rem,4vw,3.25rem)}
.cap-head .eyebrow{color:var(--green-light)}
.cap-head .eyebrow::before{background:var(--green-light)}
.cap-head h2{color:#fff;font-size:clamp(1.9rem,3.4vw,2.9rem);letter-spacing:-.02em}
.cap-head .hl{color:var(--green-light)}
.cap-sub{color:#a9a39b;margin-top:1rem;font-size:1.02rem;max-width:34rem}
.cap-grid{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.cap{position:relative;background:#15110f;border:1px solid #271f1b;border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);transform-style:preserve-3d;outline:none}
.cap:hover,.cap:focus-visible{border-color:rgba(34,197,94,.5);box-shadow:0 20px 52px rgba(0,0,0,.5),0 0 0 1px rgba(34,197,94,.16);transform:translateY(-6px)}
.cap--tilt.tilting{transition:transform .08s linear,box-shadow .35s var(--ease),border-color .35s var(--ease)}
.cap-media{position:relative;aspect-ratio:4/3;overflow:hidden;background:#0a0807;border-bottom:1px solid #271f1b}
.cap-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease),filter .4s var(--ease);filter:saturate(1.05) brightness(.9)}
.cap:hover .cap-media img,.cap:focus-visible .cap-media img{transform:scale(1.06);filter:saturate(1.18) brightness(1.04)}
.cap-num{position:absolute;left:.9rem;top:.7rem;z-index:3;font-family:var(--font-head);font-weight:700;font-size:.82rem;letter-spacing:.05em;color:rgba(255,255,255,.62);background:rgba(0,0,0,.34);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:.2rem .5rem;border-radius:6px;border:1px solid rgba(255,255,255,.13)}
.cap-body{padding:1.5rem 1.4rem 1.7rem;display:flex;flex-direction:column;flex:1}
.cap-body h3{color:#fff;font-size:1.3rem;letter-spacing:-.01em;margin-bottom:.55rem}
.cap-body p{color:#a39d95;font-size:.94rem;line-height:1.55}
.cap-feats{list-style:none;margin:1.1rem 0 0;display:flex;flex-direction:column;gap:.5rem}
.cap-feats li{position:relative;padding-left:1.5rem;color:#cfc9c0;font-size:.875rem;transition:color .2s var(--ease),transform .2s var(--ease)}
.cap-feats li::before{content:"";position:absolute;left:0;top:.2rem;width:.95rem;height:.95rem;background:var(--green-bright);-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 16.2l-3.5-3.5L4 14.2l5 5L20 8.2 18.6 6.8z'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 16.2l-3.5-3.5L4 14.2l5 5L20 8.2 18.6 6.8z'/></svg>") center/contain no-repeat}
.cap:hover .cap-feats li{color:#fff}
/* signature interaction 1 — cursor-follow spotlight */
.cap-spotlight{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:0;transition:opacity .3s var(--ease);background:radial-gradient(circle 150px at var(--mx,50%) var(--my,50%),rgba(34,197,94,.4),transparent 62%);mix-blend-mode:screen}
.cap--spot:hover .cap-spotlight,.cap--spot:focus-visible .cap-spotlight{opacity:1}
/* signature interaction 2 — scanning line sweep */
.cap-scan{position:absolute;left:0;right:0;top:0;height:45%;z-index:2;pointer-events:none;opacity:0;background:linear-gradient(180deg,transparent,rgba(34,197,94,.3),transparent);transform:translateY(-130%)}
.cap--scan:hover .cap-scan,.cap--scan:focus-visible .cap-scan{opacity:1;animation:capscan 1.8s var(--ease) infinite}
@keyframes capscan{0%{transform:translateY(-130%)}100%{transform:translateY(330%)}}
@media (prefers-reduced-motion:reduce){.cap--scan:hover .cap-scan,.cap--scan:focus-visible .cap-scan{animation:none;opacity:.5;transform:translateY(120%)}}

/* ── How It Works note ── */
.how-note{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem;padding-top:2.5rem;border-top:1px solid var(--line)}
.how-note-item{font-size:.95rem;color:var(--ink-soft);line-height:1.6}
.how-note-item strong{display:block;color:var(--ink);font-weight:600;margin-bottom:.3rem}
/* ── About ── */
.about{background:var(--sand-dark)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.about-lead h2{font-size:clamp(1.9rem,3.4vw,2.8rem);margin-top:.5rem}
.about-body p{color:var(--ink-soft);font-size:1.02rem;line-height:1.7;margin-bottom:1.1rem}
.about-stats{display:flex;flex-wrap:wrap;gap:1.75rem;margin-top:2rem;padding-top:1.75rem;border-top:1px solid var(--line)}
.about-stat{flex:1;min-width:8rem}
.about-stat .num{display:block;font-family:var(--font-head);font-weight:700;font-size:1.7rem;color:var(--green);letter-spacing:-.01em}
.about-stat .lbl{display:block;margin-top:.35rem;font-size:.82rem;color:var(--ink-mute);line-height:1.4}
/* ── Contact ── */
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.contact-lead h2{font-size:clamp(1.9rem,3.4vw,2.8rem);margin-top:.5rem}
.contact-methods{list-style:none;margin:2.25rem 0 0;display:flex;flex-direction:column;gap:1.1rem}
.contact-methods li{display:flex;flex-direction:column;gap:.15rem}
.contact-methods .cm-label{font-size:.74rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute)}
.contact-methods a{font-family:var(--font-head);font-size:1.15rem;font-weight:600;color:var(--ink);text-decoration:none;width:max-content;transition:color .2s var(--ease),transform .2s var(--ease)}
.contact-methods a:hover{color:var(--green);transform:translateX(3px)}
.contact-card{position:relative;background:var(--white);border:1px solid var(--line);border-radius:20px;padding:2rem;box-shadow:var(--shadow-2);display:flex;flex-direction:column;gap:1rem}
.cc-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.cc-field{display:flex;flex-direction:column;gap:.4rem;font-size:.8rem;font-weight:600;letter-spacing:.02em;color:var(--ink-soft)}
.cc-field input,.cc-field textarea{font-family:var(--font-body);font-size:.95rem;font-weight:400;color:var(--ink);padding:.8rem .95rem;border:1px solid var(--line);border-radius:11px;background:var(--sand);outline:none;transition:border-color .2s var(--ease),box-shadow .2s var(--ease);resize:vertical}
.cc-field input:focus,.cc-field textarea:focus{border-color:var(--green-bright);box-shadow:0 0 0 3px rgba(26,166,76,.16)}
.cc-field input::placeholder,.cc-field textarea::placeholder{color:#a9a294;font-weight:400}
.contact-card .btn{justify-content:center;margin-top:.25rem}
.contact-card .fine{font-size:.78rem;color:var(--ink-mute);text-align:center}
.cc-success{display:none;background:rgba(22,137,63,.08);border:1px solid rgba(22,137,63,.3);color:var(--green);border-radius:12px;padding:1rem;text-align:center;font-weight:600;font-size:.95rem}
/* ── Features (dark image-led showcase) ── */
.features{background:var(--ink);color:var(--sand)}
.features .eyebrow{color:var(--green-light)}
.feat-head{max-width:46rem;margin-bottom:3.25rem}
.feat-head h2{font-size:clamp(2rem,3.6vw,3rem);color:#fff}
.features .hl{color:var(--green-light)}
.feat-sub{color:#a9a39b;margin-top:1.1rem;font-size:1.08rem;max-width:38rem}
.featx-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.featx{display:flex;flex-direction:column;background:#15110f;border:1px solid #271f1b;border-radius:18px;overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease)}
.featx:hover{transform:translateY(-6px);border-color:rgba(34,197,94,.45);box-shadow:0 22px 52px rgba(0,0,0,.5)}
.featx-media{aspect-ratio:16/10;background:#070504;overflow:hidden;display:flex;align-items:center;justify-content:center;border-bottom:1px solid #271f1b}
.featx-media img{width:100%;height:100%;object-fit:contain;display:block;transition:transform .6s var(--ease)}
.featx:hover .featx-media img{transform:scale(1.05)}
.featx-body{padding:1.6rem 1.5rem 1.8rem;display:flex;flex-direction:column;flex:1}
.featx-tag{align-self:flex-start;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--green-light);background:rgba(34,199,95,.12);border:1px solid rgba(34,199,95,.22);padding:.3rem .6rem;border-radius:999px;margin-bottom:.9rem}
.featx h3{color:#fff;font-size:1.26rem;letter-spacing:-.01em;margin-bottom:.6rem}
.featx p{color:#a39d95;font-size:.95rem;line-height:1.6}
.feat-trust{display:grid;grid-template-columns:repeat(4,1fr);gap:1.75rem;margin-top:3.5rem;padding-top:3rem;border-top:1px solid #271f1b}
.feat{display:flex;flex-direction:column}
.theme-icon{display:inline-flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:var(--rad-md);background:rgba(34,199,95,.14);border:1px solid rgba(34,199,95,.2);color:var(--green-light);margin-bottom:1.1rem;transition:transform .3s var(--ease),background .3s var(--ease),color .3s var(--ease),box-shadow .3s var(--ease)}
.theme-icon svg{width:1.5rem;height:1.5rem}
.feat:hover .theme-icon{background:var(--green);color:#fff;transform:translateY(-3px) rotate(-4deg);box-shadow:0 10px 22px rgba(22,137,63,.4)}
.feat h3{font-size:1.1rem;letter-spacing:-.01em;margin-bottom:.45rem;color:#fff}
.feat p{color:#9a948c;font-size:.9rem;line-height:1.55}
/* ── Platform tabs (Mantine Tabs) ── */
/* ── Platform · premium feature showcase ── */
.products{position:relative;background:linear-gradient(180deg,var(--sand) 0%,var(--sand-dark) 100%);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.products h2{font-size:clamp(2.1rem,4vw,3.1rem);letter-spacing:-.03em}
.tabs{display:grid;grid-template-columns:minmax(268px,.82fr) 1.6fr;gap:clamp(2rem,4vw,4.25rem);margin-top:3rem;align-items:start}
.tabs-list{display:flex;flex-direction:column;gap:.4rem;border:0;margin:0}
.tab{position:relative;display:flex;align-items:flex-start;width:100%;text-align:left;padding:1rem 1.2rem;border:1px solid transparent;border-radius:14px;background:none;cursor:pointer;font-family:var(--font-body);transition:background .22s var(--ease),border-color .22s var(--ease),box-shadow .3s var(--ease)}
.tab::after{content:"";position:absolute;left:0;top:50%;width:3px;height:0;background:var(--green-bright);border-radius:0 3px 3px 0;transform:translateY(-50%);transition:height .32s var(--ease)}
.tab-txt{display:flex;flex-direction:column;gap:.16rem;min-width:0}
.tab-txt strong{font-family:var(--font-head);font-weight:600;font-size:1.06rem;letter-spacing:-.015em;color:var(--ink-soft);transition:color .2s var(--ease)}
.tab-txt em{font-style:normal;font-size:.85rem;color:var(--ink-mute);line-height:1.4;transition:color .2s var(--ease)}
.tab.on{background:var(--white);border-color:var(--line);box-shadow:0 1px 2px rgba(11,7,7,.04),0 16px 32px -20px rgba(11,7,7,.22)}
.tab.on::after{height:56%}
.tab.on .tab-txt strong{color:var(--ink)}
.tab.on .tab-txt em{color:var(--ink-soft)}
/* hover — green fill, white text (wins over .on via source order) */
.tab:hover{background:var(--green);border-color:var(--green);box-shadow:0 1px 2px rgba(11,7,7,.04),0 16px 30px -18px rgba(22,137,63,.5)}
.tab:hover::after{height:0}
.tab:hover .tab-txt strong,.tab:hover .tab-txt em{color:#fff}
@media (max-width:880px){.tabs{grid-template-columns:1fr;gap:1.75rem}.tabs-list{flex-direction:row;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:.5rem;padding-bottom:.3rem}.tab{width:auto;flex:0 0 auto;white-space:nowrap;padding:.7rem 1rem}.tab .tab-txt em{display:none}.tab::after{display:none}}
.tabs-panels{position:relative;min-width:0}
.tab-panel[hidden]{display:none}
.tab-panel{position:relative;display:block;animation:tabin .5s var(--ease)}
@keyframes tabin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.tab-panel{animation:none}}
.tp-shot{position:relative;z-index:1;border-radius:18px;overflow:hidden;background:var(--white);border:1px solid var(--line);aspect-ratio:16/10;box-shadow:0 2px 4px rgba(11,7,7,.04),0 28px 48px -24px rgba(11,7,7,.20),0 64px 88px -54px rgba(11,7,7,.16)}
.tp-shot img{width:100%;height:100%;object-fit:cover;display:block}
.tp-cap{position:relative;z-index:1;max-width:40rem;margin-top:1.85rem}
.tp-cap h3{font-size:clamp(1.4rem,2.1vw,1.85rem);letter-spacing:-.025em;line-height:1.14;margin-bottom:.6rem}
.tp-cap p{color:var(--ink-soft);font-size:1.02rem;line-height:1.6}
.tp-cap .textlink{margin-top:1.2rem}

/* 360° → measurements — light schematic, draws on activate */
.mz{position:absolute;inset:0;background:var(--sand-dark);display:grid;place-items:center;padding:1.75rem 2rem}
.mz svg{width:100%;height:100%}
.mz .room{fill:var(--white);stroke:var(--line);stroke-width:1.5}
.mz .dim{stroke:var(--green);stroke-width:1.5;stroke-dasharray:320;stroke-dashoffset:320}
.tab-panel.on .mz .dim{animation:dimdraw 1s var(--ease) forwards}
.tab-panel.on .mz .dim.d2{animation-delay:.3s}
@keyframes dimdraw{to{stroke-dashoffset:0}}
.mz .dlabel{fill:var(--ink-soft);font-family:var(--font-body);font-size:13px;font-weight:600;opacity:0}
.tab-panel.on .mz .dlabel{animation:dfade .5s var(--ease) forwards .4s}
.tab-panel.on .mz .dlabel.l2{animation-delay:.7s}
.mz .ceil{fill:var(--ink-mute);font-family:var(--font-body);font-size:11.5px;font-weight:600;opacity:0}
.tab-panel.on .mz .ceil{animation:dfade .5s var(--ease) forwards .95s}
@keyframes dfade{to{opacity:1}}
.mz .pin{fill:var(--green)}
.mz .pinr{fill:none;stroke:var(--green);stroke-width:1.5;opacity:.45}
@media (prefers-reduced-motion:reduce){.mz .dim{stroke-dashoffset:0}.mz .dlabel,.mz .ceil{opacity:1}}

/* F9 instant note — calm inline card under the comparative visual */
.f9{margin-top:1.4rem;max-width:33rem;background:var(--white);border:1px solid var(--line);border-left:2px solid var(--green);border-radius:12px;padding:.95rem 1.1rem}
.f9-k{display:flex;align-items:center;gap:.55rem;font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--green)}
.f9-k kbd{font-family:var(--font-head);background:var(--ink);color:#fff;border-radius:5px;padding:.1rem .45rem;font-size:.72rem}
.f9 p{margin-top:.5rem;font-size:.9rem;line-height:1.55;color:var(--ink-soft)}

/* ══ Platform · interactive capability demos (hover/focus reveals, draw-in on activate) ══ */
.tp-shot.canvas{background:var(--sand-dark)}
.demo{position:absolute;inset:0}

/* annotation pins on a photo */
.demo-anno{position:absolute;z-index:3;transform:scale(0);transition:transform .35s var(--ease)}
.tab-panel.on .demo-anno{transform:scale(1)}
.tab-panel.on .demo-anno.a2{transition-delay:.12s}.tab-panel.on .demo-anno.a3{transition-delay:.24s}
.demo-pin{position:relative;display:grid;place-items:center;width:1.65rem;height:1.65rem;border-radius:50%;background:var(--green);border:2px solid #fff;color:#fff;font-family:var(--font-head);font-weight:700;font-size:.74rem;cursor:pointer;box-shadow:0 4px 14px rgba(0,0,0,.35);padding:0;transition:transform .2s var(--ease)}
.demo-pin::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1.5px solid var(--green-light);opacity:.6;animation:pinpulse 2.6s var(--ease) infinite}
@keyframes pinpulse{0%{transform:scale(.85);opacity:.6}70%{transform:scale(1.8);opacity:0}100%{opacity:0}}
.demo-anno:hover .demo-pin,.demo-anno:focus-within .demo-pin{transform:scale(1.14)}
.demo-tip{position:absolute;left:50%;top:calc(100% + 9px);transform:translateX(-50%) translateY(5px);z-index:4;background:#fffdf8;border:1px solid var(--line);border-radius:10px;box-shadow:0 14px 32px rgba(0,0,0,.3);padding:.5rem .72rem;font-size:.78rem;line-height:1.2;white-space:nowrap;color:var(--ink-soft);opacity:0;pointer-events:none;transition:opacity .2s var(--ease),transform .2s var(--ease)}
.demo-tip b{color:var(--ink);font-weight:600}.demo-tip i{font-style:normal;color:var(--green);font-weight:700}
.demo-anno:hover .demo-tip,.demo-anno:focus-within .demo-tip{opacity:1;transform:translateX(-50%)}
.demo-scrim{position:absolute;inset:0;z-index:2;pointer-events:none;background:radial-gradient(120% 90% at 50% 30%,transparent 40%,rgba(11,7,7,.28))}
@media (prefers-reduced-motion:reduce){.demo-anno{transform:scale(1)}.demo-pin::after{animation:none}}

/* PDF → ESX rebuild UI */
.demo-pdf{position:absolute;inset:0;display:grid;grid-template-columns:1fr auto 1.35fr;gap:1.1rem;align-items:center;padding:clamp(1rem,2.6vw,1.9rem)}
.dp-doc{background:#fff;border:1px solid var(--line);border-radius:9px;box-shadow:var(--shadow-1);padding:.85rem .8rem;display:flex;flex-direction:column;gap:.42rem;aspect-ratio:.78}
.dp-tag{font-size:.58rem;font-weight:800;letter-spacing:.08em;color:#c0392b}
.dp-line{height:.34rem;background:var(--line);border-radius:2px}
.dp-line.s{width:55%}.dp-line.m{width:78%}
.dp-arrow{color:var(--green);font-size:1.3rem;font-weight:700}
.dp-esx{background:#fff;border:1px solid var(--line);border-radius:9px;overflow:hidden;box-shadow:var(--shadow-1)}
.dp-esx .dp-hd{display:flex;justify-content:space-between;padding:.5rem .85rem;font-size:.6rem;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--green);background:rgba(22,137,63,.08);border-bottom:1px solid var(--line-soft)}
.dp-row{display:flex;justify-content:space-between;gap:1rem;padding:.5rem .85rem;font-size:.79rem;color:var(--ink-soft);border-bottom:1px solid var(--line-soft);transition:background .18s var(--ease)}
.dp-row b{color:var(--ink);font-variant-numeric:tabular-nums;font-weight:600}
.dp-row:hover{background:rgba(22,137,63,.08)}
.dp-row.total{font-weight:700;color:var(--ink);background:var(--sand)}
.dp-row.total b{color:var(--green)}

/* Comparative diff with F9-on-hover */
.demo-diff{position:absolute;inset:0;padding:clamp(.9rem,2.4vw,1.5rem) clamp(1rem,2.8vw,1.7rem);display:flex;flex-direction:column;gap:.32rem;overflow:visible}
.dd-head{display:grid;grid-template-columns:1fr 4.4rem 4.4rem;gap:.5rem;padding:0 .7rem .3rem;font-size:.6rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-mute)}
.dd-head span:not(:first-child){text-align:right}
.dd-row{position:relative;display:grid;grid-template-columns:1fr 4.4rem 4.4rem;gap:.5rem;align-items:center;padding:.5rem .7rem;background:#fff;border:1px solid var(--line-soft);border-radius:7px;font-size:.78rem;color:var(--ink-soft)}
.dd-row .num{text-align:right;font-variant-numeric:tabular-nums;color:var(--ink)}
.dd-row .warn{color:#c98a00;font-weight:700}
.dd-row.var{cursor:pointer;transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}
.dd-row.var::after{content:"F9";position:absolute;right:.55rem;top:50%;transform:translateY(-50%);font-family:var(--font-head);font-size:.56rem;font-weight:800;color:#fff;background:var(--green);border-radius:4px;padding:.05rem .28rem;opacity:0;transition:opacity .18s}
.dd-row.var:hover,.dd-row.var:focus-within,.dd-row.var.hot{border-color:var(--green);box-shadow:var(--shadow-1)}
.dd-f9{position:absolute;left:0;right:0;top:calc(100% + 5px);z-index:6;background:#fffdf8;border:1px solid var(--line);border-left:2px solid var(--green);border-radius:8px;padding:.55rem .75rem;font-size:.74rem;line-height:1.45;color:var(--ink-soft);box-shadow:0 16px 34px rgba(0,0,0,.26);opacity:0;transform:translateY(4px);pointer-events:none;transition:opacity .2s var(--ease),transform .2s var(--ease)}
.dd-f9 kbd{font-family:var(--font-head);background:var(--ink);color:#fff;border-radius:4px;padding:.04rem .32rem;font-size:.66rem;margin-right:.35rem}
.dd-row.var:hover .dd-f9,.dd-row.var:focus-within .dd-f9{opacity:1;transform:none}
/* 360 schematic — hover a dimension group to emphasize it */
.mz .dgrp:hover .dim{stroke-width:2.6}
.mz .dgrp:hover .dlabel{fill:var(--green);font-weight:700}

/* ══ How It Works · workflow pipeline (photo → measured room → ESX) ══ */
.pipe{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:stretch;margin-top:3.75rem}
@media (max-width:760px){.pipe{grid-template-columns:1fr}.pipe-arrow{transform:rotate(90deg);padding:.5rem 0}}
.pipe-stage{position:relative;background:var(--white);border:1px solid var(--line);border-radius:16px;padding:1.3rem;box-shadow:var(--shadow-xs);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease)}
.pipe-stage:hover{transform:translateY(-5px);box-shadow:var(--shadow-2);border-color:rgba(22,137,63,.32)}
.pipe-arrow{display:grid;place-items:center;color:var(--green);font-size:1.4rem;padding:0 1.1rem;opacity:.35;transition:opacity .5s var(--ease)}
.pipe.in .pipe-arrow{opacity:1}.pipe.in .pipe-arrow.a2{transition-delay:.25s}
.pipe-k{display:inline-flex;align-items:center;gap:.5rem;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--green);margin-bottom:.85rem}
.pipe-k b{display:grid;place-items:center;width:1.35rem;height:1.35rem;border-radius:50%;background:var(--green);color:#fff;font-family:var(--font-head);font-size:.74rem}
.pipe-vis{position:relative;aspect-ratio:16/10;border-radius:10px;overflow:hidden;border:1px solid var(--line);background:var(--sand-dark);margin-bottom:.95rem}
.pipe-vis img{width:100%;height:100%;object-fit:cover;display:block}
.pipe-vis svg{position:absolute;inset:0;width:100%;height:100%}
.pipe-stage h3{font-size:1.06rem;letter-spacing:-.01em;margin-bottom:.3rem}
.pipe-stage p{font-size:.88rem;color:var(--ink-soft);line-height:1.5}
.mini-room{fill:var(--white);stroke:var(--line);stroke-width:2}
.mini-dim{stroke:var(--green);stroke-width:1.6;stroke-dasharray:200;stroke-dashoffset:200}
.pipe.in .mini-dim{animation:dimdraw 1s var(--ease) forwards .2s}
.mini-lbl{fill:var(--ink-soft);font-family:var(--font-body);font-size:13px;font-weight:600}
.mini-cam{fill:var(--green)}
.mini-esx{position:absolute;inset:0;background:#fff;display:flex;flex-direction:column}
.me-hd{display:flex;justify-content:space-between;padding:.42rem .65rem;font-size:.56rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--green);background:rgba(22,137,63,.08);border-bottom:1px solid var(--line-soft)}
.me-row{display:flex;justify-content:space-between;gap:.5rem;padding:.36rem .65rem;font-size:.74rem;color:var(--ink-soft);border-bottom:1px solid var(--line-soft);transition:background .18s var(--ease)}
.me-row b{color:var(--ink);font-variant-numeric:tabular-nums;font-weight:600}
.me-row:hover{background:rgba(22,137,63,.08)}
.me-row.tot{margin-top:auto;font-weight:700;color:var(--ink);background:var(--sand)}
.me-row.tot b{color:var(--green)}
.pipe-notes{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:2.75rem;justify-content:center}
.pipe-chip{display:inline-flex;align-items:center;gap:.55rem;background:var(--white);border:1px solid var(--line);border-radius:999px;padding:.55rem 1rem;font-size:.86rem;font-weight:600;color:var(--ink-soft)}
.pipe-chip svg{width:1.05rem;height:1.05rem;color:var(--green);flex:none}

/* ══ About · AI-handles / you-own split ══ */
.about-hero{max-width:42rem;margin:0 auto 3rem;text-align:center}
.about-hero .lede{margin:1rem auto 0}
.split{display:grid;grid-template-columns:1fr auto 1fr;gap:1.25rem;align-items:stretch;max-width:54rem;margin:0 auto}
@media (max-width:680px){.split{grid-template-columns:1fr}.split-mid{transform:rotate(90deg);padding:.4rem 0}}
.split-col{background:var(--white);border:1px solid var(--line);border-radius:16px;padding:1.5rem 1.6rem;box-shadow:var(--shadow-xs)}
.split-col.you{border-color:rgba(22,137,63,.32);box-shadow:var(--shadow-1)}
.split-h{display:flex;align-items:center;gap:.6rem;margin-bottom:1.1rem}
.split-h b{font-family:var(--font-head);font-weight:600;font-size:1.02rem;color:var(--ink)}
.split-h .tag{font-size:.6rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:.22rem .5rem;border-radius:999px}
.split-col.ai .tag{color:var(--ink-mute);background:var(--sand-dark)}
.split-col.you .tag{color:var(--green);background:rgba(22,137,63,.12)}
.split-list{list-style:none;display:flex;flex-direction:column;gap:.7rem}
.split-list li{display:flex;align-items:center;gap:.65rem;font-size:.96rem;transition:color .2s var(--ease)}
.split-list li::before{content:"";width:1.25rem;height:1.25rem;flex:none;border-radius:6px}
.split-col.ai li{color:var(--ink-mute)}
.split-col.ai li::before{background:var(--sand-dark) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b655f' stroke-width='2.4' stroke-linecap='round'%3E%3Cpath d='M12 3v3M12 18v3M3 12h3M18 12h3'/%3E%3Cpath d='M9.5 9.5l-2-2M16.5 16.5l-2-2M14.5 9.5l2-2M7.5 16.5l2-2'/%3E%3C/svg%3E") center/.78rem no-repeat}
.split-col.you li{color:var(--ink-soft)}
.split-col.you li::before{background:rgba(22,137,63,.12) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2316893f' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l4.5 4.5L19 7'/%3E%3C/svg%3E") center/.8rem no-repeat}
.split-col.you li:hover{color:var(--ink)}
.split-mid{display:grid;place-items:center;color:var(--green)}
.split-mid em{font-style:normal;font-size:1.6rem;line-height:1}
.split-mid small{display:block;font-size:.66rem;color:var(--ink-mute);font-weight:600;text-align:center;margin-top:.35rem;max-width:5rem}
.about-stats{justify-content:center;max-width:54rem;margin-left:auto;margin-right:auto}

/* ── Testimonial slider ── */
.t-slider{position:relative;max-width:56rem;margin:6.5rem auto 0;overflow:hidden}
.t-track{display:flex;transition:transform .55s cubic-bezier(.2,.7,.2,1)}
.t-slide{min-width:100%;padding:0 .75rem;text-align:center}
.t-slide .stars{color:var(--green);letter-spacing:.25em;margin-bottom:1.5rem;font-size:1.05rem}
.t-slide blockquote{font-family:var(--font-head);font-size:clamp(1.3rem,2.3vw,1.85rem);font-weight:500;line-height:1.35;letter-spacing:-.015em;max-width:48rem;margin:0 auto}
.t-slide cite{display:block;margin-top:1.9rem;font-style:normal;font-size:.95rem;color:var(--ink-mute)}
.t-slide cite strong{color:var(--ink);display:block;font-size:1.05rem}
.t-controls{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-top:2.75rem}
.t-btn{width:3rem;height:3rem;border-radius:50%;border:1.5px solid var(--ink);background:transparent;color:var(--ink);font-size:1.1rem;line-height:1;cursor:pointer;transition:all .2s}
.t-btn:hover{background:var(--green);border-color:var(--green);color:var(--white)}
.t-dots{display:flex;gap:.6rem}
.t-dot{width:.6rem;height:.6rem;border-radius:50%;border:none;background:#d8d2c0;cursor:pointer;transition:all .25s;padding:0}
.t-dot.on{background:var(--green);transform:scale(1.3)}

/* ── Blog / recent articles ── */
.blog-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:3rem;flex-wrap:wrap}
.blog-head h2{font-size:clamp(1.9rem,3.4vw,2.8rem)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.post{background:var(--white);border:1px solid var(--line);border-radius:var(--rad-lg);overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease)}
.post:hover{transform:translateY(-6px);border-color:#d6cfba;box-shadow:var(--shadow-2)}
.post-link{display:flex;flex-direction:column;height:100%;padding:1.85rem 1.7rem;text-decoration:none;color:inherit}
.post-cat{align-self:flex-start;font-size:.68rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--green);background:rgba(22,137,63,.1);border:1px solid rgba(22,137,63,.18);padding:.3rem .6rem;border-radius:999px}
.post h3{font-family:var(--font-head);font-size:1.28rem;line-height:1.25;letter-spacing:-.015em;margin:1.1rem 0 .75rem;transition:color .2s var(--ease)}
.post:hover h3{color:var(--green)}
.post p{color:var(--ink-soft);font-size:.94rem;line-height:1.6;flex:1}
.post-meta{display:flex;align-items:center;gap:.55rem;color:var(--ink-mute);font-size:.82rem;margin-top:1.4rem}
.post-go{margin-top:1.1rem;font-weight:600;color:var(--green);font-size:.92rem;display:inline-flex;align-items:center;gap:.4rem}
.post-go .arrow{transition:transform .2s var(--ease)}
.post:hover .post-go .arrow{transform:translateX(4px)}
/* ── Lead magnet ── */
.magnet{background:var(--sand-dark)}
.magnet-card{position:relative;background:var(--ink);color:var(--sand);border-radius:24px;padding:4rem 3.75rem;display:grid;grid-template-columns:1.15fr 1fr;gap:3.5rem;align-items:center;overflow:hidden;box-shadow:var(--shadow-3)}
.magnet-card::before{content:"";position:absolute;top:-40%;right:-10%;width:32rem;height:32rem;background:radial-gradient(circle,rgba(52,199,95,.16),transparent 62%);pointer-events:none}
.magnet-card>*{position:relative}
.magnet .eyebrow{color:var(--green-light)}
.magnet h2{color:var(--white);font-size:clamp(1.85rem,3vw,2.6rem)}
.magnet p{color:#b3aea4;margin-top:1.1rem;font-size:1.02rem;max-width:30rem}
.magnet-form{display:flex;flex-direction:column;gap:.75rem}
.magnet-form input{padding:.95rem 1.25rem;border-radius:11px;border:1px solid #322d2b;background:#161110;color:var(--white);font-family:var(--font-body);font-size:.975rem;outline:none;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.magnet-form input:focus{border-color:var(--green-bright);box-shadow:0 0 0 3px rgba(26,166,76,.18)}
.magnet-form input::placeholder{color:#857f76}
.magnet-form .btn{justify-content:center;margin-top:.25rem}
.magnet-form .fine{font-size:.8rem;color:#857f76;text-align:center;margin-top:.15rem}
.magnet-success{display:none;font-weight:600;color:var(--green-light);font-size:1.02rem;text-align:center}

/* ── Process ── */
.process{background:var(--sand-dark);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.process h2{font-size:clamp(2.1rem,4.2vw,3.4rem);max-width:50rem}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:2.25rem;margin-top:4rem;position:relative}
.step{position:relative}

/* ── Process · editorial numbered steps ── */
.flow{position:relative;margin-top:4.5rem}
.flow-steps{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:3.25rem;position:relative}
@media (max-width:760px){.flow-steps{grid-template-columns:1fr;gap:2.75rem}}
.flow-step{position:relative;padding-top:2.5rem}
.flow-step::before{content:"";position:absolute;top:0;left:0;right:1.6rem;height:1px;background:var(--line)}
.flow-step::after{content:"";position:absolute;top:0;left:0;height:2px;width:0;background:var(--green);transition:width .9s var(--ease)}
.flow-step.on::after{width:2.4rem}
.flow-num{display:block;font-family:var(--font-head);font-weight:700;font-size:.82rem;letter-spacing:.06em;color:var(--green);margin-bottom:1.1rem}
.flow-step h3{font-size:clamp(1.25rem,1.9vw,1.5rem);letter-spacing:-.02em;line-height:1.15;margin-bottom:.7rem}
.flow-step p{color:var(--ink-soft);font-size:1.02rem;line-height:1.6}
.step .chip-n{display:inline-flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;border-radius:var(--rad-md);background:rgba(22,137,63,.12);border:1px solid rgba(22,137,63,.16);font-family:var(--font-head);font-weight:700;font-size:1.1rem;color:var(--green);margin-bottom:1.4rem}
.step .n{font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:.7rem}
.step h3{font-size:1.4rem;margin-bottom:.75rem;letter-spacing:-.02em}
.step p{color:var(--ink-soft);font-size:.99rem}
@media (min-width:981px){
  .step:not(:last-child)::after{content:"";position:absolute;top:1.3rem;left:3.4rem;right:-2.25rem;height:1px;background:linear-gradient(90deg,var(--line) 60%,transparent);z-index:0}
}

/* ── Products ── */
.products h2{font-size:clamp(2.2rem,4.4vw,3.6rem);max-width:54rem}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:4rem}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1rem 2rem;display:flex;flex-direction:column;box-shadow:var(--shadow-1);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.card:hover{transform:translateY(-6px);border-color:#d6cfba;box-shadow:var(--shadow-3)}
.card-art{border-radius:var(--radius-sm);overflow:hidden;margin-bottom:1.7rem;background:var(--sand-dark);aspect-ratio:4/3;border:1px solid var(--line-soft)}
.card-art img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.card:hover .card-art img{transform:scale(1.05)}
.card-body{padding:0 1rem;display:flex;flex-direction:column;flex:1}
.card .tag{align-self:flex-start;display:inline-flex;align-items:center;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--green);background:rgba(22,137,63,.1);border:1px solid rgba(22,137,63,.18);padding:.32rem .65rem;border-radius:999px;margin-bottom:1.1rem;transition:background .2s var(--ease),color .2s var(--ease),transform .2s var(--ease)}
.card:hover .tag{background:var(--green);color:#fff;border-color:var(--green)}
.card h3{font-size:1.7rem;margin-bottom:1rem;letter-spacing:-.02em}
.card p{color:var(--ink-soft);font-size:.975rem}
.card ul{list-style:none;margin:1.4rem 0 1.75rem;flex:1}
.card li{font-size:.9375rem;color:var(--ink-soft);padding:.45rem 0 .45rem 1.6rem;position:relative}
.card li::before{content:"";position:absolute;left:0;top:.95rem;width:.55rem;height:.55rem;border-radius:50%;background:var(--green)}
.card .textlink{align-self:flex-start}

/* ── Stack ── */
.stack{background:var(--ink);color:var(--sand)}
.stack .eyebrow{color:var(--green-light)}
.stack h2{font-size:clamp(2.2rem,4.4vw,3.4rem);color:var(--white);max-width:52rem}
.stack .lede{color:#b8b3a6;margin-top:1.75rem}
.stack-row{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:3rem}
.chip{display:inline-flex;align-items:center;gap:.6rem;border:1px solid #2f2a28;background:rgba(255,255,255,.02);border-radius:10px;padding:.7rem 1.1rem;font-size:.9rem;color:#c5c0b6;font-weight:500;transition:border-color .2s var(--ease),background .2s var(--ease),transform .2s var(--ease)}
.chip::before{content:"";width:.5rem;height:.5rem;border-radius:50%;background:var(--green-light);flex-shrink:0}
.chip:hover{border-color:#4a4440;background:rgba(255,255,255,.04);transform:translateY(-2px)}
.chip strong{color:var(--white);font-weight:600}

/* ── FAQ ── */
.faq{background:var(--sand-dark)}
.faq-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:4rem}
.faq h2{font-size:clamp(2rem,3.6vw,3rem)}
.faq details{background:var(--white);border:1px solid var(--line);border-radius:var(--rad-md);margin-bottom:.75rem;overflow:hidden;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.faq details:hover{border-color:#d9d3c4}
.faq details[open]{border-color:rgba(22,137,63,.4);box-shadow:var(--shadow-1)}
.faq summary{font-family:var(--font-head);font-weight:600;font-size:1.08rem;letter-spacing:-.015em;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.15rem 1.3rem;transition:color .18s var(--ease),background .18s var(--ease)}
.faq summary:hover{color:var(--green);background:rgba(22,137,63,.04)}
.faq details[open] summary{color:var(--green)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"";width:1.4rem;height:1.4rem;flex-shrink:0;background:var(--green);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' d='M6 9l6 6 6-6'/%3E%3C/svg%3E") center/1.15rem no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' d='M6 9l6 6 6-6'/%3E%3C/svg%3E") center/1.15rem no-repeat;transition:transform .25s var(--ease)}
.faq details[open] summary::after{transform:rotate(180deg)}
.faq details p{margin:0;padding:0 1.3rem 1.3rem;color:var(--ink-soft);font-size:1rem;max-width:42rem}

/* ── CTA band ── */
.cta-band{background:var(--ink);color:var(--white);text-align:center}
.cta-band h2{font-size:clamp(2.4rem,5vw,4.2rem);color:var(--white);max-width:54rem;margin:0 auto}
.cta-band .lede{color:#b8b3a6;margin:1.75rem auto 2.75rem}

/* ── Footer ── */
footer{position:relative;background:var(--ink);color:#aaa49a;padding:4.5rem 0 2.5rem}
footer::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--green-bright),var(--green-light) 40%,transparent 70%)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3.5rem}
.foot-grid .logo{color:var(--white)}
.foot-tag{margin-top:1rem;font-size:.9rem;max-width:19rem;line-height:1.6}
.foot-col h4{color:#7d776e;font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.15rem}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:.65rem}
.foot-col a{color:#b8b3a6;text-decoration:none;font-size:.925rem;transition:color .15s var(--ease)}
.foot-col a:hover{color:var(--green-light)}
.foot-legal{border-top:1px solid #241f1d;padding-top:1.75rem;display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:#7d776e;flex-wrap:wrap;gap:1rem}

/* ── Scroll reveal ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  .hero .eyebrow,.hero h1,.hero .lede,.hero-ctas,.video-shell{opacity:1}
}

/* ── Responsive ── */
@media (max-width:980px){
  :root{--section:5.5rem}
  .nav-links{display:none}
  .pillars,.steps,.cards,.cap-grid,.blog-grid{grid-template-columns:1fr 1fr}
  .featx-grid{grid-template-columns:1fr}
  .feat-trust,.how-note{grid-template-columns:1fr 1fr}
  .tabs{grid-template-columns:1fr;gap:1.5rem}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .faq-grid{grid-template-columns:1fr;gap:2.5rem}
  .foot-grid{grid-template-columns:1fr 1fr}
  .magnet-card{grid-template-columns:1fr;padding:3rem 2rem;gap:2.25rem}
}
@media (max-width:620px){
  .pillars,.steps,.cards,.foot-grid,.cap-grid,.how-note,.cc-row,.featx-grid,.feat-trust,.blog-grid{grid-template-columns:1fr}
  .hero{padding:4.5rem 0 3.5rem}
  .play{width:4rem;height:4rem}
  .play::after{border-left-width:1.05rem;border-top-width:.7rem;border-bottom-width:.7rem}
}

/* ════ Subpage scaffolding (How It Works, About, …) ════ */
.page-hero{padding:6.5rem 0 3.25rem;text-align:center}
.page-hero .eyebrow{justify-content:center}
.page-hero h1{font-size:clamp(2.4rem,5vw,3.95rem);max-width:20ch;margin:0 auto;letter-spacing:-.035em;line-height:1.05}
.page-hero .lede{margin:1.6rem auto 2.1rem;font-size:1.16rem;max-width:42rem}
.page-hero .hero-ctas{justify-content:center}
.how-rows{display:flex;flex-direction:column;gap:clamp(3rem,6vw,5.5rem);margin-top:4rem}
.how-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.how-row.rev .how-vis{order:2}
@media(max-width:820px){.how-row,.how-row.rev{grid-template-columns:1fr;gap:1.75rem}.how-row.rev .how-vis{order:0}}
.how-vis{position:relative}
.step-k{font-family:var(--font-head);font-weight:700;font-size:.78rem;letter-spacing:.08em;color:var(--green);text-transform:uppercase;margin-bottom:.9rem;display:flex;align-items:center;gap:.6rem}
.step-k b{display:grid;place-items:center;width:1.5rem;height:1.5rem;border-radius:50%;background:var(--green);color:#fff;font-size:.78rem}
.how-rtext h2{font-size:clamp(1.55rem,2.7vw,2.15rem);letter-spacing:-.02em;line-height:1.12;margin-bottom:.9rem}
.how-rtext p{color:var(--ink-soft);font-size:1.06rem;line-height:1.62;margin-bottom:1.3rem}
.how-rtext ul{list-style:none;display:flex;flex-direction:column;gap:.65rem}
.how-rtext li{position:relative;padding-left:1.8rem;color:var(--ink-soft)}
.how-rtext li::before{content:"";position:absolute;left:0;top:.18rem;width:1.2rem;height:1.2rem;border-radius:6px;background:rgba(22,137,63,.12) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2316893f' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l4.5 4.5L19 7'/%3E%3C/svg%3E") center/.78rem no-repeat}
.mz.static .dim{stroke-dashoffset:0!important;animation:none!important}
.mz.static .dlabel,.mz.static .ceil{opacity:1!important;animation:none!important}
.value-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem}
@media(max-width:760px){.value-cards{grid-template-columns:1fr}}
.value-card{background:var(--white);border:1px solid var(--line);border-radius:16px;padding:1.85rem;box-shadow:var(--shadow-xs);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.value-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2);border-color:rgba(22,137,63,.28)}
.value-card .vc-ico{width:2.7rem;height:2.7rem;border-radius:11px;background:rgba(22,137,63,.1);display:grid;place-items:center;color:var(--green);margin-bottom:1.15rem}
.value-card .vc-ico svg{width:1.35rem;height:1.35rem}
.value-card h3{font-size:1.16rem;letter-spacing:-.01em;margin-bottom:.5rem}
.value-card p{color:var(--ink-soft);font-size:.96rem;line-height:1.6}
.about-story{max-width:42rem;margin:0 auto;text-align:center}
.about-story p{color:var(--ink-soft);font-size:1.08rem;line-height:1.75;margin-bottom:1.2rem}

/* ════ Auth (get-started) + app shell ════ */
.auth{min-height:100vh;display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr)}
@media(max-width:880px){.auth{grid-template-columns:1fr}}
.auth-aside{position:relative;background:var(--ink);color:var(--sand);padding:clamp(2.5rem,5vw,4.25rem);display:flex;flex-direction:column;overflow:hidden}
@media(max-width:880px){.auth-aside{display:none}}
.auth-aside::before{content:"";position:absolute;top:-28%;right:-22%;width:34rem;height:34rem;background:radial-gradient(circle,rgba(52,199,95,.2),transparent 62%);pointer-events:none}
.auth-aside .logo{color:var(--white);font-size:1.3rem;position:relative;z-index:1}
.auth-aside-body{margin-top:auto;position:relative;z-index:1}
.auth-aside h2{color:#fff;font-size:clamp(1.85rem,3vw,2.55rem);letter-spacing:-.025em;line-height:1.1}
.auth-aside h2 .hl{color:var(--green-light)}
.auth-aside ul{list-style:none;margin-top:2rem;display:flex;flex-direction:column;gap:1.05rem}
.auth-aside li{display:flex;gap:.8rem;color:#c3bdb3;font-size:1.02rem}
.auth-aside li svg{width:1.3rem;height:1.3rem;color:var(--green-light);flex:none;margin-top:.15rem}
.auth-aside .auth-trust{margin-top:2.5rem;color:#857f76;font-size:.85rem}
.auth-main{display:flex;align-items:center;justify-content:center;padding:clamp(2rem,5vw,3.5rem);background:var(--sand);position:relative}
.auth-card{width:100%;max-width:25rem}
.auth-card>.logo{display:none;margin-bottom:2rem}
@media(max-width:880px){.auth-card>.logo{display:inline-flex}}
.auth-tabs{display:flex;gap:.25rem;background:var(--sand-dark);border:1px solid var(--line);border-radius:12px;padding:.3rem;margin-bottom:1.7rem}
.auth-tab{flex:1;padding:.6rem;border:0;background:none;border-radius:9px;font-family:var(--font-body);font-weight:600;font-size:.92rem;color:var(--ink-mute);cursor:pointer;transition:background .2s var(--ease),color .2s var(--ease)}
.auth-tab.on{background:var(--white);color:var(--ink);box-shadow:var(--shadow-xs)}
.auth-card h1{font-size:1.65rem;letter-spacing:-.02em;margin-bottom:.4rem}
.auth-card .sub{color:var(--ink-soft);margin-bottom:1.5rem;font-size:.98rem}
.auth-field{display:block;margin-bottom:.95rem}
.auth-field>span{display:block;font-size:.82rem;font-weight:600;color:var(--ink-soft);margin-bottom:.4rem}
.auth-field input{width:100%;padding:.78rem .95rem;border:1px solid var(--line);border-radius:10px;background:var(--white);font-family:var(--font-body);font-size:.98rem;color:var(--ink);outline:none;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.auth-field input:focus{border-color:var(--green-bright);box-shadow:0 0 0 3px rgba(26,166,76,.16)}
.auth-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.auth-card .btn{width:100%;justify-content:center;margin-top:.55rem}
.auth-card .btn[disabled]{opacity:.6;cursor:progress}
.auth-msg{margin-top:1rem;font-size:.88rem;padding:.7rem .9rem;border-radius:9px;display:none}
.auth-msg.err{display:block;color:#9b2c2c;background:#fbeaea;border:1px solid #f3c9c9}
.auth-msg.ok{display:block;color:var(--green);background:rgba(22,137,63,.08);border:1px solid rgba(22,137,63,.22)}
.auth-alt{margin-top:1.35rem;font-size:.9rem;color:var(--ink-mute);text-align:center}
.auth-alt a{color:var(--green);font-weight:600;text-decoration:none;cursor:pointer}
.auth-forgot{font-size:.82rem;color:var(--green);text-decoration:none;float:right;margin-top:-.1rem}
.auth-fine{margin-top:1.15rem;font-size:.78rem;color:var(--ink-mute);text-align:center;line-height:1.5}
.auth-fine a{color:var(--ink-soft)}
.auth-back{position:absolute;top:1.4rem;left:1.5rem;font-size:.86rem;color:var(--ink-mute);text-decoration:none;z-index:2}
.auth-back:hover{color:var(--ink)}
.hide{display:none!important}
/* ── Nav · discernable Log in / Get Started pair (dark bar) ── */
.nav-cta .nav-login{border:1px solid rgba(255,255,255,.5);color:#fff;background:transparent;font-weight:600}
.nav-cta .nav-login:hover{border-color:#fff;background:#fff;color:var(--ink);transform:translateY(-1px)}
@media (max-width:520px){.nav-cta .nav-login{display:none}}

/* ── Platform tabs · auto-cycle progress bar ── */
.tab-prog{position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--green-bright);border-radius:0 2px 2px 0;opacity:0;pointer-events:none}
.tab.on .tab-prog{opacity:1;animation:tabfill 5200ms linear forwards}
.tabs.paused .tab.on .tab-prog{animation-play-state:paused}
.tabs.locked .tab-prog{display:none}
@keyframes tabfill{from{width:0}to{width:100%}}
@media (prefers-reduced-motion:reduce){.tab.on .tab-prog{display:none}}

/* ── Comparative diff · tap / click to pin the F9 note ── */
.dd-row.var.pin{border-color:var(--green);box-shadow:var(--shadow-1);z-index:5}
.dd-row.var.pin::after{opacity:1}
.dd-row.var.pin .dd-f9{opacity:1;transform:none}

/* ── Pricing ── */
.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.15rem;margin-top:3.5rem;align-items:stretch}
@media (max-width:1080px){.pricing-grid{grid-template-columns:1fr 1fr}}
@media (max-width:620px){.pricing-grid{grid-template-columns:1fr}}
.price-card{position:relative;display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);border-radius:18px;padding:1.9rem 1.55rem;box-shadow:var(--shadow-1);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.price-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-3);border-color:#d6cfba}
.price-card.feat{border-color:var(--green);box-shadow:0 0 0 1px var(--green),var(--shadow-2)}
.price-badge{position:absolute;top:-.72rem;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#5fce2e,#16893f);color:#fff;font-size:.64rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;padding:.32rem .75rem;border-radius:999px;white-space:nowrap;box-shadow:0 4px 12px rgba(22,137,63,.35)}
.price-name{font-family:var(--font-head);font-weight:600;font-size:1.18rem;letter-spacing:-.01em;color:var(--ink)}
.price-amt{display:flex;align-items:baseline;gap:.32rem;margin:.95rem 0 .15rem}
.price-amt .amt{font-family:var(--font-head);font-weight:700;font-size:2.45rem;letter-spacing:-.035em;color:var(--ink);line-height:1}
.price-amt .per{font-size:.9rem;color:var(--ink-mute);font-weight:500}
.price-blurb{color:var(--ink-soft);font-size:.9rem;line-height:1.5;margin:.35rem 0 1.3rem;min-height:2.7rem}
.price-feats{list-style:none;display:flex;flex-direction:column;gap:.62rem;margin:0 0 1.7rem;flex:1}
.price-feats li{position:relative;padding-left:1.65rem;font-size:.895rem;color:var(--ink-soft);line-height:1.45}
.price-feats li::before{content:"";position:absolute;left:0;top:.12rem;width:1.15rem;height:1.15rem;border-radius:5px;background:rgba(22,137,63,.12) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2316893f' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l4.5 4.5L19 7'/%3E%3C/svg%3E") center/.72rem no-repeat}
.price-card .btn{width:100%;justify-content:center;margin-top:auto}
.price-card .btn-ghost{border-color:#d3ccbb;color:var(--ink)}
.price-card .btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.price-foot-note{text-align:center;color:var(--ink-mute);font-size:.95rem;margin-top:2.6rem}
.price-foot-note b{color:var(--ink);font-weight:600}
.price-compare{max-width:34rem;margin:1.1rem auto 0;text-align:center;color:var(--ink-mute);font-size:.86rem;line-height:1.6}

/* ── Booking (Calendly) ── */
.booking{background:var(--sand-dark);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.booking-head{max-width:42rem;margin:0 auto 2.75rem;text-align:center}
.booking-head .eyebrow{justify-content:center}
.booking-head h2{font-size:clamp(1.95rem,3.8vw,3rem);letter-spacing:-.025em}
.booking-head .lede{margin:1.1rem auto 0}
.booking-embed{max-width:62rem;margin:0 auto;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-2)}
.booking-embed .calendly-inline-widget{min-width:320px;height:700px}
/* compact booking link for the auth aside */
.auth-book{position:relative;z-index:1;margin-top:1.6rem;display:inline-flex;align-items:center;gap:.5rem;color:var(--green-light);font-weight:600;font-size:.92rem;text-decoration:none;border:1px solid rgba(52,199,95,.3);border-radius:9px;padding:.6rem .95rem;background:rgba(52,199,95,.06);transition:background .2s var(--ease),border-color .2s var(--ease),transform .2s var(--ease);cursor:pointer}
.auth-book svg{width:1.05rem;height:1.05rem;flex:none}
.auth-book:hover{background:rgba(52,199,95,.12);border-color:var(--green-light);transform:translateY(-1px)}

/* app shell */
.app-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--sand)}
.app-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem clamp(1.2rem,4vw,2.5rem);border-bottom:1px solid var(--line);background:var(--white)}
.app-body{flex:1;display:grid;place-items:center;padding:2rem;text-align:center}
.app-body .inner{max-width:36rem}
.app-body h1{font-size:clamp(1.9rem,4vw,2.7rem);letter-spacing:-.03em;margin-bottom:.85rem}
.app-body p{color:var(--ink-soft);font-size:1.1rem;margin:0 auto 1.6rem}
.app-pill{display:inline-flex;align-items:center;gap:.5rem;background:rgba(22,137,63,.1);border:1px solid rgba(22,137,63,.2);color:var(--green);font-weight:600;font-size:.85rem;padding:.4rem .85rem;border-radius:999px;margin-bottom:1.5rem}
.app-user{font-size:.9rem;color:var(--ink-mute)}
