/* ============================================================
   We Will Fix — shared stylesheet (Coastal Craftsman design system)
   Used by all pages. Edit design tokens in :root to retheme.
   ============================================================ */

/* ============ DESIGN TOKENS ============ */
:root{
  --ink:#22302C; --sage:#7E9173; --sage-deep:#51634A;
  --cream:#F6F2E9; --brass:#B08A4F; --brass-deep:#8C6A38; --brass-hover:#9A7740;
  --white:#FFFFFF; --line:#E3DCCD; --muted:#5A6660;
  --shadow:0 8px 28px rgba(34,48,44,.07);
  --shadow-lift:0 14px 40px rgba(34,48,44,.12);
  --container:1200px; --radius-sm:4px; --radius-lg:12px;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.12;margin:0;letter-spacing:-.01em}
h1{font-size:clamp(2.4rem,6vw,3.9rem);font-weight:600;letter-spacing:-.02em}
h2{font-size:clamp(1.9rem,4vw,2.6rem)}
h3{font-size:clamp(1.2rem,2.4vw,1.45rem);font-weight:600}
p{margin:0 0 1rem}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--sage-deep);margin:0 0 .9rem}
.section{padding:clamp(4rem,9vw,7rem) 0}
.section--tint{background:linear-gradient(0deg,rgba(126,145,115,.10),rgba(126,145,115,.10)),var(--cream)}
.lead{font-size:1.15rem;color:var(--muted);max-width:60ch}
.center{text-align:center;margin-inline:auto}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--sans);font-weight:600;font-size:1rem;padding:.9rem 1.6rem;border-radius:var(--radius-sm);text-decoration:none;border:1.5px solid transparent;cursor:pointer;transition:background .18s,color .18s,box-shadow .18s,transform .18s}
.btn-primary{background:var(--brass);color:#16201c}
.btn-primary:hover{background:var(--brass-hover);box-shadow:var(--shadow)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--cream)}
.btn-ink{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn-ink:hover{background:#152120;box-shadow:var(--shadow-lift)}
.btn:focus-visible,a:focus-visible,button:focus-visible,summary:focus-visible{outline:3px solid var(--brass-deep);outline-offset:3px}

/* ============ SKIP LINK ============ */
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--cream);padding:.7rem 1rem;z-index:200;border-radius:0 0 var(--radius-sm) 0}
.skip:focus{left:0}

/* ============ HEADER ============ */
.site-header{position:sticky;top:0;z-index:100;background:rgba(246,242,233,.88);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:.85rem 24px;max-width:var(--container);margin:0 auto}
.brand{font-family:var(--serif);font-weight:600;font-size:1.4rem;letter-spacing:-.02em;text-decoration:none;color:var(--ink);white-space:nowrap}
.nav-links{display:flex;gap:1.8rem;list-style:none;margin:0;padding:0}
.nav-links a{text-decoration:none;font-weight:500;font-size:.97rem;color:var(--ink);opacity:.85;transition:opacity .15s}
.nav-links a:hover{opacity:1;text-decoration:underline;text-underline-offset:5px;text-decoration-color:var(--brass)}
.nav-cta{display:inline-flex;align-items:center;gap:.45rem;background:var(--brass);color:#16201c;text-decoration:none;font-weight:600;padding:.6rem 1.1rem;border-radius:999px;font-size:.95rem;white-space:nowrap}
.nav-cta:hover{background:var(--brass-hover)}
.nav-toggle{display:none;background:none;border:1.5px solid var(--ink);border-radius:var(--radius-sm);padding:.45rem .6rem;cursor:pointer;font-size:1rem;color:var(--ink)}

/* ============ HERO ============ */
.hero{padding:clamp(2.5rem,6vw,5rem) 0 clamp(3rem,7vw,5.5rem)}
.hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.hero h1{margin-bottom:1.2rem}
.hero .lead{margin-bottom:2rem;font-size:1.2rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.4rem}
.trust-line{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:var(--muted);font-weight:500}
.trust-line svg{flex:none;color:var(--sage-deep)}
.hero-media{position:relative}
.hero-media img{width:100%;height:clamp(320px,42vw,520px);object-fit:cover;border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.ph-tag{position:absolute;left:14px;bottom:14px;background:rgba(34,48,44,.82);color:var(--cream);font-size:.72rem;font-weight:500;letter-spacing:.02em;padding:.35rem .6rem;border-radius:var(--radius-sm)}

/* ============ SERVICES (cards) ============ */
.services-head{display:flex;flex-wrap:wrap;align-items:end;justify-content:space-between;gap:1rem;margin-bottom:2.6rem}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:2rem 1.8rem;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift)}
.card .eyebrow{margin-bottom:.55rem}
.card h3{margin-bottom:.6rem}
.card p{color:var(--muted);font-size:.97rem;margin-bottom:1.2rem}
.card .more{margin-top:auto;font-weight:600;color:var(--brass-deep);text-decoration:none;font-size:.95rem}
.card .more:hover{text-decoration:underline;text-underline-offset:4px}
.subservices{font-size:.85rem;color:var(--sage-deep);margin:.2rem 0 1.1rem;font-weight:500}

