/* ============================================================
   Liberty Custom — shared stylesheet
   Edit tokens at :root to re-skin from the brand style guide.
   ============================================================ */

:root{
  /* Color */
  --bg:        oklch(0.972 0.008 75);
  --bg-soft:   oklch(0.945 0.010 75);
  --bg-card:   oklch(0.985 0.005 75);
  --ink:       oklch(0.18 0.012 60);
  --ink-mute:  oklch(0.42 0.015 60);
  --ink-faint: oklch(0.62 0.012 60);
  --line:      oklch(0.86 0.008 70);
  --line-soft: oklch(0.92 0.006 70);
  --accent:    rgb(206, 36, 43);
  --accent-ink:#ffffff;

  /* Type */
  --f-display: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --f-body:    "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --f-cta:     "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --f-mono:    "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;

  /* Layout */
  --maxw: 1280px;
  --pad-x: clamp(20px, 4vw, 64px);
}

[data-theme="dark"]{
  --bg:        oklch(0.16 0.008 60);
  --bg-soft:   oklch(0.20 0.010 60);
  --bg-card:   oklch(0.22 0.010 60);
  --ink:       oklch(0.96 0.006 75);
  --ink-mute:  oklch(0.78 0.008 75);
  --ink-faint: oklch(0.58 0.010 75);
  --line:      oklch(0.30 0.010 60);
  --line-soft: oklch(0.25 0.010 60);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--f-body);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x)}

/* ---------- NAV ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:color-mix(in oklab, var(--bg) 88%, transparent);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:3px solid var(--accent);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:96px;
}
.brand{
  display:inline-flex;align-items:center;flex:none;
  height:66px;
}
.brand img{
  height:100%;width:auto;display:block;
}
/* Screen-reader-only label for the logo link */
.brand .sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.nav-links{display:flex;gap:28px}
.nav-links a{
  font-family:var(--f-body);
  font-size:15px;font-weight:500;letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--ink-mute);
  padding:6px 0;
  border-bottom:1.5px solid transparent;
  transition:color .2s, border-color .2s;
}
.nav-links a:hover{color:var(--ink);border-bottom-color:var(--accent)}
.nav-links a.active{color:var(--ink);border-bottom-color:var(--accent)}
.nav-cta{
  font-family:var(--f-cta);font-size:12px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:10px 16px;border:1px solid var(--ink);
  transition:background .2s,color .2s;
}
.nav-cta:hover{background:var(--ink);color:var(--bg)}

