/* =====================================================
   DOSESWELL · rebuilt
   Palette  sage #4A7C65 · forest #2D4A3E · mist #A8CDB9
            bone #F7F5F0 · cream #EEECE7 · slate #1C1C1A · terracotta #C4705A
   Type     DM Serif Display (display) · DM Sans (body) · DM Mono (data)
   Signature  measuring-ruler motif + mono clinical labels
   ===================================================== */

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

:root{
  --sage:#4A7C65; --sage-h:#3d6b56; --forest:#2D4A3E; --mist:#A8CDB9; --mist-bg:#E8F2ED;
  --bone:#F7F5F0; --cream:#EEECE7; --cream-d:#D8D4CC;
  --slate:#1C1C1A; --slate-2:#3A3A38; --slate-3:#74736C;
  --terra:#C4705A; --terra-bg:#F5EBE7;
  --white:#fff;
  --serif:'DM Serif Display',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --mono:'DM Mono',ui-monospace,monospace;
  --r:10px; --r-lg:16px; --maxw:1120px;
}

html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bone);color:var(--slate);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased}
::selection{background:var(--mist);color:var(--forest)}

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

/* ---- shared type bits ---- */
.mono-label{font-family:var(--mono);font-size:11px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;color:var(--slate-3)}
.mono-num{font-family:var(--mono);font-weight:500;font-variant-numeric:tabular-nums}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:500;letter-spacing:.04em;color:var(--sage);margin-bottom:18px}
.eyebrow--center{justify-content:center}
.eyebrow--mist{color:var(--mist)}
.eyebrow-dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-family:var(--sans);font-size:14px;font-weight:500;padding:11px 22px;border-radius:var(--r);border:1.5px solid transparent;cursor:pointer;text-decoration:none;transition:.18s ease;white-space:nowrap}
.btn-sm{padding:8px 16px;font-size:13px}
.btn-lg{padding:14px 28px;font-size:15px}
.btn-sage{background:var(--sage);color:#fff;border-color:var(--sage)}
.btn-sage:hover{background:var(--sage-h);border-color:var(--sage-h)}
.btn-dark{background:var(--slate);color:#fff;border-color:var(--slate)}
.btn-dark:hover{background:var(--sage);border-color:var(--sage)}
.btn-outline{background:transparent;color:var(--slate);border-color:var(--cream-d)}
.btn-outline:hover{border-color:var(--slate)}
.btn-bone{background:var(--bone);color:var(--forest);border-color:var(--bone)}
.btn-bone:hover{background:#fff;border-color:#fff}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn-ghost-light:hover{background:rgba(255,255,255,.12)}

/* ---- wordmark ---- */
.wordmark{font-family:var(--sans);font-size:21px;font-weight:300;color:var(--slate);text-decoration:none;letter-spacing:-.4px}
.wordmark span{color:var(--sage);font-weight:500}
.wordmark--light{color:var(--bone)}
.wordmark--light span{color:var(--mist)}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:100;background:rgba(247,245,240,.92);backdrop-filter:blur(14px);border-bottom:.5px solid transparent;transition:border-color .2s}
.nav.scrolled{border-bottom-color:var(--cream-d)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:0 28px;height:62px;display:flex;align-items:center;gap:34px}
.nav-links{display:flex;gap:26px;margin-left:auto}
.nav-links a{font-size:14px;color:var(--slate-2);text-decoration:none;transition:color .15s}
.nav-links a:hover{color:var(--sage)}

/* ============ HERO ============ */
.hero{padding:72px 0 84px}
.hero-grid{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.hero-h1{font-family:var(--serif);font-size:clamp(38px,5vw,60px);font-weight:400;line-height:1.08;letter-spacing:-.5px;margin-bottom:24px}
.hero-h1 em{font-style:italic;color:var(--sage)}
.hero-lede{font-size:17px;color:var(--slate-2);line-height:1.7;max-width:520px;margin-bottom:32px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:30px}
.hero-trust{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:14px;color:var(--slate-3)}
.hero-trust strong{color:var(--slate);font-weight:500}
.hero-trust .dot{color:var(--cream-d)}

/* ---- gap tool (signature) ---- */
.gap-tool{background:var(--white);border:.5px solid var(--cream-d);border-radius:var(--r-lg);padding:26px}
.gap-tool-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}
.gap-tool-tag{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--sage);background:var(--mist-bg);padding:4px 9px;border-radius:5px}
.gap-weight{margin-bottom:18px}
.gap-weight label{display:block;margin-bottom:9px}
.gap-weight-row{display:flex;align-items:center;gap:14px}
.gap-weight-row input[type=range]{flex:1;-webkit-appearance:none;appearance:none;height:4px;background:var(--cream);border-radius:2px;outline:none}
.gap-weight-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--sage);cursor:pointer;border:2px solid #fff;box-shadow:0 0 0 .5px var(--cream-d)}
.gap-weight-row input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--sage);cursor:pointer;border:2px solid #fff}
.gap-weight-row output{min-width:62px;text-align:right;font-size:14px;color:var(--slate)}

