/* ============================================================
   IRONWOOD HOME SERVICES — Site Styles
   Palette pulled from logo:
   --char  #22272B  charcoal-navy
   --bronze #955B2D  copper/bronze
   --bronze-lt #B0784A lighter bronze (hover)
   --cream #ECECE4  warm cream panel
   --paper #FAF8F3  off-white page bg
   --ink   #2A2E31  body text
   ============================================================ */
:root{
  --char:#22272B;
  --char-2:#2D343A;
  --bronze:#955B2D;
  --bronze-lt:#B0784A;
  --cream:#ECECE4;
  --paper:#FAF8F3;
  --ink:#2A2E31;
  --muted:#5C6166;
  --line:rgba(34,39,43,.14);
  --maxw:1200px;
  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --body:"Mulish","Helvetica Neue",Arial,sans-serif;
  --shadow:0 18px 50px -20px rgba(34,39,43,.35);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);color:var(--ink);background:var(--paper);
  line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;color:var(--char);line-height:1.08;letter-spacing:.01em}
h1{font-size:clamp(2.6rem,6vw,4.6rem)}
h2{font-size:clamp(2rem,4vw,3.1rem)}
h3{font-size:clamp(1.3rem,2vw,1.7rem)}
p{margin-bottom:1rem}
.eyebrow{
  font-family:var(--body);font-weight:800;font-size:.74rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--bronze);display:inline-flex;align-items:center;gap:.7rem;margin-bottom:1rem;
}
/* bronze hairline — signature accent from the logo, on BOTH sides of the label
   like the logo's "— HOME SERVICES —". Any .eyebrow containing a <span class="rule">
   gets a matching trailing dash. The homepage hero eyebrow has no .rule, so it stays plain. */
