/* Distill Works design system, CORE (site-wide).
 * Editorial-spacious Quiet Authority. Loaded on every redesigned page.
 * Tokens + base type + chrome (nav, ink footer) + buttons + form + FAQ. No legacy.
 */
:root{
  --paper:#f7f5ef; --paper2:#efece2; --card:#fffdf8;
  --ink:#191b18; --ink-soft:#4b4d46; --muted:#83857b;
  --green:#2f7d57; --green-d:#245f42; --green-bright:#4f9b76;
  --hair:rgba(25,27,24,.12); --header-h:75px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0; background:var(--paper); color:var(--ink); font-family:'Schibsted Grotesk',system-ui,sans-serif; line-height:1.6; -webkit-font-smoothing:antialiased;}
body h1,body h2,body h3,body h4,.serif{font-family:'Spectral',Georgia,serif; font-weight:500; letter-spacing:-.01em; color:var(--ink); margin:0;}
body a{color:var(--green); text-decoration:none;}
.u{color:var(--green); font-style:italic;}
img{max-width:100%;}

.container,.wrap{max-width:1100px; margin:0 auto; padding:0 40px;}
.eyebrow{font-size:12.5px; text-transform:uppercase; letter-spacing:.18em; color:var(--green); font-weight:600;}
.lab{font-family:'JetBrains Mono',monospace; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted);}

