/* Bradley Clay — main stylesheet.
   Design-DNA tokens come from inline <style id="bc-tokens"> in <head>.
   This file is the layout + components layer. Ledger constraints baked in:
   - inputs font-size:16px (#15 iOS zoom)
   - object-fit:cover + aspect-ratio container on every image slot (#5)
   - hero overlay max .40 (well under .55 cap #6)
   - eager hero / lazy below-fold is applied at template level (#13)
*/

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0; background:var(--c-bg); color:var(--c-text);
  font-family:var(--f-body); font-size:var(--fs-body); line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%;height:auto}
a{color:var(--c-primary);text-underline-offset:2px}
a:hover{color:var(--c-primary-dk)}

h1,h2,h3,h4{font-family:var(--f-head);font-weight:700;line-height:1.18;letter-spacing:-.005em;margin:0 0 .6em}
h1{font-size:var(--h1)} h2{font-size:var(--h2)} h3{font-size:var(--h3); font-weight:700}
p{margin:0 0 1em}

/* Visually-hidden skip link, revealed on focus */
.sr-only{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;padding:0;margin:-1px;border:0}
a.sr-only:focus{position:fixed!important;top:8px;left:8px;width:auto;height:auto;clip:auto;clip-path:none;background:var(--c-primary);color:#fff;padding:.6rem 1rem;border-radius:var(--r);z-index:1000}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--pad)}
section{padding:var(--sec-pad-y) 0}
section.alt{background:var(--c-bg-alt)}
.eyebrow{display:inline-block;font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--c-secondary);margin-bottom:.6rem}

/* ----- Buttons ----- */
.btn{
  display:inline-block;padding:.95em 1.5em;border-radius:var(--r);
  font-weight:600;font-size:1rem;letter-spacing:.02em;
  text-decoration:none;border:1px solid transparent;cursor:pointer;
  transition:transform .12s ease, background-color .12s ease;
}
.btn-primary{background:var(--c-primary);color:#fff}
.btn-primary:hover{background:var(--c-primary-dk);color:#fff;transform:translateY(-1px)}
.btn-accent{background:var(--c-accent);color:#1F1A14}
.btn-accent:hover{background:var(--c-accent-dk);color:#1F1A14;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--c-primary);border-color:var(--c-primary)}
.btn-ghost:hover{background:var(--c-primary);color:#fff}

/* ----- Forms (ledger #15: 16px inputs, labels, autocomplete) ----- */
.bc-form label{display:block;font-weight:600;font-size:.9rem;margin-bottom:.3rem;color:var(--c-text)}
.bc-form .row{display:grid;gap:.85rem;grid-template-columns:1fr 1fr}
.bc-form .row.one{grid-template-columns:1fr}
@media (max-width:640px){.bc-form .row{grid-template-columns:1fr}}
.bc-form input, .bc-form select, .bc-form textarea{
  width:100%; font-size:16px; line-height:1.4; padding:.7em .85em;
  border:1px solid var(--c-rule); border-radius:var(--r); background:#fff;
  font-family:inherit; color:var(--c-text);
}
.bc-form input:focus, .bc-form select:focus, .bc-form textarea:focus{
  outline:2px solid var(--c-accent); outline-offset:1px; border-color:var(--c-accent-dk);
}
.bc-form .sr-only{position:absolute!important;clip:rect(0 0 0 0);width:1px;height:1px;overflow:hidden}
.bc-form .submit-row{margin-top:.85rem}
.bc-form .submit-row button{width:100%}
.bc-form .reassure{font-size:.82rem;color:var(--c-text-mute);margin-top:.55rem}

/* ----- Header ----- */
.site-header{position:sticky;top:0;z-index:50;background:var(--c-bg);border-bottom:1px solid var(--c-rule)}
.site-header .inner{display:flex;align-items:center;justify-content:space-between;padding:.85rem 0;gap:1rem}
.brand-mark{display:flex;flex-direction:column;line-height:1;color:var(--c-text);text-decoration:none;letter-spacing:.04em}
.brand-mark .l1{font-family:var(--f-head);font-weight:700;font-size:1.05rem;color:var(--c-primary)}
.brand-mark .l2{font-family:var(--f-body);font-weight:600;font-size:.78rem;color:var(--c-text-mute);text-transform:uppercase}
.primary-nav ul{display:flex;gap:1.35rem;margin:0;padding:0;list-style:none;font-weight:500}
.primary-nav a{color:var(--c-text);text-decoration:none}
.primary-nav a:hover, .primary-nav .current-menu-item a{color:var(--c-primary)}
.header-cta{display:flex;gap:.6rem;align-items:center}
.header-phone{font-weight:700;color:var(--c-primary);text-decoration:none;white-space:nowrap}
.nav-toggle{display:none;background:none;border:0;font-size:1.5rem;color:var(--c-text);padding:.35rem .55rem;cursor:pointer}
@media (max-width:900px){
  .primary-nav{display:none}
  .nav-toggle{display:inline-block}
  .primary-nav.open{display:block;position:absolute;top:100%;right:0;background:var(--c-bg);border:1px solid var(--c-rule);border-top:0;padding:1rem;min-width:240px}
  .primary-nav.open ul{flex-direction:column;gap:.85rem}
}

/* ----- Hero (split photo/form — ledger HARD rule first-screen form) ----- */
.hero{position:relative;background:var(--c-bg)}
.hero .grid{
  display:grid;gap:2rem;align-items:center;
  grid-template-columns: 1.05fr .95fr;
  padding:clamp(2rem,4vw,3.5rem) 0;
}
@media (max-width:900px){.hero .grid{grid-template-columns:1fr}}
.hero h1{margin-top:0}
.hero .hook{font-size:1.1rem;color:var(--c-text-mute);max-width:46ch}
.hero .photo{
  position:relative;aspect-ratio:16/9;overflow:hidden;border-radius:var(--r-lg);
  background:#1F1A14;
}
.hero .photo img{width:100%;height:100%;object-fit:cover;display:block}
.hero .photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0) 55%,rgba(0,0,0,.4) 100%);
}
.hero .form-card{
  background:#fff;border:1px solid var(--c-rule);border-radius:var(--r-lg);
  padding:clamp(1.1rem,2.2vw,1.8rem);
  box-shadow:0 12px 30px -18px rgba(31,26,20,.25);
}
.hero .form-card h2{font-size:1.25rem;margin-bottom:.35rem}
.hero .form-card .reassure-row{display:flex;gap:1rem;font-size:.82rem;color:var(--c-text-mute);margin-top:.65rem}

/* ----- Trust strip ----- */
.trust-strip{background:var(--c-bg-alt);padding:2.5rem 0;border-block:1px solid var(--c-rule)}
.trust-strip .row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:2rem 3rem}
.trust-strip .heading{
  font-family:var(--f-body);font-weight:600;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--c-text-mute);margin-bottom:1.25rem;text-align:center;
}
.trust-strip img{height:24px;width:auto;max-height:24px;opacity:.6;filter:grayscale(100%);transition:opacity .15s, filter .15s}
.trust-strip img:hover{opacity:1;filter:grayscale(0%)}