.rule{display:inline-block;width:34px;height:1.5px;background:var(--bronze);vertical-align:middle;margin-right:.45rem}
.eyebrow:has(.rule)::after{content:"";display:inline-block;width:34px;height:1.5px;background:var(--bronze);vertical-align:middle;margin-left:.45rem}
/* When the rule wraps text (caps on both sides) explicitly, use .rule-caps */
.rule-caps{display:inline-flex;align-items:center;gap:.65rem;color:var(--bronze);background:none;width:auto;height:auto;margin-right:0}
.rule-caps::before,.rule-caps::after{content:"";height:1.5px;width:34px;background:var(--bronze);display:block}
.center{text-align:center}
.lede{font-size:1.15rem;color:var(--muted);max-width:60ch}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--body);font-weight:800;font-size:.92rem;letter-spacing:.04em;
  padding:16px 30px;border-radius:2px;cursor:pointer;border:1.5px solid transparent;
  transition:.22s ease;text-transform:uppercase;white-space:nowrap;
}
.btn-bronze{background:var(--bronze);color:#fff}
.btn-bronze:hover{background:var(--bronze-lt);transform:translateY(-2px)}
.btn-dark{background:var(--char);color:#fff}
.btn-dark:hover{background:var(--char-2);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--char);border-color:var(--char)}
.btn-ghost:hover{background:var(--char);color:#fff}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost-light:hover{background:#fff;color:var(--char)}

/* ---------- Header ---------- */
.topbar{background:var(--char);color:#cfd2d4;font-size:.82rem;letter-spacing:.04em}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;padding:8px 24px;flex-wrap:wrap;gap:6px}
.topbar a{color:#e7e4dd;font-weight:700}
.topbar .tb-areas{color:#aeb2b5}
header.site{position:sticky;top:0;z-index:50;background:rgba(250,248,243,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;max-width:var(--maxw);margin:0 auto}
.brand img{height:54px;width:auto}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none}
.nav-links a{font-weight:700;font-size:.93rem;letter-spacing:.02em;color:var(--char);position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--bronze);transition:.25s}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{display:flex;gap:10px;align-items:center}
.nav-cta .btn{padding:11px 18px;font-size:.8rem}
.hamburger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.hamburger span{width:26px;height:2.5px;background:var(--char);display:block;transition:.25s}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;overflow:hidden;background:var(--char)}
.hero::before{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,24,27,.62),rgba(20,24,27,.82)),
  url('assets/hero.jpg') center/cover no-repeat;}
.hero-inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:96px 24px 104px}
.hero .eyebrow{color:var(--bronze-lt)}
.hero h1{color:#fff;max-width:16ch}
.hero h1 em{font-style:italic;color:var(--bronze-lt)}
.hero .lede{color:#dcdcd6;font-size:1.22rem;margin:1.4rem 0 2rem;max-width:54ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-trust{display:flex;gap:28px;flex-wrap:wrap;margin-top:46px;padding-top:26px;border-top:1px solid rgba(255,255,255,.15)}
.hero-trust div{display:flex;align-items:center;gap:10px;font-size:.92rem;color:#e4e2db;font-weight:700}
.hero-trust .ck{color:var(--bronze-lt);font-size:1.2rem}

/* ---------- Sections ---------- */
section.band{padding:88px 0}
section.band.cream{background:var(--cream)}
section.band.char{background:var(--char);color:#e7e4dd}
section.band.char h2,section.band.char h3{color:#fff}
.sec-head{max-width:62ch}
.sec-head.center{margin:0 auto}

/* ---------- Trust strip ---------- */
.trust-strip{background:var(--char);color:#d7d4cd;padding:22px 0}
.trust-strip .wrap{display:flex;justify-content:space-around;gap:24px;flex-wrap:wrap;text-align:center}
.trust-strip b{display:block;font-family:var(--serif);font-size:1.9rem;color:#fff;line-height:1}
.trust-strip span{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bronze-lt);font-weight:800}

/* ---------- Service cards ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.svc-card{background:#fff;border:1px solid var(--line);padding:34px 28px;transition:.25s;position:relative;overflow:hidden}
.svc-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--bronze);transition:.3s}
.svc-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.svc-card:hover::before{width:100%}
.svc-card .ic{font-size:1.7rem;margin-bottom:14px;color:var(--bronze)}
.svc-card h3{font-size:1.35rem;margin-bottom:8px}
.svc-card ul{list-style:none;font-size:.95rem;color:var(--muted)}
.svc-card ul li{padding:5px 0 5px 20px;position:relative;border-bottom:1px solid var(--line)}
.svc-card ul li:last-child{border-bottom:0}
.svc-card ul li::before{content:"";position:absolute;left:0;top:13px;width:7px;height:7px;background:var(--bronze);border-radius:50%}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:50px}
.step{position:relative;padding-top:18px}
.step .n{font-family:var(--serif);font-size:3rem;color:var(--bronze);line-height:1;opacity:.85}
.step h3{margin:8px 0 6px}
.step p{color:var(--muted);font-size:.97rem}

/* ---------- Before/After ---------- */
.ba-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.ba-card{background:#fff;border:1px solid var(--line);overflow:hidden}
.ba-imgs{display:grid;grid-template-columns:1fr 1fr;position:relative}
.ba-imgs figure{position:relative;margin:0}
.ba-imgs img{height:200px;width:100%;object-fit:cover}
.ba-imgs figcaption{position:absolute;left:10px;top:10px;background:var(--char);color:#fff;font-size:.66rem;font-weight:800;letter-spacing:.14em;padding:4px 9px;text-transform:uppercase}
.ba-imgs figure:last-child figcaption{background:var(--bronze)}
.ba-card .ba-body{padding:18px 22px}
.ba-card h3{font-size:1.2rem}
.ba-card p{font-size:.92rem;color:var(--muted);margin:0}

/* ---------- Testimonials ---------- */
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.tst{background:var(--paper);border:1px solid var(--line);padding:32px 28px;position:relative}
section.char .tst{background:var(--char-2);border-color:rgba(255,255,255,.12)}
.tst .stars{color:var(--bronze-lt);letter-spacing:3px;margin-bottom:14px}
.tst p{font-family:var(--serif);font-size:1.22rem;line-height:1.5;color:var(--char)}
section.char .tst p{color:#f1efe9}
.tst .who{margin-top:16px;font-size:.85rem;font-weight:800;letter-spacing:.04em;color:var(--bronze)}
.tst .where{font-size:.8rem;color:var(--muted)}
section.char .tst .where{color:#a9adb1}

/* ---------- Areas ---------- */
.area-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.area-list span{background:rgba(149,91,45,.1);border:1px solid rgba(149,91,45,.3);color:var(--char);
  font-size:.82rem;font-weight:700;padding:7px 14px;border-radius:2px}
section.char .area-list span{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.18);color:#e7e4dd}

/* ---------- Lead form ---------- */
.lead{display:grid;grid-template-columns:1.05fr .95fr;gap:0;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}
.lead .lead-copy{background:var(--char);color:#e7e4dd;padding:52px 46px}
.lead .lead-copy h2{color:#fff}
.lead .lead-copy .eyebrow{color:var(--bronze-lt)}
.lead .lead-copy ul{list-style:none;margin-top:22px}
.lead .lead-copy ul li{padding:9px 0 9px 28px;position:relative;border-bottom:1px solid rgba(255,255,255,.1)}
.lead .lead-copy ul li::before{content:"✓";position:absolute;left:0;color:var(--bronze-lt);font-weight:800}
.lead-actions{display:flex;flex-direction:column;gap:12px;margin-top:30px}
.lead-actions .btn{width:100%}
.form{padding:48px 44px}
.form .fld{margin-bottom:18px}
.form label{display:block;font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--char);margin-bottom:7px}
.form input,.form textarea,.form select{
  width:100%;padding:14px 15px;border:1.5px solid var(--line);background:var(--paper);
  font-family:var(--body);font-size:1rem;color:var(--ink);border-radius:2px;transition:.2s;
}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--bronze);background:#fff}
.form .file-note{font-size:.78rem;color:var(--muted);margin-top:6px}
.form .btn{width:100%;margin-top:6px}
.form .fineprint{font-size:.74rem;color:var(--muted);margin-top:14px;text-align:center}

/* ---------- Floating mobile call bar ---------- */
.mobilebar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;
  background:var(--char);padding:10px 12px;gap:10px;box-shadow:0 -8px 24px rgba(0,0,0,.25)}
.mobilebar .btn{flex:1;padding:14px 8px;font-size:.82rem}

/* ---------- Footer ---------- */
footer.site{background:var(--char);color:#aeb2b5;padding:70px 0 30px}
footer.site .fcols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px}
footer.site h4{color:#fff;font-family:var(--body);font-weight:800;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px}
footer.site a{display:block;padding:5px 0;color:#bfc3c6;font-size:.92rem}
footer.site a:hover{color:var(--bronze-lt)}
footer.site .flogo img{height:62px;margin-bottom:16px}
footer.site .fp{font-size:.92rem;line-height:1.7}
footer.site .fbtm{margin-top:50px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem;color:#8b8f93}

/* ---------- Page hero (interior) ---------- */
.phero{background:var(--char);color:#fff;padding:64px 0 58px;text-align:center}
.phero h1{color:#fff}
.phero .lede{color:#d7d4cd;margin:1rem auto 0}
.crumb{font-size:.8rem;color:#9a9ea2;margin-bottom:14px;letter-spacing:.04em}
.crumb a:hover{color:var(--bronze-lt)}

/* ---------- Article (SEO pages) ---------- */
.article{max-width:760px;margin:0 auto}
.article h2{margin:38px 0 14px}
.article h3{margin:26px 0 10px}
.article p,.article li{font-size:1.05rem;color:#3a3e42}
.article ul{margin:0 0 18px 22px}
.article li{margin-bottom:8px}
.callout{background:var(--cream);border-left:3px solid var(--bronze);padding:22px 26px;margin:28px 0}
.callout p{margin:0}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:40px auto 0}
.faq details{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{cursor:pointer;list-style:none;padding:18px 40px 18px 0;font-family:var(--serif);font-size:1.3rem;color:var(--char);position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:6px;top:16px;font-size:1.6rem;color:var(--bronze);transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 0 20px;color:var(--muted)}

/* ---------- Service full list ---------- */
.svc-cat{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;margin-top:50px}
.svc-cat .col h3{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:2px solid var(--bronze);margin-bottom:8px}
.svc-cat ul{list-style:none}
.svc-cat ul li{padding:12px 0 12px 26px;position:relative;border-bottom:1px solid var(--line);font-weight:600}
.svc-cat ul li::before{content:"";position:absolute;left:0;top:18px;width:8px;height:8px;border:2px solid var(--bronze);border-radius:50%}
.svc-cat ul li span{display:block;font-weight:400;font-size:.9rem;color:var(--muted)}

/* ---------- CTA band ---------- */
.cta-band{background:var(--bronze);color:#fff;text-align:center;padding:74px 0}
.cta-band h2{color:#fff;max-width:20ch;margin:0 auto}
.cta-band p{color:#f6ece2;max-width:50ch;margin:14px auto 26px;font-size:1.1rem}
.cta-band .btn-dark{background:var(--char)}
.cta-band .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- About ---------- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-grid img{border:1px solid var(--line);box-shadow:var(--shadow)}
.vals{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:46px}
.val{background:#fff;border:1px solid var(--line);padding:28px}
.val .ic{font-size:1.6rem;color:var(--bronze);margin-bottom:10px}
.val h3{font-size:1.25rem;margin-bottom:6px}
.val p{font-size:.95rem;color:var(--muted);margin:0}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .svc-grid,.steps,.ba-grid,.tst-grid{grid-template-columns:repeat(2,1fr)}
  .lead{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr;gap:34px}
  footer.site .fcols{grid-template-columns:1fr 1fr}
  .svc-cat{grid-template-columns:1fr}
}
@media(max-width:680px){
  body{font-size:16px}
  .nav-links,.nav-cta .btn{display:none}
  .nav-links.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;
    background:var(--paper);padding:18px 24px;gap:6px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .nav-links.open a{padding:12px 0;border-bottom:1px solid var(--line)}
  .hamburger{display:flex}
  .svc-grid,.steps,.ba-grid,.tst-grid,.vals{grid-template-columns:1fr}
  .trust-strip .wrap{gap:18px}
  .trust-strip b{font-size:1.5rem}
  .hero-inner{padding:64px 24px 96px}
  .mobilebar{display:flex}
  footer.site .fcols{grid-template-columns:1fr}
  body{padding-bottom:64px}
  .form,.lead .lead-copy{padding:34px 26px}
  .topbar .tb-areas{display:none}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
