/* ===== ProtoBag Studio — Site styles (multi-page) ===== */
@import url('colors_and_type.css');

body { background: var(--bone-50); color: var(--ink-900); font-family: var(--font-sans); }
a { background-image: none; }
button { border: 0; cursor: pointer; font: inherit; color: inherit; background: transparent; }
html { scroll-behavior: smooth; }

/* Reveal */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity .65s var(--ease-out), transform .65s var(--ease-out); will-change: opacity, transform; }
.reveal.is-shown { opacity: 1; transform: translateY(0); }

/* Page transition */
@keyframes pageIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.page-enter { animation: pageIn .42s var(--ease-out) both; }

/* Eyebrow dot */
.eyebrow-dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--clay-500); margin-right: 10px; vertical-align: middle; transform: translateY(-1px); }
.eyebrow { display: inline-flex; align-items: center; }

/* Buttons */
.btn { font-family: var(--font-sans); font-size: 14px; font-weight: 500; padding: 13px 20px; border-radius: 6px; display: inline-flex; align-items: center; gap: 10px; border: 1px solid transparent; transition: background .2s var(--ease-out), border-color .2s var(--ease-out), color .2s var(--ease-out), transform .2s var(--ease-out), box-shadow .2s var(--ease-out); text-decoration: none; }
.btn-sm { padding: 10px 14px; font-size: 13px; }
.btn-primary { background: var(--clay-500); color: var(--bone-50); border-color: var(--clay-500); font-weight: 600; letter-spacing: -0.005em; box-shadow: 0 1px 0 rgba(20,19,15,0.04), 0 6px 14px rgba(138,74,43,0.18); }
.btn-primary:hover { background: var(--clay-600); border-color: var(--clay-600); transform: translateY(-1px); opacity: 1; box-shadow: 0 1px 0 rgba(20,19,15,0.06), 0 10px 22px rgba(138,74,43,0.22); }
.btn-primary:hover .btn-arrow, .btn-primary:hover::after { transform: translateX(3px); }
.btn-outline { background: transparent; color: var(--ink-900); border-color: var(--ink-900); font-weight: 600; }
.btn-outline:hover { background: var(--ink-900); color: var(--bone-50); opacity: 1; transform: translateY(-1px); }
.btn-ghost-light { background: transparent; color: var(--bone-50); border-color: rgba(255,255,255,0.32); font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; }
.btn-ghost-light:hover { border-color: var(--bone-50); opacity: 1; }
.btn-lg { padding: 17px 26px; font-size: 17px; font-weight: 600; }
@media (max-width: 600px) { .btn-lg { padding: 15px 22px; font-size: 16px; } }

/* Nav */
.nav.is-overlay { position: absolute; left: 0; right: 0; background: transparent !important; backdrop-filter: none; -webkit-backdrop-filter: none; border-bottom-color: transparent; }
.nav.is-overlay .nav-link { color: rgba(250,247,242,0.85); }
.nav.is-overlay .nav-link:hover, .nav.is-overlay .nav-link.is-active { color: #FAF7F2; }
.nav.is-overlay .nav-link::after { background: #FAF7F2; }
.nav.is-overlay .nav-toggle span { background: #FAF7F2; }
.nav.is-overlay .nav-cta .btn-primary { background: rgba(250,247,242,0.14); border: 1px solid rgba(250,247,242,0.35); color: #FAF7F2; backdrop-filter: blur(8px); }
.nav.is-overlay .nav-cta .btn-primary:hover { background: rgba(250,247,242,0.24); border-color: rgba(250,247,242,0.55); }
/* Nav */
.nav { position: sticky; top: 0; z-index: 50; background: rgba(250,247,242,0.82); backdrop-filter: saturate(140%) blur(12px); -webkit-backdrop-filter: saturate(140%) blur(12px); border-bottom: 1px solid transparent; transition: border-color .25s var(--ease-out), background .25s var(--ease-out); }
.nav.is-scrolled { border-bottom-color: var(--bone-300); background: rgba(250,247,242,0.94); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding-block: 16px; }
.brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; }
.brand-logo { display: block; height: 30px; width: auto; object-fit: contain; }
.brand-logo--invert { filter: invert(1); }
.brand-mark { width: 22px; height: 22px; border-radius: 4px; background: var(--ink-900); position: relative; flex: 0 0 auto; }
.brand-mark::before { content: ""; position: absolute; inset: 5px 6px; background: var(--clay-500); border-radius: 1px; }
.brand-name { font-family: var(--font-display); font-weight: 600; font-size: 17px; letter-spacing: -0.02em; color: var(--ink-900); }
.brand-dot { color: var(--clay-500); margin: 0 2px; }
.nav-links { display: flex; gap: 32px; align-items: center; }
.nav-link { font-size: 15px; font-weight: 500; color: var(--ink-700); position: relative; padding: 6px 0; transition: color .2s var(--ease-out); }
.nav-link::after { content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 1px; background: var(--ink-900); transform: scaleX(0); transform-origin: left; transition: transform .25s var(--ease-out); }
.nav-link:hover { color: var(--ink-900); opacity: 1; }
.nav-link:hover::after { transform: scaleX(1); }
.nav-link.is-active { color: var(--ink-900); }
.nav-link.is-active::after { transform: scaleX(1); background: var(--clay-500); }
.nav-toggle { display: none; flex-direction: column; gap: 4px; padding: 8px; }
.nav-toggle span { display: block; width: 22px; height: 1.5px; background: var(--ink-900); }
.nav-mobile { display: none; padding: 14px var(--gutter) 20px; flex-direction: column; gap: 14px; border-top: 1px solid var(--bone-300); background: var(--bone-50); }
@media (max-width: 1080px) { .nav-links, .nav-cta { display: none; } .nav-toggle { display: inline-flex; } .nav.is-open .nav-mobile { display: flex; } }

.lang-switch {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 16px 0 0;
  border-right: 1px solid var(--bone-300);
}

.lang-btn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-700);
  padding: 6px 0;
  transition: color .2s var(--ease-out);
  position: relative;
}

.lang-btn:hover {
  color: var(--ink-900);
}

.lang-btn.is-active {
  color: var(--ink-900);
  font-weight: 600;
}

.lang-btn.is-active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 1px;
  background: var(--ink-900);
}

.lang-sep {
  color: var(--ink-700);
  font-size: 13px;
}

@media (max-width: 1080px) { .nav-links, .nav-cta { display: none; } .lang-switch { border-right: none; padding: 0; margin-right: 0; margin-top: 8px; } .nav-toggle { display: inline-flex; } .nav.is-open .nav-mobile { display: flex; } }

/* Hero */
.hero-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: 64px; align-items: stretch; }
.hero-copy { display: flex; flex-direction: column; }
/* Push CTA + tags group to bottom of hero column so the CTA sits just above the service tags */
.hero-copy > .reveal:nth-last-child(2) { margin-top: auto; }
.hero-grid .flow-card { height: 100%; display: flex; flex-direction: column; }
.hero-grid .flow-list { flex: 1; }
.hero-title { font-size: clamp(40px, 5.0vw, 68px); font-weight: 500; line-height: 1.05; letter-spacing: -0.025em; }
.hero-lede { max-width: 620px; margin-top: 24px; font-size: 18px; line-height: 1.55; color: var(--ink-2, #4a4641); }
@media (max-width: 980px) { .hero-grid { grid-template-columns: 1fr; gap: 48px; } }
.dot-mono { width: 6px; height: 6px; border-radius: 50%; background: var(--clay-500); display: inline-block; }

/* Hero service tags (pills) */
.hero-tags { margin-top: 32px; display: flex; flex-wrap: wrap; gap: 8px; }
.hero-tag { display: inline-flex; align-items: center; padding: 7px 14px; border-radius: 999px; background: rgba(255, 253, 250, 0.6); border: 1px solid var(--bone-300); font-family: var(--font-sans); font-size: 13px; font-weight: 500; color: var(--ink-700); letter-spacing: -0.005em; transition: background .2s var(--ease-out), border-color .2s var(--ease-out), color .2s var(--ease-out); }
.hero-tag:hover { background: var(--paper); border-color: var(--ink-700); color: var(--ink-900); }

/* Hero glassmorphism flow card */
.flow-card { position: relative; padding: 22px 18px 16px; border-radius: 18px; background: linear-gradient(180deg, rgba(255,253,250,0.78) 0%, rgba(250,245,238,0.62) 100%); backdrop-filter: blur(22px) saturate(1.3); -webkit-backdrop-filter: blur(22px) saturate(1.3); border: 1px solid rgba(255, 255, 255, 0.7); box-shadow: 0 1px 0 rgba(255,255,255,0.9) inset, 0 1px 2px rgba(20,19,15,0.04), 0 18px 44px rgba(20, 19, 15, 0.08), 0 2px 8px rgba(138, 74, 43, 0.04); overflow: hidden; }
.flow-card-glow { position: absolute; pointer-events: none; top: -40%; right: -20%; width: 60%; height: 80%; background: radial-gradient(closest-side, rgba(216, 152, 110, 0.22), rgba(216, 152, 110, 0) 70%); filter: blur(24px); }
.flow-card-head { display: flex; align-items: baseline; justify-content: space-between; padding: 0 8px 14px; }
.flow-card-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-600); }
.flow-card-mono { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--ink-400); }
.flow-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; position: relative; }
.flow-step { position: relative; display: grid; grid-template-columns: 36px 1fr 22px; gap: 14px; align-items: start; padding: 14px 14px; border-radius: 12px; border: 1px solid transparent; background: transparent; transition: background .22s var(--ease-out), border-color .22s var(--ease-out), transform .22s var(--ease-out), box-shadow .22s var(--ease-out); cursor: default; }
.flow-step-num { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--clay-500); padding-top: 3px; transition: color .2s var(--ease-out); }
.flow-step-body { min-width: 0; }
.flow-step-t { font-family: var(--font-display); font-weight: 600; font-size: 14px; letter-spacing: -0.005em; color: var(--ink-900); }
.flow-step-d { font-size: 12.5px; line-height: 1.5; color: var(--ink-600); margin-top: 3px; }
.flow-step-arrow { display: inline-flex; align-items: center; justify-content: center; color: var(--ink-400); padding-top: 4px; transition: transform .22s var(--ease-out), color .22s var(--ease-out); }
.flow-step:hover { transform: translateY(-2px); background: rgba(255, 255, 255, 0.7); border-color: rgba(255, 255, 255, 0.95); box-shadow: 0 1px 0 rgba(255,255,255,0.9) inset, 0 8px 22px rgba(20, 19, 15, 0.08), 0 2px 6px rgba(20, 19, 15, 0.04); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); }
.flow-step:hover .flow-step-arrow { transform: translateX(3px); color: var(--clay-600); }
.flow-step:hover .flow-step-num { color: var(--clay-600); }
.flow-card-foot { margin-top: 12px; width: 100%; padding: 12px 14px; border: 0; border-top: 1px solid rgba(20, 19, 15, 0.06); background: transparent; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-700); display: inline-flex; align-items: center; justify-content: flex-start; gap: 8px; cursor: pointer; transition: color .2s var(--ease-out); }
.flow-card-foot svg { transition: transform .2s var(--ease-out); }
.flow-card-foot:hover { color: var(--clay-600); }
.flow-card-foot:hover svg { transform: translateX(3px); }

/* Trust strip */
.trust-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 24px; }
.trust-cell { display: flex; flex-direction: column; gap: 4px; }
.trust-k { font-family: var(--font-display); font-weight: 600; font-size: 16px; letter-spacing: -0.01em; color: var(--ink-900); }
.trust-v { font-size: 12px; color: var(--ink-600); line-height: 1.4; }
@media (max-width: 980px) { .trust-grid { grid-template-columns: repeat(2,1fr); gap: 20px; } }

/* Who we help */
.who-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--ink-900); }
.who-card { padding: 28px 24px 32px; border-right: 1px solid var(--bone-300); border-bottom: 1px solid var(--bone-300); height: 100%; transition: background .25s var(--ease-out); }
.who-card:hover { background: var(--bone-100); }
.who-grid > *:nth-child(3n) .who-card { border-right: none; }
.who-num { font-family: var(--font-mono); font-size: 11px; color: var(--clay-500); letter-spacing: 0.1em; margin-bottom: 28px; }
.who-title { font-family: var(--font-display); font-weight: 500; font-size: 22px; letter-spacing: -0.015em; line-height: 1.15; color: var(--ink-900); }
.who-desc { margin-top: 10px; font-size: 13px; line-height: 1.55; color: var(--ink-600); }
@media (max-width: 980px) { .who-grid { grid-template-columns: 1fr; } .who-card { border-right: none; } }

/* Who chips (compact strip on home) */
.who-strip { /* layout via inline style */ }
.who-chip { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; color: var(--ink-800); background: var(--paper); border: 1px solid var(--bone-300); border-radius: 999px; padding: 9px 14px; transition: border-color .2s, color .2s, background .2s; }
.who-chip:hover { border-color: var(--ink-900); background: var(--bone-100); }