/* ============ WHY US ============ */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:2.4rem}
.why h3{display:flex;align-items:baseline;gap:.6rem;margin-bottom:.5rem}
.why p{color:var(--muted);font-size:.98rem;margin:0}
.todo{display:inline-block;font-family:var(--sans);font-size:.62rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--brass-deep);background:rgba(176,138,79,.14);border:1px solid rgba(176,138,79,.35);padding:.12rem .4rem;border-radius:3px;vertical-align:middle}

/* ============ WHAT TO EXPECT ============ */
.expect-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.expect-list{list-style:none;margin:1.8rem 0 0;padding:0;display:grid;gap:1.1rem}
.expect-list li{display:flex;gap:.9rem;align-items:flex-start;padding-bottom:1.1rem;border-bottom:1px solid var(--line)}
.expect-list li:last-child{border-bottom:none}
.expect-list .ico{flex:none;width:34px;height:34px;border-radius:50%;background:rgba(126,145,115,.18);display:grid;place-items:center;color:var(--sage-deep)}
.expect-list strong{display:block;font-weight:600;margin-bottom:.1rem}
.expect-list span.note{color:var(--muted);font-size:.92rem}
.expect-media{background:rgba(126,145,115,.12);border:1px dashed var(--sage);border-radius:var(--radius-lg);min-height:340px;display:grid;place-items:center;text-align:center;color:var(--sage-deep);padding:2rem}
.expect-media .cam{font-size:1.6rem;margin-bottom:.4rem}

/* ============ SERVICE AREA ============ */
.area-wrap{text-align:center}
.chips{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;margin:2rem auto 2.2rem;max-width:760px}
.chip{background:var(--white);border:1px solid rgba(34,48,44,.18);border-radius:999px;padding:.5rem 1.1rem;font-size:.92rem;font-weight:500;box-shadow:var(--shadow)}

/* ============ TESTIMONIALS ============ */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.4rem}
.quote{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.8rem;box-shadow:var(--shadow)}
.quote .stars{color:var(--brass-deep);letter-spacing:2px;margin-bottom:.7rem}
.quote p{font-style:italic;color:var(--ink);margin-bottom:1rem}
.quote .who{font-size:.88rem;color:var(--muted);font-weight:600;font-style:normal}
.placeholder-note{display:block;color:var(--muted);font-size:.74rem;font-weight:400;margin-top:.35rem;font-family:var(--sans);letter-spacing:.01em;font-style:normal}

