:root{
  --paper:#f5f1e8; --paper-2:#ece5d6; --card:#fffdf7; --ink:#211d16; --ink-2:#564e3f; --ink-3:#8a8170;
  --line:#ddd3bf; --line-strong:#c9bda3;
  --green:#1f4435; --green-2:#2c5d49; --green-ink:#f3efe4;
  --clay:#b5612a; --clay-2:#9c4f1f; --clay-bg:#f4e4d3;
  --radius:12px; --maxw:1080px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
body{background:var(--paper); color:var(--ink); font-family:"Public Sans",system-ui,sans-serif; font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x:hidden}
h1,h2,h3,h4{font-family:"Fraunces",Georgia,serif; font-weight:560; line-height:1.1; letter-spacing:-0.015em}
h1{font-size:clamp(2.3rem,5.5vw,3.9rem)}
h2{font-size:clamp(1.7rem,4vw,2.55rem)}
h3{font-size:1.2rem}
p{color:var(--ink-2)}
a{color:var(--green); text-decoration:none}
img{max-width:100%; display:block; height:auto}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 22px}
section{padding:clamp(52px,8vw,96px) 0}
.eyebrow{font-size:.8rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--clay)}
.center{text-align:center}
.muted{color:var(--ink-3)}

.btn{display:inline-flex; align-items:center; justify-content:center; gap:9px; min-height:50px; padding:13px 24px; border-radius:var(--radius); font-weight:600; font-size:1rem; border:1.5px solid var(--green); cursor:pointer; transition:transform .12s ease, background .12s ease}
.btn-primary{background:var(--green); color:var(--green-ink)}
.btn-primary:hover{background:var(--green-2); transform:translateY(-2px)}
.btn-ghost{background:transparent; color:var(--green)}
.btn-ghost:hover{background:var(--paper-2); transform:translateY(-2px)}

/* ---------- header + mobile nav (zero-JS checkbox toggle) ---------- */
header{position:sticky; top:0; z-index:30; background:rgba(245,241,232,.9); backdrop-filter:blur(8px); border-bottom:1px solid var(--line)}
.nav{display:flex; align-items:center; gap:14px; min-height:70px; flex-wrap:wrap}
.brand{display:inline-flex; align-items:center; gap:11px; min-height:46px; font-family:"Fraunces",serif; font-weight:600; font-size:1.26rem; color:var(--ink)}
.brand .mark{width:34px; height:34px; flex:none}
.nav-toggle{position:absolute; opacity:0; pointer-events:none}
.hamburger{display:none; margin-left:auto; width:48px; height:48px; border-radius:10px; border:1px solid var(--line-strong); background:var(--card); cursor:pointer; align-items:center; justify-content:center; flex-direction:column; gap:5px}
.hamburger span{display:block; width:20px; height:2px; background:var(--ink); border-radius:2px; transition:.2s}
.nav-links{display:flex; align-items:center; gap:24px; margin-left:auto}
.nav-links a{color:var(--ink-2); font-weight:500; font-size:1rem; min-height:44px; display:inline-flex; align-items:center}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--green)}
.nav-links a[aria-current="page"]{font-weight:600}
.nav-links .btn{color:var(--green-ink)}

@media(max-width:820px){
  .hamburger{display:flex}
  .nav-links{display:none; flex-basis:100%; flex-direction:column; align-items:stretch; gap:2px; padding:8px 0 14px}
  .nav-links a{min-height:50px; padding:0 6px; border-bottom:1px solid var(--line)}
  .nav-links .btn{margin-top:10px; justify-content:center}
  .nav-toggle:checked ~ .nav-links{display:flex}
  .nav-toggle:focus-visible ~ .hamburger{outline:3px solid var(--green); outline-offset:2px}
}

/* ---------- page hero ---------- */
.page-hero{padding:clamp(48px,7vw,84px) 0 clamp(34px,5vw,52px)}
.page-hero .tag{display:inline-block; background:var(--clay-bg); color:var(--clay-2); font-weight:600; font-size:.86rem; padding:6px 13px; border-radius:999px; margin-bottom:20px}
.page-hero h1{max-width:16ch; margin-bottom:18px}
.page-hero p.lead{font-size:clamp(1.05rem,2.3vw,1.3rem); max-width:46ch}
.cta-row{display:flex; gap:14px; flex-wrap:wrap; margin-top:28px}

/* ---------- bands & grids ---------- */
.band{background:var(--green); color:var(--green-ink)}
.band .eyebrow{color:var(--clay-bg)}
.band h2{color:var(--green-ink)}
.band p{color:#cdd8d0}
.grid{display:grid; gap:20px}
.g3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.g2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}

.check{background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius:var(--radius); padding:20px}
.check h3{color:var(--green-ink); margin-bottom:6px; display:flex; gap:9px; align-items:baseline}
.check h3 .x{color:var(--clay-bg); font-family:"Public Sans"; font-weight:700}
.check p{color:#c4cfc6; font-size:.96rem}

figure.case{background:var(--card); border:1px solid var(--line-strong); border-radius:var(--radius); overflow:hidden; box-shadow:0 2px 14px rgba(33,29,22,.06)}
figure.case img{border-bottom:1px solid var(--line); aspect-ratio:400/353; object-fit:cover; object-position:top; width:100%}
figure.case figcaption{padding:18px 20px}
figure.case h3{margin-bottom:4px}
figure.case p{font-size:.96rem}
.kind{font-size:.78rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--clay)}