/* ---------- HAMBURGER (mobile) ---------- */
.nav-toggle{
  display:none;
  width:44px;height:44px;
  padding:0;margin-left:auto;
  background:transparent;border:0;cursor:pointer;
  position:relative;
  z-index:60;
}
.nav-toggle span{
  position:absolute;left:10px;right:10px;
  height:2px;background:var(--ink);
  transition:transform .25s ease, opacity .2s ease, top .25s ease;
}
.nav-toggle span:nth-child(1){top:14px}
.nav-toggle span:nth-child(2){top:21px}
.nav-toggle span:nth-child(3){top:28px}
.nav.is-open .nav-toggle span:nth-child(1){top:21px;transform:rotate(45deg)}
.nav.is-open .nav-toggle span:nth-child(2){opacity:0}
.nav.is-open .nav-toggle span:nth-child(3){top:21px;transform:rotate(-45deg)}
.home-bg .nav-toggle span{background:#fff}

@media (max-width:880px){
  .nav-toggle{display:block}
  /* The desktop CTA in the bar collapses on mobile \u2014 it reappears inside the menu */
  .nav-inner > .nav-cta{display:none}

  .nav-links{
    position:absolute;
    left:0;right:0;top:100%;
    display:flex;flex-direction:column;gap:0;
    padding:8px 0 20px;
    background:var(--bg);
    border-bottom:3px solid var(--accent);
    box-shadow:0 16px 32px rgba(0,0,0,.10);
    opacity:0;visibility:hidden;
    transform:translateY(-8px);
    transition:opacity .2s ease, transform .2s ease, visibility 0s linear .2s;
  }
  .nav-links a{
    font-size:18px;
    letter-spacing:.06em;
    padding:18px var(--pad-x);
    border-bottom:1px solid var(--line-soft);
    border-left:3px solid transparent;
  }
  .nav-links a:hover,
  .nav-links a.active{
    border-bottom-color:var(--line-soft);
    border-left-color:var(--accent);
    background:var(--bg-soft);
  }
  .nav-links .mobile-cta{
    margin:14px var(--pad-x) 0;
    padding:14px 18px;
    border:1px solid var(--accent);
    background:var(--accent);
    color:#fff;
    text-align:center;
    font-family:var(--f-cta);font-size:13px;font-weight:700;
    letter-spacing:.14em;text-transform:uppercase;
  }
  .nav-links .mobile-cta:hover,
  .nav-links .mobile-cta.active{
    border-left-color:var(--accent);
    background:var(--accent);color:#fff;
  }

  .nav.is-open .nav-links{
    opacity:1;visibility:visible;transform:none;
    transition:opacity .2s ease, transform .2s ease, visibility 0s linear 0s;
  }

  /* Dark home-bg variant for the open menu */
  .home-bg .nav-links{
    background:rgba(20,14,8,.96);
    backdrop-filter:saturate(140%) blur(14px);
    -webkit-backdrop-filter:saturate(140%) blur(14px);
  }
  .home-bg .nav-links a{
    color:rgba(255,255,255,.85);
    border-bottom-color:rgba(255,255,255,.08);
  }
  .home-bg .nav-links a:hover,
  .home-bg .nav-links a.active{
    color:#fff;background:rgba(255,255,255,.04);
  }
}

/* ---------- UTILITIES ---------- */
.eyebrow{
  font-family:var(--f-mono);
  font-size:11px;font-weight:500;
  letter-spacing:.42em;text-transform:uppercase;
  color:var(--accent);
  display:inline-block;
}
.h-display{
  font-family:var(--f-display);
  font-weight:900;
  letter-spacing:-.005em;
  line-height:1.02;
  color:var(--ink);
  margin:0;
  text-transform:uppercase;
}
.h1{font-size:clamp(44px,6.6vw,96px)}
.h2{font-size:clamp(34px,4.6vw,66px)}
.h3{
  font-size:clamp(24px,2.4vw,32px);
  font-weight:700;letter-spacing:.01em;
}
/* Native heading elements default to Montserrat (in case raw <h1>…<h6> are used) */
h1,h2,h3,h4,h5,h6{font-family:var(--f-display)}
.lede{
  font-size:clamp(17px,1.4vw,20px);
  color:var(--ink-mute);
  max-width:62ch;
  line-height:1.55;
}
.btn{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--f-cta);font-size:13px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  padding:16px 26px;
  border:1px solid var(--ink);
  transition:background .2s,color .2s,transform .2s;
  cursor:pointer;
}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}
.btn-primary{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.btn-primary:hover{filter:brightness(.92)}
.btn-ghost:hover{background:var(--ink);color:var(--bg)}

section{padding:clamp(72px,10vw,140px) 0;position:relative}
.rule{height:1px;background:var(--line);border:0;margin:0}

/* ---------- IMAGE PLACEHOLDER ---------- */
.ph{
  position:relative;
  background:
    repeating-linear-gradient(135deg,
      color-mix(in oklab, var(--ink) 6%, transparent) 0 2px,
      transparent 2px 12px),
    var(--bg-soft);
  border:1px solid var(--line);
  color:var(--ink-mute);
  display:flex;align-items:flex-end;justify-content:space-between;
  padding:18px;
  font-family:var(--f-mono);font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;
}
.ph::before{
  content:"";position:absolute;inset:14px;
  border:1px dashed color-mix(in oklab, var(--ink) 22%, transparent);
  pointer-events:none;
}
.ph-label{display:flex;align-items:center;gap:8px;z-index:1}
.ph-label::before{
  content:"";width:8px;height:8px;background:var(--accent);
  display:inline-block;
}
.ph-dim{color:var(--ink-faint);z-index:1}

/* ---------- PAGE INTRO (sub-pages) ---------- */
.page-intro{
  padding:clamp(60px,8vw,120px) 0 clamp(40px,5vw,60px);
  border-bottom:1px solid var(--line);
}
.page-intro .crumb{
  font-family:var(--f-mono);font-size:11px;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-faint);
  display:flex;align-items:center;gap:10px;
  margin-bottom:36px;
}
.page-intro .crumb a:hover{color:var(--ink)}
.page-intro .crumb::after{content:"";flex:1;height:1px;background:var(--line);margin-left:14px}
.page-intro-grid{
  display:grid;grid-template-columns:1.1fr .9fr;
  gap:clamp(24px,5vw,80px);align-items:end;
}
@media (max-width:880px){ .page-intro-grid{grid-template-columns:1fr} }
.page-intro h1{margin:18px 0 0}
.page-intro h1.h1{
  /* Smaller than the homepage hero h1 — sub-pages don't need to shout */
  font-size:clamp(36px, 5vw, 60px);
  line-height:1.05;
}
.page-intro .lede{margin:24px 0 0}

