/* QP Plumbing — site styles. Ported from the claude.ai design tokens. */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
  --qp-navy: #0f1e33; --qp-navy-700: #16294a; --qp-navy-500: #2a3f63;
  --qp-navy-300: #6b7a95; --qp-navy-100: #d6dce6; --qp-navy-50: #eef1f6;
  --qp-white: #ffffff; --qp-paper: #fafafa; --qp-stone-100: #f2f2f0;
  --qp-stone-200: #e5e5e2; --qp-stone-400: #a8a8a3; --qp-stone-700: #4a4a47;
  --qp-ink: #111315; --qp-steel: #5a6b80; --qp-zinc: #b8bdc5; --qp-amber: #c08a3e;
  --qp-bg: var(--qp-paper); --qp-fg: var(--qp-ink); --qp-fg-muted: var(--qp-stone-700);
  --qp-fg-subtle: var(--qp-stone-400); --qp-border: var(--qp-stone-200);
  --qp-border-strong: var(--qp-navy-100);
  --qp-font: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --qp-ease: cubic-bezier(.2,.6,.2,1);
  --qp-gutter: clamp(20px, 3vw, 40px);
  --qp-shadow-1: 0 1px 2px rgba(15,30,51,.06), 0 1px 1px rgba(15,30,51,.04);
  --qp-shadow-2: 0 2px 4px rgba(15,30,51,.08), 0 4px 12px rgba(15,30,51,.05);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; font-family: var(--qp-font); font-size: 16px; line-height: 1.55;
  color: var(--qp-fg); background: var(--qp-bg);
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
img, video { max-width: 100%; display: block; }
a { color: inherit; }
.container { max-width: 1400px; margin: 0 auto; padding-left: var(--qp-gutter); padding-right: var(--qp-gutter); }

.eyebrow {
  font-size: 12px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase;
  color: var(--qp-navy-300); display: inline-flex; align-items: center; gap: 10px;
}
.eyebrow::before { content: ''; width: 24px; height: 1px; background: currentColor; opacity: .6; }
.eyebrow--light { color: rgba(255,255,255,.65); }

.h-display { font-weight: 800; letter-spacing: -.025em; line-height: 1.04; color: var(--qp-ink); margin: 0; text-wrap: balance; }
.lead { font-size: 19px; line-height: 1.55; color: var(--qp-fg-muted); text-wrap: pretty; }