.case-row{display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:0; align-items:stretch}
.case-row img{height:100%; width:100%; object-fit:cover; object-position:top; border-bottom:0; border-right:1px solid var(--line)}
.case-row figcaption{padding:28px}
.case-row figcaption h3{font-size:1.5rem; margin:6px 0 10px}
@media(max-width:720px){
  .case-row{grid-template-columns:1fr}
  .case-row img{aspect-ratio:400/353; border-right:0; border-bottom:1px solid var(--line)}
}

.tier{background:var(--card); border:1px solid var(--line-strong); border-radius:var(--radius); padding:26px}
.tier.feature{border-color:var(--green); border-width:2px}
.tier .price{font-family:"Fraunces",serif; font-size:2rem; font-weight:600; color:var(--green); margin:6px 0 4px}
.tier .price small{font-size:.9rem; color:var(--ink-3); font-weight:400; font-family:"Public Sans"}
.tier ul{list-style:none; margin-top:14px; display:flex; flex-direction:column; gap:9px}
.tier li{font-size:.97rem; color:var(--ink-2); padding-left:22px; position:relative}
.tier li::before{content:"✓"; position:absolute; left:0; color:var(--clay); font-weight:700}

.step .n{font-family:"Fraunces",serif; font-size:1.6rem; color:var(--clay); font-weight:600}
.step h3{margin:6px 0}
.step p{font-size:.97rem}

/* ---------- forms ---------- */
.form{background:var(--card); border:1px solid var(--line-strong); border-radius:var(--radius); padding:24px}
.field{margin-bottom:16px}
.field label{display:block; font-weight:600; font-size:.92rem; margin-bottom:6px}
.field input,.field textarea,.field select{width:100%; font:inherit; font-size:16px; color:var(--ink); background:var(--paper); border:1.5px solid var(--line-strong); border-radius:10px; padding:13px 14px; min-height:50px}
.field textarea{min-height:130px; resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none; border-color:var(--green); box-shadow:0 0 0 3px rgba(31,68,53,.13)}

.contact-lines{display:flex; gap:14px; flex-wrap:wrap; margin-top:8px}
.big-link{display:inline-flex; align-items:center; gap:10px; min-height:54px; padding:14px 22px; border-radius:var(--radius); background:var(--green); color:var(--green-ink); font-weight:600; font-size:1.02rem}
.big-link.alt{background:var(--card); color:var(--green); border:1.5px solid var(--green)}
.big-link:hover{transform:translateY(-2px); transition:transform .12s}

/* ---------- footer ---------- */
footer{background:var(--green); color:var(--green-ink); padding:42px 0}
.foot{display:flex; gap:18px; flex-wrap:wrap; align-items:center; justify-content:space-between}
.foot .brand{color:var(--green-ink)}
.foot nav{display:flex; gap:18px; flex-wrap:wrap}
.foot a{color:#cdd8d0; font-size:.95rem; min-height:44px; padding:0 4px; display:inline-flex; align-items:center}
.foot a:hover{color:var(--green-ink)}
.foot .copy{color:#aebbb0; font-size:.88rem; min-height:44px; display:inline-flex; align-items:center}

.skip{position:absolute; left:-999px; min-height:44px; display:inline-flex; align-items:center; padding:0 14px}
.skip:focus{left:12px; top:12px; background:var(--green); color:#fff; border-radius:8px; z-index:50}
.lead-narrow{max-width:54ch}
.mt0{margin-top:0}

/* ---------- hero split (home page) ---------- */
.hero-grid{display:grid; grid-template-columns:1fr 310px; gap:52px; align-items:center}
@media(max-width:860px){.hero-grid{display:block} .hero-card{display:none}}

/* ---------- audit card widget ---------- */
.hero-card{position:relative}
.ac{background:var(--card); border:1px solid var(--line-strong); border-radius:18px; overflow:hidden; box-shadow:0 14px 48px rgba(33,29,22,.14), 0 3px 10px rgba(33,29,22,.07); transform:rotate(1.8deg) translateY(6px)}
.ac-head{display:flex; align-items:center; gap:12px; padding:16px 20px; background:var(--green)}
.ac-mark{width:36px; height:36px; flex:none}
.ac-brand{font-family:"Fraunces",serif; font-weight:600; font-size:.98rem; color:var(--green-ink); line-height:1.2}
.ac-sub{font-size:.74rem; color:#9dbfb5; text-transform:uppercase; letter-spacing:.1em; margin-top:2px}
.ac-grade{display:flex; align-items:center; gap:16px; padding:18px 20px 14px}
.ac-circle{width:56px; height:56px; border-radius:50%; background:var(--green); color:var(--green-ink); font-family:"Fraunces",serif; font-size:1.9rem; font-weight:600; display:flex; align-items:center; justify-content:center; flex:none}
.ac-score{font-family:"Fraunces",serif; font-size:1.45rem; font-weight:600; color:var(--green); line-height:1}
.ac-score span{font-size:.9rem; color:var(--ink-3); font-weight:400; font-family:"Public Sans"}
.ac-zero{font-size:.8rem; color:var(--ink-3); margin-top:3px}
.ac-list{padding:0 20px 14px; display:flex; flex-direction:column; gap:7px; border-bottom:1px solid var(--line)}
.ac-item{font-size:.88rem; color:var(--ink-2); display:flex; gap:9px; align-items:center}
.ac-tick{color:var(--green); font-weight:700; flex:none}
.ac-foot{padding:11px 20px; font-size:.8rem; color:var(--ink-3); text-align:center}