/* buttons */
.b1{display:inline-block; background:var(--green); color:#f3f1e8; padding:14px 26px; border-radius:3px; font-size:15px; font-weight:600; text-decoration:none;}
.b1:hover{background:var(--green-d);}
.b2{display:inline-block; color:var(--ink); font-size:15px; font-weight:600; border-bottom:1.5px solid var(--green); padding-bottom:3px; text-decoration:none;}

/* skip link */
.skip-link{position:absolute; left:-9999px; top:0; background:var(--green); color:#f3f1e8; padding:9px 16px; z-index:100; border-radius:0 0 3px 0;}
.skip-link:focus{left:0;}

/* breadcrumb baseline */
.breadcrumb{font-size:13px; color:var(--muted); padding:18px 0 0;}
.breadcrumb a{color:var(--ink-soft);}
.breadcrumb a:hover{color:var(--green);}
/* R5 visible breadcrumbs are hidden site-wide (BreadcrumbList JSON-LD is kept for SEO); user does not want them visible */
.dw-breadcrumb{display:none;}

/* ---- header / nav ---- */
header{position:sticky; top:0; z-index:30; background:rgba(247,245,239,.88); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); border-bottom:1px solid var(--hair);}
header .nav{display:flex; align-items:center; justify-content:space-between; height:74px; gap:24px; position:relative;}
.brand{display:inline-flex; align-items:center; gap:11px; font-family:'Spectral',serif; font-size:21px; font-weight:600; color:var(--ink); text-decoration:none;}
.brand svg{width:26px; height:26px; display:block; flex:0 0 auto;}
.links{display:flex; gap:25px; align-items:center; font-size:14.5px;}
.links a{color:var(--ink-soft); text-decoration:none; transition:color .15s ease;}
.links a:hover{color:var(--green);}
.links a.active{color:var(--green);}
.call{display:inline-flex; align-items:center; gap:8px; background:var(--green); color:#f3f1e8; padding:10px 18px; border-radius:3px; font-size:14.5px; font-weight:600; white-space:nowrap; text-decoration:none;}
.call:hover{background:var(--green-d);}
.call .ph{font-family:'Spectral',serif; font-size:15px;}

.menu-toggle{display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px;}
.menu-toggle span{width:24px; height:2px; background:var(--ink); display:block; border-radius:2px;}
.mobile-menu{display:none; position:absolute; top:var(--header-h); left:0; right:0; background:var(--paper); border-bottom:1px solid var(--hair); padding:18px 40px 24px; flex-direction:column; gap:15px;}
.mobile-menu.open{display:flex;}
.mobile-menu a{color:var(--ink-soft); text-decoration:none; font-size:16px; transition:color .15s ease;}
.mobile-menu a:hover{color:var(--green);}
.mobile-menu a.call{align-self:flex-start; color:#f3f1e8; margin-top:4px;}

/* ---- ink footer (evergreen link hover) ---- */
footer{background:var(--ink); padding:54px 0; font-size:14px;}
footer .wrap{display:flex; justify-content:space-between; flex-wrap:wrap; gap:30px;}
footer .col h5{font-size:11.5px; text-transform:uppercase; letter-spacing:.14em; margin:0 0 14px; font-weight:700; color:var(--paper); font-family:'Schibsted Grotesk',sans-serif;}
footer .col p{margin:0 0 10px; max-width:30ch; color:#9a9b91;}
footer .col > a,footer .col > span{display:block; margin-bottom:7px; color:#c9c8c0; text-decoration:none;}
footer .col .current-year{display:inline; margin:0;}
footer .col a{transition:color .15s ease;}
footer .col a:hover{color:var(--green-bright);}

/* ---- contact form ---- */
.visually-hidden{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;}
form .fg{margin-bottom:16px;}
form input,form select,form textarea{width:100%; background:var(--card); border:1px solid var(--hair); border-radius:4px; padding:13px 15px; font-family:inherit; font-size:15px; color:var(--ink);}
form input:focus,form select:focus,form textarea:focus{outline:none; border-color:var(--green); box-shadow:0 0 0 3px rgba(47,125,87,.12);}
form textarea{resize:vertical;}
.submit,.submit-btn{background:var(--green); color:#f3f1e8; border:0; border-radius:4px; padding:15px 28px; font-size:15px; font-weight:600; cursor:pointer;}
.submit:hover,.submit-btn:hover{background:var(--green-d);}

/* form success / error overlay (shown by main.min.js on submit) */
.message-overlay{position:fixed; inset:0; background:rgba(25,27,24,.55); z-index:200;}
.message-content{background:var(--card); border:1px solid var(--hair); border-radius:6px; padding:36px 32px; max-width:440px; margin:14vh auto; text-align:center;}
.message-content h3{font-size:24px; margin-bottom:12px;}
.message-content p{color:var(--ink-soft); margin-bottom:20px;}
.close-btn{background:var(--green); color:#f3f1e8; border:0; border-radius:4px; padding:12px 24px; font-size:15px; font-weight:600; cursor:pointer;}
.close-btn:hover{background:var(--green-d);}

/* ---- FAQ accordion (answers collapsed until .open) ---- */
.faq-item{border-top:1px solid var(--hair); padding:0;}
.faq-item:last-child{border-bottom:1px solid var(--hair);}
.faq-item h3,.faq-item .faq-q{font-size:18px; font-family:'Spectral',serif; font-weight:500; display:flex; gap:12px; align-items:baseline; cursor:pointer; padding:22px 0; margin:0; width:100%; text-align:left; background:none; border:0; color:var(--ink);}
.faq-item h3::before,.faq-item .faq-q::before{content:"+"; color:var(--green); font-weight:400; flex:0 0 auto;}
.faq-item.open h3::before,.faq-item.open .faq-q::before{content:"\2013";}
.faq-item .faq-a,.faq-item h3 + p{display:none; font-size:15.5px; color:var(--ink-soft); max-width:80ch; padding:0 24px 24px;}
.faq-item.open .faq-a,.faq-item.open h3 + p{display:block;}

/* ---- shared content sections (FAQ band + contact), used site-wide ---- */
.faq{background:var(--paper2); border-top:1px solid var(--hair); padding:80px 0;}
.faq h2{font-size:clamp(24px,2.9vw,32px); margin-bottom:36px;}
.contact{border-top:1px solid var(--hair); padding:84px 0;}
.cgrid{display:grid; grid-template-columns:.92fr 1.08fr; gap:56px; align-items:start;}
.contact h2{font-size:clamp(26px,3vw,34px); line-height:1.15; margin-bottom:14px; max-width:16ch;}
.contact .intro{font-size:16.5px; color:var(--ink-soft); margin-bottom:26px;}
.reassure strong{font-size:13px; text-transform:uppercase; letter-spacing:.1em; color:var(--ink);}
.reassure ul{list-style:none; margin-top:12px; padding:0;}
.reassure li{font-size:15px; color:var(--ink-soft); padding-left:24px; position:relative; margin-bottom:8px;}
.reassure li::before{content:""; position:absolute; left:0; top:12px; width:13px; height:1.5px; background:var(--green);}

@media (max-width:880px){
  .links{display:none;}
  .menu-toggle{display:flex;}
  .cgrid{grid-template-columns:1fr; gap:30px;}
}
@media (max-width:780px){
  .container,.wrap{padding:0 24px;}
  .mobile-menu{padding:18px 24px 24px;}
}
/* narrow phones: compact the header so brand + phone CTA + hamburger fit (no horizontal overflow) */
@media (max-width:560px){
  header .nav{gap:14px;}
  .brand{font-size:19px; gap:9px;}
  .brand svg{width:24px; height:24px;}
  .call{padding:9px 13px; font-size:13.5px; gap:6px;}
  .call .ph{font-size:13.5px;}
}
@media (max-width:460px){
  /* icon-only tap-to-call; the full number stays in the mobile menu and footer */
  .call .ph{display:none;}
  .call{padding:9px 12px;}
}
