:root {
  --bg:#24241B; --alt:#1A1A12; --ink:#D6D6CB; --sub:#AD9C79;
  --line:rgba(214,214,203,0.14); --tint:#3A3A2A;
  --accent:#B80F0F; --cta-bg:#B80F0F; --cta-fg:#D6D6CB;
  --em:#AD9C79; --nav-bg:rgba(26, 26, 18, 0.94); --trust-label:#AD9C79;
  --font-d:'Big Shoulders Display', Impact, 'Arial Narrow', sans-serif;
  --font-serif:'Fraunces', Georgia, serif;
  --font-s:'Inter', -apple-system, 'Segoe UI', sans-serif;



}
*,*::before,*::after { box-sizing:border-box; }
html,body { margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family:var(--font-s); background:var(--bg); color:var(--ink);
  line-height:1.55; font-size:15px; -webkit-font-smoothing:antialiased;
}
:focus-visible { outline:2.5px solid var(--accent); outline-offset:3px; border-radius:3px; }

/* === NAV === */
.nav {
  position:sticky; top:0; z-index:50;
  display:flex; justify-content:space-between; align-items:center;
  padding:14px 32px;
  background:var(--nav-bg); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-logo { display:flex; align-items:center; cursor:pointer; text-decoration:none; padding:4px 0; }
.nav-logo img { height:38px; width:auto; filter:invert(1); display:block; }
.nav-links { display:flex; align-items:center; gap:28px; list-style:none; padding:0; margin:0; }
.nav-links a {
  font-family:var(--font-s); font-size:11.5px; color:var(--sub);
  text-decoration:none; letter-spacing:0.16em; text-transform:uppercase;
  font-weight:600; cursor:pointer; transition:color .18s; padding:6px 0;
}
.nav-links a:hover, .nav-links a.active { color:var(--ink); }
.nav-links a.active { border-bottom:1.5px solid var(--accent); padding-bottom:4px; }
.nav-cta {
  background:var(--accent); color:#FAF8F3 !important; padding:12px 27px;
  border-radius:2px; font-weight:700 !important; letter-spacing:0.11em;
  border-bottom:none !important; min-height:43px;
  display:inline-flex; align-items:center;
}
.nav-cta:hover { filter:brightness(1.1); color:#FAF8F3 !important; }
.nav-cta .cta-mobile { display:none; }
.nav-cta .cta-desktop { display:inline; }
@media (max-width:780px) {
  .nav-cta { padding:11px 18px; }
  .nav-cta .cta-mobile { display:inline; }
  .nav-cta .cta-desktop { display:none; }
}

/* === HAMBURGER === */
.hamburger {
  display:none; background:none; border:none; cursor:pointer;
  padding:8px; margin:0; width:44px; height:44px;
  flex-direction:column; justify-content:center; align-items:center; gap:5px;
  -webkit-tap-highlight-color:rgba(184,15,15,0.2);
  touch-action:manipulation;
}
.hamburger:active { opacity:0.6; }
.hamburger span {
  display:block; width:24px; height:2px; background:var(--ink);
  transition:transform .25s ease, opacity .15s ease;
}
.hamburger[aria-expanded="true"] span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger[aria-expanded="true"] span:nth-child(2) { opacity:0; }
.hamburger[aria-expanded="true"] span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

@media (max-width:780px) {
  .nav { padding:10px 14px; gap:8px; }
  .nav-logo img { height:26px; max-width:170px; object-fit:contain; }
  .hamburger { display:flex; }
  /* v1.0.2 — Hamburger overlay fix: opaque bg, 100dvh, no backdrop-filter at mobile (which created a containing block bug) */
  .nav { backdrop-filter:none; background:rgba(26, 22, 20, 0.97); }
  .nav-links {
    display:none; position:fixed; inset:0;
    width:100vw; height:100dvh;
    flex-direction:column; align-items:stretch; gap:0;
    background:rgb(26, 22, 20); /* opaque */
    padding:72px 24px 24px;
    overflow-y:auto; z-index:48;
  }
  .nav-links.open {
    display:flex !important;
    position:fixed !important;
    inset:0 !important;
    width:100vw !important; height:100dvh !important;
    flex-direction:column !important;
    background:rgb(26, 22, 20) !important; /* opaque */
    z-index:48 !important;
    overflow-y:auto;
    animation:slideIn .25s ease;
  }
  .hamburger { z-index:49; position:relative; }
  .hamburger[aria-expanded="true"] span { background:#F4EDD8; }
  .nav-links li { width:100%; }
  .nav-links a {
    font-size:17px; padding:16px 0; letter-spacing:0.14em;
    border-bottom:1px solid var(--line); display:block; text-align:left;
  }
  .nav-links a.active { border-bottom-color:var(--accent); }
  .nav-links.open .nav-cta {
    margin-top:18px; text-align:center; padding:14px 28px !important;
    border-bottom:none !important; min-height:48px; justify-content:center;
    width:100%; box-sizing:border-box;
  }
}
@keyframes slideIn {
  from { opacity:0; transform:translateY(-8px); }
  to { opacity:1; transform:none; }
}

/* === PAGE ROUTING === */
.pages { position:relative; }
.page { display:block; }
.page.active { display:block; animation:fade .35s ease; }
@keyframes fade {
  from { opacity:0; transform:translateY(6px); }
  to { opacity:1; transform:none; }
}

/* === HERO (full-bleed bg image with text overlay) === */
.hero {
  position:relative; min-height:70vh;
  padding:96px 32px 100px;
  display:flex; align-items:center; overflow:hidden;
  background:#0d0d08;
}
.hero::before {
  content:""; position:absolute; inset:0; z-index:0;
  background-image: var(--hero-bg);
  background-size:cover; background-position:center 40%;
  filter:brightness(0.5) saturate(0.85);
}
.hero::after {
  content:""; position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(180deg, rgba(26,26,18,0.32) 0%, rgba(26,26,18,0.7) 65%, rgba(26,26,18,0.95) 100%),
    linear-gradient(90deg, rgba(26,26,18,0.55) 0%, rgba(26,26,18,0.18) 50%, rgba(26,26,18,0.45) 100%);
}
body.page-about .hero, body.page-contact .hero { min-height:62vh; padding:96px 32px 100px; }
@media (max-width:780px) {
  body.page-about .hero, body.page-contact .hero { min-height:56vh; padding:72px 24px 64px; }
}
.scroll-indicator {
  position:absolute; bottom:24px; left:50%; transform:translateX(-50%);
  z-index:3; display:flex; flex-direction:column; align-items:center; gap:6px;
  font-family:var(--font-s); font-size:9.5px; letter-spacing:0.22em;
  text-transform:uppercase; color:var(--ink); opacity:0.7; font-weight:600;
  animation:bob 1.8s ease-in-out infinite;
  pointer-events:none;
}
.scroll-indicator svg { width:14px; height:14px; opacity:0.85; }
@keyframes bob {
  0%, 100% { transform:translateX(-50%) translateY(0); opacity:0.65; }
  50% { transform:translateX(-50%) translateY(6px); opacity:0.95; }
}
/* Per-page hero photo set via inline --hero-bg custom property in PHP */

.hero-content {
  position:relative; z-index:2; max-width:980px; width:100%; margin:0 auto;
}
.eyebrow {
  font-family:var(--font-s); font-size:11px; letter-spacing:0.3em;
  text-transform:uppercase; color:var(--ink); font-weight:600;
  margin-bottom:28px; opacity:0.88;
}
.eyebrow .dot {
  display:inline-block; width:5px; height:5px; background:var(--accent);
  border-radius:50%; vertical-align:middle; margin:0 10px 3px;
}
.hero h1 {
  font-family:var(--font-d); font-weight:900;
  font-size:clamp(2.2rem, 5vw, 3.8rem); line-height:1; letter-spacing:-0.005em;
  margin:0 0 28px; color:#F4EDD8; text-transform:uppercase;
  text-shadow:0 2px 24px rgba(0,0,0,0.45);
}
.hero h1 em {
  font-family:var(--font-serif); font-style:italic; font-weight:400;
  color:var(--em); text-transform:none; letter-spacing:-0.01em; font-size:0.86em;
}
.hero p.sub {
  font-family:var(--font-s); color:var(--ink); font-size:16px;
  max-width:64ch; line-height:1.6; margin:0 0 36px; opacity:0.92;
  text-shadow:0 1px 12px rgba(0,0,0,0.5);
}
.cta-row { display:flex; gap:14px; align-items:center; flex-wrap:wrap; }

@media (max-width:780px) {
  .hero { min-height:68vh; padding:80px 24px 72px; }
  .hero::before { background-attachment:scroll; }
  .hero h1 { font-size:clamp(1.9rem, 7vw, 2.6rem); margin-bottom:20px; }
  .eyebrow { font-size:10px; letter-spacing:0.22em; margin-bottom:18px; }
  .hero p.sub { font-size:15px; margin-bottom:28px; }
}

/* === BUTTONS === */
.btn-p, button.btn-p, .btn-g, .btn-close {
  font-family:var(--font-s); font-size:11px; font-weight:700;
  letter-spacing:0.16em; text-transform:uppercase; text-decoration:none;
  cursor:pointer; transition:filter .18s, border-color .18s, background-color .18s;
  display:inline-flex; align-items:center; justify-content:center;
  min-height:42px; padding:10px 22px; border-radius:2px;
}
@media (max-width:780px) {
  .btn-p, button.btn-p, .btn-g, .btn-close { min-height:44px; padding:11px 20px; font-size:11px; }
}
.btn-p, button.btn-p {
  background:var(--cta-bg); color:var(--cta-fg);
  border:1.5px solid var(--cta-bg);
}
.btn-p:hover { filter:brightness(1.08); }
.btn-g {
  color:var(--ink); background:transparent;
  border:1.5px solid rgba(214,214,203,0.45);
}
.btn-g:hover { border-color:var(--ink); background:rgba(214,214,203,0.08); }

/* === TRUST STRIP === */
.trust { background:var(--alt); padding:32px; border-bottom:1px solid var(--line); }
.trust-inner {
  max-width:1080px; margin:0 auto;
  display:flex; flex-wrap:wrap; gap:20px 56px; justify-content:center;
}
.trust-item { display:flex; flex-direction:column; gap:4px; align-items:center; text-align:center; }
.trust-label {
  font-family:var(--font-s); font-size:10px; font-weight:700;
  letter-spacing:0.2em; text-transform:uppercase; color:var(--trust-label);
}
.trust-value {
  font-family:var(--font-d); font-size:14px; font-weight:700;
  letter-spacing:0.05em; color:var(--ink); text-transform:uppercase;
}
@media (max-width:780px) { .trust { padding:22px 20px; } .trust-inner { gap:16px 28px; } }

/* === SECTIONS === */
.section { padding:80px 32px; background:var(--bg); }
.section.alt { background:var(--alt); }
.section-inner { max-width:1280px; margin:0 auto; }
.head { margin-bottom:44px; max-width:680px; }
.kicker {
  font-family:var(--font-s); font-size:10.5px; letter-spacing:0.28em;
  text-transform:uppercase; color:var(--trust-label); font-weight:700;
  margin-bottom:14px;
}
.head h2 {
  font-family:var(--font-d); font-weight:900;
  font-size:clamp(1.9rem, 3.6vw, 2.8rem); line-height:0.98;
  color:var(--ink); margin:0 0 16px; letter-spacing:-0.005em; text-transform:uppercase;
}
.head h2 em {
  font-family:var(--font-serif); font-style:italic; font-weight:400;
  color:var(--em); text-transform:none; letter-spacing:-0.01em; font-size:0.88em;
}
.head .sub {
  font-family:var(--font-s); color:var(--sub); font-size:15px;
  max-width:62ch; margin:0; line-height:1.65;
}
@media (max-width:780px) { .section { padding:56px 24px; } .head { margin-bottom:32px; } }

/* === SERVICE TILES (7 tiles) — 3-col with NFA spanning row 3 === */
.svc-grid {
  display:grid; grid-template-columns:repeat(3, 1fr); gap:0;
  border-top:1px solid var(--line); border-left:1px solid var(--line);
}
.svc-grid .svc-nfa { grid-column:1 / -1; }
@media (max-width:920px) {
  .svc-grid { grid-template-columns:repeat(2, 1fr); }
  .svc-grid .svc-nfa { grid-column:1 / -1; }
}
@media (max-width:520px) {
  .svc-grid { grid-template-columns:1fr; }
  .svc-grid .svc-nfa { grid-column:1; }
}
.svc {
  padding:32px 28px; border-right:1px solid var(--line);
  border-bottom:1px solid var(--line); display:flex; flex-direction:column;
  background:rgba(36, 36, 27, 0.55);
  transition:background .25s ease;
}
.svc:hover { background:rgba(58, 58, 42, 0.4); }
.svc.svc-nfa {
  background:rgba(184, 15, 15, 0.06);
  border-top:1px solid rgba(184, 15, 15, 0.4);
  align-items:flex-start;
}
.svc-name {
  font-family:var(--font-d); font-size:19px; color:var(--ink);
  font-weight:800; margin-bottom:8px; letter-spacing:0.02em; text-transform:uppercase;
}
.svc-meta {
  font-family:var(--font-s); font-size:13.5px; color:var(--sub);
  line-height:1.6; margin-bottom:16px; flex:1;
}
.svc-price {
  font-family:var(--font-serif); font-style:italic; font-size:13px;
  color:var(--em); font-weight:500; margin:-4px 0 14px;
}
.svc-link {
  font-family:var(--font-s); font-size:11px; color:var(--em);
  font-weight:700; letter-spacing:0.16em; text-transform:uppercase;
  text-decoration:none; cursor:pointer; align-self:flex-start;
  transition:color .18s, transform .18s;
}
.svc-link:hover { color:var(--accent); transform:translateX(3px); }
.soon-pill {
  display:inline-block; font-family:var(--font-s); font-size:9.5px;
  letter-spacing:0.2em; text-transform:uppercase; color:var(--accent);
  border:1px solid var(--accent); padding:3px 10px; border-radius:30px;
  font-weight:700; margin-top:-4px; margin-bottom:12px; align-self:flex-start;
}

/* Brand promise callout — under tiles on home */
.promise {
  margin-top:48px; padding:28px 32px;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  text-align:center;
}
.promise blockquote {
  font-family:var(--font-serif); font-style:italic;
  font-size:clamp(1.2rem, 2.4vw, 1.6rem); line-height:1.4;
  color:var(--ink); margin:0; max-width:38ch; margin-left:auto; margin-right:auto;
}
.promise blockquote em {
  color:var(--em); font-weight:500;
}
.promise .promise-attr {
  display:block; margin-top:14px; font-family:var(--font-s);
  font-style:normal; font-size:11px; letter-spacing:0.2em;
  text-transform:uppercase; color:var(--sub); font-weight:600;
}

/* === SVC DETAIL (Services page) === */
.svc-detail {
  padding:56px 32px; border-top:1px solid var(--line);
  display:grid; grid-template-columns:280px 1fr; gap:56px;
  background:var(--bg); max-width:1280px; margin:0 auto;
}
@media (max-width:760px) { .svc-detail { grid-template-columns:1fr; padding:40px 24px; gap:24px; } }
.svc-detail-head h3 {
  font-family:var(--font-d); font-weight:800; font-size:26px;
  color:var(--ink); margin:0 0 8px; text-transform:uppercase; letter-spacing:0.005em;
}
.svc-detail-head h3 em {
  font-family:var(--font-serif); font-style:italic; font-weight:400;
  color:var(--em); text-transform:none; font-size:0.86em;
}
.svc-detail-head .kicker { margin-bottom:8px; }
.svc-detail-body p {
  font-family:var(--font-s); font-size:14.5px; color:var(--ink);
  line-height:1.7; margin:0 0 18px;
}
.svc-detail-body p.lede {
  font-family:var(--font-serif); font-style:italic; font-size:17px;
  color:var(--ink); opacity:0.92;
}
.svc-list { list-style:none; padding:0; margin:0 0 18px; }
.svc-list li {
  padding:12px 0; border-bottom:1px solid var(--line);
  font-family:var(--font-s); font-size:13.5px; color:var(--sub);
  display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap;
}
.svc-list li b {
  font-family:var(--font-d); color:var(--ink); font-weight:700;
  letter-spacing:0.02em; text-transform:uppercase; font-size:13.5px;
}
.svc-list li:last-child { border-bottom:none; }
.svc-list li i { font-family:var(--font-serif); font-style:italic; color:var(--em); font-size:13.5px; }
.brand-row { display:flex; flex-wrap:wrap; gap:14px 24px; margin:14px 0 0; }
.brand-row span {
  font-family:var(--font-d); font-size:12px; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--ink);
  border:1px solid var(--line); padding:7px 14px; border-radius:2px;
}

.svc-detail-img { aspect-ratio:4/3; border-radius:4px; overflow:hidden; border:1px solid var(--line); background:#000; }
.svc-detail-img img { width:100%; height:100%; object-fit:cover; display:block; }

/* === STORY (image + text) === */
.story {
  background:var(--alt); padding:80px 32px;
  display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:start;
  max-width:1180px; margin:0 auto;
}
.story > div:not(.story-img) { padding-top:8px; }
.story-inner { max-width:1280px; margin:0 auto; display:contents; }
@media (max-width:780px) { .story { grid-template-columns:1fr; gap:32px; padding:56px 24px; } }
.story-img {
  aspect-ratio:9/14; border-radius:4px; overflow:hidden;
  border:1px solid var(--line); background:#000; max-height:760px;
}
.story-img img { width:100%; height:100%; object-fit:cover; object-position:center 18%; display:block; }
@media (max-width:780px) { .story-img { aspect-ratio:5/6; max-height:560px; } }
.story h2 {
  font-family:var(--font-d); font-weight:900;
  font-size:clamp(1.9rem, 3.6vw, 2.8rem); line-height:0.98;
  color:var(--ink); margin:0 0 20px; letter-spacing:-0.005em; text-transform:uppercase;
}
.story h2 em {
  font-family:var(--font-serif); font-style:italic; font-weight:400;
  color:var(--em); text-transform:none; font-size:0.88em;
}
.story p {
  font-family:var(--font-s); color:var(--ink); font-size:15.5px;
  margin:0 0 14px; line-height:1.7;
}
.story-quote {
  margin-top:24px; padding-top:24px; border-top:1px solid var(--line);
  font-family:var(--font-serif); font-style:italic; font-size:18px;
  color:var(--ink); line-height:1.5;
}
.story-quote-attr {
  display:block; margin-top:14px; font-family:var(--font-s);
  font-style:normal; font-size:10.5px; letter-spacing:0.2em;
  text-transform:uppercase; color:var(--em); font-weight:700;
}

/* === CUSTOM BUILDS HERO (split layout per Drew) === */
.builds-hero {
  display:grid; grid-template-columns:1.1fr 1fr; gap:48px; align-items:start;
  padding:32px 32px 64px; max-width:1280px; margin:0 auto; background:var(--bg);
}
.builds-hero > div:first-child { padding-top:48px; }
@media (max-width:920px) { .builds-hero { grid-template-columns:1fr; gap:36px; padding:64px 24px 48px; } }
.builds-hero-img {
  aspect-ratio:4/5; border-radius:4px; overflow:hidden;
  border:1px solid var(--line); background:#000;
}
.builds-hero-img img { width:100%; height:100%; object-fit:cover; display:block; }
.builds-hero h1 {
  font-family:var(--font-d); font-weight:900;
  font-size:clamp(1.9rem, 3.8vw, 3rem); line-height:1.05;
  letter-spacing:-0.005em; margin:0 0 24px; color:var(--ink); text-transform:uppercase;
}
.builds-hero h1 em {
  font-family:var(--font-serif); font-style:italic; font-weight:400;
  color:var(--em); text-transform:none; letter-spacing:-0.01em; font-size:0.86em;
}
.builds-hero p.sub {
  font-family:var(--font-s); color:var(--sub); font-size:15.5px;
  max-width:62ch; line-height:1.65; margin:0 0 32px;
}

/* === BUILD CATEGORY CARDS === */
.build-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:28px; padding-top:40px; border-top:1px solid var(--line); }
@media (max-width:780px) { .build-grid { grid-template-columns:1fr; } }
.build-card .build-num {
  font-family:var(--font-serif); font-style:italic; font-size:14px;
  color:var(--em); margin-bottom:10px; font-weight:500;
}
.build-card h4 {
  font-family:var(--font-d); font-size:19px; font-weight:800;
  color:var(--ink); margin:0 0 12px; letter-spacing:0.02em; text-transform:uppercase;
}
.build-card p { font-family:var(--font-s); font-size:13.5px; color:var(--sub); line-height:1.65; margin:0; }

/* === PROCESS STEPS === */
.process-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:28px; padding-top:40px; border-top:1px solid var(--line); }
@media (max-width:780px) { .process-grid { grid-template-columns:1fr 1fr; gap:22px; } }
@media (max-width:480px) { .process-grid { grid-template-columns:1fr; } }
.process-step .process-num {
  font-family:var(--font-serif); font-style:italic; color:var(--em);
  font-size:13px; margin-bottom:8px; font-weight:500;
}
.process-step h4 {
  font-family:var(--font-d); font-size:17px; font-weight:800;
  color:var(--ink); margin:0 0 10px; letter-spacing:0.02em; text-transform:uppercase;
}
.process-step p { font-family:var(--font-s); font-size:13.5px; color:var(--sub); line-height:1.65; margin:0; }

/* === GALLERY (custom builds) === */
.gallery { display:grid; grid-template-columns:repeat(3, 1fr); gap:14px; margin-top:40px; }
@media (max-width:780px) { .gallery { grid-template-columns:1fr 1fr; } }
@media (max-width:480px) { .gallery { grid-template-columns:1fr; } }
.gallery-item { aspect-ratio:4/3; overflow:hidden; border-radius:3px; background:#000; border:1px solid var(--line); }
.gallery-item img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .35s ease; }
.gallery-item:hover img { transform:scale(1.04); }

/* === PULL QUOTE === */
.pull { padding:80px 32px; text-align:center; background:var(--alt); }
.pull blockquote {
  font-family:var(--font-serif); font-style:italic;
  font-size:clamp(1.6rem, 3vw, 2.2rem); line-height:1.3;
  color:var(--ink); margin:0; max-width:34ch; margin-left:auto; margin-right:auto;
}
.pull .pull-attr {
  display:block; margin-top:20px; font-family:var(--font-s);
  font-style:normal; font-size:11px; letter-spacing:0.22em;
  text-transform:uppercase; color:var(--em); font-weight:700;
}

/* === CREDS (About) === */
.creds { padding:80px 32px; background:var(--bg); }
.creds-inner { max-width:780px; margin:0 auto; }
.creds h2 {
  font-family:var(--font-d); font-weight:900;
  font-size:clamp(1.7rem, 3vw, 2.4rem); line-height:1;
  color:var(--ink); margin:0 0 24px; letter-spacing:-0.005em; text-transform:uppercase;
}
.creds h2 em {
  font-family:var(--font-serif); font-style:italic; font-weight:400;
  color:var(--em); text-transform:none; font-size:0.88em;
}
.creds p {
  font-family:var(--font-s); font-size:15.5px; color:var(--ink);
  line-height:1.75; margin:0 0 20px;
}
.creds .codes { display:flex; flex-wrap:wrap; gap:9px; margin:16px 0 24px; }
.creds .codes span {
  font-family:var(--font-d); font-size:12px; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--sub);
  border:1px solid var(--line); padding:6px 12px; border-radius:2px;
}

