/* =========================================================================
   Absolute Metal Roofing – redesign mockup stylesheet
   Implements 03-design/design-system.md exactly: steel-derived palette,
   Saira Condensed + Archivo, the standing-seam ridge motif, square corners.
   No frameworks, no build step. border-radius:0 everywhere.
   ========================================================================= */

/* ---- Fonts (Google Fonts, self-hostable in production; CDN here for the
   static mockup so it opens directly in a browser) ---- */
@import url("https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700&family=Saira+Condensed:wght@500;600;700&display=swap");

/* =========================================================================
   1. Root tokens (from design-system section 6.1)
   ========================================================================= */
:root{
  /* colour: surfaces */
  --bg:#F6F5F0; --surface:#FCFBF8; --surface-2:#E4E2D5; --ink-bg:#1C1C1D;
  /* colour: text */
  --ink:#323233; --muted:#6D6C6E; --ink-inv:#F6F5F0; --muted-inv:#C9CBCC;
  /* colour: lines */
  --line:#8A8D8F; --line-soft:#D7D6CE; --line-inv:#4A4A4C; --galv:#C9CBCC;
  /* colour: accent */
  --accent:#D6531B; --accent-hover:#B8420F; --accent-ink:#FFFFFF;
  --accent-tint:#FBEDE6;
  /* colour: feedback */
  --ok:#2F6E3B; --warn:#9A6B00; --error:#B3261E; --focus:#1B6CC4;

  /* type families */
  --font-display:"Saira Condensed","Arial Narrow",system-ui,sans-serif;
  --font-body:"Archivo",system-ui,-apple-system,"Segoe UI",sans-serif;

  /* type scale (fluid, clamped to mobile floor) */
  --fs-display:clamp(2.50rem,1.6rem + 3.4vw,4.20rem);
  --fs-h1:clamp(2.10rem,1.5rem + 2.2vw,3.05rem);
  --fs-h2:clamp(1.70rem,1.3rem + 1.4vw,2.30rem);
  --fs-h3:clamp(1.35rem,1.15rem + 0.7vw,1.65rem);
  --fs-h4:clamp(1.15rem,1.05rem + 0.35vw,1.30rem);
  --fs-h5:clamp(1.05rem,1.0rem + 0.2vw,1.10rem);
  --fs-h6:clamp(0.90rem,0.88rem + 0.1vw,0.95rem);
  --fs-lead:clamp(1.15rem,1.05rem + 0.5vw,1.30rem);
  --fs-body:clamp(1.0rem,0.98rem + 0.2vw,1.0625rem);
  --fs-small:0.875rem;
  --fs-xs:0.78rem;
  --fs-overline:0.80rem;

  /* line-height */
  --lh-tight:1.0; --lh-head:1.08; --lh-snug:1.25; --lh-body:1.62; --lh-lead:1.55;
  /* tracking */
  --ls-display:-0.01em; --ls-head:0; --ls-caps:0.04em; --ls-overline:0.16em;
  /* weight */
  --w-reg:400; --w-med:500; --w-semi:600; --w-bold:700;

  /* spacing (4px base) */
  --space-0:0; --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px;
  --space-5:24px; --space-6:32px; --space-7:48px; --space-8:64px;
  --space-9:96px; --space-10:128px;

  /* layout */
  --container:1200px; --container-wide:1320px;
  --gutter:24px; --gutter-sm:16px; --measure:68ch;
  --header-h:72px; --header-h-sm:60px;

  /* borders / radius / motion */
  --radius:0;
  --border:1px solid var(--line);
  --border-2:2px solid var(--ink);
  --border-accent:3px solid var(--accent);
  --shadow-card:0 1px 0 0 var(--line);
  --ring:0 0 0 3px var(--focus);
  --transition:140ms cubic-bezier(0,0,0.2,1);

  /* breakpoints (reference) */
  --bp-xs:360px; --bp-sm:480px; --bp-md:768px;
  --bp-lg:1080px; --bp-xl:1280px; --bp-xxl:1440px;
}