/* Services grid */
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--ink-900); }
.service-card { padding: 28px 24px 36px; border-right: 1px solid var(--bone-300); border-bottom: 1px solid var(--bone-300); height: 100%; background: transparent; transition: background .25s var(--ease-out); position: relative; }
.service-card::before { content: ""; position: absolute; left: 0; top: -1px; height: 2px; width: 0; background: var(--clay-500); transition: width .35s var(--ease-out); }
.service-card:hover { background: var(--paper); }
.service-card:hover::before { width: 100%; }
.services-grid > *:nth-child(3n) .service-card { border-right: none; }
.service-num { font-family: var(--font-mono); font-size: 11px; color: var(--clay-500); letter-spacing: 0.1em; margin-bottom: 32px; }
.service-title { font-family: var(--font-display); font-weight: 500; font-size: 21px; letter-spacing: -0.015em; line-height: 1.18; color: var(--ink-900); }
.service-desc { margin-top: 12px; font-size: 14px; line-height: 1.6; color: var(--ink-600); }
@media (max-width: 980px) { .services-grid { grid-template-columns: 1fr; } .service-card { border-right: none; } }

/* Process rail (preview) */
.process-rail { display: flex; flex-wrap: wrap; align-items: stretch; gap: 12px; }
.process-node { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 6px; padding: 18px 18px 20px; min-width: 150px; flex: 1 1 150px; transition: border-color .2s, box-shadow .2s, transform .2s; }
.process-node:hover { border-color: var(--ink-900); box-shadow: var(--shadow-2); transform: translateY(-2px); }
.process-node-num { font-family: var(--font-mono); font-size: 11px; color: var(--clay-500); letter-spacing: 0.1em; margin-bottom: 10px; }
.process-node-title { font-family: var(--font-display); font-weight: 500; font-size: 16px; letter-spacing: -0.01em; }
.process-arrow { display: flex; align-items: center; color: var(--ink-300); font-size: 18px; }
@media (max-width: 720px) { .process-arrow { display: none; } }

/* Process list (full) */
.process-list { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--ink-900); }
.process-row { display: grid; grid-template-columns: 80px 1fr; gap: 32px; padding: 24px 0 26px; border-bottom: 1px solid var(--bone-300); position: relative; transition: background .2s; }
.process-row::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 0; background: var(--clay-500); transition: width .3s var(--ease-out); }
.process-row:hover { background: var(--bone-100); }
.process-row:hover::before { width: 3px; }
.process-row-num { font-family: var(--font-mono); font-size: 12px; color: var(--clay-500); letter-spacing: 0.1em; padding-top: 4px; }
.process-row-title { font-family: var(--font-display); font-weight: 500; font-size: 22px; letter-spacing: -0.015em; }
.process-row-desc { margin-top: 6px; font-size: 14px; line-height: 1.6; color: var(--ink-600); max-width: 64ch; }

/* Process steps (full, accordion cards) */
.process-steps { display: flex; flex-direction: column; gap: 10px; }
.process-step-card { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 8px; overflow: hidden; transition: border-color .2s, box-shadow .2s; }
.process-step-card:hover { border-color: var(--ink-700); }
.process-step-card.is-open { border-color: var(--ink-900); box-shadow: var(--shadow-2); }
.process-step-head { display: grid; grid-template-columns: 60px 1fr 32px; gap: 18px; align-items: center; width: 100%; padding: 22px 24px; text-align: left; cursor: pointer; background: transparent; border: none; }
.process-step-num { font-family: var(--font-mono); font-size: 11px; color: var(--clay-500); letter-spacing: 0.12em; }
.process-step-meta { display: flex; flex-direction: column; gap: 4px; }
.process-step-title { font-family: var(--font-sans); font-weight: 600; font-size: 18px; letter-spacing: -0.015em; color: var(--ink-900); }
.process-step-sub { font-size: 14px; color: var(--ink-600); line-height: 1.5; font-weight: 400; }
.process-step-icon { font-family: var(--font-mono); font-size: 22px; color: var(--ink-500); text-align: center; line-height: 1; transition: color .2s; }
.process-step-card.is-open .process-step-icon { color: var(--clay-500); }
.process-step-body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .35s var(--ease-out); }
.process-step-body-inner { overflow: hidden; }
.process-step-rows { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; padding: 4px 24px 28px 102px; border-top: 1px solid var(--bone-300); padding-top: 22px; margin-top: 0; }
.process-step-rows > div p { font-size: 14px; line-height: 1.6; color: var(--ink-700); margin: 0; }
.process-step-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; color: var(--clay-500); text-transform: uppercase; margin-bottom: 8px; }
@media (max-width: 820px) {
  .process-step-head { grid-template-columns: 44px 1fr 28px; gap: 12px; padding: 18px 18px; }
  .process-step-title { font-size: 17px; }
  .process-step-rows { grid-template-columns: 1fr; gap: 18px; padding: 18px 18px 22px 18px; }
}

/* Process timeline note */
.process-timeline-note { margin-top: 32px; background: var(--bone-100); border: 1px solid var(--bone-300); border-radius: 8px; padding: 24px 26px 26px; }
.process-timeline-list { list-style: none; padding: 0; margin: 14px 0 14px; display: flex; flex-direction: column; gap: 8px; font-size: 14px; color: var(--ink-700); }
.process-timeline-list strong { font-family: var(--font-mono); font-weight: 500; font-size: 13px; color: var(--ink-900); margin-right: 6px; }
.process-timeline-foot { font-size: 12px; line-height: 1.55; color: var(--ink-500); margin-top: 6px; }

/* Consulting grid */
.consulting-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; }
@media (max-width: 980px) { .consulting-grid { grid-template-columns: 1fr; gap: 40px; } }
.consulting-list { display: flex; flex-direction: column; }
.consulting-row { display: grid; grid-template-columns: 36px 1fr; gap: 14px; padding: 14px 0; border-top: 1px solid var(--bone-300); font-size: 14px; line-height: 1.55; color: var(--ink-700); transition: background .2s, padding .2s; }
.consulting-list > *:last-child .consulting-row { border-bottom: 1px solid var(--bone-300); }
.consulting-row:hover { background: var(--bone-100); padding-inline: 8px; }
.consulting-num { font-family: var(--font-mono); font-size: 11px; color: var(--clay-500); letter-spacing: 0.1em; padding-top: 3px; }

/* QC */
.qc-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 56px; }
@media (max-width: 980px) { .qc-grid { grid-template-columns: 1fr; gap: 40px; } }
.qc-list { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--ink-900); }
.qc-item { display: grid; grid-template-columns: 28px 1fr; gap: 12px; padding: 14px 0; border-bottom: 1px solid var(--bone-300); font-size: 14px; color: var(--ink-800); transition: padding .2s, background .2s; }
.qc-item:hover { background: var(--bone-100); padding-inline: 8px; }
.qc-check { font-family: var(--font-mono); color: var(--clay-500); font-size: 14px; }
.qc-card { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 8px; padding: 24px 24px 28px; }
.qc-card-lede { font-size: 14px; line-height: 1.6; color: var(--ink-700); }
.cert-row { display: flex; gap: 16px; margin-top: 18px; flex-wrap: wrap; }
.cert-badge { display: flex; flex-direction: column; align-items: flex-start; gap: 14px; padding: 18px 20px; background: var(--paper); border: 1px solid var(--bone-300); border-radius: 8px; min-width: 200px; flex: 1 1 220px; transition: border-color .2s; outline: none; }
.cert-badge:hover, .cert-badge:focus-visible { border-color: var(--ink-900); }
.cert-img-wrap { width: 100%; height: 96px; background: transparent; border: 0; border-radius: 0; overflow: hidden; display: flex; align-items: center; justify-content: flex-start; }
.cert-img { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; object-position: left center; display: block; mix-blend-mode: multiply; }
.cert-meta { display: flex; flex-direction: column; gap: 2px; padding-top: 10px; border-top: 1px solid var(--bone-200); width: 100%; }
.cert-code { font-family: var(--font-mono); font-size: 11px; color: var(--clay-500); letter-spacing: 0.12em; text-transform: uppercase; }
.cert-name { font-family: var(--font-display); font-weight: 600; font-size: 15px; letter-spacing: -0.005em; color: var(--ink-900); }

/* Why */
.why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--ink-900); }
.why-card { padding: 28px 24px 36px; border-right: 1px solid var(--bone-300); border-bottom: 1px solid var(--bone-300); height: 100%; transition: background .25s; }
.why-card:hover { background: var(--paper); }
.why-grid > *:nth-child(3n) .why-card { border-right: none; }
.why-num { font-family: var(--font-mono); font-size: 11px; color: var(--clay-500); letter-spacing: 0.1em; margin-bottom: 28px; }
.why-title { font-family: var(--font-display); font-weight: 500; font-size: 20px; letter-spacing: -0.015em; line-height: 1.18; }
.why-desc { margin-top: 10px; font-size: 14px; line-height: 1.6; color: var(--ink-600); }
@media (max-width: 980px) { .why-grid { grid-template-columns: 1fr; } .why-card { border-right: none; } }

/* Team */
.team-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.team-card { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 8px; padding: 24px; transition: border-color .25s, box-shadow .25s, transform .25s; }
.team-card:hover { border-color: var(--ink-900); box-shadow: var(--shadow-2); transform: translateY(-2px); }
.team-photo { aspect-ratio: 4/3; background: linear-gradient(135deg, var(--bone-200), var(--bone-300)); border-radius: 6px; margin-bottom: 18px; display: flex; align-items: center; justify-content: center; }
.team-photo-label { font-family: var(--font-mono); font-size: 11px; color: var(--ink-500); letter-spacing: 0.1em; text-transform: uppercase; }
.team-city { font-family: var(--font-mono); font-size: 11px; color: var(--clay-500); letter-spacing: 0.12em; text-transform: uppercase; }
.team-role { font-family: var(--font-display); font-weight: 500; font-size: 20px; letter-spacing: -0.015em; margin-top: 6px; }
.team-note { margin-top: 8px; font-size: 14px; color: var(--ink-600); line-height: 1.55; }
@media (max-width: 720px) { .team-grid { grid-template-columns: 1fr; } }

/* FAQ */
.faq-list { display: flex; flex-direction: column; border-top: 1px solid var(--ink-900); }
.faq-item { border-bottom: 1px solid var(--bone-300); transition: background .2s; }
.faq-item:hover { background: var(--bone-100); }
.faq-q { display: grid; grid-template-columns: 56px 1fr 32px; gap: 16px; align-items: baseline; width: 100%; padding: 22px 8px; text-align: left; cursor: pointer; }
.faq-q-num { font-family: var(--font-mono); font-size: 11px; color: var(--clay-500); letter-spacing: 0.1em; padding-top: 4px; }
.faq-q-text { font-family: var(--font-display); font-weight: 500; font-size: 20px; letter-spacing: -0.015em; color: var(--ink-900); line-height: 1.25; }
.faq-q-icon { font-family: var(--font-mono); font-size: 22px; color: var(--ink-500); justify-self: end; transition: transform .25s var(--ease-out), color .2s; }
.faq-item.is-open .faq-q-icon { color: var(--clay-500); transform: rotate(180deg); }
.faq-a-wrap { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .35s var(--ease-out); }
.faq-a-inner { overflow: hidden; }
.faq-a { padding: 0 8px 24px 80px; font-size: 15px; line-height: 1.65; color: var(--ink-700); margin: 0; max-width: 80ch; }
@media (max-width: 720px) { .faq-q { grid-template-columns: 36px 1fr 24px; gap: 10px; } .faq-q-text { font-size: 17px; } .faq-a { padding-left: 50px; } }

/* Contact */
.contact-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 48px; align-items: stretch; }
@media (max-width: 980px) { .contact-grid { grid-template-columns: 1fr; gap: 40px; } }
.contact-grid > .reveal { display: flex; flex-direction: column; }
.contact-grid > .reveal > .contact-form { flex: 1; }
.contact-form { display: flex; flex-direction: column; gap: 18px; background: var(--paper); border: 1px solid var(--bone-300); border-radius: 10px; padding: 32px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 720px) { .field-row { grid-template-columns: 1fr; } }
.field { display: flex; flex-direction: column; gap: 6px; }
.field-label { font-size: 12px; font-weight: 500; color: var(--ink-700); letter-spacing: 0.02em; }
.field-hint { font-size: 12px; color: var(--ink-500); }
.field input, .field select, .field textarea { font-family: var(--font-sans); font-size: 14px; color: var(--ink-900); background: var(--bone-50); border: 1px solid var(--bone-300); border-radius: 4px; padding: 12px 13px; outline: none; transition: border-color .2s, box-shadow .2s; width: 100%; }
.field textarea { min-height: 120px; resize: vertical; line-height: 1.5; }
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--ink-900); box-shadow: 0 0 0 3px rgba(20,19,15,0.06); }
.form-meta { display: flex; flex-direction: column; gap: 8px; padding-top: 8px; }
.form-fineprint { font-size: 12px; line-height: 1.55; color: var(--ink-500); margin: 0; }
.form-fineprint a { color: var(--ink-900); border-bottom: 1px solid var(--bone-300); }
.form-thanks { padding: 24px 8px; }
.contact-aside { display: flex; flex-direction: column; gap: 16px; }
.contact-card { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 8px; padding: 22px 24px; transition: border-color .25s; }
.contact-card:hover { border-color: var(--ink-900); }
.contact-email { display: inline-block; font-family: var(--font-sans); font-weight: 500; font-size: 14px; letter-spacing: 0; color: var(--ink-900); border-bottom: 1px solid var(--ink-900); padding-bottom: 1px; }
.contact-meta { font-size: 13px; line-height: 1.55; color: var(--ink-600); margin-top: 8px; }
.contact-checklist { list-style: none; padding: 0; margin: 8px 0 0; display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--ink-700); }
.contact-checklist li::before { content: "→ "; color: var(--clay-500); font-family: var(--font-mono); }