.btn {
  font-family: inherit; font-size: 14px; font-weight: 600; letter-spacing: .015em;
  padding: 14px 22px; border-radius: 4px; cursor: pointer; border: 1px solid transparent;
  transition: all 160ms var(--qp-ease); display: inline-flex; align-items: center; gap: 8px;
  white-space: nowrap; text-decoration: none;
}
.btn--primary { background: var(--qp-navy); color: #fff; }
.btn--primary:hover { background: var(--qp-navy-700); }
.btn--invert { background: #fff; color: var(--qp-navy); }
.btn--invert:hover { background: rgba(255,255,255,.92); }
.btn--outline-light { background: transparent; color: #fff; border-color: rgba(255,255,255,.4); }
.btn--outline-light:hover { background: rgba(255,255,255,.10); }
.btn--ghost-light { background: transparent; color: #fff; padding: 14px 4px; opacity: .85; }
.btn--ghost-light:hover { opacity: 1; }

.link-underline {
  font-size: 13px; font-weight: 600; color: var(--qp-navy); text-decoration: none;
  border-bottom: 1px solid var(--qp-amber); padding-bottom: 4px;
  letter-spacing: .04em; text-transform: uppercase; display: inline-block;
}

/* ── Nav ── */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(250,250,250,.92);
  backdrop-filter: blur(14px) saturate(140%); -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--qp-border);
  transition: background 240ms var(--qp-ease), border-color 240ms var(--qp-ease);
}
.nav--inverted { background: transparent; border-bottom-color: transparent; color: #fff; backdrop-filter: none; -webkit-backdrop-filter: none; position: fixed; left: 0; right: 0; }
.nav--inverted.is-scrolled { background: rgba(15,30,51,.94); border-bottom-color: rgba(255,255,255,.08); backdrop-filter: blur(14px) saturate(140%); -webkit-backdrop-filter: blur(14px) saturate(140%); }
.nav__inner { max-width: 1400px; margin: 0 auto; padding: 14px var(--qp-gutter); display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.nav__brand { display: flex; align-items: center; gap: 14px; text-decoration: none; color: inherit; }
.nav__brand img { width: 40px; height: 40px; }
.nav--inverted .nav__brand img, .footer .footer__logo { filter: brightness(0) invert(1); }
.nav__brand-name { font-size: 11px; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; opacity: .78; display: block; line-height: 1.2; }
.nav__brand-sub { font-size: 12px; opacity: .55; letter-spacing: .02em; display: block; line-height: 1.2; }
.nav__links { display: flex; align-items: center; gap: 32px; }
.nav__link { font-size: 14px; font-weight: 500; letter-spacing: .01em; color: inherit; text-decoration: none; opacity: .7; position: relative; padding: 4px 0; transition: opacity 160ms var(--qp-ease); }
.nav__link:hover { opacity: 1; }
.nav__link.is-active { opacity: 1; }
.nav__link.is-active::after { content: ''; position: absolute; left: 0; right: 0; bottom: -6px; height: 2px; background: var(--qp-amber); }
.nav__phone { font-size: 13px; font-weight: 600; letter-spacing: .02em; color: inherit; text-decoration: none; border: 1px solid var(--qp-navy); padding: 9px 16px; border-radius: 4px; transition: all 160ms var(--qp-ease); }
.nav__phone:hover { background: var(--qp-navy); color: #fff; }
.nav--inverted .nav__phone { border-color: rgba(255,255,255,.35); }
.nav--inverted .nav__phone:hover { background: rgba(255,255,255,.08); color: #fff; }
.nav__toggle { display: none; background: none; border: none; cursor: pointer; padding: 8px; color: inherit; }
.nav__toggle svg { display: block; }

/* ── Hero (home) ── */
.hero { position: relative; min-height: 92vh; background: var(--qp-navy); color: #fff; overflow: hidden; }
.hero__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; }
.hero__shade { position: absolute; inset: 0; pointer-events: none; background: linear-gradient(120deg, rgba(15,30,51,.78) 0%, rgba(15,30,51,.55) 55%, rgba(15,30,51,.25) 100%); }
.hero__glow { position: absolute; inset: 0; pointer-events: none; background: radial-gradient(70% 60% at 80% 100%, rgba(192,138,62,.15), transparent 65%); }
.hero__inner { position: relative; max-width: 1400px; margin: 0 auto; padding: 180px var(--qp-gutter) 72px; display: flex; flex-direction: column; min-height: 92vh; justify-content: space-between; }
.hero h1 { font-size: clamp(44px, 8vw, 120px); font-weight: 800; letter-spacing: -.028em; line-height: .96; margin: 32px 0 0; max-width: 1200px; text-wrap: balance; color: #fff; }
.hero h1 .dim { color: rgba(255,255,255,.55); }
.hero__sub { font-size: clamp(17px, 1.3vw, 21px); line-height: 1.5; color: rgba(255,255,255,.82); max-width: 580px; margin-top: 40px; }
.hero__ctas { display: flex; gap: 14px; margin-top: 44px; flex-wrap: wrap; }
.hero__strip { display: flex; align-items: center; justify-content: space-between; margin-top: 64px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.18); flex-wrap: wrap; gap: 16px; }
.hero__stats { display: flex; gap: 48px; flex-wrap: wrap; align-items: center; }
.hero-stat__label { font-size: 11px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; opacity: .55; }
.hero-stat__value { font-size: 22px; font-weight: 700; letter-spacing: -.005em; margin-top: 6px; }
.hero__scroll { display: flex; align-items: center; gap: 12px; opacity: .7; font-size: 11px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; }
.hero__scroll::after { content: ''; width: 32px; height: 1px; background: rgba(255,255,255,.5); }

/* ── Stats strip ── */
.stats { background: #fff; border-bottom: 1px solid var(--qp-border); }
.stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; padding-top: 56px; padding-bottom: 56px; }
.stat { border-left: 1px solid var(--qp-border); padding-left: 32px; }
.stat:first-child { border-left: none; padding-left: 0; }
.stat__num { font-size: clamp(40px, 4vw, 56px); font-weight: 800; letter-spacing: -.025em; color: var(--qp-navy); line-height: .95; font-variant-numeric: tabular-nums; }
.stat__label { font-size: 14px; color: var(--qp-ink); margin-top: 14px; font-weight: 600; letter-spacing: .01em; }
.stat__sub { font-size: 12px; color: var(--qp-fg-subtle); margin-top: 4px; }

/* ── Approach ── */
.approach { background: var(--qp-paper); padding: 128px 0; }
.approach__grid { display: grid; grid-template-columns: 1fr 1.6fr; gap: clamp(32px, 6vw, 96px); align-items: start; }
.approach__sticky { position: sticky; top: 96px; }
.approach h2 { font-size: clamp(36px, 5vw, 68px); }
.approach h2 .amber { color: var(--qp-amber); }
.approach__lead { font-size: 21px; line-height: 1.5; color: var(--qp-fg-muted); margin-top: 32px; max-width: 640px; }
.approach__steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; margin-top: 64px; }
.step__num { font-size: 13px; font-weight: 700; color: var(--qp-amber); letter-spacing: .18em; }
.step__title { font-size: 17px; font-weight: 700; color: var(--qp-ink); margin-top: 12px; letter-spacing: -.005em; }
.step__body { font-size: 14px; line-height: 1.6; color: var(--qp-fg-muted); margin: 8px 0 0; }

/* ── Section scaffolding ── */
.section { padding: 128px 0; }
.section--white { background: #fff; }
.section--paper { background: var(--qp-paper); }
.section--navy { background: var(--qp-navy); color: #fff; position: relative; overflow: hidden; }
.section-head { margin-bottom: 56px; }
.section-head h2 { font-size: clamp(34px, 4.6vw, 60px); font-weight: 800; letter-spacing: -.022em; line-height: 1.04; margin: 20px 0 0; }
.section--navy .section-head h2 { color: #fff; }
.section-head .sub { font-size: 19px; line-height: 1.55; color: var(--qp-fg-muted); margin-top: 20px; max-width: 620px; text-wrap: pretty; }
.section--navy .section-head .sub { color: rgba(255,255,255,.78); }
.section-head--row { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 24px; }
.amber { color: var(--qp-amber); }

/* ── Media / cards ── */
.media { position: relative; width: 100%; overflow: hidden; background: var(--qp-navy-700); }
.media img, .media video { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; }
.media__label { position: absolute; left: 0; right: 0; bottom: 0; padding: 20px 22px 18px; background: linear-gradient(0deg, rgba(15,30,51,.65) 0%, rgba(15,30,51,0) 100%); display: flex; align-items: flex-end; justify-content: space-between; gap: 12px; pointer-events: none; z-index: 2; }
.media__label span { font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.85); }
.ar-16-10 { aspect-ratio: 16/10; } .ar-4-3 { aspect-ratio: 4/3; } .ar-21-9 { aspect-ratio: 21/9; } .ar-1-1 { aspect-ratio: 1/1; }

.project-card { position: relative; display: block; background: #fff; border: 1px solid var(--qp-border); border-radius: 8px; overflow: hidden; text-decoration: none; color: inherit; box-shadow: var(--qp-shadow-1); transition: box-shadow 240ms var(--qp-ease); }
.project-card:hover { box-shadow: var(--qp-shadow-2); }
.project-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--qp-amber); transform: scaleX(0); transform-origin: left; transition: transform 240ms var(--qp-ease); z-index: 3; }
.project-card:hover::before { transform: scaleX(1); }
.project-card .media { transition: transform 480ms var(--qp-ease); }
.project-card:hover .media { transform: scale(1.025); }
.project-card__body { padding: 20px 22px 24px; }
.project-card__top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.project-card__year { font-size: 12px; color: var(--qp-fg-subtle); font-variant-numeric: tabular-nums; letter-spacing: .04em; }
.project-card__title { font-size: 19px; font-weight: 700; letter-spacing: -.012em; margin: 0 0 8px; color: var(--qp-ink); line-height: 1.25; text-wrap: balance; }
.project-card__meta { font-size: 13px; color: var(--qp-fg-subtle); letter-spacing: .01em; }

.feature { display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items: center; text-decoration: none; color: inherit; }
.feature--reverse { direction: rtl; }
.feature > * { direction: ltr; }
.feature .media-wrap { overflow: hidden; }
.feature .media { transition: transform 600ms var(--qp-ease); }
.feature:hover .media { transform: scale(1.015); }
.feature h3 { font-size: clamp(28px, 3vw, 40px); font-weight: 800; letter-spacing: -.02em; line-height: 1.08; margin: 18px 0 16px; color: var(--qp-ink); text-wrap: balance; }
.feature p { font-size: 17px; line-height: 1.55; color: var(--qp-fg-muted); margin: 0; text-wrap: pretty; }
.feature__facts { margin-top: 28px; display: flex; flex-wrap: wrap; gap: 14px 28px; }
.fact__k { font-size: 10px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--qp-navy-300); }
.fact__v { font-size: 14px; color: var(--qp-ink); margin-top: 4px; font-weight: 500; }
.feature .link-underline { margin-top: 32px; }

/* ── Capabilities preview (navy) ── */
.cap-preview__grid { display: grid; grid-template-columns: 1.1fr 1.6fr; gap: clamp(32px, 6vw, 96px); align-items: start; position: relative; }
.cap-preview__cells { display: grid; grid-template-columns: 1fr 1fr; }
.cap-cell { padding: 32px 28px; border-top: 1px solid rgba(255,255,255,.12); }
.cap-cell:nth-child(even) { border-left: 1px solid rgba(255,255,255,.12); }
.cap-cell h4 { font-size: 28px; font-weight: 700; letter-spacing: -.015em; margin: 0 0 12px; color: #fff; }
.cap-cell p { font-size: 14px; line-height: 1.6; color: rgba(255,255,255,.7); margin: 0; }
.section--navy .glow-tr { position: absolute; inset: 0; background: radial-gradient(70% 60% at 100% 0%, rgba(192,138,62,.08), transparent 60%); pointer-events: none; }

/* ── Reel ── */
.reel { display: grid; grid-template-columns: 2fr 1fr; gap: 20px; }
.reel__side { display: grid; grid-template-rows: 1fr 1fr; gap: 20px; }
.reel .media { height: 100%; }

/* ── Builders ── */
.builders { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--qp-border); }
.builders__cell { padding: 36px 18px; min-height: 120px; border-right: 1px solid var(--qp-border); border-bottom: 1px solid var(--qp-border); display: flex; align-items: center; justify-content: center; text-align: center; }
.builders__cell:nth-child(4n) { border-right: none; }
.builders__cell:nth-child(n+5) { border-bottom: none; }
.builders__cell span { font-size: 19px; font-weight: 700; letter-spacing: -.005em; color: var(--qp-navy); opacity: .78; line-height: 1.2; text-wrap: balance; }

/* ── CTA ── */
.cta-block { max-width: 1200px; margin: 0 auto; background: var(--qp-navy); color: #fff; padding: clamp(48px, 7vw, 96px); position: relative; overflow: hidden; border-radius: 8px; }
.cta-block__glow { position: absolute; inset: 0; background: radial-gradient(50% 80% at 100% 50%, rgba(192,138,62,.18), transparent 70%); }
.cta-block__grid { position: relative; display: grid; grid-template-columns: 1.4fr 1fr; gap: 64px; align-items: center; }
.cta-block h2 { font-size: clamp(36px, 5vw, 64px); font-weight: 800; letter-spacing: -.025em; line-height: 1.04; margin: 20px 0 0; text-wrap: balance; max-width: 700px; color: #fff; }
.cta-block .sub { font-size: 18px; line-height: 1.55; color: rgba(255,255,255,.78); margin-top: 24px; max-width: 540px; }
.cta-block__side { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; }
.cta-block__call { font-size: 14px; color: rgba(255,255,255,.75); text-decoration: none; margin-top: 8px; }
.cta-block__call strong { color: #fff; font-weight: 600; }

/* ── Page headers ── */
.page-head { background: #fff; padding: 152px 0 56px; border-bottom: 1px solid var(--qp-border); }
.page-head h1 { font-size: clamp(44px, 7vw, 104px); font-weight: 800; letter-spacing: -.028em; line-height: .98; margin: 20px 0 0; color: var(--qp-ink); text-wrap: balance; }
.page-head__row { display: grid; grid-template-columns: 1.4fr 1fr; gap: 64px; margin-top: 40px; align-items: end; }
.page-head__row .lead { margin: 0; max-width: 720px; }

/* ── Work index ── */
.filters { background: #fff; border-bottom: 1px solid var(--qp-border); position: sticky; top: 69px; z-index: 10; }
.filters__row { display: flex; align-items: center; gap: 4px; overflow-x: auto; }
.filter-btn { background: transparent; border: none; cursor: pointer; font-family: inherit; font-size: 14px; font-weight: 600; letter-spacing: .01em; padding: 20px; color: var(--qp-fg-subtle); border-bottom: 2px solid transparent; display: flex; align-items: center; gap: 8px; white-space: nowrap; transition: color 160ms var(--qp-ease); }
.filter-btn.is-active { color: var(--qp-navy); border-bottom-color: var(--qp-amber); }
.filter-btn .count { font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: 999px; background: var(--qp-navy-50); color: var(--qp-navy-300); font-variant-numeric: tabular-nums; }
.filter-btn.is-active .count { background: var(--qp-navy); color: #fff; }
.work-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }

/* ── Project detail ── */
.detail-hero { background: var(--qp-navy); padding-top: 69px; }
.detail-hero .media { aspect-ratio: 21/9; min-height: 320px; }
.detail-title { background: #fff; padding: 80px 0 64px; border-bottom: 1px solid var(--qp-border); }
.back-link { font-size: 13px; color: var(--qp-fg-subtle); text-decoration: none; letter-spacing: .04em; }
.back-link:hover { color: var(--qp-navy); }
.detail-title__grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: clamp(32px, 6vw, 96px); margin-top: 24px; align-items: end; }
.detail-title h1 { font-size: clamp(36px, 5vw, 76px); font-weight: 800; letter-spacing: -.025em; line-height: 1.02; margin: 20px 0 0; color: var(--qp-ink); text-wrap: balance; }
.detail-title .lead { margin: 0; }
.spec { background: #fff; padding-bottom: 80px; }
.spec__grid { display: grid; grid-template-columns: repeat(5, 1fr); border-top: 1px solid var(--qp-border); }
.spec__cell { padding: 32px 28px 32px 0; }
.spec__cell + .spec__cell { padding-left: 32px; border-left: 1px solid var(--qp-border); }
.spec__k { font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--qp-navy-300); }
.spec__v { font-size: 17px; font-weight: 600; color: var(--qp-ink); margin-top: 10px; }
.scope { padding: 96px 0; }
.scope__grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: clamp(32px, 6vw, 96px); align-items: start; }
.scope__copy { font-size: 18px; line-height: 1.65; color: var(--qp-fg-muted); }
.scope__copy p { margin: 24px 0 0; }
.scope__note { color: var(--qp-fg-subtle); font-style: italic; }
.materials ul { list-style: none; padding: 0; margin: 24px 0 0; }
.materials li { font-size: 15px; padding: 14px 0; border-bottom: 1px solid var(--qp-border); color: var(--qp-ink); display: flex; align-items: center; gap: 12px; }
.materials li::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--qp-amber); flex-shrink: 0; }
.gallery-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 56px; }
.gallery-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 20px; }
.gallery-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 20px; }
.gallery-video { margin-top: 20px; }
.gallery-video--narrow { max-width: 900px; margin-inline: auto; }
.gallery-video video { width: 100%; height: auto; display: block; }
.next-project { background: var(--qp-navy); color: #fff; display: block; text-decoration: none; padding: 96px 0; }
.next-project__grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 64px; align-items: center; }
.next-project h3 { font-size: clamp(28px, 3.5vw, 48px); font-weight: 800; letter-spacing: -.02em; line-height: 1.05; margin: 18px 0 0; color: #fff; max-width: 500px; }
.next-project .meta { margin-top: 16px; font-size: 14px; color: rgba(255,255,255,.65); }

/* ── Capabilities page ── */
.cap-group { display: grid; grid-template-columns: 1fr 1.8fr; gap: clamp(32px, 5vw, 64px); padding: 80px 0; border-top: 1px solid var(--qp-border); align-items: start; }
.cap-group:first-child { border-top: none; padding-top: 0; }
.cap-group__sticky { position: sticky; top: 96px; }
.cap-group__num { font-size: 14px; font-weight: 700; color: var(--qp-amber); letter-spacing: .18em; }
.cap-group h2 { font-size: clamp(32px, 4vw, 52px); font-weight: 800; letter-spacing: -.022em; line-height: 1.04; margin: 14px 0 0; color: var(--qp-ink); }
.cap-group__blurb { font-size: 16px; line-height: 1.6; color: var(--qp-fg-muted); margin-top: 16px; max-width: 360px; }
.cap-item { display: grid; grid-template-columns: 40px 1fr; gap: 28px; padding: 24px 0; border-top: 1px solid var(--qp-border); }
.cap-item:first-child { border-top: 2px solid var(--qp-navy); }
.cap-item__num { font-family: ui-monospace, Menlo, Consolas, monospace; font-size: 13px; color: var(--qp-fg-subtle); padding-top: 4px; }
.cap-item h4 { font-size: 18px; font-weight: 700; margin: 0; color: var(--qp-ink); letter-spacing: -.005em; }
.cap-item p { font-size: 15px; line-height: 1.6; color: var(--qp-fg-muted); margin: 8px 0 0; }
.tags { display: flex; flex-wrap: wrap; gap: 10px; }
.tags span { font-size: 13px; padding: 8px 14px; border: 1px solid rgba(255,255,255,.2); color: rgba(255,255,255,.88); border-radius: 2px; letter-spacing: .01em; }
.compliance { list-style: none; padding: 0; margin: 0; }
.compliance li { padding: 18px 0; border-top: 1px solid rgba(255,255,255,.12); display: flex; justify-content: space-between; gap: 24px; align-items: baseline; }
.compliance .k { font-size: 15px; font-weight: 600; color: #fff; }
.compliance .v { font-size: 13px; color: rgba(255,255,255,.7); text-align: right; }
.two-col-96 { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 6vw, 96px); margin-top: 64px; }
.col-label { font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: 24px; }

/* ── About ── */
.about-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.about-stat { border-top: 2px solid var(--qp-navy); padding-top: 16px; }
.about-stat__num { font-size: 44px; font-weight: 800; color: var(--qp-navy); letter-spacing: -.025em; line-height: 1; font-variant-numeric: tabular-nums; }
.about-stat__label { font-size: 13px; color: var(--qp-fg-muted); margin-top: 8px; letter-spacing: .01em; }
.kv { display: grid; grid-template-columns: auto 1fr; gap: 14px 20px; font-size: 15px; align-items: baseline; }
.kv .k { color: var(--qp-fg-subtle); }
.kv .v, .kv a { color: var(--qp-ink); text-decoration: none; font-weight: 500; }

/* ── Contact ── */
.contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(32px, 6vw, 96px); }
.contact-facts { margin-top: 56px; display: grid; grid-template-columns: 120px 1fr; gap: 20px 24px; font-size: 16px; align-items: baseline; }
.contact-facts .k { font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--qp-navy-300); }
.contact-facts a { color: var(--qp-ink); text-decoration: none; font-weight: 500; }
.contact-form { background: var(--qp-paper); padding: clamp(28px, 4vw, 48px); border: 1px solid var(--qp-border); border-radius: 8px; align-self: start; }
.contact-form h3 { font-size: 28px; font-weight: 700; letter-spacing: -.015em; margin: 12px 0 0; }
.contact-form .req-note { font-size: 14px; color: var(--qp-fg-muted); margin: 8px 0 28px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.field { display: flex; flex-direction: column; gap: 8px; }
.field--full { grid-column: span 2; }
.field span { font-size: 12px; font-weight: 600; color: var(--qp-fg); letter-spacing: .02em; }
.field input, .field select, .field textarea {
  font-family: inherit; font-size: 15px; padding: 14px; border: 1px solid var(--qp-border-strong);
  border-radius: 4px; background: #fff; color: var(--qp-fg); outline: none; width: 100%;
  transition: border-color 160ms var(--qp-ease);
}
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--qp-navy); }
.field input[type=file] { padding: 12px; border-style: dashed; color: var(--qp-fg-subtle); cursor: pointer; }
.contact-form .btn { margin-top: 28px; width: 100%; justify-content: center; }
.contact-form .alt-note { font-size: 12px; color: var(--qp-fg-subtle); margin-top: 16px; text-align: center; }
.contact-form .alt-note a { color: var(--qp-navy); }
.map-strip__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 6vw, 96px); align-items: center; }
.map-strip h2 { font-size: clamp(28px, 3.5vw, 48px); font-weight: 800; letter-spacing: -.022em; margin: 18px 0 0; line-height: 1.05; color: #fff; }
.map-strip p { font-size: 16px; line-height: 1.6; color: rgba(255,255,255,.75); margin-top: 20px; max-width: 480px; }

/* ── Footer ── */
.footer { background: var(--qp-navy); color: #fff; position: relative; overflow: hidden; }
.footer__glow { position: absolute; inset: 0; background: radial-gradient(60% 50% at 90% 0%, rgba(192,138,62,.06), transparent 70%); pointer-events: none; }
.footer__inner { position: relative; max-width: 1400px; margin: 0 auto; padding: 96px var(--qp-gutter) 28px; }
.footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 56px; margin-bottom: 72px; }
.footer__logo { width: 56px; height: 56px; }
.footer__blurb { font-size: 15px; line-height: 1.55; opacity: .78; margin-top: 24px; max-width: 340px; }
.footer__ctas { display: flex; gap: 12px; margin-top: 28px; }
.footer__col-title { font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; opacity: .5; margin-bottom: 18px; }
.footer__col div, .footer__col a { font-size: 14px; line-height: 1.85; opacity: .88; color: #fff; text-decoration: none; display: block; }
.footer__base { padding-top: 24px; border-top: 1px solid rgba(255,255,255,.10); display: flex; justify-content: space-between; align-items: center; font-size: 12px; opacity: .55; flex-wrap: wrap; gap: 12px; }

/* ── Reveal ── */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity 600ms var(--qp-ease), transform 600ms var(--qp-ease); }
.reveal.is-visible { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  html { scroll-behavior: auto; }
}

/* ── Lightbox ── */
.lightbox { position: fixed; inset: 0; z-index: 100; background: rgba(15,30,51,.96); display: none; align-items: center; justify-content: center; padding: 4vmin; }
.lightbox.is-open { display: flex; }
.lightbox img { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; box-shadow: 0 24px 80px rgba(0,0,0,.5); position: static; }
.lightbox__close { position: absolute; top: 20px; right: 24px; background: none; border: none; color: #fff; font-size: 36px; cursor: pointer; line-height: 1; opacity: .8; }
.lightbox__close:hover { opacity: 1; }
.gallery-2 .media, .gallery-3 .media, .gallery-4 .media { cursor: zoom-in; }

/* ── Responsive ── */
@media (max-width: 1000px) {
  .stats__grid { grid-template-columns: repeat(2, 1fr); }
  .stat:nth-child(odd) { border-left: none; padding-left: 0; }
  .stat:nth-child(even) { border-left: 1px solid var(--qp-border); padding-left: 32px; }
  .approach__grid, .cap-preview__grid, .detail-title__grid, .scope__grid, .cap-group, .contact-grid, .map-strip__grid, .two-col-96, .page-head__row, .cta-block__grid, .next-project__grid { grid-template-columns: 1fr; }
  .approach__sticky, .cap-group__sticky { position: static; }
  .work-grid, .gallery-3 { grid-template-columns: repeat(2, 1fr); }
  .gallery-4 { grid-template-columns: repeat(2, 1fr); }
  .spec__grid { grid-template-columns: repeat(2, 1fr); }
  .spec__cell { padding-left: 0 !important; border-left: none !important; border-top: 1px solid var(--qp-border); }
  .spec__grid { border-top: none; }
  .feature, .feature--reverse { grid-template-columns: 1fr; gap: 28px; }
  .reel { grid-template-columns: 1fr; }
  .reel__side { grid-template-rows: none; grid-template-columns: 1fr 1fr; }
  .reel__side .media { aspect-ratio: 16/10; }
  .builders { grid-template-columns: repeat(2, 1fr); }
  .builders__cell:nth-child(2n) { border-right: none; }
  .builders__cell:nth-child(4n-1), .builders__cell:nth-child(4n) { border-right: 1px solid var(--qp-border); }
  .builders__cell:nth-child(2n) { border-right: none !important; }
  .builders__cell:nth-child(n+5) { border-bottom: 1px solid var(--qp-border); }
  .builders__cell:nth-child(n+7) { border-bottom: none; }
  .footer__grid { grid-template-columns: 1fr 1fr; gap: 40px; }
}
@media (max-width: 760px) {
  .nav__links { display: none; position: absolute; top: 100%; left: 0; right: 0; flex-direction: column; align-items: stretch; gap: 0; background: #fff; border-bottom: 1px solid var(--qp-border); padding: 8px 0; box-shadow: var(--qp-shadow-2); }
  .nav--inverted .nav__links { background: var(--qp-navy); border-bottom-color: rgba(255,255,255,.1); }
  .nav__links.is-open { display: flex; }
  .nav__link { padding: 14px var(--qp-gutter); opacity: .85; }
  .nav__link.is-active::after { display: none; }
  .nav__toggle { display: block; }
  .nav__phone { display: none; }
  .nav__links .nav__phone { display: block; margin: 8px var(--qp-gutter); text-align: center; }
  .hero__inner { padding-top: 140px; }
  .hero__stats { gap: 24px; }
  .section, .approach { padding: 80px 0; }
  .page-head { padding-top: 120px; }
  .work-grid, .gallery-4, .gallery-3, .gallery-2, .reel__side, .about-stats { grid-template-columns: 1fr; }
  .approach__steps { grid-template-columns: 1fr; }
  .stats__grid { grid-template-columns: 1fr 1fr; gap: 24px; }
  .form-grid { grid-template-columns: 1fr; }
  .field--full { grid-column: span 1; }
  .builders { grid-template-columns: 1fr 1fr; }
  .footer__grid { grid-template-columns: 1fr; gap: 36px; }
  .filters { top: 61px; }
  .contact-facts { grid-template-columns: 90px 1fr; }
}