/* =========================================================================
   2. Reset / base (design-system 6.2) – HARD CONSTRAINT border-radius:0
   ========================================================================= */
*,*::before,*::after{ box-sizing:border-box; border-radius:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font-body); font-size:var(--fs-body);
  line-height:var(--lh-body); font-weight:var(--w-reg);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}

h1,h2,h3,h4,h5,h6{
  font-family:var(--font-display); font-weight:var(--w-semi);
  line-height:var(--lh-head); letter-spacing:var(--ls-head);
  color:var(--ink); margin:0 0 var(--space-4); hyphens:none;
}
h1{ font-size:var(--fs-h1); font-weight:var(--w-bold); letter-spacing:-0.005em; }
h2{ font-size:var(--fs-h2); }
h3{ font-size:var(--fs-h3); }
h4{ font-size:var(--fs-h4); }
h5{ font-size:var(--fs-h5); }
h6{ font-size:var(--fs-h6); font-weight:var(--w-bold); text-transform:uppercase; letter-spacing:var(--ls-caps); }

p{ margin:0 0 var(--space-4); max-width:var(--measure); }
.lead{ font-size:var(--fs-lead); line-height:var(--lh-lead); color:var(--ink); max-width:60ch; }
small,.small{ font-size:var(--fs-small); }
.xs{ font-size:var(--fs-xs); color:var(--muted); }
.tnum{ font-variant-numeric:tabular-nums; }
strong,b{ font-weight:var(--w-bold); }

a{ color:var(--accent-hover); text-underline-offset:3px; text-decoration-thickness:1px; transition:color var(--transition); }
a:hover{ color:var(--ink); }
img{ max-width:100%; height:auto; display:block; }
ul,ol{ margin:0 0 var(--space-4); padding-left:var(--space-5); }
li{ margin-bottom:var(--space-2); }

.overline{
  font-family:var(--font-body); font-size:var(--fs-overline); font-weight:var(--w-bold);
  text-transform:uppercase; letter-spacing:var(--ls-overline); color:var(--accent-hover);
  display:block; margin:0 0 var(--space-3);
}

.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.container--wide{ max-width:var(--container-wide); }
@media (max-width:480px){ .container{ padding-inline:var(--gutter-sm); } }

/* generic vertical section rhythm */
.section{ padding-block:var(--space-9); }
@media (max-width:768px){ .section{ padding-block:var(--space-7); } }

.section__head{ max-width:62ch; margin-bottom:var(--space-7); }
.section__head .lead{ margin-bottom:0; }

/* =========================================================================
   3. Accessibility primitives (design-system 6.3)
   ========================================================================= */
.skip-link{
  position:absolute; left:var(--space-4); top:-100px;
  background:var(--ink); color:var(--ink-inv);
  padding:var(--space-3) var(--space-4); z-index:1000;
  font-weight:var(--w-bold); text-decoration:none; transition:top var(--transition);
}
.skip-link:focus{ top:var(--space-4); }

:focus-visible{ outline:3px solid var(--focus); outline-offset:2px; }
:focus:not(:focus-visible){ outline:none; }

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.001ms !important; animation-iteration-count:1 !important;
    transition-duration:0.001ms !important; scroll-behavior:auto !important;
  }
}

.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;
}

/* =========================================================================
   4. Motif – the standing-seam ridge rule (design-system section 4)
   ========================================================================= */
.ridge{
  border:0; height:10px; margin:0; display:block;
  background:
    repeating-linear-gradient(to right,
      var(--accent) 0,var(--accent) 2px,
      transparent 2px,transparent 16px) top left / 100% 8px no-repeat,
    var(--line) bottom left / 100% 2px no-repeat;
}
.ridge--short{ width:64px; height:10px; }
.ridge--inv{
  background:
    repeating-linear-gradient(to right,
      var(--accent) 0,var(--accent) 2px,
      transparent 2px,transparent 16px) top left / 100% 8px no-repeat,
    var(--galv) bottom left / 100% 2px no-repeat;
}