/* Needs grid (Contact page — best starting points / helpful info / hard to quote) */
.needs-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 980px) { .needs-grid { grid-template-columns: 1fr; } }
.needs-card { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 8px; padding: 22px 22px 24px; height: 100%; transition: border-color .2s, box-shadow .2s; }
.needs-card:hover { border-color: var(--ink-700); box-shadow: var(--shadow-1); }
.needs-card--good { border-top: 3px solid var(--clay-500); }
.needs-card--warn { border-top: 3px solid var(--ink-700); background: var(--bone-100); }
.needs-card-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-700); margin-bottom: 14px; }
.needs-card--good .needs-card-label { color: var(--clay-600); }
.needs-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; font-size: 14px; line-height: 1.55; color: var(--ink-800); }
.needs-list li { padding-left: 18px; position: relative; }
.needs-list li::before { content: "·"; position: absolute; left: 4px; top: -2px; color: var(--clay-500); font-family: var(--font-mono); font-size: 18px; }
.needs-card--warn .needs-list li::before { content: "—"; left: 0; font-size: 12px; top: 0; color: var(--ink-500); }

/* Final CTA */
.final-cta { background: var(--ink-900); color: var(--bone-50); padding-block: clamp(72px, 10vw, 120px); }
.final-cta-inner { display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items: end; }
.final-cta-actions { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; }
@media (max-width: 980px) { .final-cta-inner { grid-template-columns: 1fr; gap: 32px; } }

/* Footer */
.footer { background: var(--ink-900); color: var(--bone-200); padding-top: 64px; border-top: 1px solid rgba(255,255,255,0.08); }
.footer-inner { display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 48px; padding-bottom: 48px; }
.footer-cols { display: contents; }
.footer-cols--two { display: contents; }
.footer-brand .brand-mark { background: var(--bone-50); }
.footer-brand .brand-mark::before { background: var(--clay-400); }
.footer-tagline { font-size: 14px; line-height: 1.55; color: var(--bone-200); margin-top: 14px; max-width: 36ch; }
.footer-email { display: inline-block; margin-top: 16px; color: var(--bone-50); font-family: var(--font-display); font-weight: 500; border-bottom: 1px solid rgba(255,255,255,0.3); padding-bottom: 1px; }
.footer-email:hover { border-color: var(--clay-400); color: var(--clay-300); opacity: 1; }
.footer-col-title { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--bone-300); margin-bottom: 14px; }
.footer-links { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; font-size: 14px; }
.footer-links a { color: var(--bone-200); transition: color .2s; }
.footer-links a:hover { color: var(--bone-50); opacity: 1; }
.footer-base { border-top: 1px solid rgba(255,255,255,0.08); padding: 20px 0; font-size: 12px; color: var(--bone-400); }
.footer-base-inner { display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
@media (max-width: 980px) { .footer-inner { grid-template-columns: 1fr 1fr; gap: 32px; } }
@media (max-width: 600px) { .footer-inner { grid-template-columns: 1fr; } }

/* Legal modal */
.legal-modal-overlay { position: fixed; inset: 0; background: rgba(20,19,15,0.5); z-index: 80; display: flex; align-items: flex-start; justify-content: center; padding: 48px 20px; overflow-y: auto; animation: pageIn .25s var(--ease-out) both; }
.legal-modal { background: var(--bone-50); border: 1px solid var(--bone-300); border-radius: 10px; padding: 40px; max-width: 720px; width: 100%; box-shadow: var(--shadow-3); position: relative; animation: pageIn .3s var(--ease-out) both; }
.legal-close { position: absolute; top: 12px; right: 16px; font-size: 28px; line-height: 1; color: var(--ink-500); padding: 6px 10px; }
.legal-close:hover { color: var(--ink-900); }
.legal-body h3 { font-family: var(--font-display); font-weight: 600; font-size: 16px; margin-top: 18px; margin-bottom: 6px; letter-spacing: -0.005em; }
.legal-body p { font-size: 14px; line-height: 1.6; color: var(--ink-700); margin-bottom: 8px; }
.cookie-row { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 14px 0; border-top: 1px solid var(--bone-300); }
.cookie-row:first-of-type { border-top: 1px solid var(--ink-900); margin-top: 18px; }
.cookie-toggle { position: relative; display: inline-block; width: 38px; height: 22px; flex: 0 0 auto; }
.cookie-toggle input { opacity: 0; position: absolute; }
.cookie-toggle span { position: absolute; inset: 0; background: var(--bone-300); border-radius: 999px; transition: background .2s; cursor: pointer; }
.cookie-toggle span::before { content: ""; position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; background: var(--bone-50); border-radius: 50%; transition: transform .2s var(--ease-out); }
.cookie-toggle input:checked + span { background: var(--clay-500); }
.cookie-toggle input:checked + span::before { transform: translateX(16px); }
.cookie-toggle input:disabled + span { background: var(--ink-700); cursor: not-allowed; }

/* Cookie banner */
.cookie-banner { position: fixed; bottom: 16px; left: 16px; right: 16px; max-width: 720px; margin-left: auto; background: var(--ink-900); color: var(--bone-50); border: 1px solid rgba(255,255,255,0.1); border-radius: 8px; padding: 18px 22px; z-index: 60; display: grid; grid-template-columns: 1fr auto; gap: 20px; align-items: center; box-shadow: var(--shadow-3); animation: pageIn .35s var(--ease-out) both; }
.cookie-banner .actions { display: flex; gap: 8px; flex-wrap: wrap; }
@media (max-width: 720px) { .cookie-banner { grid-template-columns: 1fr; } }

/* Theme tweaks */
body[data-accent="oxblood"] { --clay-500: #7E2A1F; --clay-400: #A04434; --clay-600: #6A2218; --clay-700: #571A12; --clay-100: #EDD6D0; --clay-300: #C9806E; }
body[data-accent="forest"]  { --clay-500: #3F5C3A; --clay-400: #5C7C56; --clay-600: #2F4A2C; --clay-700: #243B22; --clay-100: #DFE7DA; --clay-300: #8FA988; }
body[data-accent="sand"]    { --clay-500: #B88A3A; --clay-400: #D5A85A; --clay-600: #9D742E; --clay-700: #806026; --clay-100: #F0E4CB; --clay-300: #E2C285; }
body[data-bg="cooler"] { --bone-50: #F5F4F0; --bone-100: #ECEAE3; --bone-200: #E2DFD5; }
body[data-bg="paper"]  { --bone-50: #FBFAF6; --bone-100: #F4F1E9; }

/* ===== Hero with full-bleed video background ===== */
.hero--video { padding-top: 0 !important; margin-top: -82px; padding-top: 0 !important; }
.hero--video .hero-video-content { padding-top: clamp(170px, 22vh, 260px); }
.hero-video-stage { position: relative; width: 100%; min-height: clamp(560px, 78vh, 820px); overflow: visible; background: #0e0d0a; isolation: isolate; }
.hero-video-poster { position: absolute; inset: 0; background-size: cover; background-position: center; background-repeat: no-repeat; filter: brightness(0.55) saturate(1.05); z-index: 0; }
.hero-video-wrap { position: absolute; inset: 0; overflow: hidden; pointer-events: none; z-index: 1; }
.hero-video-block { position: absolute; inset: 0; pointer-events: auto; background: transparent; cursor: default; z-index: 2; }
.hero-video-iframe { position: absolute; top: 50%; left: 50%; width: 178%; height: 178%; transform: translate(-50%, -50%); border: 0; pointer-events: none; background: transparent; }
.hero-video-scrim { position: absolute; inset: 0; pointer-events: auto; z-index: 2; background:
  linear-gradient(180deg, rgba(14,13,10,0.75) 0%, rgba(14,13,10,0.55) 35%, rgba(14,13,10,0.45) 65%, rgba(14,13,10,0.78) 100%),
  linear-gradient(90deg, rgba(14,13,10,0.55) 0%, rgba(14,13,10,0.15) 55%, rgba(14,13,10,0) 100%);
}
.hero-video-content { position: relative; z-index: 3; padding-top: clamp(120px, 16vh, 200px); padding-bottom: clamp(80px, 12vh, 140px); max-width: 880px; }
.hero-title--light { color: #FAF7F2; font-size: clamp(40px, 5.4vw, 76px); font-weight: 500; line-height: 1.04; letter-spacing: -0.025em; text-shadow: 0 2px 24px rgba(0,0,0,0.35); }
.hero-lede--light { color: rgba(250,247,242,0.92); max-width: 640px; margin-top: 22px; font-size: clamp(16px, 1.4vw, 19px); line-height: 1.55; text-shadow: 0 1px 14px rgba(0,0,0,0.35); }
.eyebrow--light { color: rgba(250,247,242,0.85); }
.eyebrow--light .eyebrow-dot { background: var(--clay-400, #E2A57E); }
.hero-tags--light { margin-top: 32px; }
.hero-tag--light { background: rgba(250,247,242,0.10); border-color: rgba(250,247,242,0.25); color: rgba(250,247,242,0.94); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }
.hero-tag--light:hover { background: rgba(250,247,242,0.18); border-color: rgba(250,247,242,0.45); color: #FAF7F2; }
@media (max-width: 800px) {
  .hero--video { padding-bottom: 40px !important; }
  .hero-video-stage { min-height: 420px; overflow: hidden; }
  .hero-video-content { position: absolute; z-index: 3; inset: 0; padding-top: 80px; padding-bottom: 40px; background: transparent; max-width: 100%; display: flex; flex-direction: column; justify-content: center; }
  .hero-video-content > * { text-shadow: 0 2px 12px rgba(0,0,0,0.4); }
  .hero-title--light { color: #FAF7F2; font-size: clamp(28px, 7vw, 44px); }
  .hero-lede--light { color: rgba(250,247,242,0.88); }
  .eyebrow--light { color: rgba(250,247,242,0.85); }
  .hero-tag--light { background: rgba(250,247,242,0.10); border-color: rgba(250,247,242,0.25); color: rgba(250,247,242,0.94); }
}

@media (max-width: 560px) {
  /* On very small screens, hide the YouTube iframe and show only poster + content */
  .hero-video-wrap { display: none; }
  .hero-video-stage { min-height: 480px; }
  .hero-video-poster { z-index: 1; }
  .hero-video-scrim { z-index: 2; }
  .hero-video-content { position: absolute; inset: 0; z-index: 3; padding-top: 60px; padding-bottom: 60px; }
}
.factory-video { padding-top: 0 !important; }
.fv-frame { position: relative; width: 100%; aspect-ratio: 16/9; background: #000; border-radius: 14px; overflow: hidden; box-shadow: 0 1px 0 rgba(20,19,15,0.04), 0 24px 60px rgba(20,19,15,0.10); }
.fv-iframe-wrap { position: absolute; inset: 0; overflow: hidden; pointer-events: none; background: #000; }
/* Overscale crops YouTube edge chrome and any letterbox bars. Pointer-events: none on the wrapper means clicks/taps cannot reach the iframe — keeps autoplay muted and prevents user interaction. */
.fv-iframe-wrap iframe,
.fv-iframe { position: absolute; top: 50%; left: 50%; width: 178%; height: 178%; transform: translate(-50%, -50%); border: 0; pointer-events: none; background: #000; }
.fv-overlay { position: absolute; left: 18px; bottom: 18px; display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px 8px 12px; border-radius: 999px; background: rgba(20,19,15,0.55); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border: 1px solid rgba(250,247,242,0.16); z-index: 3; pointer-events: none; }
.fv-overlay-dot { width: 7px; height: 7px; border-radius: 50%; background: #E84545; box-shadow: 0 0 0 0 rgba(232, 69, 69, 0.6); animation: fv-pulse 1.8s ease-out infinite; }
@keyframes fv-pulse { 0% { box-shadow: 0 0 0 0 rgba(232, 69, 69, 0.55); } 70% { box-shadow: 0 0 0 8px rgba(232, 69, 69, 0); } 100% { box-shadow: 0 0 0 0 rgba(232, 69, 69, 0); } }
.fv-overlay-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--bone-50); }
@media (max-width: 600px) {
  .fv-overlay { left: 12px; bottom: 12px; padding: 6px 10px; }
  .fv-overlay-label { font-size: 10px; letter-spacing: 0.08em; }
}

/* ===== Hero image collage ===== */
.hero-collage { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 14px; height: 100%; min-height: 480px; }
.hero-collage-tile { position: relative; margin: 0; border-radius: 14px; overflow: hidden; background: var(--bone-100); box-shadow: 0 1px 0 rgba(20,19,15,0.04), 0 18px 44px rgba(20,19,15,0.08); transform: translateY(0); transition: transform .5s var(--ease-out), box-shadow .5s var(--ease-out); }
.hero-collage-tile.is-tall { grid-row: span 2; }
.hero-collage-tile img { display: block; width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--ease-out); }
.hero-collage-tile:hover { transform: translateY(-3px); box-shadow: 0 1px 0 rgba(20,19,15,0.04), 0 22px 56px rgba(20,19,15,0.12); }
.hero-collage-tile:hover img { transform: scale(1.04); }
.hero-collage-cap { position: absolute; left: 12px; bottom: 10px; padding: 5px 10px; border-radius: 999px; background: rgba(20,19,15,0.55); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--bone-50); }
@media (max-width: 980px) {
  .hero-collage { min-height: 420px; }
}
@media (max-width: 600px) {
  .hero-collage { grid-template-columns: 1fr 1fr; min-height: 360px; gap: 10px; }
  .hero-collage-cap { font-size: 9.5px; padding: 4px 8px; }
}

/* ===== Hero flow strip — replaces the right-column flow card ===== */
.hero-flow-strip { display: grid; grid-template-rows: auto 1fr; gap: 18px; padding: 24px; border-radius: 16px; background: var(--bone-100); border: 1px solid var(--bone-300); }
.hero-flow-strip-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.hero-flow-strip-link { background: transparent; border: 0; padding: 0; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-700); display: inline-flex; align-items: center; gap: 8px; cursor: pointer; transition: color .2s var(--ease-out); }
.hero-flow-strip-link svg { transition: transform .2s var(--ease-out); }
.hero-flow-strip-link:hover { color: var(--clay-600); }
.hero-flow-strip-link:hover svg { transform: translateX(3px); }
.hero-flow-strip-list { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.hero-flow-strip-step { display: grid; grid-template-columns: auto 1fr; gap: 10px; align-items: start; padding: 14px; border-radius: 10px; background: var(--paper, #FAFAF7); border: 1px solid rgba(20,19,15,0.05); }
.hero-flow-strip-num { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--clay-500); padding-top: 2px; }
.hero-flow-strip-t { font-family: var(--font-display); font-weight: 600; font-size: 14px; letter-spacing: -0.005em; color: var(--ink-900); }
.hero-flow-strip-d { font-size: 12.5px; line-height: 1.5; color: var(--ink-600); margin-top: 4px; }
@media (max-width: 980px) {
  .hero-flow-strip-list { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .hero-flow-strip-list { grid-template-columns: 1fr; }
}

/* ===== Sample work gallery ===== */
.sw-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 16px; grid-auto-rows: 220px; }
.sw-grid > .reveal { display: block; height: 100%; }
.sw-card { position: relative; margin: 0; border-radius: 8px; overflow: hidden; background: var(--paper); border: 1px solid var(--bone-300); height: 100%; transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out), border-color .35s var(--ease-out); }
.sw-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-2); border-color: var(--ink-700); }
.sw-media { position: absolute; inset: 0; overflow: hidden; background: var(--bone-100); }
.sw-media img { width: 100%; height: 100%; object-fit: contain; padding: 8%; transition: transform .8s var(--ease-out), padding .35s var(--ease-out); }
.sw-card:hover .sw-media img { transform: scale(1.04); }
.sw-cap { position: absolute; left: 14px; bottom: 12px; right: 14px; display: flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-700); opacity: 0; transform: translateY(4px); transition: opacity .25s var(--ease-out), transform .25s var(--ease-out); pointer-events: none; }
.sw-card:hover .sw-cap { opacity: 1; transform: translateY(0); }
.sw-cap-num { color: var(--clay-500); }
.sw-cap-label { padding: 4px 10px; background: rgba(250,247,242,0.92); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); border: 1px solid var(--bone-300); border-radius: 999px; }

/* Full gallery: uniform 4-up grid */
.sw-grid--full > .reveal { grid-column: span 3; grid-row: span 1; }
@media (max-width: 980px) {
  .sw-grid { grid-template-columns: repeat(6, 1fr); grid-auto-rows: 180px; gap: 12px; }
  .sw-grid--full > .reveal { grid-column: span 3; grid-row: span 1; }
}
@media (max-width: 560px) {
  .sw-grid { grid-template-columns: 1fr 1fr; grid-auto-rows: 150px; gap: 10px; }
  .sw-grid--full > .reveal { grid-column: span 1; grid-row: span 1; }
  .sw-cap { opacity: 1; transform: none; }
}

/* ===== Testimonials ===== */
.tm-feature-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 16px; }
.tm-feature-grid > .reveal:nth-child(1) { grid-row: span 2; }
.tm-feature-grid > .reveal { display: block; }
.tm-card { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 10px; padding: 28px 28px 26px; transition: border-color .25s var(--ease-out), box-shadow .25s var(--ease-out), transform .25s var(--ease-out); position: relative; height: 100%; display: flex; flex-direction: column; gap: 14px; }
.tm-card:hover { border-color: var(--ink-700); box-shadow: var(--shadow-2); transform: translateY(-2px); }
.tm-card--lead { padding: 36px 36px 32px; }
.tm-mark { font-family: var(--font-serif); font-size: 64px; line-height: 0.7; color: var(--clay-400); display: block; height: 28px; }
.tm-card--lead .tm-mark { font-size: 96px; height: 44px; }
.tm-quote { font-family: var(--font-display); font-weight: 500; font-size: 18px; line-height: 1.45; letter-spacing: -0.01em; color: var(--ink-900); margin: 0; }
.tm-card--lead .tm-quote { font-size: 22px; line-height: 1.4; letter-spacing: -0.01em; }
.tm-trans { font-size: 14px; line-height: 1.55; color: var(--ink-600); margin: 0; padding-top: 10px; border-top: 1px solid var(--bone-300); }
.tm-card--lead .tm-trans { font-size: 15px; }
.tm-meta { margin-top: auto; padding-top: 16px; display: flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-700); }
.tm-meta .tm-name { color: var(--ink-900); font-weight: 500; }
.tm-meta .tm-sep { color: var(--clay-500); }
.tm-meta .tm-place { color: var(--ink-600); }
.tm-rest-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.tm-card--small { padding: 20px 22px 18px; gap: 8px; }
.tm-trans--sm { font-size: 13px; padding-top: 8px; }
.tm-meta--sm { padding-top: 12px; font-size: 10px; }
@media (max-width: 1080px) {
  .tm-feature-grid { grid-template-columns: 1fr 1fr; }
  .tm-feature-grid > .reveal:nth-child(1) { grid-column: span 2; grid-row: auto; }
  .tm-rest-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .tm-feature-grid, .tm-rest-grid { grid-template-columns: 1fr; }
  .tm-feature-grid > .reveal:nth-child(1) { grid-column: span 1; }
  .tm-card--lead { padding: 26px 24px; }
  .tm-card--lead .tm-quote { font-size: 20px; }
}

/* ===== About page — visual-led layout ===== */
.about-section { background: var(--bone-50); }
.ab-mosaic { display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 14px; margin-top: 48px; }
.ab-mosaic > .reveal:nth-child(1) { grid-row: span 2; }
.ab-mosaic > .reveal { display: block; }
.ab-mosaic-hero, .ab-mosaic-clip { margin: 0; position: relative; border-radius: 14px; overflow: hidden; background: var(--ink-900); height: 100%; min-height: 280px; box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, 0 22px 50px rgba(20,19,15,0.10), 0 2px 8px rgba(20,19,15,0.05); transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out); }
.ab-mosaic-hero:hover, .ab-mosaic-clip:hover { transform: translateY(-3px); box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, 0 28px 60px rgba(20,19,15,0.14), 0 2px 8px rgba(20,19,15,0.05); }
.ab-mosaic-hero { min-height: 540px; }
.ab-mosaic-hero img, .ab-mosaic-clip video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 1.4s var(--ease-out); }
.ab-mosaic-hero:hover img { transform: scale(1.03); }
.ab-cap { position: absolute; left: 16px; bottom: 14px; right: 16px; display: inline-flex; align-items: center; gap: 8px; padding: 8px 12px; border-radius: 999px; background: rgba(20,19,15,0.6); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--bone-50); width: fit-content; }
.ab-cap-light { background: rgba(20,19,15,0.5); }
.ab-cap-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--clay-400); }
.ab-cap-dot--live { background: #ef5d3f; box-shadow: 0 0 0 0 rgba(239, 93, 63, 0.6); animation: ab-live-pulse 1.8s var(--ease-out) infinite; }
@keyframes ab-live-pulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(239, 93, 63, 0.5); } 70% { box-shadow: 0 0 0 8px rgba(239, 93, 63, 0); } }