/* ============ FAQ ============ */
.faq{max-width:820px;margin-inline:auto}
.faq details{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:0 1.4rem;margin-bottom:1rem;box-shadow:var(--shadow)}
.faq summary{list-style:none;cursor:pointer;font-family:var(--serif);font-weight:600;font-size:1.1rem;padding:1.2rem 0;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .plus{flex:none;color:var(--brass-deep);font-size:1.4rem;transition:transform .2s}
.faq details[open] summary .plus{transform:rotate(45deg)}
.faq details p{color:var(--muted);padding-bottom:1.3rem;margin:0}

/* ============ CTA BAND ============ */
.cta-band{background:var(--ink);color:var(--cream);border-radius:var(--radius-lg);padding:clamp(2.5rem,5vw,3.5rem);text-align:center}
.cta-band h2{color:var(--cream);margin-bottom:.7rem}
.cta-band p{color:rgba(246,242,233,.8);max-width:52ch;margin:0 auto 1.8rem}
.cta-band .btn-outline{color:var(--cream);border-color:var(--cream)}
.cta-band .btn-outline:hover{background:var(--cream);color:var(--ink)}
.cta-meta{margin-top:1.6rem;font-size:.95rem;color:rgba(246,242,233,.75)}
.cta-meta a{color:var(--cream);font-weight:600}

/* ============ BREADCRUMB ============ */
.breadcrumb{font-size:.85rem;color:var(--muted)}
.breadcrumb .container{padding-top:1.3rem;padding-bottom:.2rem}
.breadcrumb a{color:var(--sage-deep);text-decoration:none;font-weight:500}
.breadcrumb a:hover{text-decoration:underline;text-underline-offset:3px}
.breadcrumb .sep{margin:0 .5rem;color:var(--sage);opacity:.7}
.breadcrumb [aria-current]{color:var(--ink);font-weight:600}

/* ============ SERVICE GROUPS (handyman) ============ */
.group{padding:clamp(2.6rem,5vw,3.6rem) 0;border-bottom:1px solid var(--line)}
.group:last-of-type{border-bottom:none}
.group-intro{max-width:62ch;margin:.2rem 0 1.8rem}
.service-items{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:0 2rem}
.service-items li{display:flex;align-items:flex-start;gap:.65rem;padding:.85rem 0;border-bottom:1px solid var(--line);font-weight:500;font-size:1rem}
.service-items li svg{flex:none;color:var(--brass-deep);margin-top:.25rem}
.and-more{margin-top:1.8rem;padding:1.3rem 1.5rem;background:rgba(126,145,115,.10);border:1px solid var(--line);border-radius:var(--radius-lg)}
.and-more .label{font-weight:600;display:block;margin-bottom:.7rem;color:var(--ink)}
.and-more .more-chips{display:flex;flex-wrap:wrap;gap:.5rem}
.and-more .more-chips span{background:var(--white);border:1px solid rgba(34,48,44,.14);border-radius:999px;padding:.35rem .85rem;font-size:.84rem;color:var(--muted);font-weight:500}
.related{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.6rem}
.related a{font-weight:600;color:var(--brass-deep);text-decoration:none}
.related a:hover{text-decoration:underline;text-underline-offset:4px}

/* ============ FOOTER ============ */
.site-footer{background:#1b2522;color:rgba(246,242,233,.75);padding:3.5rem 0 6.5rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2rem}
.foot-grid h3{font-family:var(--serif);color:var(--cream);font-size:1.05rem;margin-bottom:1rem;font-weight:500}
.site-footer .brand{color:var(--cream);font-size:1.5rem;display:inline-block;margin-bottom:.7rem}
.foot-grid ul{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}
.foot-grid a{color:rgba(246,242,233,.78);text-decoration:none;font-size:.95rem}
.foot-grid a:hover{color:var(--cream);text-decoration:underline;text-underline-offset:4px}
.foot-bottom{border-top:1px solid rgba(246,242,233,.15);margin-top:2.6rem;padding-top:1.6rem;font-size:.85rem;color:rgba(246,242,233,.55);display:flex;flex-wrap:wrap;gap:.6rem;justify-content:space-between}

/* ============ MOBILE STICKY CALL BAR ============ */
.call-bar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:120;background:var(--brass);color:#16201c;text-align:center;font-weight:600;padding:.95rem;text-decoration:none;box-shadow:0 -4px 20px rgba(34,48,44,.18)}

/* ============ RESPONSIVE ============ */
@media (max-width:960px){
  .cards,.quotes,.why-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .service-items{grid-template-columns:1fr 1fr}
}
@media (max-width:768px){
  .nav-links,.nav .nav-cta{display:none}
  .nav-toggle{display:inline-block}
  .nav[data-open="true"] .nav-links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--cream);border-bottom:1px solid var(--line);padding:1rem 24px;gap:1rem}
  .hero-grid,.expect-grid{grid-template-columns:1fr}
  .hero-media{order:-1}
  .cards,.quotes,.why-grid,.foot-grid,.service-items{grid-template-columns:1fr}
  .call-bar{display:block}
  body{padding-bottom:0}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}