/* =========================================================================
   5. Header: utility strip + sticky nav (design-system 7.1)
   ========================================================================= */
.util{ background:var(--ink-bg); color:var(--ink-inv); font-size:var(--fs-small); }
.util .container{ display:flex; justify-content:space-between; align-items:center; min-height:40px; gap:var(--space-4); }
.util__left{ display:flex; gap:var(--space-5); flex-wrap:wrap; align-items:center; }
.util a{ color:var(--ink-inv); font-weight:var(--w-med); text-decoration:none; display:inline-flex; align-items:center; gap:var(--space-2); }
.util a:hover{ color:var(--accent); }
.util .tnum{ font-weight:var(--w-bold); }

.header{
  position:sticky; top:0; z-index:100;
  background:var(--surface); border-bottom:var(--border-2);
  transition:box-shadow var(--transition);
}
.header.is-condensed{ box-shadow:var(--shadow-card); }
.header .container{ display:flex; align-items:center; justify-content:space-between; min-height:var(--header-h); gap:var(--space-5); }
.header__logo{ display:inline-flex; align-items:center; }
.header__logo img{ height:40px; width:auto; transition:height var(--transition); }
.header.is-condensed .header__logo img{ height:34px; }

.nav{ display:flex; align-items:center; gap:var(--space-6); }
.nav__list{ display:flex; align-items:center; gap:var(--space-6); list-style:none; margin:0; padding:0; }
.nav__list li{ margin:0; }
.nav a{
  font-family:var(--font-body); font-weight:var(--w-semi);
  font-size:0.95rem; color:var(--ink); text-decoration:none;
  padding:var(--space-3) 0; position:relative;
  display:inline-flex; align-items:center; min-height:44px;
}
.nav a:hover{ color:var(--accent-hover); }
.nav a[aria-current="page"]{ color:var(--ink); font-weight:var(--w-bold); }
.nav a[aria-current="page"]::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:6px;
  background:
    repeating-linear-gradient(to right,
      var(--accent) 0,var(--accent) 2px,transparent 2px,transparent 12px) top left / 100% 4px no-repeat,
    var(--ink) bottom left / 100% 2px no-repeat;
}
.nav .btn{ margin-left:var(--space-2); }

.nav-toggle{
  display:none; width:44px; height:44px; padding:0;
  background:var(--ink); color:var(--ink-inv); border:0; cursor:pointer;
  align-items:center; justify-content:center;
}
.nav-toggle svg{ width:22px; height:22px; }

@media (max-width:768px){
  .util{ display:none; }
  .header .container{ min-height:var(--header-h-sm); }
  .nav-toggle{ display:inline-flex; }
  .nav{
    position:fixed; inset:var(--header-h-sm) 0 0 0; flex-direction:column;
    align-items:stretch; gap:0; background:var(--surface);
    border-top:var(--border-2); padding:var(--space-4) var(--gutter-sm);
    transform:translateY(-100%); visibility:hidden;
    transition:transform var(--transition),visibility var(--transition);
    overflow-y:auto; z-index:99;
  }
  .nav[data-open="true"]{ transform:translateY(0); visibility:visible; }
  .nav__list{ flex-direction:column; align-items:stretch; gap:0; }
  .nav a{ min-height:52px; border-bottom:1px solid var(--line-soft); padding:var(--space-4) 0; }
  .nav a[aria-current="page"]::after{ display:none; }
  .nav a[aria-current="page"]{ border-left:var(--border-accent); padding-left:var(--space-3); }
  .nav .btn{ margin:var(--space-4) 0 var(--space-2); width:100%; }
  .nav__call{ margin-top:var(--space-2); }
}