@media (max-width: 980px) {
  .ab-mosaic { grid-template-columns: 1fr 1fr; }
  .ab-mosaic > .reveal:nth-child(1) { grid-column: span 2; grid-row: auto; }
  .ab-mosaic-hero { min-height: 360px; }
  .ab-mosaic-clip, .ab-mosaic-hero { min-height: 240px; }
}
@media (max-width: 600px) {
  .ab-mosaic { grid-template-columns: 1fr; }
  .ab-mosaic > .reveal:nth-child(1) { grid-column: span 1; }
}

/* Stats strip */
.ab-stats { margin-top: 48px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid var(--bone-300); border-bottom: 1px solid var(--bone-300); }
.ab-stat { padding: 28px 24px; border-right: 1px solid var(--bone-300); display: flex; flex-direction: column; gap: 4px; opacity: 0; transform: translateY(8px); animation: ab-stat-in .6s var(--ease-out) forwards; }
.ab-stat:last-child { border-right: 0; }
@keyframes ab-stat-in { to { opacity: 1; transform: translateY(0); } }
.ab-stat-k { font-family: var(--font-display); font-weight: 500; font-size: clamp(40px, 5vw, 56px); line-height: 1; letter-spacing: -0.03em; color: var(--ink-900); }
.ab-stat-label { font-family: var(--font-display); font-weight: 600; font-size: 14px; letter-spacing: -0.005em; color: var(--ink-900); margin-top: 12px; }
.ab-stat-sub { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-500); }
@media (max-width: 720px) {
  .ab-stats { grid-template-columns: 1fr 1fr; }
  .ab-stat:nth-child(2n) { border-right: 0; }
  .ab-stat:nth-child(-n+2) { border-bottom: 1px solid var(--bone-300); }
  .ab-stat { padding: 22px 18px; }
}

/* Two-column intro */
.ab-intro { margin-top: 80px; display: grid; grid-template-columns: 1fr 1.2fr; gap: 56px; align-items: start; }
.ab-intro-prose p { font-family: var(--font-display); font-weight: 400; font-size: 22px; line-height: 1.42; letter-spacing: -0.01em; color: var(--ink-900); margin: 0; max-width: 30ch; }
.ab-bullets { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.ab-bullets li { display: grid; grid-template-columns: 36px 1fr; gap: 14px; padding: 16px 0; border-top: 1px solid var(--bone-300); align-items: baseline; font-family: var(--font-display); font-weight: 500; font-size: 16px; letter-spacing: -0.005em; color: var(--ink-800); transition: color .2s var(--ease-out), padding-left .2s var(--ease-out); }
.ab-bullets li:hover { color: var(--ink-900); padding-left: 6px; }
.ab-bullets li:last-child { border-bottom: 1px solid var(--bone-300); }
.ab-bullet-num { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--clay-500); padding-top: 4px; }
@media (max-width: 880px) {
  .ab-intro { grid-template-columns: 1fr; gap: 32px; }
}

/* About achievements (override) */
.ab-stats--achievements { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--ink-900); border-bottom: 1px solid var(--bone-300); }
.ab-stats--achievements .ab-stat { padding: 28px 24px 30px; border-right: 1px solid var(--bone-300); position: relative; flex-direction: column; gap: 4px; }
.ab-stats--achievements .ab-stat::before { content: ""; position: absolute; left: 0; top: 0; height: 2px; width: 36px; background: var(--clay-500); }
.ab-stats--achievements .ab-stat:last-child { border-right: none; }
.ab-stats--achievements .ab-stat .ab-stat-k { color: var(--clay-600); }
@media (max-width: 720px) {
  .ab-stats--achievements { grid-template-columns: 1fr; }
  .ab-stats--achievements .ab-stat { border-right: none; border-bottom: 1px solid var(--bone-300); }
  .ab-stats--achievements .ab-stat:last-child { border-bottom: none; }
}

/* Section block spacing */
.ab-section-block { margin-top: 96px; }
.ab-section-h3 { font-family: var(--font-display); font-weight: 500; font-size: clamp(28px, 3.4vw, 40px); line-height: 1.15; letter-spacing: -0.02em; color: var(--ink-900); max-width: 24ch; margin-top: 8px; }

/* Pillars row */
.ab-pillars { list-style: none; padding: 0; margin: 56px 0 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid var(--bone-300); }
.ab-pillar { display: grid; grid-template-columns: 32px 1fr; gap: 12px; padding: 22px 24px 22px 0; border-right: 1px solid var(--bone-300); align-items: start; }
.ab-pillar:last-child { border-right: none; padding-right: 0; }
.ab-pillar-num { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--clay-500); padding-top: 4px; }
.ab-pillar-t { font-family: var(--font-display); font-weight: 600; font-size: 15px; color: var(--ink-900); letter-spacing: -0.005em; }
.ab-pillar-d { font-size: 13px; line-height: 1.55; color: var(--ink-600); margin-top: 4px; }
@media (max-width: 880px) {
  .ab-pillars { grid-template-columns: 1fr 1fr; }
  .ab-pillar { border-bottom: 1px solid var(--bone-300); padding: 20px 18px; }
  .ab-pillar:nth-child(2n) { border-right: none; }
  .ab-pillar:nth-last-child(-n+2) { border-bottom: none; }
}
@media (max-width: 540px) {
  .ab-pillars { grid-template-columns: 1fr; }
  .ab-pillar { border-right: none; }
}

.ab-section-eyebrow { margin-top: 88px; margin-bottom: 24px; }