/* ---------- HERO (home only) ---------- */
.hero{
  padding:clamp(60px,8vw,120px) 0 clamp(60px,8vw,120px);
  overflow:hidden;
}
.hero-grid{
  display:grid;grid-template-columns:1.1fr .9fr;
  gap:clamp(32px,5vw,80px);align-items:end;
}
@media (max-width:980px){ .hero-grid{grid-template-columns:1fr} }
.hero h1{margin:18px 0 0}
.hero .lede{margin:28px 0 36px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{
  display:flex;gap:18px;flex-wrap:wrap;
  margin-top:48px;padding-top:28px;
  border-top:1px solid var(--line);
  font-family:var(--f-mono);font-size:11px;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-faint);
}
.hero-meta span{display:inline-flex;align-items:center;gap:8px}
.hero-meta .dot{width:6px;height:6px;background:var(--accent);border-radius:50%}
.hero-ph{aspect-ratio: 4 / 5; min-height: 380px}
.hero-top{
  display:flex;justify-content:space-between;
  color:var(--ink-faint);
  font-family:var(--f-mono);font-size:11px;
  letter-spacing:.22em;text-transform:uppercase;
  margin-bottom:36px;
}

/* ---------- ABOUT / PILLARS ---------- */
.about-head{
  display:grid;grid-template-columns:.9fr 1.1fr;
  gap:clamp(24px,5vw,80px);
  margin-bottom:clamp(48px,7vw,96px);
  align-items:end;
}
@media (max-width:880px){ .about-head{grid-template-columns:1fr} }
.about-head .lede{margin:0}

.pillars{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--line);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
@media (max-width:980px){ .pillars{grid-template-columns:repeat(2,1fr)} }
@media (max-width:540px){ .pillars{grid-template-columns:1fr} }
.pillar{
  background:var(--bg-soft);
  padding:36px 28px 40px;
  display:flex;flex-direction:column;gap:14px;
  min-height:240px;
}
.pillar-icon{
  width:56px;height:56px;
  display:block;
  margin-bottom:6px;
  object-fit:contain;
  /* The icons are already in the brand red; this keeps them aligned to
     --accent if the brand color changes later. */
}
.pillar .num{
  font-family:var(--f-mono);font-size:11px;
  color:var(--accent);letter-spacing:.22em;
}
.pillar h4{
  font-family:var(--f-display);
  font-size:20px;font-weight:800;letter-spacing:.005em;
  text-transform:uppercase;
  margin:0;line-height:1.2;
}
.pillar p{color:var(--ink-mute);font-size:15px;margin:0;line-height:1.55}

/* ---------- CAPABILITIES ---------- */
.cap-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  flex-wrap:wrap;gap:24px;
  margin-bottom:clamp(48px,6vw,72px);
}
.cap-tag{
  font-family:var(--f-mono);font-size:11px;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-faint);
}
.cap-tag b{color:var(--accent);font-weight:500;padding:0 4px}

.cap-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(20px,2vw,28px);
  align-items:start;
}
.cap{
  grid-column:2;
  border-top:1px solid var(--ink);
  padding-top:22px;
  display:flex;flex-direction:column;
  min-height:200px;
}
/* legacy span helpers (now no-ops in this 2-col layout) */
.cap.span-6,.cap.span-12{grid-column:2}