/* ----- Services grid ----- */
.services-grid{display:grid;gap:1.1rem;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.svc-card{
  background:#fff;border:1px solid var(--c-rule);border-radius:var(--r);
  padding:1.4rem 1.4rem 1.5rem;display:flex;flex-direction:column;gap:.6rem;
  text-decoration:none;color:var(--c-text);
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.svc-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px -14px rgba(31,26,20,.2);border-color:var(--c-primary)}
.svc-card .ic{
  width:46px;height:46px;display:grid;place-items:center;
  background:var(--c-bg-alt);border-radius:var(--r);color:var(--c-primary);
  flex:0 0 auto;
}
.svc-card .ic svg{width:24px;height:24px;display:block}
.svc-card h3{margin:.25rem 0 .1rem;font-size:1.35rem;font-weight:700;line-height:1.25;color:var(--c-text)}
.svc-card p{margin:0;color:var(--c-text-mute);font-size:1rem;line-height:1.5}
.svc-card .more{margin-top:auto;color:var(--c-primary);font-weight:600;text-decoration:none;font-size:.95rem}
.svc-card:hover .more{text-decoration:underline;text-underline-offset:3px}

/* ----- Owner block ----- */
.owner-block{display:grid;gap:2rem;grid-template-columns:.7fr 1fr;align-items:center}
@media (max-width:780px){.owner-block{grid-template-columns:1fr}}
.owner-block .ph{aspect-ratio:4/5;overflow:hidden;border-radius:var(--r-lg);border:1px solid var(--c-rule)}
.owner-block .ph img{width:100%;height:100%;object-fit:cover}
.owner-block blockquote{margin:0;font-family:var(--f-head);font-size:1.25rem;line-height:1.45;color:var(--c-text);border-left:3px solid var(--c-accent);padding-left:1rem}

/* ----- Process steps ----- */
.steps{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));counter-reset:s;margin-top:2.5rem}
.step{padding:2.2rem 1.7rem 1.7rem;background:#fff;border:1px solid var(--c-rule);border-radius:var(--r);position:relative;box-shadow:0 1px 2px rgba(31,26,20,.04),0 8px 24px -16px rgba(31,26,20,.08)}
.step::before{counter-increment:s;content:counter(s);position:absolute;top:1.2rem;left:1.7rem;background:var(--c-accent);color:#1F1A14;width:38px;height:38px;display:grid;place-items:center;border-radius:50%;font-weight:700;font-size:1.05rem}
.step h3{font-size:1.2rem;margin:3.2rem 0 .5rem}
.step p{margin:0;color:var(--c-text-mute);font-size:1rem;line-height:1.55}

/* ----- Reviews ----- */
.reviews-grid{display:grid;gap:1.1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.review-card{background:#fff;border:1px solid var(--c-rule);border-radius:var(--r);padding:1.25rem;display:flex;flex-direction:column;gap:.55rem}
.review-card .who{display:flex;gap:.7rem;align-items:center}
.review-card .av{width:56px;height:56px;border-radius:50%;overflow:hidden;flex:0 0 auto;background:var(--c-bg-alt)}
.review-card .av img{width:100%;height:100%;object-fit:cover}
.review-card .meta{display:flex;flex-direction:column;line-height:1.25}
.review-card .meta .nm{font-weight:600}
.review-card .meta .sub{font-size:.82rem;color:var(--c-text-mute)}
.review-card .stars{color:var(--c-accent);letter-spacing:.06em}
.review-card .body{color:var(--c-text)}
.review-card .src{font-size:.78rem;color:var(--c-text-mute);text-transform:uppercase;letter-spacing:.08em;margin-top:auto}

/* ----- Service Areas Strip ----- */
.areas-strip{display:flex;flex-wrap:wrap;gap:.5rem .7rem;justify-content:center}
.areas-strip a{display:inline-block;padding:.5rem .85rem;background:#fff;border:1px solid var(--c-rule);border-radius:var(--r);text-decoration:none;color:var(--c-text);font-weight:500;font-size:.95rem}
.areas-strip a:hover{border-color:var(--c-primary);color:var(--c-primary)}

/* ----- CTA band ----- */
.cta-band{background:var(--c-secondary);color:#F8F5F0}
.cta-band .inner{display:grid;gap:1.5rem;grid-template-columns:1fr auto;align-items:center}
@media (max-width:780px){.cta-band .inner{grid-template-columns:1fr;text-align:center}}
.cta-band h2{color:#fff;margin:0}
.cta-band p{color:rgba(248,245,240,.85);margin:.3rem 0 0}

/* ----- FAQ ----- */
.faq details{background:#fff;border:1px solid var(--c-rule);border-radius:var(--r);padding:1rem 1.1rem;margin-bottom:.6rem}
.faq summary{cursor:pointer;font-weight:600;list-style:none;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--c-primary);line-height:1}
.faq details[open] summary::after{content:"−"}
.faq details > div{padding-top:.65rem;color:var(--c-text-mute)}

/* ----- Footer ----- */
.site-footer{background:#1F1A14;color:#D7CEC0;padding-block:3rem 1.5rem;margin-top:3rem}
.site-footer a{color:#F8F5F0;text-decoration:none}
.site-footer a:hover{text-decoration:underline;text-underline-offset:3px}
.site-footer .grid{display:grid;gap:2.5rem;grid-template-columns:1.4fr 1fr 1fr}
@media (max-width:900px){.site-footer .grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.site-footer .grid{grid-template-columns:1fr}}
.site-footer h4{color:#F8F5F0;font-family:var(--f-head);font-size:1.05rem;margin:0 0 .65rem}
.site-footer ul{margin:0;padding:0;list-style:none;display:grid;gap:.4rem}
.site-footer .creds{font-size:.85rem;line-height:1.55;color:#9C8E7B}
.site-footer .bottom{display:flex;justify-content:space-between;gap:1rem;padding-top:1.5rem;margin-top:2rem;border-top:1px solid #3a322a;font-size:.82rem;color:#9C8E7B}

/* ----- Generic page intro hero (non-home) ----- */
.page-hero{background:var(--c-bg-alt);padding:clamp(2rem,4vw,3rem) 0 0;border-bottom:1px solid var(--c-rule)}
.page-hero .grid{display:grid;gap:2rem;grid-template-columns:1.1fr .9fr;align-items:end;padding-bottom:clamp(1.5rem,3vw,2.5rem)}
@media (max-width:900px){.page-hero .grid{grid-template-columns:1fr}}
.page-hero h1{margin-bottom:.45rem}
.page-hero .breadcrumb{font-size:.82rem;color:var(--c-text-mute);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.08em}

/* ----- Aspect helpers ----- */
.aspect-16-9{aspect-ratio:16/9;overflow:hidden;border-radius:var(--r)}
.aspect-4-5{aspect-ratio:4/5;overflow:hidden;border-radius:var(--r)}
.aspect-3-2{aspect-ratio:3/2;overflow:hidden;border-radius:var(--r)}
.aspect-1-1{aspect-ratio:1/1;overflow:hidden;border-radius:var(--r)}
.aspect-16-10{aspect-ratio:16/10;overflow:hidden;border-radius:var(--r)}
.aspect-16-9 img,.aspect-4-5 img,.aspect-3-2 img,.aspect-1-1 img,.aspect-16-10 img{width:100%;height:100%;object-fit:cover}

/* ----- Generic content layout ----- */
.content-wrap{display:grid;gap:2rem;grid-template-columns:1fr 320px;align-items:start}
@media (max-width:980px){.content-wrap{grid-template-columns:1fr}}
.content-wrap .main p{margin-bottom:1em}
.content-wrap .main h2{margin-top:1.6em}
.content-wrap .main h3{margin-top:1.4em}
.aside-quote{background:var(--c-bg-alt);border:1px solid var(--c-rule);border-radius:var(--r);padding:1.25rem;position:sticky;top:90px}
.aside-quote h3{margin-top:0}

/* ----- Utility ----- */
.text-center{text-align:center}
.mt-2{margin-top:2rem}
.mb-2{margin-bottom:2rem}
.muted{color:var(--c-text-mute)}