/* Photo grid */
.ab-photo-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 12px; grid-auto-rows: 200px; }
.ab-photo-grid > .reveal { display: block; }
.ab-photo { margin: 0; position: relative; border-radius: 10px; overflow: hidden; background: var(--ink-900); height: 100%; transition: transform .3s var(--ease-out), box-shadow .3s var(--ease-out); }
.ab-photo:hover { transform: translateY(-2px); box-shadow: var(--shadow-2); }
.ab-photo img, .ab-photo video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--ease-out); }
.ab-photo:hover img { transform: scale(1.04); }
.ab-photo figcaption { position: absolute; left: 12px; bottom: 10px; padding: 5px 10px; border-radius: 999px; background: rgba(20,19,15,0.55); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--bone-50); display: inline-flex; align-items: center; gap: 6px; opacity: 0; transform: translateY(4px); transition: opacity .25s var(--ease-out), transform .25s var(--ease-out); }
.ab-photo:hover figcaption { opacity: 1; transform: translateY(0); }
.ab-photo--lg { grid-column: span 6; grid-row: span 2; }
.ab-photo-grid > .reveal:nth-child(1) { grid-column: span 6; grid-row: span 2; }
.ab-photo-grid > .reveal:nth-child(n+2) { grid-column: span 3; }
.ab-photo-grid > .reveal:nth-child(7) { grid-column: span 6; }
.ab-photo-grid > .reveal:nth-child(8) { grid-column: span 6; }
.ab-photo--video figcaption { opacity: 1; transform: none; }
@media (max-width: 880px) {
  .ab-photo-grid { grid-template-columns: repeat(6, 1fr); grid-auto-rows: 160px; }
  .ab-photo-grid > .reveal:nth-child(1) { grid-column: span 6; }
  .ab-photo-grid > .reveal:nth-child(n+2) { grid-column: span 3; }
  .ab-photo-grid > .reveal:nth-child(7) { grid-column: span 6; }
  .ab-photo-grid > .reveal:nth-child(8) { grid-column: span 6; }
  .ab-photo figcaption { opacity: 1; transform: none; }
}
@media (max-width: 520px) {
  .ab-photo-grid { grid-template-columns: 1fr 1fr; grid-auto-rows: 140px; }
  .ab-photo-grid > .reveal:nth-child(n) { grid-column: span 1; grid-row: span 1; }
  .ab-photo-grid > .reveal:nth-child(1) { grid-column: span 2; grid-row: span 2; }
}

/* Founder & partner section */
.ab-founder { margin-top: 48px; display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; align-items: center; }
.ab-founder-photo { margin: 0; position: relative; border-radius: 14px; overflow: hidden; background: var(--ink-900); aspect-ratio: 3 / 2; box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, 0 22px 50px rgba(20,19,15,0.10), 0 2px 8px rgba(20,19,15,0.05); }
.ab-founder-photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 1.4s var(--ease-out); }
.ab-founder-photo:hover img { transform: scale(1.025); }
.ab-founder-cap { position: absolute; left: 16px; right: 16px; bottom: 14px; padding: 10px 14px; border-radius: 10px; background: rgba(20,19,15,0.62); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); color: var(--bone-50); font-family: var(--font-display); font-weight: 400; font-size: 13px; line-height: 1.45; letter-spacing: -0.005em; max-width: 460px; }
.ab-founder-text { display: flex; flex-direction: column; gap: 18px; }
.ab-founder-h { font-family: var(--font-display); font-weight: 500; font-size: clamp(28px, 3vw, 36px); line-height: 1.15; letter-spacing: -0.02em; color: var(--ink-900); margin: 0; max-width: 22ch; }
.ab-founder-p { font-family: var(--font-display); font-weight: 400; font-size: 16px; line-height: 1.55; color: var(--ink-700); margin: 0; max-width: 50ch; }
@media (max-width: 880px) {
  .ab-founder { grid-template-columns: 1fr; gap: 28px; }
  .ab-founder-photo { aspect-ratio: 4 / 3; }
}

/* Reduced motion */
@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; }
  .reveal { opacity: 1 !important; transform: none !important; }
  html { scroll-behavior: auto; }
}

/* ===== QC inspection video wall ===== */
.qc-video-wall {
  margin-top: 40px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.qc-video-wall > .reveal { display: block; }
.qc-video {
  margin: 0;
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  background: var(--ink-900);
  aspect-ratio: 16 / 9;
  box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, 0 18px 40px rgba(20,19,15,0.10), 0 2px 8px rgba(20,19,15,0.05);
  transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out);
}
.qc-video:hover { transform: translateY(-2px); box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, 0 28px 60px rgba(20,19,15,0.14), 0 2px 8px rgba(20,19,15,0.05); }
.qc-video video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 880px) {
  .qc-video-wall { grid-template-columns: 1fr 1fr; }
  .qc-video-wall > .reveal:nth-child(3) { grid-column: span 2; }
}
@media (max-width: 520px) {
  .qc-video-wall { grid-template-columns: 1fr; }
  .qc-video-wall > .reveal:nth-child(3) { grid-column: span 1; }
}

/* ===== Factory visit photo wall ===== */
.ab-visit-wall {
  margin-top: 28px;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 220px;
  gap: 12px;
}
.ab-visit-wall > .reveal { display: block; height: 100%; min-height: 220px; }
.ab-visit {
  margin: 0;
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  background: var(--ink-900);
  height: 100%;
  transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out);
  box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, 0 1px 2px rgba(20,19,15,0.04);
}
.ab-visit:hover {
  transform: translateY(-2px);
  box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, 0 22px 50px rgba(20,19,15,0.12), 0 2px 8px rgba(20,19,15,0.05);
}
.ab-visit img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.4s var(--ease-out);
}
.ab-visit:hover img { transform: scale(1.035); }

/* Layout: hero founders shot on left spans 2 rows; supporting tiles fill the rest */
.ab-visit-wall > .reveal:nth-child(1) { grid-column: span 7; grid-row: span 2; }
.ab-visit-wall > .reveal:nth-child(2) { grid-column: span 5; grid-row: span 1; }
.ab-visit-wall > .reveal:nth-child(3) { grid-column: span 5; grid-row: span 1; }
.ab-visit-wall > .reveal:nth-child(4) { grid-column: span 6; grid-row: span 1; }
.ab-visit-wall > .reveal:nth-child(5) { grid-column: span 6; grid-row: span 1; }

@media (max-width: 980px) {
  .ab-visit-wall { grid-template-columns: repeat(6, 1fr); grid-auto-rows: 180px; }
  .ab-visit-wall > .reveal:nth-child(1) { grid-column: span 6; grid-row: span 2; }
  .ab-visit-wall > .reveal:nth-child(2) { grid-column: span 6; }
  .ab-visit-wall > .reveal:nth-child(3) { grid-column: span 3; }
  .ab-visit-wall > .reveal:nth-child(4) { grid-column: span 3; }
  .ab-visit-wall > .reveal:nth-child(5) { grid-column: span 6; grid-row: span 2; }
}
@media (max-width: 560px) {
  .ab-visit-wall { grid-template-columns: 1fr; grid-auto-rows: 220px; }
  .ab-visit-wall > .reveal:nth-child(n) { grid-column: span 1; grid-row: span 1; }
  .ab-visit-wall > .reveal:nth-child(1) { grid-row: span 2; }
}


/* ===== WhoWeHelp — compact strip ===== */
.who-strip-grid { display: grid; gap: 28px; margin-top: 40px; }
.who-strip-row { display: grid; grid-template-columns: 160px 1fr; gap: 24px; align-items: start; padding: 20px 0; border-top: 1px solid var(--bone-300); }
.who-strip-row:last-child { border-bottom: 1px solid var(--bone-300); }
.who-strip-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--clay-500); padding-top: 6px; }
.who-strip-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.who-chip { display: inline-flex; align-items: center; padding: 8px 14px; border: 1px solid var(--bone-300); border-radius: 999px; background: var(--paper); font-size: 14px; color: var(--ink-900); transition: border-color .2s, color .2s, background .2s; }
.who-chip:hover { border-color: var(--ink-900); }
.who-chip--accent { background: var(--ink-900); color: var(--bone-50); border-color: var(--ink-900); }
.who-chip--accent:hover { background: var(--clay-500); border-color: var(--clay-500); color: var(--paper); }
@media (max-width: 720px) {
  .who-strip-row { grid-template-columns: 1fr; gap: 12px; }
}

/* ===== ServicesGrid — icon cards ===== */
.svc-icon-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.svc-preview-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: stretch; }
.svc-preview-cards { display: grid; grid-template-columns: 1fr; gap: 16px; }
.svc-preview-photo-wrap { display: block; height: 100%; }
.svc-preview-photo { margin: 0; position: relative; height: 100%; min-height: 100%; border-radius: 14px; overflow: hidden; border: 1px solid var(--bone-300); background: var(--ink-900); }
.svc-preview-photo img { width: 100%; height: 100%; min-height: 360px; object-fit: cover; display: block; }
.svc-preview-photo-cap { position: absolute; left: 16px; bottom: 14px; color: var(--bone-50); }
.svc-preview-photo-cap .rf-col-mono { color: rgba(250,247,242,0.85); }
@media (max-width: 980px) {
  .svc-preview-grid { grid-template-columns: 1fr; }
  .svc-preview-photo img { min-height: 280px; }
}
.svc-icon-card { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 10px; padding: 28px 26px 30px; transition: transform .35s var(--ease-out), border-color .25s, box-shadow .35s; }

/* Expandable variant (homepage preview) */
.svc-icon-card--expandable { padding: 0; overflow: hidden; }
.svc-icon-card--expandable:hover { transform: none; }
.svc-icon-card--expandable.is-open { border-color: var(--ink-900); box-shadow: 0 1px 0 rgba(20,19,15,0.04), 0 12px 28px rgba(20,19,15,0.06); }
.svc-icon-card-head { display: grid; grid-template-columns: 56px 1fr 24px; align-items: start; gap: 18px; padding: 24px 24px 24px; cursor: pointer; text-align: left; background: transparent; border: 0; font: inherit; color: inherit; width: 100%; }
.svc-icon-card--expandable .svc-icon-wrap { margin-bottom: 0; margin-top: 2px; }
.svc-icon-card--expandable.is-open .svc-icon-wrap { background: var(--ink-900); color: var(--bone-50); }
.svc-icon-meta { min-width: 0; }
.svc-icon-card--expandable .svc-icon-title { margin: 0 0 6px; }
.svc-icon-card--expandable .svc-icon-desc { margin: 0; }
.svc-icon-toggle { width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; font-size: 20px; color: var(--ink-500); margin-top: 4px; }
.svc-icon-body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .35s var(--ease-out); }
.svc-icon-body-inner { overflow: hidden; min-height: 0; padding: 0 24px 0 98px; display: flex; flex-direction: column; gap: 10px; }
.svc-icon-card--expandable.is-open .svc-icon-body-inner { padding-top: 4px; padding-bottom: 22px; }
.svc-icon-body-inner p { font-size: 13.5px; line-height: 1.6; color: var(--ink-700); margin: 0; text-wrap: pretty; }
.svc-icon-card:hover { transform: translateY(-3px); border-color: var(--ink-900); box-shadow: var(--shadow-2); }
.svc-icon-wrap { width: 52px; height: 52px; border-radius: 10px; background: var(--bone-100); display: flex; align-items: center; justify-content: center; color: var(--clay-500); margin-bottom: 22px; transition: background .25s, color .25s; }
.svc-icon-card:hover .svc-icon-wrap { background: var(--ink-900); color: var(--bone-50); }
.svc-icon { display: block; }
.svc-icon-title { font-family: var(--font-display); font-weight: 600; font-size: 19px; letter-spacing: -0.01em; line-height: 1.25; margin: 0 0 10px; color: var(--ink-900); }
.svc-icon-desc { font-size: 14px; line-height: 1.55; color: var(--ink-700); margin: 0; }
@media (max-width: 980px) { .svc-icon-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .svc-icon-grid { grid-template-columns: 1fr; } }

/* ===== ServicesGrid — detailed cards (Services page) ===== */
/* ===== ServicesGrid — Services page (new spec) ===== */
/* Section heads */
.svc-section-head { max-width: 880px; }
.svc-section-title { font-family: var(--font-display); font-weight: 600; font-size: clamp(28px, 3vw, 38px); letter-spacing: -0.015em; line-height: 1.15; margin: 14px 0 0; color: var(--ink-900); text-wrap: balance; }
.svc-section-lede { font-size: 16px; line-height: 1.6; color: var(--ink-700); margin: 14px 0 0; max-width: 70ch; text-wrap: pretty; }

/* Core services — accordion list */
.svc-core-list { display: flex; flex-direction: column; gap: 10px; }
.svc-core-item { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 14px; transition: border-color .25s, box-shadow .3s; overflow: hidden; }
.svc-core-item.is-open { border-color: var(--ink-900); box-shadow: 0 1px 0 rgba(20,19,15,0.04), 0 20px 40px rgba(20,19,15,0.06); }
.svc-core-item-head { width: 100%; display: grid; grid-template-columns: 64px 1fr 28px; align-items: center; gap: 20px; padding: 22px 28px; cursor: pointer; text-align: left; background: transparent; border: 0; font: inherit; color: inherit; }
.svc-core-icon-wrap { width: 52px; height: 52px; border-radius: 10px; background: var(--bone-100); color: var(--clay-500); display: flex; align-items: center; justify-content: center; transition: background .2s var(--ease-out), color .2s var(--ease-out); }
.svc-core-item.is-open .svc-core-icon-wrap { background: var(--ink-900); color: var(--bone-50); }
.svc-core-meta { min-width: 0; display: flex; flex-direction: column; gap: 4px; }
.svc-core-num { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.18em; color: var(--ink-500); }
.svc-core-title { font-family: var(--font-display); font-weight: 600; font-size: 20px; letter-spacing: -0.01em; line-height: 1.25; margin: 0; color: var(--ink-900); text-wrap: balance; }
.svc-core-toggle { width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; font-size: 22px; color: var(--ink-500); font-weight: 400; }
.svc-core-body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .35s var(--ease-out); }
.svc-core-body-inner { overflow: hidden; min-height: 0; padding: 0 28px 0 112px; display: flex; flex-direction: column; gap: 12px; }
.svc-core-item.is-open .svc-core-body-inner { padding-top: 4px; padding-bottom: 26px; }
.svc-core-body-inner p { font-size: 14.5px; line-height: 1.6; color: var(--ink-700); margin: 0; text-wrap: pretty; }
@media (max-width: 720px) {
  .svc-core-item-head { grid-template-columns: 52px 1fr 24px; padding: 18px 20px; gap: 14px; }
  .svc-core-icon-wrap { width: 44px; height: 44px; }
  .svc-core-title { font-size: 17px; }
  .svc-core-body-inner { padding: 0 20px 0 80px; }
}