/* Feature image — left column, spans all cap rows; sticks while you scroll */
.cap-feature{
  grid-column:1;
  grid-row:1 / -1;
  position:sticky;
  top:120px; /* sits under the 96px nav + a bit of breathing room */
  align-self:start;
  aspect-ratio:16/9;
  background:var(--bg-soft);
  border:1px solid var(--line);
  overflow:hidden;
}
.cap-feature img{
  width:100%;height:100%;
  object-fit:cover;display:block;
}
.cap-feature figcaption{
  position:absolute;left:0;right:0;bottom:0;
  padding:14px 18px;
  font-family:var(--f-mono);
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:#fff;
  background:linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.55) 100%);
}
@media (max-width:880px){
  .cap-grid{grid-template-columns:1fr}
  .cap, .cap.span-6, .cap.span-12{grid-column:1}
  .cap-feature{
    grid-column:1;grid-row:auto;
    position:static;
    aspect-ratio:5/3;min-height:240px;
  }
}
.cap-num{
  font-family:var(--f-mono);font-size:11px;
  color:var(--ink-faint);letter-spacing:.22em;
  margin-bottom:24px;
}
.cap h3{
  font-family:var(--f-display);
  font-size:clamp(22px,2vw,28px);font-weight:800;
  letter-spacing:.005em;line-height:1.15;
  text-transform:uppercase;
  margin:0 0 18px;
}
.cap ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.cap li{
  color:var(--ink-mute);font-size:15px;
  display:flex;align-items:baseline;gap:10px;
}
.cap li::before{
  content:"";width:5px;height:5px;flex:none;
  background:var(--accent);transform:translateY(-3px);
}

/* ---------- FACILITY / STATS ---------- */
.facility{background:var(--ink);color:var(--bg)}
[data-theme="dark"] .facility{background:oklch(0.10 0.008 60)}
.facility .eyebrow{color:color-mix(in oklab, var(--accent) 70%, white 30%)}
.facility h1,.facility h2{color:var(--bg)}
.facility .lede{color:color-mix(in oklab, var(--bg) 75%, transparent)}
.facility-head{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;
  align-items:end;margin-bottom:64px;
}
@media (max-width:880px){ .facility-head{grid-template-columns:1fr} }

.stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:color-mix(in oklab, var(--bg) 18%, transparent);
  border-top:1px solid color-mix(in oklab, var(--bg) 18%, transparent);
  border-bottom:1px solid color-mix(in oklab, var(--bg) 18%, transparent);
}
@media (max-width:780px){ .stats{grid-template-columns:repeat(2,1fr)} }
.stat{
  background:var(--ink);
  padding:36px 24px 32px;
}
[data-theme="dark"] .stat{background:oklch(0.10 0.008 60)}
.stat .v{
  font-family:var(--f-display);
  font-weight:600;letter-spacing:-.03em;
  font-size:clamp(48px,6vw,88px);line-height:1;
  color:var(--bg);
}
.stat .v sup{
  font-size:.42em;vertical-align:super;
  color:var(--accent);font-weight:500;
  margin-left:4px;letter-spacing:0;
}
.stat .k{
  font-family:var(--f-mono);font-size:11px;
  letter-spacing:.26em;text-transform:uppercase;
  color:color-mix(in oklab, var(--bg) 65%, transparent);
  margin-top:16px;
}

.markets-block{margin-top:96px}
.markets-head{
  display:flex;justify-content:space-between;align-items:baseline;
  margin-bottom:36px;flex-wrap:wrap;gap:16px;
}
.markets-head h3{
  font-family:var(--f-display);font-size:clamp(22px,2vw,28px);
  font-weight:800;color:var(--bg);margin:0;
  letter-spacing:.01em;text-transform:uppercase;
}
.markets{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:color-mix(in oklab, var(--bg) 18%, transparent);
  border-top:1px solid color-mix(in oklab, var(--bg) 18%, transparent);
  border-bottom:1px solid color-mix(in oklab, var(--bg) 18%, transparent);
}
@media (max-width:980px){ .markets{grid-template-columns:repeat(2,1fr)} }
@media (max-width:540px){ .markets{grid-template-columns:1fr} }
.market{
  background:var(--ink);
  padding:28px 24px;
  display:flex;flex-direction:column;gap:14px;
  min-height:180px;justify-content:space-between;
}
[data-theme="dark"] .market{background:oklch(0.10 0.008 60)}
.market .idx{
  font-family:var(--f-mono);font-size:10px;
  color:color-mix(in oklab, var(--bg) 50%, transparent);
  letter-spacing:.22em;
}
.market .name{
  font-family:var(--f-display);
  font-size:17px;font-weight:700;line-height:1.2;
  letter-spacing:.005em;text-transform:uppercase;
  color:var(--bg);
}
.market .sub{
  font-size:13px;
  color:color-mix(in oklab, var(--bg) 60%, transparent);
}
.market .sub-list{
  list-style:none;margin:10px 0 0;padding:0;
  display:flex;flex-direction:column;gap:6px;
}
.market .sub-list li{
  font-size:13px;line-height:1.35;
  color:color-mix(in oklab, var(--bg) 65%, transparent);
  padding-left:14px;position:relative;
}
.market .sub-list li::before{
  content:"";
  position:absolute;left:0;top:.6em;
  width:6px;height:1px;
  background:var(--accent);
}

