/* A2 Craftsmen shared design system. Link this from new pages; keep a small
   page-specific <style> block for anything unique (hero art, panel CSS, etc). */
:root{
  --a2-green:#2E6B43; --a2-green-deep:#245636; --a2-green-soft:#7FB58C;
  --a2-charcoal:#2E3338; --a2-ink:#1C2226; --a2-slate:#49525A; --a2-top:#E9EBEA;
  --green-50:#EEF5F0; --green-100:#D7E8DD;
  --neutral-0:#FFFFFF; --neutral-50:#F4F5F4; --neutral-100:#E9EBEA; --neutral-200:#D8DCDA;
  --neutral-300:#BCC2C1; --neutral-500:#5C636A; --neutral-800:#2E3338; --neutral-900:#20262A; --neutral-950:#1C2226;
  --cedar-500:#B9854A;
  --bg:var(--neutral-50); --bg-raised:#fff; --bg-sunken:#EDEFEE;
  --fg1:var(--neutral-950); --fg2:var(--neutral-800); --fg3:var(--neutral-500);
  --fg-on-dark:#EFF1F0; --fg-on-dark-2:#9FB0A4;
  --border:var(--neutral-200); --hairline:#E2E5E3; --brand:var(--a2-green); --brand-hover:#357A4D;
  --shadow-sm:0 1px 2px rgba(28,34,38,.06),0 1px 1px rgba(28,34,38,.04);
  --shadow-md:0 4px 12px rgba(28,34,38,.08),0 2px 4px rgba(28,34,38,.04);
  --shadow-lg:0 12px 28px rgba(28,34,38,.12),0 4px 8px rgba(28,34,38,.06);
  --shadow-xl:0 24px 56px rgba(28,34,38,.16),0 8px 16px rgba(28,34,38,.08);
  --shadow-green:0 8px 22px rgba(46,107,67,.26);
  --font:'Poppins','Helvetica Neue',Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--fg1);line-height:1.6;-webkit-font-smoothing:antialiased}