/* Support — accordion list (size-matched to core to keep Part 1 / Part 2 consistent) */
.svc-support-list { display: flex; flex-direction: column; gap: 10px; }
.svc-support-item { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 14px; transition: border-color .25s, box-shadow .3s; overflow: hidden; }
.svc-support-item.is-open { border-color: var(--ink-900); box-shadow: 0 1px 0 rgba(20,19,15,0.04), 0 20px 40px rgba(20,19,15,0.06); }
.svc-support-head { width: 100%; display: grid; grid-template-columns: 64px 1fr 28px; align-items: center; gap: 20px; padding: 22px 28px; background: transparent; border: 0; cursor: pointer; text-align: left; font: inherit; color: inherit; }
.svc-support-icon-wrap { width: 52px; height: 52px; border-radius: 10px; background: var(--bone-100); color: var(--clay-500); display: flex; align-items: center; justify-content: center; transition: background .2s var(--ease-out), color .2s var(--ease-out); }
.svc-support-item.is-open .svc-support-icon-wrap { background: var(--ink-900); color: var(--bone-50); }
.svc-support-meta { min-width: 0; display: flex; flex-direction: column; gap: 4px; }
.svc-support-num { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.18em; color: var(--ink-500); }
.svc-support-title { font-family: var(--font-display); font-weight: 600; font-size: 20px; letter-spacing: -0.01em; line-height: 1.25; color: var(--ink-900); text-wrap: balance; }
.svc-support-toggle { width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; font-size: 22px; color: var(--ink-500); font-weight: 400; }
.svc-support-body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .35s var(--ease-out); }
.svc-support-body-inner { overflow: hidden; min-height: 0; padding: 0 28px 0 112px; display: flex; flex-direction: column; gap: 12px; }
.svc-support-item.is-open .svc-support-body-inner { padding-top: 4px; padding-bottom: 26px; }
.svc-support-body-inner p { font-size: 14.5px; line-height: 1.6; color: var(--ink-700); margin: 0; text-wrap: pretty; }
@media (max-width: 720px) {
  .svc-support-head { grid-template-columns: 52px 1fr 24px; padding: 18px 20px; gap: 14px; }
  .svc-support-icon-wrap { width: 44px; height: 44px; }
  .svc-support-title { font-size: 17px; }
  .svc-support-body-inner { padding: 0 20px 0 80px; }
}

/* Do not provide */
.svc-dnp { margin-top: 96px; padding: 48px 48px 44px; background: var(--bone-100); border: 1px solid var(--bone-300); border-radius: 14px; }
.svc-dnp-head { max-width: 70ch; }
.svc-dnp-title { font-family: var(--font-display); font-weight: 600; font-size: clamp(22px, 2.4vw, 28px); letter-spacing: -0.01em; line-height: 1.2; margin: 14px 0 0; color: var(--ink-900); text-wrap: balance; }
.svc-dnp-list { list-style: none; padding: 0; margin: 28px 0 0; display: grid; grid-template-columns: 1fr 1fr; gap: 14px 32px; }
.svc-dnp-list li { position: relative; padding-left: 22px; font-size: 14.5px; line-height: 1.6; color: var(--ink-800); text-wrap: pretty; }
.svc-dnp-list li::before { content: "—"; position: absolute; left: 0; top: 0; color: var(--clay-500); font-weight: 500; }
@media (max-width: 880px) {
  .svc-dnp { padding: 32px 26px 30px; margin-top: 72px; }
  .svc-dnp-list { grid-template-columns: 1fr; gap: 12px; }
}

/* Final CTA */
.svc-final-cta { margin-top: 80px; background: var(--ink-900); color: var(--bone-50); border-radius: 14px; padding: 64px 56px; }
.svc-final-cta-inner { max-width: 720px; }
.svc-final-cta .eyebrow { color: var(--clay-300, var(--clay-500)); }
.svc-final-cta .eyebrow-dot { background: var(--clay-500); }
.svc-final-cta-title { font-family: var(--font-display); font-weight: 600; font-size: clamp(28px, 3.2vw, 40px); letter-spacing: -0.015em; line-height: 1.15; margin: 14px 0 18px; color: var(--bone-50); text-wrap: balance; }
.svc-final-cta-lede { font-size: 16px; line-height: 1.6; color: var(--bone-100); margin: 0; max-width: 60ch; text-wrap: pretty; }
.svc-final-cta .btn-outline { border-color: var(--bone-300); color: var(--bone-50); }
.svc-final-cta .btn-outline:hover { background: rgba(255,255,255,0.08); border-color: var(--bone-50); }
@media (max-width: 880px) {
  .svc-final-cta { padding: 44px 28px; margin-top: 60px; }
}

/* Service detail photo (Services page, between Part 1 & Part 2) */
.svc-detail-photo { margin: 0; position: relative; border-radius: 14px; overflow: hidden; border: 1px solid var(--bone-300); background: var(--ink-900); aspect-ratio: 16 / 7; }
.svc-detail-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.svc-detail-photo-cap { position: absolute; left: 18px; bottom: 16px; }
.svc-detail-photo-cap .rf-col-mono { color: rgba(250,247,242,0.85); }

/* Process detail photo (Process page, above the steps) */
.contact-photo { margin: 0; position: relative; border-radius: 12px; overflow: hidden; border: 1px solid var(--bone-300); background: var(--ink-900); aspect-ratio: 4 / 3; }
.contact-photo--lg { aspect-ratio: 3 / 4; }
.contact-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.contact-photo-cap { position: absolute; left: 14px; bottom: 12px; }
.contact-photo-cap .rf-col-mono { color: rgba(250,247,242,0.85); }
.process-detail-photo { margin: 0 0 36px; position: relative; border-radius: 14px; overflow: hidden; border: 1px solid var(--bone-300); background: var(--ink-900); aspect-ratio: 16 / 7; }
.process-detail-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.process-detail-photo-cap { position: absolute; left: 18px; bottom: 16px; }
.process-detail-photo-cap .rf-col-mono { color: rgba(250,247,242,0.85); }

/* ===== ReviewFirst — head w/ photo ===== */
.rf-head-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 48px; align-items: end; }
.rf-head-copy { min-width: 0; }
.rf-head-photo { display: block; }
.rf-photo { margin: 0; border-radius: 14px; overflow: hidden; border: 1px solid var(--bone-300); background: var(--ink-900); aspect-ratio: 4 / 3; }
.rf-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width: 980px) { .rf-head-grid { grid-template-columns: 1fr; gap: 28px; } }

/* ===== ReviewFirst — compare ===== */
.rf-compare { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items: stretch; }
.rf-compare--vertical { align-items: stretch; }
.rf-compare > .reveal { display: flex; height: 100%; }
.rf-col { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 12px; padding: 28px; flex: 1; display: flex; flex-direction: column; }
.rf-col--after { border-color: oklch(0.78 0.10 150); background: oklch(0.93 0.05 150); color: var(--ink-900); }
.rf-col-label { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 22px; }
.rf-col-tag { display: inline-flex; align-items: center; padding: 5px 11px; border-radius: 999px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; }
.rf-col-tag--mute { background: var(--bone-100); color: var(--ink-700); border: 1px solid var(--bone-300); }
.rf-col-tag--accent { background: oklch(0.55 0.14 150); color: var(--bone-50); }
.rf-col-logo { height: 22px; width: auto; opacity: 0.92; filter: none; }
.rf-col-mono { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--clay-500); }
.rf-col--after .rf-col-mono { color: oklch(0.45 0.10 150); }
.rf-flow { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 10px 8px; align-items: center; }
.rf-flow--vertical { flex-direction: column; align-items: stretch; gap: 10px; flex-wrap: nowrap; }
.rf-flow--vertical .rf-step { display: flex; padding: 14px 16px; border-radius: 8px; gap: 12px; align-items: center; position: relative; }
.rf-flow--vertical .rf-step + .rf-step::before { content: ""; position: absolute; left: 22px; top: -10px; width: 1px; height: 10px; background: var(--bone-300); }
.rf-col--after .rf-flow--vertical .rf-step + .rf-step::before { background: oklch(0.65 0.10 150 / 0.45); }
.rf-step { display: inline-flex; align-items: center; gap: 8px; padding: 10px 14px; border-radius: 8px; background: var(--bone-100); font-size: 14px; font-weight: 500; }
.rf-col--after .rf-step { background: rgba(255,255,255,0.6); color: var(--ink-900); border: 1px solid oklch(0.78 0.08 150 / 0.4); }
.rf-step-num { font-family: var(--font-mono); font-size: 10px; color: var(--clay-500); letter-spacing: 0.1em; }
.rf-step--mute { color: var(--ink-700); }
.rf-step--warn { background: oklch(0.92 0.04 50); color: oklch(0.4 0.1 35); }
.rf-step--accent { background: oklch(0.55 0.14 150) !important; color: var(--bone-50) !important; }
.rf-flow-arrow { font-family: var(--font-mono); color: var(--clay-500); font-size: 14px; }
.rf-col--after .rf-flow-arrow { color: oklch(0.45 0.10 150); }
.rf-note { margin-top: 28px; font-size: 13px; line-height: 1.55; color: var(--ink-700); max-width: 760px; font-style: italic; }
@media (max-width: 820px) { .rf-compare { grid-template-columns: 1fr; } }

/* ===== Testimonials — small ===== */
.tm-rest-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.tm-card--small { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 10px; padding: 28px 28px 26px; display: flex; flex-direction: column; gap: 14px; }
.tm-quote-sm { font-family: var(--font-display); font-weight: 500; font-size: 18px; line-height: 1.45; letter-spacing: -0.01em; color: var(--ink-900); margin: 0; }
.tm-meta--sm { padding-top: 16px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-700); }
@media (max-width: 720px) { .tm-rest-grid { grid-template-columns: 1fr; } }

/* ===== SampleWork — clean (no captions) variant ===== */
.sw-grid--clean .sw-card--clean { background: transparent; border: 0; }
.sw-grid--clean .sw-card--clean:hover { transform: translateY(-2px); box-shadow: none; border-color: transparent; }
.sw-media--clean { background: transparent; }
.sw-media--clean img { padding: 4%; }

/* Preview grid: 4-up, simple */
.sw-grid--preview { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 220px; }
.sw-grid--preview > .reveal { grid-column: span 1; grid-row: span 1; }
@media (max-width: 980px) { .sw-grid--preview { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .sw-grid--preview { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 160px; } }


/* ===== ConsultingPreview — minimal two-column ===== */
.cp-groups { display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; }
.cp-group { padding: 28px 0 4px; border-top: 1px solid var(--ink-900); }
.cp-group-head { display: flex; align-items: baseline; gap: 14px; margin-bottom: 22px; }
.cp-group-num { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; color: var(--clay-500); }
.cp-group-label { font-family: var(--font-display); font-weight: 600; font-size: 22px; letter-spacing: -0.01em; color: var(--ink-900); }
.cp-group-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.cp-group-item { padding: 14px 0; border-bottom: 1px solid var(--bone-300); font-size: 15px; line-height: 1.55; color: var(--ink-700); }
.cp-group-item:last-child { border-bottom: 0; }
@media (max-width: 820px) { .cp-groups { grid-template-columns: 1fr; gap: 8px; } }

/* ===== Three-step preview (homepage) ===== */
.ptl3 { display: grid; grid-template-columns: 1fr 1.05fr; gap: 56px; align-items: stretch; }
.ptl3-photo { margin: 0; border-radius: 12px; overflow: hidden; border: 1px solid var(--bone-300); position: relative; min-height: 420px; }
.ptl3-photo img { width: 100%; height: 100%; min-height: 420px; object-fit: cover; display: block; }
.ptl3-stack { display: flex; flex-direction: column; justify-content: space-between; gap: 24px; }
.ptl3-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 24px; position: relative; }
.ptl3-list::before { content: ""; position: absolute; left: 19px; top: 24px; bottom: 24px; width: 2px; background: var(--bone-300); }
.ptl3-item { display: grid; grid-template-columns: 40px 1fr; gap: 18px; align-items: start; position: relative; }
.ptl3-num {
  width: 40px; height: 40px; border-radius: 50%; background: var(--paper);
  border: 2px solid var(--clay-500); color: var(--clay-600);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono, ui-monospace, monospace); font-size: 13px; font-weight: 600;
  position: relative; z-index: 2;
}
.ptl3-body {}
.ptl3-label { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; margin-bottom: 6px; }
.ptl3-label-name { font-family: var(--font-sans); font-size: 22px; font-weight: 600; color: var(--ink-900); }
.ptl3-label-range { font-family: var(--font-mono, ui-monospace, monospace); font-size: 11px; letter-spacing: 0.08em; color: var(--ink-500); text-transform: uppercase; }
.ptl3-desc { font-size: 15px; line-height: 1.55; color: var(--ink-700); margin: 0; max-width: 520px; }
.ptl3-cta { padding-top: 8px; }