/* ---------- CTA ---------- */
.cta-grid{
  display:grid;grid-template-columns:1.2fr .8fr;
  gap:clamp(40px,6vw,96px);align-items:center;
}
@media (max-width:880px){ .cta-grid{grid-template-columns:1fr} }
.cta h2{margin:18px 0 24px}
.cta-ph{aspect-ratio: 5/4; min-height: 320px}
img.cta-ph{width:100%; height:100%; object-fit:cover; display:block}

/* ---------- CONTACT page ---------- */
.contact-grid{
  display:grid;grid-template-columns:1.1fr .9fr;
  gap:clamp(32px,5vw,80px);align-items:start;
}
@media (max-width:880px){ .contact-grid{grid-template-columns:1fr} }
.contact-card{
  border:1px solid var(--line);
  padding:clamp(28px,3vw,40px);
  background:var(--bg-card);
}
.contact-card h3{
  font-family:var(--f-display);font-size:20px;font-weight:800;
  margin:0 0 8px;letter-spacing:.005em;text-transform:uppercase;
}
.contact-info{
  display:grid;gap:24px;
}
.contact-info .row{
  display:grid;grid-template-columns:140px 1fr;
  gap:16px;align-items:baseline;
  border-top:1px solid var(--line);
  padding-top:18px;
}
.contact-info .row:first-child{border-top:0;padding-top:0}
.contact-info .k{
  font-family:var(--f-mono);font-size:11px;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-faint);
}
.contact-info .v{
  font-family:var(--f-display);font-size:17px;font-weight:700;
  color:var(--ink);letter-spacing:.005em;text-transform:uppercase;
}
.contact-info .v small{
  display:block;font-family:var(--f-body);font-size:14px;
  font-weight:400;color:var(--ink-mute);margin-top:4px;letter-spacing:0;
}

/* Contact form */
.qf{display:grid;gap:18px}
.qf .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:540px){ .qf .row{grid-template-columns:1fr} }
.qf label{
  display:block;
  font-family:var(--f-mono);font-size:10px;
  letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-faint);
  margin-bottom:8px;
}
.qf input,.qf select,.qf textarea{
  width:100%;
  background:var(--bg);
  color:var(--ink);
  border:1px solid var(--line);
  padding:14px 14px;
  font-family:var(--f-body);font-size:15px;
  border-radius:0;
  transition:border-color .2s, background .2s;
}
.qf input:focus,.qf select:focus,.qf textarea:focus{
  outline:0;border-color:var(--accent);
}
.qf textarea{resize:vertical;min-height:120px}
.qf .submit-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:6px}
.qf .submit-note{
  font-family:var(--f-mono);font-size:11px;
  color:var(--ink-faint);letter-spacing:.18em;text-transform:uppercase;
}

/* ---------- FOOTER ---------- */
footer{
  border-top:1px solid var(--line);
  padding:64px 0 56px;
  margin-top:0;
}
.foot{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:48px;
}
.foot-left{
  display:flex;align-items:center;gap:28px;
  flex-wrap:wrap;
}
.foot-left .brand{height:64px}

/* Made in USA badge */
.usa-badge{
  width:96px;height:96px;
  flex:none;
  display:block;
  color:var(--ink);
}
.usa-badge .ring{fill:none;stroke:var(--ink);stroke-width:1.5}
.usa-badge .ring-accent{fill:none;stroke:var(--accent);stroke-width:2}
.usa-badge .star{fill:var(--accent)}
.usa-badge text{
  font-family:var(--f-display);
  font-weight:800;
  font-size:8.5px;
  letter-spacing:.22em;
  fill:var(--ink);
  text-transform:uppercase;
}
.usa-badge text.bottom{letter-spacing:.18em}

.foot-links{
  display:flex;gap:24px;flex-wrap:wrap;
  font-family:var(--f-mono);font-size:11px;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-faint);
  justify-self:end;
}
.foot-links a:hover{color:var(--ink)}
.copy{
  font-family:var(--f-mono);font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-faint);
}