html,body{overflow-x:clip}
::selection{background:rgba(46,107,67,.2)}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.eyebrow{font-weight:600;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--brand)}
.h2{font-weight:800;font-size:clamp(26px,3vw,36px);letter-spacing:-.01em;line-height:1.12;color:var(--fg1);text-wrap:balance}
.lead{font-size:19px;line-height:1.6;color:var(--fg2)}
.btn{font-family:var(--font);font-weight:600;font-size:15px;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:8px;padding:12px 20px;transition:all 160ms cubic-bezier(.16,.84,.36,1)}
.btn:hover{transform:translateY(-1px)}
.btn-lg{font-size:17px;padding:15px 26px}
.btn-primary{background:var(--brand);color:#fff;box-shadow:var(--shadow-green)}
.btn-primary:hover{background:var(--brand-hover)}
.btn-secondary{background:#fff;color:var(--fg1);border:1.5px solid var(--border)}
.btn-secondary:hover{border-color:var(--brand);color:var(--brand);background:var(--green-50)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.photo{position:relative;border-radius:16px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.star{color:#B9854A}
section{scroll-margin-top:84px}
.wordmark{font-weight:800;letter-spacing:.005em;line-height:1;white-space:nowrap}

/* header */
header{position:sticky;top:0;z-index:50;transition:all 220ms cubic-bezier(.16,.84,.36,1);background:transparent;border-bottom:1px solid transparent}
header.solid{background:rgba(255,255,255,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--hairline)}
.nav{height:76px;display:flex;align-items:center;justify-content:space-between}
.navlinks{display:flex;gap:4px}
.navlinks a{font-weight:500;font-size:15px;color:var(--fg2);padding:9px 14px;border-radius:8px}
.navlinks a:hover{color:var(--brand)}
.navlinks a.current{color:var(--brand);font-weight:600}
@media(max-width:880px){.navlinks{display:none}}

/* hero */
.hero{position:relative;margin-top:-76px;padding-top:76px;background:radial-gradient(900px 520px at 92% 0%,rgba(46,107,67,.10),transparent 60%),var(--bg)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;padding-top:56px;padding-bottom:72px}
.hero h1{font-weight:800;font-size:clamp(34px,4.4vw,52px);line-height:1.06;letter-spacing:-.02em;margin:18px 0 20px;text-wrap:balance}
.hero .sub{font-size:18px;line-height:1.6;color:var(--fg2);max-width:520px;margin-bottom:30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:28px}
.trustline{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.tbadge{display:inline-flex;align-items:center;gap:6px;background:var(--green-50);color:var(--a2-green-deep);font-weight:600;font-size:13px;padding:8px 14px;border-radius:999px}
.tbadge .star{color:#B9854A}
.tbadge .ck{color:var(--brand);font-weight:800}
.hero-photo{position:relative}
.hero-photo .photo{height:440px;box-shadow:var(--shadow-xl)}
.float-card{position:absolute;left:-22px;bottom:28px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px 18px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-lg)}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr;gap:26px;padding-top:32px;padding-bottom:44px}.float-card{left:12px;bottom:16px}.hero-photo .photo{height:300px}.hero h1{font-size:clamp(30px,8.2vw,44px)}.hero h1 br{display:none}}
@media(max-width:520px){.hero-photo .photo{height:240px}}

/* type / material cards */
.types{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:780px){.types{grid-template-columns:1fr}}
.tcard{background:#fff;border:1px solid var(--border);border-radius:16px;padding:28px 30px;box-shadow:var(--shadow-md);transition:all 200ms cubic-bezier(.16,.84,.36,1)}
.tcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.tcard h3{font-weight:700;font-size:21px;margin-bottom:8px}
.tcard p{font-size:15px;color:var(--fg2);margin-bottom:16px}
.tmark{width:46px;height:46px;margin-bottom:14px;border-radius:12px;background:var(--green-50);color:var(--brand);display:flex;align-items:center;justify-content:center}
.tmark svg{width:24px;height:24px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-weight:600;font-size:12px;padding:5px 11px;border-radius:999px;background:var(--bg-sunken);color:var(--fg2)}
.chip.g{background:var(--green-50);color:var(--a2-green-deep)}
.addon{margin-top:24px;background:#fff;border:1px solid var(--border);border-radius:16px;padding:22px 30px;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.addon p{font-size:15px;color:var(--fg2)}
.addon b{color:var(--fg1)}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:780px){.steps{grid-template-columns:1fr}}
.step{background:#fff;border:1px solid var(--border);border-radius:16px;padding:26px 24px;box-shadow:var(--shadow-sm)}
.step .n{font-weight:800;font-size:14px;letter-spacing:.06em;color:var(--brand);margin-bottom:8px}
.step h3{font-weight:700;font-size:19px;color:var(--fg1);margin-bottom:8px}
.step p{font-size:14.5px;line-height:1.55;color:var(--fg2)}

/* details / story */
.story{display:grid;grid-template-columns:.95fr 1.05fr;gap:48px;align-items:center}
@media(max-width:840px){.story{grid-template-columns:1fr;gap:28px}}
.story.flip .photo{order:2}
@media(max-width:840px){.story.flip .photo{order:0}}
.dlist{list-style:none;display:flex;flex-direction:column;gap:16px}
.dlist li{display:flex;gap:14px;font-size:15.5px;color:var(--fg2)}
.dlist .ic{flex:0 0 28px;height:28px;border-radius:8px;background:var(--green-50);color:var(--brand);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;margin-top:2px}
.dlist b{color:var(--fg1)}

/* gallery */
.galfilter{display:flex;gap:8px;justify-content:center;margin-bottom:28px;flex-wrap:wrap}
.galbtn{font-family:var(--font);font-weight:600;font-size:14px;padding:8px 18px;border-radius:999px;border:1.5px solid var(--border);background:#fff;color:var(--fg2);cursor:pointer;transition:all 140ms}
.galbtn.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.galgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:900px){.galgrid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.galgrid{grid-template-columns:repeat(2,1fr)}}
.galitem{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow-sm)}
.galitem img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.galitem:hover img{transform:scale(1.05)}

/* reviews marquee */
.marquee{overflow:hidden;position:relative}
.mtrack{display:flex;gap:20px;width:max-content;animation:scrollx 60s linear infinite;animation-play-state:paused;padding:6px 10px}
.marquee.live .mtrack{animation-play-state:running}
.marquee:hover .mtrack{animation-play-state:paused}
@media (prefers-reduced-motion: reduce){.mtrack{animation:none}}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.rchip{flex:0 0 360px;background:#fff;border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:var(--shadow-md)}
.rchip .st{color:#B9854A;letter-spacing:2px;font-size:14px}
.rchip p{font-size:14.5px;line-height:1.5;color:var(--fg2);margin:10px 0 14px}
.rchip .who b{font-weight:700;font-size:14px;color:var(--fg1)}
.rchip .who span{display:block;font-size:13px;color:var(--fg3)}
@media(max-width:600px){.rchip{flex-basis:300px}}

/* faq */
.faq{max-width:780px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px 24px;margin-bottom:12px;box-shadow:var(--shadow-sm)}
.faq summary{font-weight:700;font-size:16px;cursor:pointer;color:var(--fg1);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:'+';font-weight:700;color:var(--brand);font-size:20px;line-height:1}
.faq details[open] summary:after{content:'\2212'}
.faq details p{margin-top:10px;font-size:15px;color:var(--fg2)}

/* section helper */
.sec{padding:88px 0}
.sec.intro{padding-top:56px}
.sec-head{max-width:640px;margin-bottom:44px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.prose p{font-size:16.5px;line-height:1.7;color:var(--fg2);margin-bottom:16px}
.prose p:last-child{margin-bottom:0}

/* final cta */
.cta-band{background:linear-gradient(120deg,#2E6B43 0%,#1D4530 100%);border-radius:24px;padding:64px 56px;position:relative;overflow:hidden;box-shadow:var(--shadow-xl);text-align:center}
.cta-band .plank{position:absolute;inset:0;opacity:.1;background-image:repeating-linear-gradient(115deg,transparent 0 26px,rgba(255,255,255,.7) 26px 27px)}
.cta-band h2{position:relative;font-weight:800;font-size:clamp(30px,3.4vw,42px);line-height:1.08;letter-spacing:-.015em;color:#fff;margin-bottom:14px}
.cta-band p{position:relative;font-size:18px;color:rgba(239,241,240,.9);max-width:520px;margin:0 auto 28px}
.cta-band .row{position:relative;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* legal / prose pages */
.legal{max-width:760px}
.legal .updated{font-size:14px;color:var(--fg3);margin:6px 0 24px}
.legal h2{font-weight:800;font-size:21px;margin:30px 0 10px;color:var(--fg1)}
.legal p{font-size:15.5px;line-height:1.7;color:var(--fg2);margin-bottom:14px}
.legal a{color:var(--brand);font-weight:600}

/* breadcrumb */
.crumb{font-size:13px;color:var(--fg3);margin-bottom:14px}
.crumb a{color:var(--fg3);font-weight:600}
.crumb a:hover{color:var(--brand)}

/* footer */
footer{background:var(--neutral-950);padding:64px 0 34px;color:var(--fg-on-dark-2)}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
@media(max-width:780px){.fgrid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.fgrid{grid-template-columns:1fr;gap:30px}}
footer h4{font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--a2-green-soft);margin-bottom:16px}
footer ul{list-style:none;display:flex;flex-direction:column;gap:11px}
footer a{font-size:14px;color:var(--fg-on-dark);opacity:.82}
footer a:hover{opacity:1}
.fbottom{margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:var(--fg-on-dark-2)}
.fbottom a{color:var(--fg-on-dark-2)}
.fbottom a:hover{color:var(--fg-on-dark)}