/* Project Flow Panel (homepage "How we work together" right column) */
.pfp {
  position: relative;
  border: 1px solid var(--bone-300);
  border-radius: 16px;
  padding: 32px 32px 24px;
  background:
    radial-gradient(ellipse at 100% 0%, rgba(204, 102, 67, 0.10), transparent 60%),
    var(--paper);
  display: flex;
  flex-direction: column;
}
.pfp-head { margin-bottom: 24px; }
.pfp-eyebrow {
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-500);
}
.pfp-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 22px;
  position: relative;
}
.pfp-list::before {
  content: "";
  position: absolute;
  left: 12px;
  top: 24px;
  bottom: 24px;
  width: 1px;
  background: var(--bone-300);
}
.pfp-item {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 14px;
  align-items: start;
  position: relative;
}
.pfp-num {
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 12px;
  letter-spacing: 0.18em;
  color: var(--clay-500);
  font-weight: 500;
  padding-top: 4px;
  background: var(--paper);
  z-index: 1;
}
.pfp-body { min-width: 0; }
.pfp-title {
  font-family: var(--font-display, var(--font-sans));
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.005em;
  line-height: 1.3;
  margin: 0 0 4px 0;
  color: var(--ink-900);
}
.pfp-desc {
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink-700);
  margin: 0;
  text-wrap: pretty;
}
.pfp-divider {
  height: 1px;
  background: var(--bone-300);
  margin: 28px 0 14px;
}
.pfp-cta { padding: 0; }
.pfp-cta-link {
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-900);
  text-decoration: none;
  transition: color 0.2s var(--ease-out);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.pfp-cta-link:hover {
  color: var(--clay-500);
}

@media (max-width: 900px) {
  .ptl3 { grid-template-columns: 1fr; gap: 32px; }
  .ptl3-photo { min-height: 280px; }
  .ptl3-photo img { min-height: 280px; }
  .pfp { padding: 24px 22px 20px; }
}


/* Process horizontal stepper (Process page) */
.phs { display: flex; flex-direction: column; gap: 28px; }
.phs-rail-wrap { position: relative; padding: 16px 8px 8px; }
.phs-rail { position: absolute; left: 8px; right: 8px; top: 28px; height: 2px; background: var(--bone-300); border-radius: 2px; }
.phs-rail-fill { position: absolute; left: 0; top: 0; bottom: 0; background: var(--clay-500); border-radius: 2px; transition: width .35s ease; }
.phs-nodes { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(8, 1fr); gap: 4px; position: relative; }
.phs-node-btn { width: 100%; background: transparent; border: 0; padding: 0; cursor: pointer; display: flex; flex-direction: column; align-items: center; gap: 10px; font-family: inherit; color: inherit; text-align: center; }
.phs-dot { width: 18px; height: 18px; border-radius: 50%; background: var(--paper); border: 2px solid var(--bone-300); transition: background .2s, border-color .2s, box-shadow .2s, transform .2s; position: relative; z-index: 1; }
.phs-node--done .phs-dot { background: var(--clay-500); border-color: var(--clay-500); }
.phs-node--active .phs-dot { background: var(--clay-500); border-color: var(--clay-500); box-shadow: 0 0 0 6px rgba(193,98,53,0.18); transform: scale(1.05); }
.phs-node-num { font-family: var(--font-mono); font-size: 11px; color: var(--ink-500); letter-spacing: 0.04em; }
.phs-node--active .phs-node-num { color: var(--clay-600); font-weight: 600; }
.phs-node-title { font-size: 12px; line-height: 1.35; color: var(--ink-700); padding: 0 4px; }
.phs-node--active .phs-node-title { color: var(--ink-900); font-weight: 600; }
.phs-node-btn:hover .phs-dot { border-color: var(--clay-500); }
.phs-node-btn:hover .phs-node-title { color: var(--ink-900); }

.phs-card { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 12px; padding: 36px 36px 28px; animation: phsFade .35s ease both; }
@keyframes phsFade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }
.phs-card-eyebrow { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--clay-600); display: flex; gap: 8px; align-items: center; margin-bottom: 10px; }
.phs-card-eyebrow-sep { color: var(--bone-400); }
.phs-card-title { font-family: var(--font-sans); font-size: 36px; line-height: 1.15; font-weight: 600; color: var(--ink-900); margin: 0 0 20px; }
.phs-card-divider { height: 1px; background: var(--bone-300); margin: 0 0 24px; }
.phs-card-cols { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 32px; margin-bottom: 28px; }
.phs-card-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-500); margin-bottom: 10px; }
.phs-card-col p { font-size: 15px; line-height: 1.6; color: var(--ink-800); margin: 0; }
.phs-card-foot { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-top: 20px; border-top: 1px solid var(--bone-300); }
.phs-card-counter { font-family: var(--font-mono); font-size: 14px; color: var(--ink-500); }
.phs-card-counter strong { color: var(--ink-900); font-weight: 600; }
.phs-card-counter span { margin: 0 4px; color: var(--bone-400); }
.btn-outline:disabled { opacity: 0.4; cursor: not-allowed; }

@media (max-width: 900px) {
  .phs-nodes { grid-template-columns: repeat(8, 1fr); gap: 0; }
  .phs-node-title { display: none; }
  .phs-card { padding: 24px; }
  .phs-card-title { font-size: 26px; }
  .phs-card-cols { grid-template-columns: 1fr; gap: 20px; }
}

/* =====================================================
   MATERIALS PAGE
===================================================== */
.materials-toc { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 12px; padding: 24px 28px; }
.materials-toc-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px 24px; }
.materials-toc-list a { display: flex; align-items: baseline; gap: 12px; text-decoration: none; color: var(--ink-800); font-family: var(--font-sans); font-size: 16px; padding: 8px 0; border-bottom: 1px solid transparent; transition: border-color .2s, color .2s; }
.materials-toc-list a:hover { color: var(--clay-600); border-bottom-color: var(--clay-500); }
.materials-toc-num { font-family: var(--font-mono); font-size: 12px; color: var(--ink-500); letter-spacing: 0.06em; }

.materials-stack { display: flex; flex-direction: column; gap: 56px; }
.material-card { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 14px; padding: 40px; }
.material-card-head { display: flex; gap: 24px; align-items: flex-start; margin-bottom: 28px; padding-bottom: 24px; border-bottom: 1px solid var(--bone-300); }
.material-card-num { font-family: var(--font-mono); font-size: 14px; color: var(--clay-600); letter-spacing: 0.08em; padding-top: 8px; min-width: 36px; }
.material-card-title { margin: 0 0 6px; }
.material-card-tagline { margin: 0; max-width: 640px; color: var(--ink-700); }

