/* ===== Rooted — heirloom family-tree site ===== */
:root{
  --parch:#f4ecd6;       /* warm parchment */
  --parch-lt:#faf6ea;    /* lighter cream */
  --green:#2e4633;       /* forest green */
  --green-d:#22351f;     /* deep green */
  --green-dd:#1a2b18;
  --gold:#a9863f;        /* antique gold */
  --gold-lt:#c9a85f;
  --brown:#3a2c1a;       /* walnut text */
  --brown-lt:#6b5b43;    /* muted brown */
  --line:#d9cba6;
  --shadow:0 18px 50px rgba(34,53,31,.22);
  --serif:"Cormorant Garamond",Georgia,serif;
  --body:"EB Garamond",Georgia,serif;
  --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--body);color:var(--brown);
  background:var(--parch-lt);font-size:19px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
h1,h2,h3{font-family:var(--serif);font-weight:600;color:var(--green-d);line-height:1.08;margin:0}
h1{font-size:clamp(2.6rem,5.5vw,4.4rem);letter-spacing:-.01em}
h2{font-size:clamp(2rem,3.6vw,3rem)}
h3{font-size:1.5rem}
p{margin:0 0 1rem}
a{color:var(--green);text-decoration:none}
img{max-width:100%;display:block}
.center{text-align:center}
.eyebrow{font-family:var(--serif);text-transform:uppercase;letter-spacing:.28em;
  font-size:.8rem;font-weight:600;color:#8a6a2c;margin:0 0 .6rem}
.eyebrow.gold{color:var(--gold-lt)}
.sub{font-size:1.18rem;color:var(--brown-lt);max-width:640px;margin:0 auto 1.4rem}
.light{color:var(--parch)}
.sub.light{color:#d8e0d0}

/* ----- buttons ----- */
.btn{display:inline-block;background:var(--green-d);color:var(--parch);
  font-family:var(--serif);font-weight:600;letter-spacing:.02em;
  padding:.7em 1.4em;border-radius:999px;border:1px solid var(--green-d);
  cursor:pointer;transition:transform .15s ease,background .2s ease,box-shadow .2s ease;
  font-size:1.05rem;box-shadow:0 6px 18px rgba(34,53,31,.18)}
.btn:hover{background:var(--green);transform:translateY(-2px);box-shadow:0 10px 24px rgba(34,53,31,.28)}
.btn-lg{font-size:1.25rem;padding:.8em 1.8em}
.btn-sm{font-size:.95rem;padding:.5em 1.1em;box-shadow:none}
.btn-ghost{background:transparent;color:var(--parch);border-color:rgba(244,236,214,.55)}
.btn-ghost:hover{background:rgba(244,236,214,.12)}

/* ----- nav ----- */
.nav{position:sticky;top:0;z-index:50;background:rgba(250,246,234,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 24px}
.brand{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--serif);
  font-size:1.6rem;font-weight:700;color:var(--green-d)}
.brand-mark{color:var(--gold);font-size:1.3rem}
.nav-links{display:flex;align-items:center;gap:1.6rem;font-family:var(--serif);font-size:1.1rem}
.nav-links a{color:var(--green-d)}
.nav-links a:hover{color:var(--gold)}
.nav-links .btn{color:var(--parch)}
.nav-toggle{display:none;background:none;border:0;font-size:1.7rem;line-height:1;color:var(--green-d);cursor:pointer;padding:2px 6px}

/* ----- hero ----- */
.hero{background:
  radial-gradient(1200px 500px at 80% -10%,rgba(169,134,63,.14),transparent 60%),
  linear-gradient(180deg,var(--parch) 0%,var(--parch-lt) 100%);
  padding:64px 0 72px;border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero-copy .lead{font-size:1.3rem;color:var(--brown);max-width:30ch;margin-top:1.2rem}
.hero-cta{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;margin:1.8rem 0 .8rem}
.price-chip{font-family:var(--serif);font-weight:700;font-size:1.5rem;color:var(--green-d)}
.price-chip em{font-style:normal;font-size:.8rem;font-weight:500;color:var(--brown-lt);letter-spacing:.02em}
.hero-note{color:var(--brown-lt);font-size:1rem;font-style:italic}

/* ----- green-wall mockup ----- */
.hero-art{margin:0}
.wall{position:relative;display:block;width:100%;aspect-ratio:5/2;border:0;
  border-radius:10px;overflow:hidden;padding:0;
  background:
    radial-gradient(120% 90% at 50% 8%,#3c5942 0%,#2e4633 42%,#21351f 100%);
  box-shadow:var(--shadow)}
.wall-light{position:absolute;inset:0;background:radial-gradient(60% 45% at 50% 12%,rgba(255,250,225,.18),transparent 70%);pointer-events:none}
.wall .frame{position:absolute;top:46%;left:50%;transform:translate(-50%,-50%);
  width:96%;padding:1.2%;background:linear-gradient(150deg,#5a4327,#3a2a16 55%,#6b5230);
  border-radius:4px;box-shadow:0 22px 40px rgba(0,0,0,.45),inset 0 0 0 2px rgba(0,0,0,.25)}
.wall .frame img{border:5px solid #fbf6ea;border-radius:2px;box-shadow:0 2px 8px rgba(0,0,0,.4)}
.wall .plant{display:none}
.wall .shelf{position:absolute;left:0;right:0;bottom:0;height:13%;
  background:linear-gradient(180deg,#3a2a18,#251a0e);border-top:2px solid rgba(169,134,63,.4)}
.wall .plant{position:absolute;right:7%;bottom:11%;width:46px;height:80px;
  background:
   radial-gradient(circle at 50% 18%,#3f7a4d 0 18%,transparent 19%),
   radial-gradient(circle at 30% 30%,#356b42 0 16%,transparent 17%),
   radial-gradient(circle at 70% 30%,#356b42 0 16%,transparent 17%),
   radial-gradient(circle at 50% 48%,#2f5e3a 0 20%,transparent 21%);
  filter:drop-shadow(0 6px 6px rgba(0,0,0,.4))}
.wall .plant::after{content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);
  width:26px;height:26px;background:linear-gradient(#9c7b46,#6b4f2a);border-radius:3px 3px 5px 5px}
.hero-art figcaption{margin-top:.9rem;text-align:center;font-style:italic;color:var(--brown-lt);font-size:1rem}

/* ----- trust strip ----- */
.strip{background:var(--green-d);color:var(--parch)}
.strip-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;padding:30px 24px}
.strip strong{display:block;font-family:var(--serif);font-size:1.25rem;color:var(--gold-lt);margin-bottom:.2rem}
.strip span{color:#d8e0d0;font-size:1rem}

/* ----- sections ----- */
.section{padding:80px 0}
section[id]{scroll-margin-top:76px}
.section-cream{background:var(--parch)}
.section-dark{background:
  radial-gradient(900px 400px at 50% 0,#35513e,transparent 70%),var(--green-d);color:var(--parch)}
.section-dark h2{color:var(--parch)}

/* ----- steps ----- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:48px}
.step{background:var(--parch-lt);border:1px solid var(--line);border-radius:14px;
  padding:34px 30px;box-shadow:0 8px 24px rgba(34,53,31,.06)}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;
  border-radius:50%;background:var(--green-d);color:var(--gold-lt);font-family:var(--serif);
  font-size:1.4rem;font-weight:700;margin-bottom:1rem}
.step h3{margin-bottom:.5rem}
.step p{color:var(--brown-lt);margin:0;font-size:1.05rem}

/* ----- proof grid (real-tree close-ups) ----- */
.proof-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:34px}
.proof-grid figure{margin:0}
.proof-grid img{width:100%;height:auto;display:block;border:6px solid #fbf6ea;border-radius:5px;
  box-shadow:0 12px 32px rgba(34,53,31,.22)}
.proof-grid figcaption{margin-top:.7rem;text-align:center;font-style:italic;color:var(--brown-lt);font-size:.95rem}
@media (max-width:760px){.proof-grid{grid-template-columns:1fr;gap:20px}}

/* ----- pricing ----- */
.checklist{list-style:none;padding:0;margin:1.4rem 0}
.checklist li{position:relative;padding:.45rem 0 .45rem 2rem;border-bottom:1px dashed var(--line);font-size:1.1rem}
.checklist li::before{content:"❦";position:absolute;left:0;color:#8a6a2c;font-size:1rem;top:.55rem}
.fineprint{font-size:.95rem;color:var(--brown-lt);font-style:italic;margin:1rem 0 1.6rem}

/* ----- mission ----- */
.mission-wrap{max-width:760px}
.mission-body{margin-top:1.6rem}
.mission-body p{font-size:1.3rem;line-height:1.55;color:var(--brown);text-align:center;margin:0 auto 1.3rem;max-width:62ch}
.mission-body p:first-child{font-size:1.5rem;color:var(--green-d)}

/* ----- pricing tiers ----- */
.tiers{display:grid;grid-template-columns:1fr 1fr;gap:30px;max-width:920px;margin:42px auto 0;align-items:start}
.tier{position:relative;background:var(--parch-lt);color:var(--brown);border:1px solid var(--line);
  border-radius:16px;padding:34px 30px;box-shadow:0 10px 30px rgba(0,0,0,.18)}
.tier h3{color:var(--green-d);font-size:1.7rem}
.tier-feature{border:2px solid var(--gold);box-shadow:0 16px 40px rgba(0,0,0,.32)}
.tier-flag{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--gold);
  color:#3a2c1a;font-family:var(--serif);font-weight:700;font-size:.85rem;letter-spacing:.06em;
  text-transform:uppercase;padding:.25rem .9rem;border-radius:999px;white-space:nowrap}
.tier-price{font-family:var(--serif);font-size:2.8rem;font-weight:700;color:var(--gold);margin:.4rem 0 .1rem}
.tier-price-note{font-size:1rem;font-weight:500;color:var(--brown-lt);font-style:italic}
.tier-sub{color:var(--brown-lt);font-style:italic;margin-bottom:.4rem;min-height:2.6em}
.tier .checklist{margin:1rem 0 1.5rem}
.tier .checklist li{font-size:1.02rem}
.tier .btn{width:100%;text-align:center}
.btn-dark-ghost{background:transparent;color:var(--green-d);border-color:var(--green-d)}
.btn-dark-ghost:hover{background:var(--green-d);color:var(--parch)}

/* ----- hero gift line ----- */
.hero-gift{font-family:var(--serif);font-style:italic;font-size:1.22rem;color:var(--gold);
  margin:.1rem 0 1.3rem;border-left:3px solid var(--gold);padding-left:.95rem;max-width:38ch}

/* ----- comparison table ----- */
.compare{max-width:940px;margin:42px auto 0;border:1px solid var(--line);border-radius:14px;
  overflow:hidden;box-shadow:0 12px 34px rgba(34,53,31,.10);background:var(--parch-lt)}
.compare-row{display:grid;grid-template-columns:1.05fr 1.3fr 1.35fr}
.compare-row + .compare-row{border-top:1px solid var(--line)}
.compare-row > span{padding:16px 20px;font-size:1.02rem;line-height:1.35}
.cl{font-family:var(--serif);font-weight:600;color:var(--green-d);background:var(--parch)}
.them{color:var(--brown-lt)}
.us{color:var(--brown);background:rgba(169,134,63,.10);font-weight:500}
.compare-head{background:var(--parch)}
.compare-head > span{font-family:var(--serif);font-weight:700;font-size:1.12rem;padding-top:18px;padding-bottom:18px}
.compare-head .them{color:var(--brown-lt)}
.compare-head .us{background:var(--green-d);color:var(--parch)}

/* ----- finishing options ----- */
.finishes{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:42px}
.finish{background:var(--parch-lt);border:1px solid var(--line);border-radius:14px;padding:26px 22px;
  box-shadow:0 8px 24px rgba(34,53,31,.06)}
.finish h3{color:var(--green-d);font-size:1.35rem;margin-bottom:.55rem}
.finish p{color:var(--brown-lt);font-size:1rem;margin:0}
.finish-tag{display:inline-block;font-family:var(--serif);font-size:.74rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--gold);border:1px solid var(--gold);border-radius:999px;padding:.15rem .7rem;margin-bottom:.9rem}
.tag-included{color:var(--green-d);border-color:var(--green-d)}
.finish-mock{max-width:160px;margin:0 auto 16px}
.finish-mock svg{width:100%;height:auto;display:block;filter:drop-shadow(0 6px 14px rgba(34,53,31,.14))}
.finish{text-align:center}
.finish .finish-tag{margin-top:0}
.finish p{text-align:left}

/* ----- about ----- */
.about-wrap{max-width:680px}
.about-avatar{width:72px;height:72px;border-radius:50%;margin:24px auto 4px;background:var(--green-d);
  color:var(--gold-lt);font-family:var(--serif);font-weight:700;font-size:2rem;
  display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px rgba(34,53,31,.18)}
.about-body{margin-top:.6rem}
.about-body p{font-size:1.2rem;line-height:1.6;color:var(--brown);max-width:60ch;margin:0 auto 1.1rem;text-align:center}
.about-sign{font-family:var(--serif);font-style:italic;color:var(--green-d)}

/* ----- contact ----- */
.contact-wrap{max-width:620px}

/* ----- room to grow ----- */
.grow-wrap{max-width:700px}
.family-note{font-family:var(--serif);font-style:italic;color:var(--green-d);font-size:1.12rem;margin-top:.7rem}

/* ----- lead magnet ----- */
.guide-wrap{max-width:600px}
.guide-form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:1.4rem}
.guide-form input[type=email]{max-width:300px;flex:1 1 240px}
.guide-success{margin-top:1.3rem;font-size:1.1rem;color:var(--green-d);text-align:center}

/* ----- sticky mobile CTA ----- */
.sticky-cta{display:none}
@media (max-width:760px){
  body{padding-bottom:88px}
  .sticky-cta{display:block;position:fixed;left:14px;right:14px;bottom:calc(14px + env(safe-area-inset-bottom));z-index:60;text-align:center;
    background:var(--green-d);color:var(--parch);font-family:var(--serif);font-weight:600;font-size:1.15rem;
    padding:.8rem 1rem;border-radius:999px;box-shadow:0 8px 24px rgba(0,0,0,.32);
    opacity:0;transform:translateY(20px);transition:opacity .25s ease,transform .25s ease;pointer-events:none}
  .sticky-cta.show{opacity:1;transform:translateY(0);pointer-events:auto}
}

/* ----- form ----- */
.form-wrap{max-width:860px}
.intake{margin-top:36px}
fieldset{border:1px solid var(--line);border-radius:14px;padding:26px 28px 30px;margin:0 0 26px;background:var(--parch-lt)}
legend{font-family:var(--serif);font-size:1.5rem;font-weight:600;color:var(--green-d);padding:0 .6rem}
.legend-note{font-family:var(--body);font-size:1rem;font-style:italic;color:var(--brown-lt);font-weight:400}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px 22px}
.grid-1{display:grid;gap:18px}
.span-2{grid-column:1/-1}
label{display:flex;flex-direction:column;gap:.35rem;font-family:var(--serif);
  font-size:1.12rem;color:var(--green-d);font-weight:600}
.req{color:var(--gold)}
.opt{color:var(--brown-lt);font-weight:400;font-size:.9rem;font-style:italic}
input,textarea,select{font-family:var(--body);font-size:1.05rem;color:var(--brown);
  background:#fff;border:1px solid var(--line);border-radius:9px;padding:.6rem .8rem;width:100%}
input::placeholder,textarea::placeholder{color:#8a7c5a}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(169,134,63,.18)}
textarea{resize:vertical}
.hp{position:absolute;left:-9999px}
.form-foot{text-align:center;margin-top:8px}
.form-note{font-size:.95rem;color:var(--brown-lt);max-width:520px;margin:1rem auto 0;font-style:italic}
.form-success{text-align:center;padding:60px 20px;background:var(--parch-lt);border:1px solid var(--line);border-radius:16px;margin-top:30px}
.success-mark{font-size:3rem;color:var(--gold);display:block;margin-bottom:.5rem}

/* ----- agreement checkbox ----- */
.agree{flex-direction:row;align-items:flex-start;gap:.6rem;font-family:var(--body);
  font-size:1rem;font-weight:400;color:var(--brown-lt);max-width:560px;margin:0 auto 1.3rem;text-align:left}
.agree input{width:auto;margin-top:.25rem;accent-color:var(--green-d)}

/* ----- legal page ----- */
.legal-wrap{max-width:760px}
.legal-title{font-size:clamp(2.2rem,4vw,3.2rem)}
.legal-tldr{background:var(--parch-lt);border:1px solid var(--gold);border-left:5px solid var(--gold);
  border-radius:12px;padding:20px 24px;margin:28px 0 36px;font-size:1.15rem;color:var(--brown)}
.legal-body h2{color:var(--green-d);font-size:1.45rem;margin:1.9rem 0 .5rem}
.legal-body p{color:var(--brown);margin:0 0 1rem;font-size:1.08rem}
.footer-link{color:#cdd8c5;text-decoration:underline;font-size:.95rem}
.footer-link:hover{color:var(--parch)}

/* ----- faq ----- */
.faq-wrap{max-width:760px}
.faq{margin-top:34px}
details{border-bottom:1px solid var(--line);padding:.4rem 0}
summary{font-family:var(--serif);font-size:1.3rem;font-weight:600;color:var(--green-d);
  cursor:pointer;padding:.7rem 0;list-style:none;display:flex;justify-content:space-between;align-items:center}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";color:var(--gold);font-size:1.6rem;font-weight:400}
details[open] summary::after{content:"–"}
details p{color:var(--brown-lt);padding:0 0 1rem;margin:0;font-size:1.08rem}

/* ----- footer ----- */
.footer{background:var(--green-dd,#1a2b18);color:var(--parch);padding:38px 0}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer .brand{color:var(--parch)}
.footer .brand-name{color:var(--parch)}
.footer p{margin:0;color:#cdd8c5;font-style:italic}

/* ----- responsive ----- */
@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-copy .lead,.hero-copy .price-chip{max-width:none}
  .strip-inner{grid-template-columns:1fr;gap:18px;text-align:center}
  .steps{grid-template-columns:1fr}
  .tiers{grid-template-columns:1fr;gap:34px;max-width:440px}
  .finishes{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr}
  .nav-toggle{display:block}
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--parch-lt);border-bottom:1px solid var(--line);box-shadow:0 14px 26px rgba(34,53,31,.14);
    padding:6px 22px 16px;display:none}
  .nav-links.open{display:flex}
  .nav-links a{padding:13px 2px;border-bottom:1px solid var(--line);font-size:1.15rem}
  .nav-links a:last-child{border-bottom:0}
  .nav-links .btn{margin-top:12px;text-align:center}
}
@media (max-width:520px){
  body{font-size:18px}
  .section{padding:56px 0}
  .wall{aspect-ratio:4/3}
  .mission-body p,.mission-body p:first-child{font-size:1.2rem}
  .tier-sub{min-height:0}
  .hero-gift{font-size:1.1rem;max-width:none}
  .compare-row > span{padding:11px 11px;font-size:.86rem}
  .compare-head > span{font-size:.95rem;padding-top:13px;padding-bottom:13px}
  .finishes{grid-template-columns:1fr}
}

@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important;animation:none!important}}

/* ===== Documented Sources book showcase (#sources) ===== */
.sources-show{display:flex;gap:48px;align-items:center;justify-content:center;flex-wrap:wrap;margin-top:36px}
.sources-img{flex:1 1 360px;max-width:560px;display:block}
.sources-img img{width:100%;height:auto;display:block;filter:drop-shadow(0 16px 30px rgba(0,0,0,.5));transition:transform .25s ease}
.sources-img:hover img{transform:translateY(-4px)}
.sources-points{flex:1 1 340px;max-width:460px;text-align:left}
.sources-points .checklist{margin:0 0 4px}
.sources-price{display:flex;align-items:baseline;gap:14px;margin:22px 0 18px;flex-wrap:wrap}
.sources-price .sp-amt{font-family:'Cormorant Garamond',Georgia,serif;font-size:3rem;line-height:1;font-weight:700;color:#d9b566}
.sources-price .sp-note{color:#cfc7ad}
.sources-samples{margin-top:18px;font-size:.92rem;color:#cfc7ad}
.sources-samples a{color:#d9b566;text-decoration:underline}
@media (max-width:760px){.sources-show{gap:26px}.sources-price .sp-amt{font-size:2.5rem}}

/* ===== Weekly capacity badge (spots left / waitlist) ===== */
.spots-left{display:inline-flex;align-items:center;gap:.55em;margin:.2rem 0 1.1rem;
  font-family:var(--serif);font-weight:600;font-size:1.04rem;color:var(--green-d);
  background:var(--parch-lt);border:1px solid var(--gold);border-radius:999px;
  padding:.5em 1.05em;box-shadow:0 4px 14px rgba(0,0,0,.12);line-height:1.25}
.spots-left strong{color:var(--gold);font-weight:800}
.spots-dot{width:.62em;height:.62em;border-radius:50%;background:#3fae5a;flex:0 0 auto;
  box-shadow:0 0 0 0 rgba(63,174,90,.6);animation:spotsPulse 1.8s ease-out infinite}
@keyframes spotsPulse{
  0%{box-shadow:0 0 0 0 rgba(63,174,90,.55)}
  70%{box-shadow:0 0 0 .55em rgba(63,174,90,0)}
  100%{box-shadow:0 0 0 0 rgba(63,174,90,0)}}
.spots-left.is-full{border-color:#b06a2c;background:#f7ede0}
.spots-left.is-full strong{color:#b06a2c}
.spots-left.is-full .spots-dot{background:#d08a3c;animation:none}
.spots-left--form{display:flex;width:max-content;max-width:92%;margin:0 auto 1.5rem}
@media (max-width:760px){
  .spots-left{font-size:.94rem;padding:.48em .95em}
  .spots-left--form{margin:0 auto 1.2rem}}
