/* =================================================================
   BLFG — Shared sub-page styles
   Used by service / industry / location pages
   ================================================================= */

:root{
  --ink: #0A0A0A;
  --ink-soft: #1A1A1A;
  --paper: #F6F3EC;
  --paper-warm: #EFEAE0;
  --paper-deep: #E7E1D3;
  --line: rgba(10,10,10,.14);
  --line-soft: rgba(10,10,10,.08);
  --muted: rgba(10,10,10,.62);
  --muted-2: rgba(10,10,10,.78);
  --accent: #B08A3E;
  --accent-ink: #0A0A0A;
  --accent-text: #7d5f26;

  --font-display: "Fraunces", "Times New Roman", Georgia, serif;
  --font-body: "Work Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", "SF Mono", ui-monospace, monospace;
  --section-y: clamp(72px, 9vw, 132px);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{ max-width:100%; display:block; }
a{ color:inherit; }

.skip{
  position:absolute; left:-9999px; top:auto;
  padding:8px 16px; background:var(--ink); color:var(--paper);
  z-index:100; border-radius:4px;
}
.skip:focus{ left:16px; top:16px; }

.wrap{ max-width:1280px; margin-inline:auto; padding-inline: clamp(20px, 4vw, 56px); }

/* =================================
   NAV
   ================================= */
.nav{
  position:sticky; top:0; z-index:40;
  background:color-mix(in srgb, var(--paper) 92%, transparent);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line-soft);
}
.nav__inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; padding-block:18px;
}
.nav__brand{ display:flex; align-items:center; gap:12px; text-decoration:none; }
.nav__logo{ height:28px; width:auto; }
.nav__links{ display:flex; gap:28px; list-style:none; padding:0; margin:0; }
.nav__links a{
  font-size:13px; font-weight:500; text-decoration:none; color:var(--ink);
  letter-spacing:.01em;
}
.nav__links a:hover{ color:var(--accent-text); }
.nav__cta{
  background:var(--accent); color:var(--accent-ink);
  padding:10px 20px; font-size:13px; font-weight:600;
  border-radius:999px; text-decoration:none;
  letter-spacing:.01em; white-space:nowrap;
  transition:background .18s ease;
}
.nav__cta:hover{ background:#9c7935; }
/* Dropdown menus (desktop) */
.nav__links li{ list-style:none; }
.nav__item.has-menu{ position:relative; }
.nav__btn{
  font-family:var(--font-body); font-size:13px; font-weight:500;
  color:var(--ink); background:none; border:0; cursor:pointer; padding:0;
  display:inline-flex; align-items:center; gap:6px;
  letter-spacing:.01em;
}
.nav__btn:hover{ color:var(--accent-text); }
.nav__menu{
  position:absolute; top:calc(100% + 14px); left:-16px;
  min-width:280px; padding:8px;
  background:var(--paper); border:1px solid var(--line-soft);
  box-shadow:0 24px 60px -20px rgba(0,0,0,.2);
  opacity:0; visibility:hidden; transform:translateY(-6px);
  transition:opacity .2s ease, visibility .2s ease, transform .2s ease;
  z-index:50;
}
.nav__item.has-menu:hover .nav__menu,
.nav__item.has-menu:focus-within .nav__menu,
.nav__item.has-menu.is-open .nav__menu{
  opacity:1; visibility:visible; transform:translateY(0);
}
.nav__menu a{
  display:flex; flex-direction:column; gap:2px;
  padding:10px 12px; border-radius:2px; text-decoration:none;
}
.nav__menu a span{ font-size:14px; font-weight:500; color:var(--ink); }
.nav__menu a em{ font-size:11px; font-style:normal; color:var(--muted); letter-spacing:.02em; }
.nav__menu a:hover{ background:rgba(0,0,0,.04); }
.nav__menu a[aria-current="page"] span{ color:var(--accent-text); }

@media (max-width: 880px){
  .nav__links{ display:none; }
  .nav__cta{ padding:8px 14px; font-size:12px; }
}

/* Mobile safety net: prevent horizontal scroll from rogue overflowing elements */
html, body{ overflow-x:hidden; }
.wrap{ max-width:100%; box-sizing:border-box; }

/* =================================
   PAGE HERO
   ================================= */
.phero{
  padding-block: clamp(56px, 7vw, 96px) clamp(48px, 6vw, 72px);
  border-bottom:1px solid var(--line-soft);
  background:
    radial-gradient(1200px 600px at 90% -20%, rgba(176,138,62,.10), transparent 60%),
    var(--paper);
}
.phero__crumbs{
  font-family:var(--font-mono); font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--muted);
  margin-bottom:24px;
}
.phero__crumbs a{ color:var(--muted); text-decoration:none; }
.phero__crumbs a:hover{ color:var(--ink); }
.phero__crumbs span{ margin:0 8px; opacity:.5; }
.phero__eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-mono); font-size:12px; font-weight:500;
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--accent-text);
  margin-bottom:18px;
}
.phero__eyebrow::before{
  content:""; width:24px; height:1px; background:var(--accent);
}
.phero h1{
  font-family:var(--font-display); font-weight:400;
  font-size:clamp(40px, 6vw, 84px); line-height:1.02;
  letter-spacing:-.02em; margin:0 0 24px;
  max-width:18ch;
  text-wrap:balance;
}
.phero h1 em{ font-style:italic; color:var(--accent-text); }
.phero__lede{
  font-size:clamp(17px, 1.6vw, 21px);
  line-height:1.5; color:var(--muted-2);
  max-width:64ch; margin:0 0 32px;
}
.phero__cta{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }

/* =================================
   BUTTONS
   ================================= */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-body); font-weight:600; font-size:14px;
  padding:14px 26px; border-radius:999px; border:1px solid transparent;
  text-decoration:none; cursor:pointer; transition:all .18s ease;
  letter-spacing:.005em;
}
.btn--primary{
  background:var(--accent); color:var(--accent-ink);
  box-shadow: 0 1px 0 rgba(0,0,0,.05), 0 8px 24px -8px rgba(176,138,62,.5);
}
.btn--primary:hover{ background:#9c7935; transform:translateY(-1px); }
.btn--ghost{
  background:transparent; color:var(--ink); border-color:var(--line);
}
.btn--ghost:hover{ background:var(--paper-warm); border-color:var(--ink); }
.btn .arrow{ transition:transform .18s ease; }
.btn:hover .arrow{ transform:translateX(2px); }

/* =================================
   SECTION SHELL
   ================================= */
.sect{ padding-block:var(--section-y); border-bottom:1px solid var(--line-soft); }
.sect--warm{ background:var(--paper-warm); }
.sect--deep{ background:var(--paper-deep); }
.sect--ink{ background:var(--ink); color:#EDE7D9; border-bottom-color:rgba(255,255,255,.08); }
.sect--ink .muted-out{ color:rgba(237,231,217,.7); }

.section-head{
  display:flex; align-items:baseline; gap:16px;
  margin-bottom:48px;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--muted);
}
.sect--ink .section-head{ color:rgba(237,231,217,.6); }
.section-num{ color:var(--accent-text); }
.sect--ink .section-num{ color:var(--accent); }
.section-kicker::before{ content:"·  "; opacity:.5; }

.sect h2{
  font-family:var(--font-display); font-weight:400;
  font-size:clamp(32px, 4.2vw, 56px); line-height:1.05;
  letter-spacing:-.018em; margin:0 0 32px;
  max-width:20ch; text-wrap:balance;
}
.sect h2 em{ font-style:italic; color:var(--accent-text); }
.sect--ink h2 em{ color:var(--accent); }
.sect h3{
  font-family:var(--font-display); font-weight:400;
  font-size:clamp(22px, 2.4vw, 30px); line-height:1.15;
  letter-spacing:-.012em; margin:0 0 12px;
}
.sect p{ font-size:16px; line-height:1.65; color:var(--muted-2); max-width:64ch; }
.sect--ink p{ color:rgba(237,231,217,.8); }

/* =================================
   GRIDS
   ================================= */
.grid-2, .grid-3, .grid-4{
  display:grid; gap:32px;
}
.grid-2{ grid-template-columns:repeat(2, 1fr); }
.grid-3{ grid-template-columns:repeat(3, 1fr); }
.grid-4{ grid-template-columns:repeat(4, 1fr); }
@media (max-width: 880px){
  .grid-2, .grid-3, .grid-4{ grid-template-columns:1fr; gap:24px; }
}

/* card */
.card{
  background:var(--paper); border:1px solid var(--line-soft);
  border-radius:8px; padding:32px;
  display:flex; flex-direction:column; gap:12px;
}
.sect--warm .card, .sect--deep .card{ background:var(--paper); }
.sect--ink .card{ background:rgba(255,255,255,.03); border-color:rgba(255,255,255,.08); color:#EDE7D9; }
.card__num{
  font-family:var(--font-mono); font-size:11px; letter-spacing:.14em;
  color:var(--accent-text); text-transform:uppercase;
}
.sect--ink .card__num{ color:var(--accent); }
.card h3{ margin:0; }
.card p{ margin:0; max-width:none; font-size:15px; }

/* checklist */
.checklist{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:14px;
}
.checklist li{
  display:flex; gap:14px; align-items:flex-start;
  font-size:15px; line-height:1.55; color:var(--muted-2);
}
.sect--ink .checklist li{ color:rgba(237,231,217,.8); }
.checklist li::before{
  content:""; flex-shrink:0; width:18px; height:18px; margin-top:3px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23B08A3E' stroke-width='2.5'%3E%3Cpath d='M4 12l5 5L20 6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:center; background-size:contain;
}

/* numbered split row (problem/solution pattern) */
.split{
  display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start;
}
@media (max-width: 880px){ .split{ grid-template-columns:1fr; gap:32px; } }

/* callout */
.callout{
  background:var(--paper-deep); border:1px solid var(--line-soft);
  border-left:3px solid var(--accent);
  padding:28px 32px; border-radius:6px;
  display:flex; flex-direction:column; gap:8px;
  margin-top:32px;
}
.callout__label{
  font-family:var(--font-mono); font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--accent-text);
}
.callout p{ margin:0; font-size:16px; line-height:1.55; color:var(--ink); max-width:none; }

/* =================================
   FAQ
   ================================= */
.faq{ border-top:1px solid var(--line); }
.faq details{
  border-bottom:1px solid var(--line);
  padding:24px 0;
}
.faq summary{
  cursor:pointer; list-style:none;
  font-family:var(--font-display); font-weight:400;
  font-size:clamp(18px, 1.8vw, 22px); line-height:1.3;
  letter-spacing:-.005em; color:var(--ink);
  display:flex; justify-content:space-between; gap:24px; align-items:flex-start;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{
  content:"+"; flex-shrink:0;
  font-family:var(--font-display); font-size:28px; font-weight:300;
  color:var(--accent-text); line-height:1;
  transition:transform .2s ease;
}
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq__a{
  margin-top:16px; font-size:16px; line-height:1.65;
  color:var(--muted-2); max-width:72ch;
}

/* =================================
   END CTA
   ================================= */
.endcta{
  padding-block: clamp(72px, 9vw, 120px);
  background:var(--ink); color:#EDE7D9;
  text-align:center;
}
.endcta h2{
  font-family:var(--font-display); font-weight:400;
  font-size:clamp(36px, 5vw, 64px); line-height:1.05;
  letter-spacing:-.018em;
  margin:0 auto 20px; max-width:22ch;
  color:#EDE7D9;
}
.endcta h2 em{ font-style:italic; color:var(--accent); }
.endcta p{
  font-size:17px; line-height:1.55; color:rgba(237,231,217,.7);
  max-width:48ch; margin:0 auto 32px;
}
.endcta__cta{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.endcta .btn--ghost{ color:#EDE7D9; border-color:rgba(255,255,255,.18); }
.endcta .btn--ghost:hover{ background:rgba(255,255,255,.05); border-color:#EDE7D9; }

/* =================================
   FOOTER
   ================================= */
.foot{
  background:var(--ink); color:rgba(237,231,217,.7);
  padding-block: clamp(56px, 6vw, 80px) 32px;
  font-size:13px;
}
.foot__grid{
  display:grid; grid-template-columns:2fr repeat(3, 1fr); gap:48px;
  margin-bottom:48px;
}
@media (max-width:880px){
  .foot__grid{ grid-template-columns:1fr 1fr; }
  .foot__brand{ grid-column:1 / -1; }
}
.foot__logo{ height:32px; width:auto; margin-bottom:20px; }
.foot__brand p{ max-width:36ch; line-height:1.6; color:rgba(237,231,217,.6); margin:0; }
.foot__col h4{
  font-family:var(--font-mono); font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:rgba(237,231,217,.5);
  margin:0 0 16px; font-weight:500;
}
.foot__col ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.foot__col a{
  color:rgba(237,231,217,.78); text-decoration:none;
  transition:color .15s ease;
}
.foot__col a:hover{ color:var(--accent); }
.foot__bot{
  border-top:1px solid rgba(237,231,217,.12);
  padding-top:24px; display:flex; justify-content:space-between; gap:16px;
  flex-wrap:wrap; font-size:12px; color:rgba(237,231,217,.5);
}
.foot__bot a{ color:rgba(237,231,217,.78); text-decoration:none; }
.foot__bot a:hover{ color:var(--accent); }

/* =================================
   COOKIE BANNER
   ================================= */
.ck{
  position:fixed; left:16px; right:16px; bottom:16px;
  max-width:520px; margin-left:auto;
  background:var(--ink); color:#EDE7D9;
  padding:16px 20px; border-radius:10px;
  display:flex; gap:14px; align-items:center;
  font-size:13px; line-height:1.45;
  box-shadow:0 18px 50px -12px rgba(0,0,0,.4);
  z-index:50;
  transform:translateY(120%); transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.ck.is-open{ transform:translateY(0); }
.ck a{ color:var(--accent); text-decoration:underline; text-underline-offset:2px; }
.ck button{
  flex-shrink:0; background:var(--accent); color:var(--ink);
  border:0; border-radius:999px; padding:8px 16px;
  font-family:var(--font-body); font-size:12px; font-weight:600;
  cursor:pointer; transition:background .15s ease;
}
.ck button:hover{ background:#9c7935; }

/* =================================
   UTIL
   ================================= */
.muted-out{ color:var(--muted); }
.mono{ font-family:var(--font-mono); font-size:12px; letter-spacing:.06em; text-transform:uppercase; }
.lede{
  font-size:clamp(17px, 1.6vw, 20px); line-height:1.55;
  color:var(--muted-2); max-width:64ch;
}
.sect--ink .lede{ color:rgba(237,231,217,.8); }

/* =================================
   MOBILE NAV (hamburger + slide-in panel)
   ================================= */
.nav__hamburger{
  display:none;
  background:none; border:0; padding:10px 6px; margin-left:4px;
  cursor:pointer;
  flex-direction:column; align-items:center; justify-content:center;
  gap:5px;
}
.nav__hamburger span{
  display:block; width:24px; height:2px; background:var(--ink);
  border-radius:2px;
  transition:transform .25s ease, opacity .2s ease;
}
.nav__hamburger.is-open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__hamburger.is-open span:nth-child(2){ opacity:0; }
.nav__hamburger.is-open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.mobile-menu{
  position:fixed; inset:0; z-index:60;
  background:var(--paper);
  transform:translateX(100%);
  transition:transform .3s cubic-bezier(.2,.7,.2,1);
  overflow-y:auto;
  visibility:hidden;
}
.mobile-menu.is-open{ transform:translateX(0); visibility:visible; }
.mobile-menu__inner{
  padding:20px 24px 48px;
  max-width:560px; margin:0 auto;
  min-height:100%;
  display:flex; flex-direction:column;
}
.mobile-menu__head{
  display:flex; justify-content:space-between; align-items:center;
  padding:6px 0 20px; border-bottom:1px solid var(--line-soft);
}
.mobile-menu__brand{
  font-family:var(--font-display); font-size:16px; letter-spacing:.01em;
  color:var(--ink);
}
.mobile-menu__close{
  background:none; border:0; cursor:pointer;
  font-size:28px; line-height:1; padding:6px 10px;
  color:var(--ink);
}
.mobile-menu__nav{
  flex:1;
  display:flex; flex-direction:column;
}
.mobile-menu__group{
  padding:22px 0;
  border-bottom:1px solid var(--line-soft);
}
.mobile-menu__group:last-of-type{ border-bottom:0; }
.mobile-menu__label{
  font-family:var(--font-mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--muted);
  margin:0 0 12px; font-weight:500;
}
.mobile-menu__group a{
  display:block;
  padding:12px 0;
  font-family:var(--font-body); font-size:18px; font-weight:500;
  color:var(--ink); text-decoration:none;
  border-bottom:1px solid rgba(0,0,0,.04);
}
.mobile-menu__group a:last-child{ border-bottom:0; }
.mobile-menu__cta{
  padding-top:24px;
  display:flex; flex-direction:column; gap:14px;
}
.mobile-menu__cta .btn{
  justify-content:center; width:100%; padding:16px 26px;
}
.mobile-menu__phone{
  display:block; text-align:center;
  padding:12px;
  font-family:var(--font-mono); font-size:14px; letter-spacing:.04em;
  color:var(--ink); text-decoration:none;
}
body.menu-open{ overflow:hidden; }

@media (max-width: 880px){
  .nav__hamburger{ display:flex; }
}
@media (min-width: 881px){
  .mobile-menu{ display:none; }
}