.material-card-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px 36px; }
.material-block { padding: 0; }
.material-block--full { grid-column: 1 / -1; }
.material-block--note { background: var(--bone-50, #faf6f1); border-left: 3px solid var(--clay-500); padding: 16px 20px; border-radius: 4px; }
.material-block-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-500); margin-bottom: 10px; }
.material-block-label--good { color: #2f6e44; }
.material-block-label--warn { color: #a35a13; }
.material-block p { font-size: 15px; line-height: 1.65; color: var(--ink-800); margin: 0; }
.material-list { list-style: none; padding: 0; margin: 0; }
.material-list li { font-size: 15px; line-height: 1.6; color: var(--ink-800); padding: 6px 0 6px 18px; position: relative; }
.material-list li:before { content: "•"; color: var(--clay-500); position: absolute; left: 4px; }

.materials-foot { margin-top: 80px; padding: 56px 48px; background: var(--paper); border: 1px solid var(--bone-300); border-radius: 14px; }

@media (max-width: 800px) {
  .material-card { padding: 28px 22px; }
  .material-card-head { flex-direction: column; gap: 8px; }
  .material-card-grid { grid-template-columns: 1fr; gap: 22px; }
  .materials-foot { padding: 32px 22px; }
}

/* =====================================================
   PRODUCT TYPES PAGE
===================================================== */
.ptypes-toc { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 12px; padding: 24px 28px; }
.ptypes-toc-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px 24px; }
.ptypes-toc-list a { display: flex; align-items: baseline; gap: 12px; text-decoration: none; color: var(--ink-800); font-size: 16px; padding: 8px 0; border-bottom: 1px solid transparent; transition: border-color .2s, color .2s; }
.ptypes-toc-list a:hover { color: var(--clay-600); border-bottom-color: var(--clay-500); }
.ptypes-toc-num { font-family: var(--font-mono); font-size: 12px; color: var(--ink-500); letter-spacing: 0.06em; }

.ptypes-stack { display: flex; flex-direction: column; gap: 56px; }
.ptype-card { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 14px; padding: 40px; }
.ptype-card-head { display: flex; gap: 24px; align-items: flex-start; margin-bottom: 28px; padding-bottom: 24px; border-bottom: 1px solid var(--bone-300); }
.ptype-card-num { font-family: var(--font-mono); font-size: 14px; color: var(--clay-600); letter-spacing: 0.08em; padding-top: 8px; min-width: 36px; }
.ptype-card-title { margin: 0 0 6px; }
.ptype-card-tagline { margin: 0; max-width: 640px; color: var(--ink-700); }

.ptype-card-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px 36px; }
.ptype-block { padding: 0; }
.ptype-block--full { grid-column: 1 / -1; }
.ptype-block--note { background: var(--bone-50, #faf6f1); border-left: 3px solid var(--clay-500); padding: 16px 20px; border-radius: 4px; }
.ptype-block-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-500); margin-bottom: 10px; }
.ptype-block p { font-size: 15px; line-height: 1.65; color: var(--ink-800); margin: 0; }
.ptype-list { list-style: none; padding: 0; margin: 0; }
.ptype-list li { font-size: 15px; line-height: 1.6; color: var(--ink-800); padding: 6px 0 6px 18px; position: relative; }
.ptype-list li:before { content: "•"; color: var(--clay-500); position: absolute; left: 4px; }
.ptype-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.ptype-tag { display: inline-block; padding: 6px 12px; background: var(--bone-100, #f4ece2); border: 1px solid var(--bone-300); border-radius: 999px; font-size: 13px; color: var(--ink-800); }

.ptypes-foot { margin-top: 80px; padding: 56px 48px; background: var(--paper); border: 1px solid var(--bone-300); border-radius: 14px; }

@media (max-width: 800px) {
  .ptype-card { padding: 28px 22px; }
  .ptype-card-head { flex-direction: column; gap: 8px; }
  .ptype-card-grid { grid-template-columns: 1fr; gap: 22px; }
  .ptypes-foot { padding: 32px 22px; }
}

/* =====================================================
   BLOG INDEX
===================================================== */
.blog-featured-wrap { margin-bottom: 48px; }
.blog-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 28px; }
.blog-card { background: var(--paper); border: 1px solid var(--bone-300); border-radius: 14px; overflow: hidden; transition: transform .25s, border-color .25s, box-shadow .25s; }
.blog-card:hover { transform: translateY(-3px); border-color: var(--clay-500); box-shadow: 0 12px 32px rgba(0,0,0,0.06); }
.blog-card--featured { display: grid; grid-template-columns: 1.2fr 1fr; }
.blog-card--featured .blog-card-link { display: contents; }
.blog-card-link { display: block; text-decoration: none; color: inherit; }
.blog-card-cover { margin: 0; aspect-ratio: 16 / 9; overflow: hidden; background: var(--bone-200); }
.blog-card--featured .blog-card-cover { aspect-ratio: auto; height: 100%; }
.blog-card-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.blog-card-body { padding: 28px; }
.blog-card--featured .blog-card-body { padding: 40px; align-self: center; }
.blog-card-meta { font-family: var(--font-mono); font-size: 11px; color: var(--ink-500); letter-spacing: 0.06em; text-transform: uppercase; display: flex; align-items: center; flex-wrap: wrap; gap: 6px; margin-bottom: 16px; }
.blog-card-cat { color: var(--clay-600); }
.blog-card-sep { color: var(--bone-400); }
.blog-card-title { font-family: var(--font-sans); font-size: 22px; line-height: 1.3; font-weight: 600; color: var(--ink-900); margin: 0 0 14px; }
.blog-card--featured .blog-card-title { font-size: 32px; line-height: 1.15; }
.blog-card-excerpt { font-size: 15px; line-height: 1.6; color: var(--ink-700); margin: 0 0 18px; }
.blog-card-audience { font-size: 13px; color: var(--ink-600); margin-bottom: 18px; padding: 10px 14px; background: var(--bone-50, #faf6f1); border-radius: 6px; }
.blog-card-cta { font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.04em; color: var(--clay-600); }
.blog-card--soon { opacity: 0.85; background: var(--bone-50, #faf6f1); border-style: dashed; }
.blog-card-cta--soon { color: var(--ink-500); }

.blog-cta-foot { margin-top: 48px; padding: 56px 48px; background: var(--paper); border: 1px solid var(--bone-300); border-radius: 14px; }

@media (max-width: 800px) {
  .blog-card--featured { grid-template-columns: 1fr; }
  .blog-card--featured .blog-card-body { padding: 28px; }
  .blog-card--featured .blog-card-title { font-size: 24px; }
  .blog-cta-foot { padding: 32px 22px; }
}

/* =====================================================
   BLOG POST (article)
===================================================== */
.article { padding: 48px 0 100px; }
.article-header { max-width: 880px; margin: 0 auto 32px; }
.article-meta { font-family: var(--font-mono); font-size: 12px; color: var(--ink-500); letter-spacing: 0.06em; text-transform: uppercase; display: flex; align-items: center; flex-wrap: wrap; gap: 8px; margin-bottom: 22px; }
.article-meta-cat { color: var(--clay-600); }
.article-meta-sep { color: var(--bone-400); }
.article-title { font-family: var(--font-sans); font-size: 56px; line-height: 1.05; font-weight: 700; letter-spacing: -0.02em; color: var(--ink-900); margin: 0 0 24px; }
.article-subtitle { max-width: 760px; font-size: 22px; line-height: 1.5; color: var(--ink-700); margin: 0 0 28px; }
.article-audience { display: inline-block; font-size: 14px; color: var(--ink-700); padding: 10px 16px; background: var(--bone-50, #faf6f1); border-left: 3px solid var(--clay-500); border-radius: 4px; }

.article-cover { margin: 0 auto 56px; max-width: 1100px; }
.article-cover img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; display: block; border-radius: 14px; background: var(--bone-200); }
.article-cover-disclaimer { font-family: var(--font-mono); font-size: 12px; line-height: 1.55; color: var(--ink-500); padding: 12px 4px 0; max-width: 800px; margin: 0 auto; text-align: center; letter-spacing: 0.02em; }

.article-toc { max-width: 880px; margin: 0 auto 56px; background: var(--paper); border: 1px solid var(--bone-300); border-radius: 12px; padding: 28px 32px; }
.article-toc-list { list-style: none; padding: 0; margin: 0; counter-reset: none; display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 8px 24px; }
.article-toc-list a { display: flex; align-items: baseline; gap: 12px; text-decoration: none; color: var(--ink-800); font-size: 15px; padding: 8px 0; border-bottom: 1px solid transparent; transition: border-color .2s, color .2s; }
.article-toc-list a:hover { color: var(--clay-600); border-bottom-color: var(--clay-500); }
.article-toc-num { font-family: var(--font-mono); font-size: 11px; color: var(--ink-500); letter-spacing: 0.06em; min-width: 22px; }

.article-body { max-width: 760px; margin: 0 auto; font-family: var(--font-sans); }
.article-section { margin-bottom: 64px; }
.article-section-head { display: flex; align-items: baseline; gap: 16px; margin-bottom: 20px; padding-bottom: 14px; border-bottom: 1px solid var(--bone-300); }
.article-section-num { font-family: var(--font-mono); font-size: 13px; color: var(--clay-600); letter-spacing: 0.08em; font-weight: 500; }
.article-section-title { margin: 0; font-size: 30px; line-height: 1.2; }
.article-section-body p { font-size: 17px; line-height: 1.75; color: var(--ink-800); margin: 0 0 18px; }
.article-section-body h3 { font-family: var(--font-sans); font-size: 22px; font-weight: 600; line-height: 1.3; color: var(--ink-900); margin: 30px 0 14px; }
.article-section-body a { color: var(--clay-600); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.article-section-body a:hover { color: var(--clay-700, #8a3d18); }
.article-section-body strong { color: var(--ink-900); font-weight: 600; }
.article-section-body em { font-style: italic; }

.article-list { list-style: none; padding: 0; margin: 0 0 18px; }
.article-list li { font-size: 17px; line-height: 1.75; color: var(--ink-800); padding: 4px 0 4px 26px; position: relative; }
.article-list li:before { content: "→"; color: var(--clay-500); position: absolute; left: 0; font-family: var(--font-mono); font-size: 14px; top: 8px; }
.article-list--warn li:before { content: "!"; color: #a35a13; font-weight: 700; }

.article-pullquote { margin: 36px 0; padding: 28px 32px; border-left: 4px solid var(--clay-500); background: var(--bone-50, #faf6f1); font-family: var(--font-display, var(--font-sans)); font-size: 22px; line-height: 1.5; font-style: italic; color: var(--ink-900); border-radius: 0 8px 8px 0; }
.article-pullquote::before { content: "\201C"; display: block; font-size: 36px; color: var(--clay-500); line-height: 0.4; margin-bottom: 12px; }

.article-callout { margin: 28px 0; padding: 20px 24px; border-radius: 10px; font-size: 16px; line-height: 1.6; color: var(--ink-800); }
.article-callout--note { background: var(--bone-50, #faf6f1); border: 1px solid var(--bone-300); }
.article-callout--good { background: #f1f7f3; border: 1px solid #c8d8cc; }
.article-callout--warn { background: #fbf3eb; border: 1px solid #ddc3a3; }
.article-callout-title { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 8px; }
.article-callout--good .article-callout-title { color: #2f6e44; }
.article-callout--warn .article-callout-title { color: #a35a13; }
.article-callout--note .article-callout-title { color: var(--clay-600); }
.article-callout-body p { margin: 0; font-size: 16px; }

.article-footer { margin-top: 80px; padding: 48px 0 0; border-top: 1px solid var(--bone-300); display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 32px; }
.article-footer-author-name { font-family: var(--font-sans); font-size: 18px; font-weight: 600; color: var(--ink-900); }
.article-footer-author-meta { font-size: 14px; color: var(--ink-600); margin-top: 4px; max-width: 420px; }
.article-footer-cta { display: flex; gap: 12px; flex-wrap: wrap; }

/* Case study — facts table at top of post */
.case-facts {
  border: 1px solid var(--bone-300);
  border-radius: 12px;
  background: var(--bone-50, #faf6f1);
  padding: 6px 0;
  margin: 12px 0 36px;
}
.case-facts-row {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 24px;
  padding: 14px 28px;
  border-bottom: 1px solid var(--bone-300);
}
.case-facts-row:last-child { border-bottom: 0; }
.case-facts-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-500);
  padding-top: 2px;
}
.case-facts-value { font-size: 16px; line-height: 1.55; color: var(--ink-800); }

@media (max-width: 700px) {
  .case-facts-row { grid-template-columns: 1fr; gap: 4px; padding: 14px 22px; }
}

/* Pull quote attribution */
.article-pullquote-attribution {
  display: block;
  font-style: normal;
  font-size: 13px;
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  color: var(--ink-500);
  margin-top: 14px;
}
/* Translation under a German pull-quote (lighter, smaller, English) */
.article-pullquote-translation {
  display: block;
  margin-top: 12px;
  font-style: normal;
  font-size: 15px;
  line-height: 1.5;
  color: var(--ink-600);
  font-weight: 400;
}

/* =====================================================
   WHO WE WORK WITH (HomePage section)
   Layout: [image-design] [4 cards 2x2] [image-shelf] — three columns
===================================================== */
.who-section { background: var(--paper); }
.who-layout {
  display: grid;
  grid-template-columns: 1fr 1.3fr 1fr;
  gap: 24px;
  align-items: stretch;
}

/* Cards in middle column — 2 columns × 2 rows, both rows STRETCH to match image height */
.who-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 16px;
}
.who-card {
  padding: 22px 24px;
  background: var(--bone-50, #faf6f1);
  border: 1px solid var(--bone-300);
  border-left: 3px solid var(--clay-500);
  border-radius: 8px;
  transition: transform .25s, box-shadow .25s;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.who-card:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,0,0,0.04); }
.who-card-tag {
  font-family: var(--font-sans);
  font-size: 22px;
  font-weight: 600;
  color: var(--ink-900);
  margin-bottom: 10px;
  line-height: 1.2;
  letter-spacing: -0.01em;
}
.who-card-note {
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink-600);
}

/* Side images — vertical 4:5 (matches the user's reference shots) */
.who-image {
  margin: 0;
  border-radius: 12px;
  overflow: hidden;
  background: var(--bone-200);
  position: relative;
  height: 100%;
}
.who-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.who-image figcaption {
  position: absolute;
  bottom: 12px;
  left: 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: #fff;
  background: rgba(0,0,0,0.55);
  padding: 5px 10px;
  border-radius: 4px;
  backdrop-filter: blur(2px);
}

/* Tablet: 2 column — design image on left, cards on right; shelf image goes full-width below */
@media (max-width: 1100px) {
  .who-layout {
    grid-template-columns: 1fr 1.2fr;
    grid-template-rows: auto auto;
  }
  .who-image--design { grid-column: 1; grid-row: 1; }
  .who-cards { grid-column: 2; grid-row: 1; }
  .who-image--shelf {
    grid-column: 1 / -1;
    grid-row: 2;
    aspect-ratio: 16 / 6;
  }
  .who-image--shelf img { aspect-ratio: 16 / 6; }
}

/* Mobile: stack everything */
@media (max-width: 700px) {
  .who-layout { grid-template-columns: 1fr; gap: 20px; }
  .who-image--design, .who-cards, .who-image--shelf {
    grid-column: 1;
    grid-row: auto;
  }
  .who-cards { grid-template-columns: 1fr; gap: 12px; }
  .who-image--shelf { aspect-ratio: 16 / 9; }
  .who-image img { aspect-ratio: 4 / 3; }
  .who-card { padding: 18px 20px; }
}

@media (max-width: 800px) {
  .article-title { font-size: 36px; }
  .article-subtitle { font-size: 18px; }
  .article-toc { padding: 22px 22px; }
  .article-section { margin-bottom: 44px; }
  .article-section-title { font-size: 24px; }
  .article-section-body p, .article-list li { font-size: 16px; line-height: 1.7; }
  .article-pullquote { padding: 22px 20px; font-size: 18px; }
  .article-footer { grid-template-columns: 1fr; }
}

/* =====================================================
   NAV: dropdown menus
===================================================== */
.nav-dd { position: relative; padding-bottom: 12px; margin-bottom: -12px; }
/* Force button to match <a class="nav-link"> exactly — buttons have UA defaults that "font:inherit" doesn't always reset across systems */
.nav-dd-trigger {
  background: transparent;
  border: 0;
  padding: 6px 0;
  cursor: pointer;
  font-family: inherit;
  font-size: 15px;
  font-weight: 500;
  color: var(--ink-700);
  letter-spacing: inherit;
  line-height: inherit;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  position: relative;
  transition: color .2s var(--ease-out);
}
.nav-dd-trigger::after {
  content: "";
  position: absolute;
  left: 0;
  right: 16px;
  bottom: -2px;
  height: 1px;
  background: var(--ink-900);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .25s var(--ease-out);
}
.nav-dd-trigger:hover { color: var(--ink-900); }
.nav-dd-trigger:hover::after { transform: scaleX(1); }
.nav-dd-caret { font-size: 9px; opacity: 0.6; transition: transform .2s; }
.nav-dd.is-open .nav-dd-caret { transform: rotate(180deg); }
.nav-dd.is-active > .nav-dd-trigger { color: var(--ink-900); }
.nav-dd.is-active > .nav-dd-trigger::after { transform: scaleX(1); background: var(--clay-500); }
.nav-dd-menu {
  position: absolute;
  top: calc(100% + 12px);
  left: -12px;
  min-width: 280px;
  background: var(--paper, #fff);
  border: 1px solid var(--bone-300, #e8dccb);
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
  padding: 8px;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-4px);
  transition: opacity .15s, transform .15s;
  z-index: 60;
}
.nav-dd.is-open .nav-dd-menu { opacity: 1; pointer-events: auto; transform: translateY(0); }
.nav-dd-item {
  display: block;
  padding: 12px 14px;
  border-radius: 8px;
  text-decoration: none;
  color: var(--ink-800);
  transition: background-color .15s;
}
.nav-dd-item:hover { background: var(--bone-50, #faf6f1); }
.nav-dd-item.is-active { background: var(--bone-100, #f4ece2); }
.nav-dd-item-label { font-size: 14px; font-weight: 600; color: var(--ink-900); margin-bottom: 2px; }
.nav-dd-item-desc { font-size: 12px; color: var(--ink-600); line-height: 1.4; }

/* Mobile menu sub-grouping */
.nav-mobile-group { margin: 8px 0 14px; padding-bottom: 12px; border-bottom: 1px solid var(--bone-300, #e8dccb); }
.nav-mobile-group-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-500); padding: 8px 0 4px; }
.nav-mobile-group .nav-link--sub { padding-left: 12px; font-size: 14px; }

/* =====================================================
   NAV: handle more items at small widths
===================================================== */
@media (max-width: 1180px) {
  .nav-links { gap: 18px; }
  .nav-links .nav-link, .nav-links .nav-dd-trigger { font-size: 14px; }
}
@media (max-width: 1024px) {
  .nav-links { gap: 14px; }
  .nav-links .nav-link, .nav-links .nav-dd-trigger { font-size: 13px; }
}

/* =====================================================
   MATERIAL & PRODUCT TYPE — section figures (full-bleed inside the card)
===================================================== */
.material-card-figure,
.ptype-card-figure {
  margin: 0 0 28px;
  border-radius: 10px;
  overflow: hidden;
  background: var(--bone-200);
  aspect-ratio: 16 / 9;
}
.material-card-figure img,
.ptype-card-figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* Sample/product images need contain (not cover) and a soft backdrop */
.ptype-card-figure {
  background: linear-gradient(135deg, var(--bone-100, #f4ece2) 0%, var(--bone-50, #faf6f1) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.ptype-card-figure img {
  object-fit: contain;
  padding: 32px;
  width: 100%;
  height: 100%;
}

/* Audience tag — small uppercase line for "Written for: ..." */
.audience-tag {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.04em;
  color: var(--ink-600);
  margin: 0;
}
.audience-tag strong { color: var(--ink-800); font-weight: 600; }

/* =====================================================
   ARTICLE — inline figures (within blog post)
===================================================== */
.article-inline-figure {
  margin: 36px 0;
  border-radius: 10px;
  overflow: hidden;
  background: var(--bone-200);
}
.article-inline-figure img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}
.article-inline-figure figcaption {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--ink-500);
  padding: 12px 4px 0;
  text-align: center;
}