/* === CONTACT === */
.contact-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:56px;
  padding:80px 32px; max-width:1080px; margin:0 auto; background:var(--bg);
}
@media (max-width:780px) { .contact-grid { grid-template-columns:1fr; gap:36px; padding:56px 24px; } }
.contact-info dl { display:grid; grid-template-columns:auto 1fr; gap:18px 28px; margin:0; }
.contact-info dt {
  font-family:var(--font-s); font-size:10.5px; letter-spacing:0.22em;
  text-transform:uppercase; color:var(--trust-label); font-weight:700; padding-top:3px;
}
.contact-info dd { font-family:var(--font-s); font-size:15.5px; color:var(--ink); margin:0; line-height:1.6; }
.contact-info dd .small { font-size:13px; color:var(--sub); display:block; margin-top:2px; }
.form { background:var(--alt); padding:36px 32px; border-radius:4px; border:1px solid var(--line); }
.form h3 {
  font-family:var(--font-d); font-size:20px; font-weight:800;
  color:var(--ink); margin:0 0 24px; letter-spacing:0.02em; text-transform:uppercase;
}
.form-row { margin-bottom:18px; }
.form-row label {
  display:block; font-family:var(--font-s); font-size:10.5px;
  letter-spacing:0.18em; text-transform:uppercase; color:var(--trust-label);
  font-weight:700; margin-bottom:7px;
}
.form-row input, .form-row select, .form-row textarea {
  width:100%; background:var(--bg); border:1px solid var(--line);
  border-radius:2px; padding:12px 14px; font-family:var(--font-s);
  font-size:14.5px; color:var(--ink); min-height:44px;
}
.form-row textarea { min-height:100px; resize:vertical; }
.form button.btn-p { width:100%; margin-top:8px; }