/* ============ INNER-PAGE HELPERS (service / about / area / contact) ============ */
.page-hero{padding:clamp(3rem,7vw,5rem) 0 clamp(2.4rem,5vw,3.4rem);text-align:center}
.page-hero .inner{max-width:760px;margin:0 auto}
.page-hero .hero-actions{justify-content:center}
.page-hero .trust-line{justify-content:center}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.split img{width:100%;height:100%;max-height:420px;object-fit:cover;border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.media-ph{position:relative;width:100%;min-height:320px;border-radius:var(--radius-lg);background:rgba(126,145,115,.12);border:1px dashed var(--sage);display:grid;place-items:center;text-align:center;color:var(--sage-deep);padding:2rem}
.media-ph .cam{font-size:1.6rem;margin-bottom:.4rem}
.checklist{list-style:none;margin:1.4rem 0 0;padding:0;display:grid;gap:.85rem}
.checklist li{display:flex;gap:.6rem;align-items:flex-start;font-weight:500}
.checklist li svg{flex:none;color:var(--brass-deep);margin-top:.28rem}
.prose{max-width:68ch}
.prose p{color:var(--muted)}
.contact-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.form{display:grid;gap:1.1rem;max-width:640px}
.form .row{display:grid;gap:1.1rem}
@media(min-width:560px){.form .row{grid-template-columns:1fr 1fr}}
.field{display:grid;gap:.4rem}
.field label{font-weight:600;font-size:.92rem}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:1rem;padding:.78rem .9rem;border:1px solid rgba(34,48,44,.25);border-radius:var(--radius-sm);background:var(--white);color:var(--ink);width:100%}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(176,138,79,.18)}
.areas{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem;margin-top:2rem}
.areas span{background:var(--white);border:1px solid rgba(34,48,44,.16);border-radius:var(--radius-sm);padding:.7rem 1rem;font-size:.92rem;font-weight:500;text-align:center}
@media(max-width:768px){.split,.contact-grid{grid-template-columns:1fr}.areas{grid-template-columns:1fr 1fr}}

/* ============ PORTFOLIO GALLERY ============ */
.filters{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin:0 0 2.6rem}
.filters button{font-family:var(--sans);font-weight:600;font-size:.88rem;padding:.5rem 1.05rem;border-radius:999px;border:1px solid rgba(34,48,44,.2);background:var(--white);color:var(--ink);cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.filters button:hover{border-color:var(--ink)}
.filters button[aria-pressed="true"]{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.work-grid{column-count:3;column-gap:1.4rem}
.work{break-inside:avoid;margin:0 0 1.4rem;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.work img{width:100%;height:auto;display:block}
.work figcaption{padding:1rem 1.15rem;font-weight:600;font-size:.95rem;line-height:1.4}
.work .tag{display:inline-block;font-family:var(--sans);font-size:.64rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--sage-deep);background:rgba(126,145,115,.16);padding:.15rem .5rem;border-radius:3px;margin-right:.5rem;vertical-align:middle}
.work[hidden]{display:none}
@media(max-width:960px){.work-grid{column-count:2}}
@media(max-width:600px){.work-grid{column-count:1}}

/* ============ HERO CAROUSEL ============ */
.carousel{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;background:var(--ink)}
.carousel .slides{position:absolute;inset:0}
.carousel .slide{position:absolute;inset:0;opacity:0;pointer-events:none;transition:opacity .6s ease;display:block}
.carousel .slide.is-active{opacity:1;pointer-events:auto}
.carousel .slide img{width:100%;height:100%;object-fit:cover;display:block}
.car-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:42px;height:42px;border-radius:50%;border:none;background:rgba(246,242,233,.92);color:var(--ink);font-size:1.5rem;line-height:1;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow);transition:background .15s}
.car-btn:hover{background:var(--cream)}
.car-prev{left:12px}.car-next{right:12px}
.dots{position:absolute;left:0;right:0;bottom:.35rem;z-index:3;display:flex;gap:.15rem;justify-content:center}
.dots button{width:32px;height:32px;padding:0;border:0;background:transparent;cursor:pointer;display:grid;place-items:center}
.dots button::before{content:"";display:block;width:9px;height:9px;border-radius:50%;border:1.5px solid var(--cream);background:rgba(34,48,44,.3);transition:background .15s}
.dots button:hover::before{background:rgba(246,242,233,.65)}
.dots button[aria-current="true"]::before{background:var(--cream)}
.dots button:focus-visible{outline:none}
.dots button:focus-visible::before{box-shadow:0 0 0 3px rgba(246,242,233,.9)}
@media (prefers-reduced-motion:reduce){.carousel .slide{transition:none}}

/* handyman hero montage — show the full grid (no cover-crop clipping) */
.hero-media--full img{height:auto;max-height:none}

/* what-to-expect — text-only 2x2 item grid (centered, no photo) */
.expect-list--grid{grid-template-columns:1fr 1fr;gap:1.7rem 2.8rem;max-width:880px;margin:2.4rem auto 0}
.expect-list--grid li{border-bottom:none;padding-bottom:0}
@media(max-width:640px){.expect-list--grid{grid-template-columns:1fr;max-width:460px}}