/* =========================================================================
   6. Buttons (design-system 7.2)
   ========================================================================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:var(--space-2);
  min-height:48px; padding:0 var(--space-6);
  font-family:var(--font-body); font-size:1rem; font-weight:var(--w-bold);
  letter-spacing:0.01em; text-decoration:none; cursor:pointer; text-align:center;
  border:2px solid transparent;
  transition:background var(--transition),color var(--transition),border-color var(--transition),transform var(--transition);
}
.btn:active{ transform:translateY(1px); }
.btn--primary{ background:var(--accent); color:var(--accent-ink); border-color:var(--accent); }
.btn--primary:hover{ background:var(--accent-hover); border-color:var(--accent-hover); color:#fff; }
.btn--secondary{ background:transparent; color:var(--ink); border-color:var(--ink); }
.btn--secondary:hover{ background:var(--ink); color:var(--ink-inv); }
.btn--ghost-inv{ background:transparent; color:var(--ink-inv); border-color:var(--galv); }
.btn--ghost-inv:hover{ background:var(--ink-inv); color:var(--ink); border-color:var(--ink-inv); }
.btn--call{ background:var(--ink); color:var(--ink-inv); border-color:var(--ink); }
.btn--call:hover{ background:var(--accent); border-color:var(--accent); color:#fff; }
.btn:focus-visible{ outline:3px solid var(--focus); outline-offset:3px; }
.btn svg{ width:18px; height:18px; flex:0 0 auto; }
@media (max-width:480px){ .btn--block-sm{ width:100%; } }

/* =========================================================================
   7. Hero (design-system 7.3)
   ========================================================================= */
.hero{ position:relative; background:var(--ink-bg); color:var(--ink-inv); overflow:hidden; }
.hero__media{ position:absolute; inset:0; }
.hero__media img{ width:100%; height:100%; object-fit:cover; }
.hero__media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg,rgba(28,28,29,0.86) 0%,rgba(28,28,29,0.86) 40%,rgba(28,28,29,0.45) 100%);
}
.hero__inner{ position:relative; z-index:1; padding:var(--space-10) 0 0; }
.hero__copy{ max-width:42ch; padding-bottom:var(--space-9); }
.hero h1{ font-size:var(--fs-display); color:var(--ink-inv); margin-bottom:var(--space-4); letter-spacing:var(--ls-display); }
.hero .overline{ color:var(--galv); }
.hero .lead{ color:var(--muted-inv); max-width:48ch; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:var(--space-3); margin-top:var(--space-6); }
.hero .ridge--inv{ position:absolute; left:0; right:0; bottom:0; z-index:1; }

/* compact hero used on sub-pages */
.hero--sub .hero__inner{ padding-top:var(--space-9); }
.hero--sub .hero__copy{ padding-bottom:var(--space-8); max-width:52ch; }
.hero--sub h1{ font-size:var(--fs-h1); }

@media (max-width:768px){
  .hero__media::after{ background:rgba(28,28,29,0.78); }
  .hero__inner{ padding-top:var(--space-8); }
  .hero__copy{ padding-bottom:var(--space-7); }
}

/* =========================================================================
   8. Sector / service cards (design-system 7.4)
   ========================================================================= */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-5); }