/* === SECTION CLOSE / CTA BANNER === */
.cta-band {
  background:var(--cta-bg); color:var(--cta-fg);
  padding:80px 32px; text-align:center;
}
.cta-band .kicker { color:rgba(214,214,203,0.65); }
.cta-band h2 {
  font-family:var(--font-d); font-weight:900;
  font-size:clamp(1.9rem, 3.6vw, 2.8rem); line-height:0.98;
  color:var(--cta-fg); margin:0 auto 18px; max-width:24ch;
  letter-spacing:-0.005em; text-transform:uppercase;
}
.cta-band h2 em {
  font-family:var(--font-serif); font-style:italic; font-weight:400;
  color:#D6D6CB; text-transform:none; font-size:0.88em;
}
.cta-band p {
  font-family:var(--font-s); font-size:15px; color:rgba(214,214,203,0.85);
  max-width:56ch; margin:0 auto 28px;
}
.cta-band .btn-close {
  background:#24241B; color:#D6D6CB;
  border:1.5px solid #D6D6CB;
}
.cta-band .btn-close:hover { background:#1A1A12; }

/* === FOOTER === */
.footer {
  background:var(--alt); padding:48px 32px 24px;
  border-top:1px solid var(--line);
}
.footer-inner {
  max-width:1280px; margin:0 auto;
  display:grid; grid-template-columns:1fr auto auto; gap:32px; align-items:start;
}
@media (max-width:780px) { .footer-inner { grid-template-columns:1fr; gap:24px; } }
.footer-brand img { height:42px; width:auto; filter:invert(1); display:block; margin-bottom:12px; opacity:0.92; }
.footer-brand .footer-tag {
  font-family:var(--font-serif); font-style:italic; font-size:13.5px;
  color:var(--sub); margin:6px 0 0;
}
.footer-col h4 {
  font-family:var(--font-d); font-size:11px; letter-spacing:0.22em;
  text-transform:uppercase; color:var(--trust-label); margin:0 0 12px; font-weight:700;
}
.footer-col p, .footer-col a {
  font-family:var(--font-s); font-size:13px; color:var(--ink);
  line-height:1.6; margin:0 0 6px; text-decoration:none; display:block;
}
.footer-col a:hover { color:var(--em); }
.footer-bottom {
  max-width:1280px; margin:32px auto 0; padding-top:20px;
  border-top:1px solid var(--line);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  font-family:var(--font-s); font-size:11px; color:var(--sub);
}

.gallery-sage { background-image: url("../images/rifle-sage.jpg"); background-size: cover; background-position: center; transition: transform .35s ease; }
.gallery-sage:hover { transform: scale(1.04); }

.fb-icon { display:inline-flex; align-items:center; padding:6px 0; color:var(--ink); transition:color .18s; }
.fb-icon:hover { color:var(--em); }

@media (max-width:780px) {
  .story {
    display:flex; flex-direction:column; justify-content:flex-end;
    padding:0; min-height:80vh; position:relative;
    background:transparent; overflow:hidden;
  }
  .story-img {
    position:absolute; inset:0; width:100%; height:100%;
    aspect-ratio:auto; max-height:none; border:none; border-radius:0;
    z-index:0;
  }
  .story-img img { object-position:center 18%; }
  .story-img::after {
    content:""; position:absolute; inset:0;
    background:linear-gradient(180deg, rgba(26,26,18,0.32) 0%, rgba(26,26,18,0.78) 70%, rgba(26,26,18,0.96) 100%);
  }
  .story > div:not(.story-img) {
    position:relative; z-index:2;
    padding:64px 24px 48px;
    color:var(--ink);
  }
  .story h2 { color:#F4EDD8; text-shadow:0 2px 16px rgba(0,0,0,0.55); }
  .story p { color:var(--ink); text-shadow:0 1px 10px rgba(0,0,0,0.45); }
  .story-quote { border-top-color:rgba(232,220,196,0.28); }
}

/* R2: Brighten home + contact heros, drop image, raise text */
body.home .hero::before {
  filter:brightness(0.72) saturate(0.92);
  background-position:center 70%;
}
body.page-contact .hero::before {
  filter:brightness(0.7) saturate(0.92);
}
.hero.hero-home::after, .hero.hero-contact::after {
  background:
    linear-gradient(180deg, rgba(26,26,18,0.55) 0%, rgba(26,26,18,0.4) 35%, rgba(26,26,18,0.5) 70%, rgba(26,26,18,0.85) 100%),
    linear-gradient(90deg, rgba(26,26,18,0.45) 0%, rgba(26,26,18,0.12) 50%, rgba(26,26,18,0.35) 100%);
}
body.home .hero {
  align-items:flex-start; min-height:78vh; padding-top:96px; padding-bottom:130px;
}
@media (max-width:780px) {
  body.home .hero { padding-top:64px; padding-bottom:80px; }
}

.accuracy-inner { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
@media (max-width:780px) { .accuracy-inner { grid-template-columns:1fr; gap:28px; } }
.accuracy-target {
  aspect-ratio:3/4; max-width:480px; width:100%; justify-self:center;
  border:1px solid var(--line); border-radius:4px; overflow:hidden;
  background:#000;
}
.accuracy-target img { width:100%; height:100%; object-fit:cover; display:block; }

.katie-block { margin-top:56px; padding-top:40px; border-top:1px solid var(--line); }
.katie-block .kicker { color:var(--trust-label); margin-bottom:10px; }
.katie-name {
  font-family:var(--font-d); font-weight:900;
  font-size:clamp(1.4rem, 2.4vw, 1.8rem); line-height:1.05;
  color:var(--ink); margin:0 0 14px; letter-spacing:-0.003em; text-transform:uppercase;
}
.katie-name em {
  font-family:var(--font-serif); font-style:italic; font-weight:400;
  color:var(--em); text-transform:none; font-size:0.88em;
}
.katie-block p {
  font-family:var(--font-s); font-size:15px; color:var(--ink);
  line-height:1.7; margin:0;
}

/* ===========================================================================
 * v1.0.2 refinements — bundled additions
 * =========================================================================== */

/* --- Service cards now <a class="svc-card-link"> — reset link defaults, lift on hover --- */
a.svc-card-link {
  text-decoration:none; color:inherit;
  cursor:pointer;
}
.svc-grid .svc.svc-card-link {
  transition: background .25s ease, transform .25s ease;
}
.svc-grid .svc.svc-card-link:hover {
  background:rgba(58, 58, 42, 0.6);
  transform:translateY(-2px);
}
.svc-grid .svc.svc-card-link:focus-visible {
  outline:2.5px solid var(--accent); outline-offset:-3px;
}
/* The inner "See what's in stock →" is now a <span> not <a> — keep matching visuals */
.svc-grid .svc.svc-card-link .svc-link {
  pointer-events:none; /* let card click handle navigation; no double-trigger */
}
.svc-grid .svc.svc-card-link:hover .svc-link {
  color:var(--accent); transform:translateX(3px);
}

/* --- Build-card title (was h4, now h3) and process-step title (was h4, now h3) ---
 * Preserve original visual style. */
.build-card-title {
  font-family:var(--font-d); font-size:19px; font-weight:800;
  color:var(--ink); margin:0 0 12px; letter-spacing:0.02em; text-transform:uppercase;
}
.process-step-title {
  font-family:var(--font-d); font-size:17px; font-weight:800;
  color:var(--ink); margin:0 0 10px; letter-spacing:0.02em; text-transform:uppercase;
}

/* --- Footer column headers (h4 → h3) preserve original look --- */
.footer-col h3 {
  font-family:var(--font-d); font-size:11px; letter-spacing:0.22em;
  text-transform:uppercase; color:var(--trust-label); margin:0 0 12px; font-weight:700;
}

/* --- Contrast fixes (WCAG AA) --- */
/* .cta-band kicker — translucent ink on red failed AA. Use solid ink at full opacity. */
.cta-band .kicker { color:#F4EDD8; opacity:0.9; }
.cta-band p { color:#F4EDD8; opacity:0.96; }

/* .soon-pill — red on dark failed AA. Switch to tan-em which passes. */
.soon-pill {
  color:var(--em);
  border-color:var(--em);
  background:rgba(173, 156, 121, 0.08);
}

/* --- CTA padding (v23): horizontal 27px settled final --- */
/* (Applied above to .nav-cta — this block is documentation marker.) */

/* --- LCP image hints helper: hero <img> with fetchpriority if templates ever switch from CSS bg --- */
.hero img.hero-img {
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;
}

/* --- Build cards layout safety with new h3 inside --- */
.build-card h3.build-card-title { font-size:19px; }
.process-step h3.process-step-title { font-size:17px; }

/* --- Body.page-home equivalent for older selectors; WP adds body.home automatically --- */
/* No changes — body.home already in main flow. body.page-{slug} now added by v1.0.2 body_class filter. */

/* --- Custom Builds page now uses .hero pattern (not .builds-hero). Old .builds-hero rules
 *      remain in this file as dead CSS — kept for backward safety if any cached page exists. --- */

/* --- Service Showroom detail body — Drew v26 sentence swap is in page-services.php, no CSS change --- */