/* Dark home variant — invert badge */
.home-bg .usa-badge{color:#fff}
.home-bg .usa-badge .ring{stroke:rgba(255,255,255,.85)}
.home-bg .usa-badge text{fill:#fff}

@media (max-width:780px){
  .foot{grid-template-columns:1fr;gap:32px}
  .foot-links{justify-self:start}
}

/* ---------- HOMEPAGE — IMAGE BACKGROUND ---------- */
.home-bg{
  background:
    linear-gradient(180deg,
      rgba(10,8,6,.55) 0%,
      rgba(10,8,6,.50) 40%,
      rgba(10,8,6,.75) 100%),
    url("assets/hero-bg.jpg") center / cover no-repeat fixed;
  color:#fff;
}
/* Make nav glass over the photo */
.home-bg .nav{
  background:rgba(20,14,8,.32);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:3px solid var(--accent);
}
.home-bg .brand,
.home-bg .nav-links a{color:rgba(255,255,255,.85)}
.home-bg .nav-links a:hover,
.home-bg .nav-links a.active{color:#fff;border-bottom-color:var(--accent)}
/* Logo invert on dark home — the wordmark reads white against the photo.
   Loses the red torch on this surface; full-color version returns on
   all other (light) pages. */
.home-bg .brand img{filter:brightness(0) invert(1)}
.home-bg .nav-cta{
  color:#fff;
  border-color:var(--accent);
  background:var(--accent);
}
.home-bg .nav-cta:hover{background:#fff;color:#1a1612;border-color:#fff}

/* Hero text on photo */
.home-bg .hero h1,
.home-bg .h-display{color:#fff;text-shadow:0 1px 30px rgba(0,0,0,.35)}
.home-bg .lede{color:rgba(255,255,255,.88)}
.home-bg .hero-top,
.home-bg .hero-meta{color:rgba(255,255,255,.7);border-top-color:rgba(255,255,255,.18)}
.home-bg .hero-meta .dot{background:var(--accent)}
.home-bg .btn{color:#fff;border-color:rgba(255,255,255,.7)}
.home-bg .btn-ghost:hover{background:#fff;color:#1a1612;border-color:#fff}
.home-bg .btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Hero: drop the right-hand placeholder slot — photo is the imagery */
.home-bg .hero-grid{grid-template-columns:1fr; max-width:880px}
.home-bg .hero-ph{display:none}

/* Footer over photo */
.home-bg footer{
  background:rgba(20,14,8,.55);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-top:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.7);
}
.home-bg footer .copy,
.home-bg footer .foot-links{color:rgba(255,255,255,.7)}
.home-bg footer .foot-links a:hover{color:#fff}

/* Make sure the hero takes the viewport so the photo reads */
.home-bg .hero{min-height:calc(100vh - 96px);display:flex;align-items:center}

/* ---------- MARKETS PAGE — IMAGE HERO BAND ---------- */
.facility-with-hero{padding-top:0}
.facility-with-hero .facility-body{padding-top:clamp(56px,7vw,96px)}
.market-hero{
  position:relative;
  min-height:clamp(420px, 55vh, 600px);
  display:flex;align-items:flex-end;
  overflow:hidden;
  background:#0c0a08;
  margin-bottom:0;
}
.market-hero img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  /* Slightly cool the image so it reads behind warm-white text */
  opacity:.55;
}
.market-hero::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(10,8,6,.35) 0%, rgba(10,8,6,.55) 55%, rgba(10,8,6,.92) 100%),
    linear-gradient(90deg, rgba(10,8,6,.55) 0%, rgba(10,8,6,0) 50%);
}
.market-hero-content{
  position:relative;z-index:1;
  padding-top:clamp(80px,10vw,140px);
  padding-bottom:clamp(48px,6vw,80px);
}
.market-hero .crumb{
  font-family:var(--f-mono);font-size:11px;
  letter-spacing:.28em;text-transform:uppercase;
  color:color-mix(in oklab, var(--bg) 50%, transparent);
  display:flex;align-items:center;gap:10px;margin-bottom:36px;
}
.market-hero .crumb a{color:color-mix(in oklab, var(--bg) 70%, transparent)}
.market-hero .crumb a:hover{color:var(--bg)}

/* Subtle reveal */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(14px);transition:opacity .7s ease, transform .7s ease}
  .reveal.in{opacity:1;transform:none}
}