@media (max-width:768px){ .cards{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px){ .cards{ grid-template-columns:1fr; } }

.card{
  display:flex; flex-direction:column; background:var(--surface);
  border:var(--border); border-top:var(--border-accent);
  transition:transform var(--transition),border-color var(--transition);
}
.card__media{ aspect-ratio:4/3; overflow:hidden; }
.card__media img{ width:100%; height:100%; object-fit:cover; }
.card__body{ padding:var(--space-5); display:flex; flex-direction:column; flex:1; }
.card .overline{ margin-bottom:var(--space-2); }
.card h3{ margin-bottom:var(--space-3); }
.card p{ color:var(--muted); margin-bottom:var(--space-5); }
.card__link{
  margin-top:auto; font-weight:var(--w-bold); color:var(--accent-hover);
  text-decoration:none; display:inline-flex; align-items:center; gap:var(--space-2); min-height:44px;
}
.card__link::after{ content:"\2192"; transition:transform var(--transition); }
.card:hover{ border-color:var(--ink); transform:translateY(-2px); }
.card:hover .card__link::after{ transform:translateX(4px); }
.card:focus-within{ border-color:var(--ink); }

/* =========================================================================
   9. Category / material cards (design-system 7.5)
   ========================================================================= */
.cats{ display:grid; grid-template-columns:repeat(4,1fr); gap:var(--space-4); }
@media (max-width:1080px){ .cats{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:768px){ .cats{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:360px){ .cats{ grid-template-columns:1fr; } }

.cat{ border:var(--border); background:var(--surface); display:flex; flex-direction:column; transition:border-color var(--transition); }
.cat__swatch{ height:96px; border-bottom:var(--border); overflow:hidden; }
.cat__swatch img{ width:100%; height:100%; object-fit:cover; }
.cat__swatch--solid{ display:block; }
.cat__label{ padding:var(--space-3) var(--space-4); font-family:var(--font-display); font-weight:var(--w-semi); font-size:var(--fs-h5); }
.cat__note{ padding:0 var(--space-4) var(--space-4); color:var(--muted); font-size:var(--fs-small); margin:0; }
.cat:hover{ border-color:var(--ink); }

/* =========================================================================
   10. Project showcase + named case studies (design-system 7.6)
   ========================================================================= */
.projects{ display:grid; grid-template-columns:repeat(4,1fr); gap:var(--space-4); }
@media (max-width:1080px){ .projects{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:768px){ .projects{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:360px){ .projects{ grid-template-columns:1fr; } }

.project{ position:relative; border:var(--border); background:var(--ink-bg); overflow:hidden; }
.project img{ width:100%; aspect-ratio:1/1; object-fit:cover; transition:opacity var(--transition),transform var(--transition); }
.project__cap{
  position:absolute; left:0; right:0; bottom:0; padding:var(--space-3) var(--space-4);
  background:rgba(28,28,29,0.82); color:var(--ink-inv);
  font-size:var(--fs-small); font-weight:var(--w-med);
}
.project__cap b{ font-family:var(--font-display); font-weight:var(--w-semi); display:block; letter-spacing:0.01em; }
.project:hover img{ opacity:0.9; transform:scale(1.02); }
.project:focus-within{ outline:3px solid var(--focus); outline-offset:2px; }

.cases{ display:grid; gap:var(--space-5); }
.case{
  display:grid; grid-template-columns:1.2fr 1fr; gap:0;
  border:var(--border); border-left:var(--border-accent); background:var(--surface);
}
@media (max-width:768px){ .case{ grid-template-columns:1fr; } }
.case__media{ overflow:hidden; }
.case__media img{ width:100%; height:100%; object-fit:cover; aspect-ratio:16/10; }
.case__body{ padding:var(--space-6); }
.case .overline{ margin-bottom:var(--space-2); }
.case h3{ margin-bottom:var(--space-3); }
.case p{ color:var(--muted); }
.case dl{ display:grid; grid-template-columns:auto 1fr; gap:var(--space-2) var(--space-4); margin:var(--space-4) 0 0; }
.case dt{ font-weight:var(--w-bold); color:var(--ink); font-size:var(--fs-small); }
.case dd{ margin:0; color:var(--muted); font-size:var(--fs-small); }

/* =========================================================================
   11. Trust band / logo wall (design-system 7.7)
   ========================================================================= */
.trust{ background:var(--ink-bg); color:var(--ink-inv); }
.trust .container{ display:grid; grid-template-columns:auto 1fr; gap:var(--space-8); align-items:center; padding-block:var(--space-7); }
@media (max-width:768px){ .trust .container{ grid-template-columns:1fr; gap:var(--space-6); } }
.trust__stat{ font-family:var(--font-display); font-weight:var(--w-bold); line-height:1; }
.trust__stat .num{ font-size:3.4rem; color:var(--accent); display:block; }
.trust__stat .lab{ font-size:var(--fs-small); color:var(--muted-inv); text-transform:uppercase; letter-spacing:var(--ls-caps); font-family:var(--font-body); }
.trust__points{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(2,1fr); gap:var(--space-3) var(--space-6); }
@media (max-width:480px){ .trust__points{ grid-template-columns:1fr; } }
.trust__points li{ display:flex; gap:var(--space-3); align-items:flex-start; color:var(--muted-inv); margin:0; }
.trust__points li::before{ content:""; flex:0 0 auto; width:10px; height:10px; margin-top:6px; background:var(--accent); }
.logos{ display:flex; flex-wrap:wrap; align-items:center; gap:var(--space-7); margin-top:var(--space-5); }
.logos img{ height:38px; width:auto; opacity:0.95; }

/* =========================================================================
   12. Bands / dividers (design-system 7.8)
   ========================================================================= */
.band{ padding-block:var(--space-9); }
@media (max-width:768px){ .band{ padding-block:var(--space-7); } }
.band--tint{ background:var(--surface-2); }
.band--paper{ background:var(--surface); }
.band--dark{ background:var(--ink-bg); color:var(--ink-inv); }
.band--dark h2,.band--dark h3,.band--dark h4{ color:var(--ink-inv); }
.band--dark p{ color:var(--muted-inv); }
.band--dark .overline{ color:var(--galv); }

hr.rule{ border:0; height:2px; background:var(--ink); margin:var(--space-8) 0; }
hr.ridge{ margin:0; }

/* =========================================================================
   13. Testimonials (design-system 7.9)
   ========================================================================= */
.quotes{ display:grid; grid-template-columns:repeat(2,1fr); gap:var(--space-5); }
@media (max-width:768px){ .quotes{ grid-template-columns:1fr; } }
.quote{ background:var(--surface); border:var(--border); border-left:var(--border-accent); padding:var(--space-6); display:flex; flex-direction:column; }
.quote__mark{ font-family:var(--font-display); font-weight:var(--w-bold); font-size:2.4rem; color:var(--accent); line-height:0.6; margin-bottom:var(--space-3); }
.quote blockquote{ margin:0 0 var(--space-5); font-size:1.1rem; line-height:1.55; color:var(--ink); }
.quote figcaption{ margin-top:auto; border-top:1px solid var(--line-soft); padding-top:var(--space-4); }
.quote .who{ font-family:var(--font-display); font-weight:var(--w-semi); font-size:var(--fs-h5); color:var(--ink); display:block; }
.quote .role{ color:var(--muted); font-size:var(--fs-small); }
.quote .logo{ height:28px; width:auto; margin-top:var(--space-3); }

/* single featured quote (home) */
.quote--feature{ border-left:var(--border-accent); }
.quote--feature blockquote{ font-size:var(--fs-h4); line-height:1.4; }

/* =========================================================================
   14. Forms (design-system 7.10)
   ========================================================================= */
.form{ display:grid; gap:var(--space-5); }
.form__row{ display:grid; gap:var(--space-2); }
.form__grid{ display:grid; grid-template-columns:1fr 1fr; gap:var(--space-5); }
@media (max-width:560px){ .form__grid{ grid-template-columns:1fr; } }
.form label{ font-weight:var(--w-bold); font-size:var(--fs-small); color:var(--ink); }
.form .req{ color:var(--accent-hover); }
.form input,.form select,.form textarea{
  font-family:var(--font-body); font-size:1rem; color:var(--ink);
  background:var(--surface); border:2px solid var(--line);
  padding:0 var(--space-4); min-height:48px; width:100%;
  transition:border-color var(--transition),box-shadow var(--transition);
}
.form textarea{ min-height:140px; padding:var(--space-4); resize:vertical; line-height:1.5; }
.form input::placeholder,.form textarea::placeholder{ color:var(--muted); }
.form input:focus,.form select:focus,.form textarea:focus{ outline:none; border-color:var(--focus); box-shadow:var(--ring); }
.form input:user-invalid,.form textarea:user-invalid{ border-color:var(--error); }
.form .hint{ font-size:var(--fs-xs); color:var(--muted); }
.form .err{ font-size:var(--fs-xs); color:var(--error); }
.form__file input[type="file"]{ padding:var(--space-3); min-height:48px; }

.chips{ display:flex; flex-wrap:wrap; gap:var(--space-2); }
.chip{ position:relative; }
.chip input{ position:absolute; opacity:0; inset:0; cursor:pointer; }
.chip span{ display:inline-flex; align-items:center; min-height:44px; padding:0 var(--space-4); border:2px solid var(--line); font-weight:var(--w-semi); cursor:pointer; transition:background var(--transition),color var(--transition),border-color var(--transition); }
.chip input:checked + span{ background:var(--ink); color:var(--ink-inv); border-color:var(--ink); }
.chip input:focus-visible + span{ outline:3px solid var(--focus); outline-offset:2px; }

.form__status{ display:none; padding:var(--space-4) var(--space-5); border:2px solid var(--ok); background:#EAF3EC; color:var(--ok); font-weight:var(--w-bold); }
.form__status.is-shown{ display:block; }

/* contact details list */
.contact-list{ list-style:none; margin:0; padding:0; display:grid; gap:var(--space-4); }
.contact-list li{ display:grid; grid-template-columns:120px 1fr; gap:var(--space-4); margin:0; align-items:baseline; }
@media (max-width:480px){ .contact-list li{ grid-template-columns:1fr; gap:var(--space-1); } }
.contact-list dt,.contact-list .lab{ font-family:var(--font-display); font-weight:var(--w-semi); font-size:var(--fs-h5); color:var(--ink); }
.contact-list a{ font-weight:var(--w-semi); }

.map-frame{ border:var(--border-2); }
.map-frame iframe{ display:block; width:100%; height:360px; border:0; }

/* =========================================================================
   15. Sticky mobile call/quote bar (design-system 7.11)
   ========================================================================= */
.mbar{ display:none; }
@media (max-width:768px){
  .mbar{ display:grid; grid-template-columns:1fr 1fr; position:fixed; left:0; right:0; bottom:0; z-index:90; border-top:var(--border-2); }
  .mbar a{ min-height:52px; display:inline-flex; align-items:center; justify-content:center; gap:var(--space-2); font-weight:var(--w-bold); text-decoration:none; }
  .mbar .call{ background:var(--ink); color:var(--ink-inv); }
  .mbar .quote{ background:var(--accent); color:#fff; }
  .mbar svg{ width:18px; height:18px; }
  body{ padding-bottom:52px; }
}

/* =========================================================================
   16. Footer (design-system 7.12)
   ========================================================================= */
.footer{ background:var(--ink-bg); color:var(--ink-inv); }
.footer__cols{ display:grid; grid-template-columns:1.3fr 1fr 1.4fr; gap:var(--space-8); padding-block:var(--space-8); }
@media (max-width:768px){ .footer__cols{ grid-template-columns:1fr; gap:var(--space-6); } }
.footer h4{ color:var(--ink-inv); font-size:var(--fs-h5); margin-bottom:var(--space-4); }
.footer a{ color:var(--muted-inv); text-decoration:none; }
.footer a:hover{ color:var(--accent); }
.footer ul{ list-style:none; margin:0; padding:0; display:grid; gap:var(--space-2); }
.footer li{ margin:0; }
.footer li a{ min-height:44px; display:inline-flex; align-items:center; }
.footer__logo img{ height:40px; width:auto; filter:brightness(0) invert(1); margin-bottom:var(--space-4); }
.footer__about{ color:var(--muted-inv); max-width:36ch; }
.footer__contact{ display:grid; gap:var(--space-2); color:var(--muted-inv); }
.footer__contact .lab{ color:var(--galv); font-weight:var(--w-bold); }
.footer__bottom{
  border-top:1px solid var(--line-inv); padding-block:var(--space-5);
  display:flex; flex-wrap:wrap; gap:var(--space-4); justify-content:space-between; align-items:center;
  font-size:var(--fs-small); color:var(--muted-inv);
}
.footer__bottom .logos{ margin:0; gap:var(--space-5); }
.footer__bottom .logos img{ height:26px; }

/* =========================================================================
   17. Utility helpers
   ========================================================================= */
.stack > * + *{ margin-top:var(--space-4); }
.feature-list{ list-style:none; margin:0; padding:0; display:grid; gap:var(--space-3); }
.feature-list li{ display:flex; gap:var(--space-3); align-items:flex-start; margin:0; color:var(--ink); }
.feature-list li::before{ content:""; flex:0 0 auto; width:10px; height:10px; margin-top:8px; background:var(--accent); }
.band--dark .feature-list li{ color:var(--ink-inv); }

.split{ display:grid; grid-template-columns:1.1fr 1fr; gap:var(--space-8); align-items:start; }
@media (max-width:768px){ .split{ grid-template-columns:1fr; gap:var(--space-6); } }
.split--center{ align-items:center; }
.split__media{ border:var(--border-2); overflow:hidden; }
.split__media img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/3; }

.cta-band{ background:var(--accent-tint); border-top:var(--border-accent); }
.cta-band .container{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:var(--space-6); padding-block:var(--space-8); }
.cta-band h2{ margin-bottom:var(--space-2); }
.cta-band p{ margin:0; color:var(--muted); }
.cta-band__actions{ display:flex; flex-wrap:wrap; gap:var(--space-3); align-items:center; }

.eyebrow-rule{ margin-bottom:var(--space-5); }

.breadcrumb{ font-size:var(--fs-small); color:var(--muted-inv); padding-top:var(--space-3); }
.breadcrumb a{ color:var(--galv); }
.breadcrumb a:hover{ color:var(--accent); }

.anchor-offset{ scroll-margin-top:calc(var(--header-h) + var(--space-5)); }

/* =========================================================================
   18. Scroll-reveal (one effect, IntersectionObserver-driven)
   ========================================================================= */
.reveal{ opacity:0; transform:translateY(8px); transition:opacity 360ms cubic-bezier(0,0,0.2,1),transform 360ms cubic-bezier(0,0,0.2,1); }
.reveal.is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1 !important; transform:none !important; transition:none !important; }
}
/* if JS is disabled, never hide content */
.no-js .reveal{ opacity:1; transform:none; }

/* =========================================================================
   19. Lightbox (vanilla focus-trapped dialog; opened on user click only)
   ========================================================================= */
.lightbox{ display:none; position:fixed; inset:0; z-index:200; padding:var(--space-5);
  background:rgba(28,28,29,0.92); align-items:center; justify-content:center; }
.lightbox[data-open="true"]{ display:flex; }
.lightbox__inner{ position:relative; max-width:min(1100px,94vw); max-height:90vh; display:flex; flex-direction:column; }
.lightbox__img{ max-width:100%; max-height:78vh; object-fit:contain; border:var(--border-2); border-color:var(--galv); background:var(--ink-bg); }
.lightbox__cap{ margin-top:var(--space-3); color:var(--ink-inv); font-size:var(--fs-small); }
.lightbox__close{
  position:absolute; top:calc(-1 * var(--space-7)); right:0;
  width:48px; height:48px; min-width:44px; min-height:44px;
  background:var(--accent); color:#fff; border:0; cursor:pointer;
  font-size:1.4rem; line-height:1; display:inline-flex; align-items:center; justify-content:center;
}
.lightbox__close:hover{ background:var(--accent-hover); }
.lightbox__close:focus-visible{ outline:3px solid var(--ink-inv); outline-offset:2px; }
@media (max-width:480px){ .lightbox__close{ top:0; right:0; } }

/* =========================================================================
   20. Print (design-system section 9)
   ========================================================================= */
@media print{
  .util,.nav-toggle,.mbar,.hero__cta,.btn,.form,.skip-link,.nav{ display:none !important; }
  *{ color:#000 !important; background:#fff !important; box-shadow:none !important; }
  body{ font-size:11pt; padding-bottom:0; }
  a[href^="http"]::after{ content:" (" attr(href) ")"; font-size:9pt; }
  .ridge,.ridge--inv{ background:#000 !important; height:2px !important; }
  .footer{ border-top:1px solid #000; }
  .hero{ color:#000 !important; }
  .hero__media{ display:none; }
}