/* the ruler */
.ruler{height:42px;margin:6px 0 20px;position:relative;border-bottom:1.5px solid var(--slate);display:flex;align-items:flex-end}
.ruler .tick{position:absolute;bottom:0;width:.5px;background:var(--cream-d)}
.ruler .tick.major{background:var(--slate-3);height:14px}
.ruler .tick.minor{height:7px}
.ruler .zone{position:absolute;bottom:0;height:22px;border-radius:3px 3px 0 0;opacity:.9}
.ruler .zone-low{background:var(--terra)}
.ruler .zone-fill{background:var(--mist)}
.ruler .marker{position:absolute;bottom:0;width:2px;height:30px;background:var(--sage)}
.ruler .marker::after{content:'';position:absolute;top:-5px;left:-3px;width:8px;height:8px;border-radius:50%;background:var(--sage)}

.gap-readout{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.gap-col{flex:1;display:flex;flex-direction:column;gap:5px}
.gap-val{font-family:var(--mono);font-size:26px;font-weight:500}
.gap-val--low{color:var(--terra)}
.gap-val--goal{color:var(--sage)}
.gap-arrow{color:var(--cream-d);font-size:18px}
.gap-banner{background:var(--slate);color:var(--bone);font-size:14px;text-align:center;padding:13px;border-radius:var(--r)}
.gap-banner strong{color:var(--mist);font-family:var(--mono);font-weight:500}

/* ============ STRIP ============ */
.strip{background:var(--slate);padding:60px 0}
.strip-eyebrow{display:block;text-align:center;color:var(--mist);margin-bottom:36px}
.strip-grid{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.strip-stat{flex:1;min-width:200px;text-align:center;padding:0 34px}
.strip-num{display:block;font-family:var(--serif);font-size:clamp(40px,5vw,58px);color:var(--mist);line-height:1;margin-bottom:14px}
.strip-text{font-size:14px;color:#9b9a94;line-height:1.5}
.strip-rule{width:.5px;height:70px;background:#34332f;flex-shrink:0}

/* ============ SECTION shell ============ */
.section{padding:92px 0}
.section--alt{background:var(--cream)}
.sec-head{text-align:center;max-width:660px;margin:0 auto 60px}
.sec-h2{font-family:var(--serif);font-size:clamp(28px,4vw,42px);font-weight:400;line-height:1.18;letter-spacing:-.4px;margin-bottom:16px}
.sec-sub{color:var(--slate-2);font-size:16px;line-height:1.7}

/* ---- steps ---- */
.steps{max-width:740px;margin:0 auto;list-style:none;position:relative}
.steps::before{content:'';position:absolute;left:35px;top:40px;bottom:40px;width:.5px;background:var(--cream-d)}
.step{display:flex;gap:30px;align-items:flex-start;position:relative;margin-bottom:18px}
.step:last-child{margin-bottom:0}
.step-rail{flex-shrink:0;width:70px;display:flex;justify-content:center}
.step-price{width:70px;height:70px;border-radius:50%;background:var(--white);border:.5px solid var(--cream-d);display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--sage);position:relative;z-index:1}
.step--featured .step-price{background:var(--sage);color:#fff;border-color:var(--sage)}
.step-body{flex:1;background:var(--white);border:.5px solid var(--cream-d);border-radius:var(--r-lg);padding:26px 28px}
.step--featured .step-body{border:1.5px solid var(--sage)}
.step-kicker{display:block;margin-bottom:8px}
.step-h3{font-family:var(--serif);font-size:22px;font-weight:400;line-height:1.25;margin-bottom:10px}
.step-p{font-size:15px;color:var(--slate-2);line-height:1.65}
.step-p em{font-style:italic;color:var(--slate)}
.step-badge{display:inline-block;margin-top:14px;color:var(--sage);background:var(--mist-bg);padding:5px 11px;border-radius:5px}

/* ============ FREE ============ */
.free{background:var(--forest);padding:92px 0}
.free-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.free-h2{font-family:var(--serif);font-size:clamp(27px,4vw,38px);font-weight:400;color:var(--bone);line-height:1.2;margin-bottom:16px;letter-spacing:-.3px}
.free-p{color:#a9bcb2;font-size:15px;line-height:1.7;margin-bottom:22px}
.free-list{list-style:none;margin-bottom:30px;display:flex;flex-direction:column;gap:10px}
.free-list li{font-size:14px;color:var(--bone);opacity:.9;padding-left:22px;position:relative}
.free-list li::before{content:'';position:absolute;left:0;top:9px;width:8px;height:8px;border-radius:50%;background:var(--mist)}
.email-form{display:flex;gap:10px;flex-wrap:wrap}
.email-form input{flex:1;min-width:200px;padding:12px 16px;font-family:var(--sans);font-size:14px;background:rgba(255,255,255,.08);border:.5px solid rgba(255,255,255,.2);border-radius:var(--r);color:var(--bone);outline:none;transition:border-color .15s}
.email-form input::placeholder{color:#7f9389}
.email-form input:focus{border-color:var(--mist)}
.free-note{margin-top:12px;color:#6f8378}

.sheet{background:var(--white);border-radius:var(--r-lg);overflow:hidden;border:.5px solid rgba(0,0,0,.04)}
.sheet-bar{background:var(--sage);padding:14px 18px;display:flex;justify-content:space-between;align-items:center}
.sheet-name{font-size:13px;font-weight:500;color:#fff}
.sheet-tag{color:#fff !important;background:rgba(255,255,255,.22);padding:3px 9px;border-radius:5px}
.sheet-row{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;padding:11px 18px;font-size:13px;border-bottom:.5px solid var(--cream);align-items:center}
.sheet-head{background:var(--cream);color:var(--slate-3)}
.sheet-row--muted{color:var(--slate-3)}
.sheet-row .neg{color:var(--terra)}
.sheet-row .pos{color:var(--sage)}
.sheet-foot{padding:13px 18px;background:var(--cream);color:var(--slate-3)}
.sheet-foot strong{color:var(--slate)}

/* ============ CARDS ============ */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.card{background:var(--white);border:.5px solid var(--cream-d);border-radius:var(--r-lg);padding:28px;display:flex;flex-direction:column;gap:16px;position:relative}
.card--featured{border:1.5px solid var(--sage)}
.card-feature-badge{position:absolute;top:0;left:50%;transform:translate(-50%,-50%);background:var(--sage);color:#fff !important;padding:5px 14px;border-radius:20px;white-space:nowrap}
.card-top{display:flex;justify-content:space-between;align-items:baseline}
.card-price{font-family:var(--serif);font-size:34px;color:var(--sage)}
.card-time{background:var(--cream);padding:5px 10px;border-radius:5px}
.card-h3{font-family:var(--serif);font-size:21px;font-weight:400;line-height:1.25}
.card-tag{font-size:14px;color:var(--slate-3);margin-top:-8px}
.card-elim{background:var(--terra-bg);border-radius:var(--r);padding:13px 15px}
.card-elim--featured{background:var(--mist-bg)}
.card-elim-label{color:var(--terra);display:block;margin-bottom:5px}
.card-elim--featured .card-elim-label{color:var(--sage)}
.card-elim p{font-size:13px;color:var(--slate-2);line-height:1.45}
.card-list{list-style:none;display:flex;flex-direction:column;gap:8px;flex:1}
.card-list li{font-size:13px;color:var(--slate-2);padding-left:20px;position:relative;line-height:1.45}
.card-list li::before{content:'';position:absolute;left:2px;top:7px;width:7px;height:7px;border-radius:50%;border:1.5px solid var(--sage)}
.card-btn{width:100%;margin-top:4px}
.card-note{text-align:center;margin-top:-6px}

/* ============ QUOTES ============ */
.quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.quote{background:var(--white);border:.5px solid var(--cream-d);border-radius:var(--r-lg);padding:28px}
.quote blockquote{font-family:var(--serif);font-size:18px;font-weight:400;font-style:italic;color:var(--slate-2);line-height:1.5;margin-bottom:20px}
.quote figcaption{display:flex;justify-content:space-between;align-items:center}
.quote-name{font-size:13px;font-weight:500;color:var(--slate)}
.quote-prod{color:var(--sage) !important;background:var(--mist-bg);padding:4px 9px;border-radius:5px}

/* ============ FAQ ============ */
.faq{max-width:720px;margin:0 auto}
.faq-item{border-bottom:.5px solid var(--cream-d)}
.faq-item:first-child{border-top:.5px solid var(--cream-d)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:18px;padding:20px 0;font-family:var(--sans);font-size:16px;font-weight:500;color:var(--slate);background:none;border:none;cursor:pointer;text-align:left}
.faq-q:hover{color:var(--sage)}
.faq-ic{position:relative;width:14px;height:14px;flex-shrink:0}
.faq-ic::before,.faq-ic::after{content:'';position:absolute;background:var(--slate-3);transition:.2s}
.faq-ic::before{top:6px;left:0;width:14px;height:1.5px}
.faq-ic::after{left:6px;top:0;width:1.5px;height:14px}
.faq-q.open .faq-ic::after{transform:rotate(90deg);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .28s ease}
.faq-a p{font-size:15px;color:var(--slate-2);line-height:1.7;padding-bottom:20px}

/* ============ CTA ============ */
.cta{background:var(--sage);padding:84px 0}
.cta-inner{text-align:center;max-width:620px;margin:0 auto}
.cta-h2{font-family:var(--serif);font-size:clamp(27px,4vw,42px);font-weight:400;color:#fff;line-height:1.22;margin-bottom:14px;letter-spacing:-.3px}
.cta-sub{color:rgba(255,255,255,.8);font-size:15px;margin-bottom:32px}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ============ FOOTER ============ */
.footer{background:var(--slate);padding:52px 0}
.footer-inner{display:flex;flex-direction:column;gap:22px}
.footer .wordmark{font-size:22px}
.footer-tag{margin-top:6px;color:#5d5c57}
.footer-links{display:flex;gap:22px;flex-wrap:wrap}
.footer-links a{font-size:13px;color:#74736c;text-decoration:none;transition:color .15s}
.footer-links a:hover{color:var(--bone)}
.footer-legal{font-size:12px;color:#48473f;line-height:1.6;max-width:700px;padding-top:14px;border-top:.5px solid #2c2b27}

/* ============ reveal ============ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease}
.reveal.in{opacity:1;transform:none}

/* ============ responsive ============ */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:44px}
  .free-grid,.quotes{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr;max-width:460px;margin:0 auto}
  .nav-links{display:none}
  .strip-rule{display:none}
  .strip-stat{min-width:160px;padding:16px 24px}
}
@media(max-width:600px){
  .section,.free,.strip,.cta{padding:56px 0}
  .hero{padding:48px 0 60px}
  .hero-cta,.cta-btns,.email-form{flex-direction:column}
  .hero-cta .btn,.cta-btns .btn{width:100%}
  .steps::before{left:24px}
  .step{gap:16px}
  .step-rail,.step-price{width:48px}
  .step-price{height:48px;font-size:14px}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none;transition:none}
}
