/* =========================================================
   Migrate Digital — Home Page Component CSS
   Depends on: ./migrate-tokens.css (tokens + type presets)
   ========================================================= */

/* ---------- Base ---------- */

body {
  background: var(--page-bg);
  color: var(--ink);
  font-family: var(--body);
  font-size: var(--t-4);
  line-height: var(--lh-body);
}

a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }

::selection { background: var(--bronze); color: var(--cream); }

/* ---------- Shared signature components ---------- */

/* 6px bronze square — bullet for tags and lists */
.sq {
  display: inline-block;
  width: 6px; height: 6px;
  background: var(--bronze);
  margin-right: var(--sp-3);
  transform: translateY(-1px);
  flex-shrink: 0;
}
[data-variant="dark"] .sq, .on-dark .sq { background: var(--bronze-hi); }

/* Panel-head triplet: tag / title / meta */
.panel-head {
  display: grid;
  grid-template-columns: max-content 1fr max-content;
  align-items: baseline;
  gap: var(--sp-10);
  padding: var(--sp-9) var(--sp-10);
  background: #f7f7f7;
  border-bottom: var(--rule) solid var(--hairline);
}
[data-variant="dark"] .panel-head,
.on-dark .panel-head {
  background: rgba(255, 255, 255, 0.04);
  border-bottom-color: var(--dark-4);
}

.ph-tag {
  display: inline-flex; align-items: center;
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-1); letter-spacing: var(--track-ui-s);
  text-transform: uppercase; color: var(--bronze);
  white-space: nowrap;
}
[data-variant="dark"] .ph-tag, .on-dark .ph-tag { color: var(--bronze-hi); }

.ph-title {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-3); letter-spacing: var(--track-ui-xl);
  text-transform: uppercase; color: var(--ink);
  line-height: 1.2;
}
[data-variant="dark"] .ph-title, .on-dark .ph-title { color: var(--cream); }

.ph-meta {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-1); letter-spacing: var(--track-ui-m);
  text-transform: uppercase; color: var(--ink-3);
  font-variant-numeric: tabular-nums;
  white-space: nowrap; text-align: right;
}
[data-variant="dark"] .ph-meta, .on-dark .ph-meta { color: var(--dark-3); }

/* Panel-foot: left meta + right bronze stamp */
.panel-foot {
  display: grid;
  grid-template-columns: 1fr max-content;
  align-items: center;
  gap: var(--sp-10);
  padding: var(--sp-7) var(--sp-10);
  border-top: var(--rule) solid var(--hairline);
}
[data-variant="dark"] .panel-foot,
.on-dark .panel-foot { border-top-color: var(--dark-4); }

.pf-l {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-1); letter-spacing: var(--track-ui-m);
  text-transform: uppercase; color: var(--ink-3);
}
[data-variant="dark"] .pf-l, .on-dark .pf-l { color: var(--dark-3); }

.pf-stamp {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-1); letter-spacing: var(--track-ui-s);
  text-transform: uppercase; color: var(--bronze);
  padding: var(--sp-2) var(--sp-5);
  border: var(--rule) solid var(--bronze);
  background: transparent;
  font-variant-numeric: tabular-nums;
}
[data-variant="dark"] .pf-stamp, .on-dark .pf-stamp {
  color: var(--bronze-hi);
  border-color: var(--bronze-hi);
}
.pf-stamp-link { cursor: pointer; transition: background 160ms ease, color 160ms ease; }
.pf-stamp-link:hover { background: var(--bronze); color: var(--cream); }
[data-variant="dark"] .pf-stamp-link:hover,
.on-dark .pf-stamp-link:hover { background: var(--bronze-hi); color: var(--dark); }

/* Generic panel container */
.panel {
  display: block;
  background: var(--surface);
  border: var(--rule) solid var(--hairline);
  color: inherit;
}
[data-variant="dark"] .panel,
.on-dark .panel {
  background: rgba(250, 246, 241, 0.035);
  border-color: var(--dark-4);
  color: var(--cream);
}

/* Section head: bronze section number + uppercase headline + lede */
.section-head {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--sp-12);
  align-items: start;
  margin-bottom: var(--sp-14);
}

/* Scale section headlines up from the base .t-headline preset */
.t-headline { font-size: calc(var(--t-7) * 1.155); }

.sh-num {
  padding-top: var(--sp-2);
}
.section-head-body { max-width: 780px; }
.section-lede { margin-top: var(--sp-7); }

/* Generic section foot link */
.section-foot {
  margin-top: var(--sp-13);
  padding-top: var(--sp-9);
  border-top: var(--rule) solid var(--hairline);
  text-align: right;
}
.section-foot-link {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-3); letter-spacing: var(--track-ui-l);
  text-transform: uppercase; color: var(--bronze);
  transition: color 160ms ease;
}
.section-foot-link:hover { color: var(--ink); }

/* ---------- Buttons ---------- */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-6);
  padding: var(--sp-6) var(--sp-10);
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-3); letter-spacing: var(--track-ui-l);
  text-transform: uppercase;
  border: var(--rule) solid transparent;
  border-radius: var(--r);
  cursor: pointer;
  transition: background 180ms ease, color 180ms ease, border-color 180ms ease, transform 120ms ease;
  white-space: nowrap;
  text-decoration: none;
}
.btn:active { transform: translateY(1px); }
.btn:focus-visible {
  outline: var(--rule) solid var(--bronze-hi);
  outline-offset: 3px;
}
.btn-icon {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  transition: transform 250ms ease;
  color: currentColor;
}
.btn:hover .btn-icon {
  transform: translate(3px, -3px);
}


.btn-primary {
  background: var(--ink); color: var(--cream);
  border-color: var(--ink);
}
.btn-primary:hover { background: var(--bronze); border-color: var(--bronze); color: var(--cream); }

.btn-bronze {
  background: var(--bronze); color: var(--cream);
  border-color: var(--bronze);
}
.btn-bronze:hover { background: var(--bronze-hi); border-color: var(--bronze-hi); color: var(--dark); }

[data-variant="dark"] .btn-primary,
.on-dark .btn-primary {
  background: var(--cream); color: var(--dark); border-color: var(--cream);
}
[data-variant="dark"] .btn-primary:hover,
.on-dark .btn-primary:hover {
  background: var(--bronze-hi); color: var(--dark); border-color: var(--bronze-hi);
}

/* ==========================================================
   MASTHEAD
   ========================================================== */

.masthead {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  background: var(--dark);
  border-bottom: var(--rule) solid var(--dark-4);
  transform: translateY(0);
  transition: transform 350ms cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}
.masthead--hidden {
  transform: translateY(-100%);
}
@media (prefers-reduced-motion: reduce) {
  .masthead { transition: none; }
  .masthead--hidden { transform: translateY(0); }
}
.masthead-grid {
  display: grid;
  grid-template-columns: max-content 1fr max-content;
  align-items: center;
  gap: var(--sp-12);
  height: 72px;
}

/* Overlay chrome sits on the dark hero — shift colors accordingly */
.masthead .nav-list a { color: var(--dark-3); }
.masthead .nav-list a:hover { color: var(--bronze-hi); }
.masthead .btn-primary {
  background: var(--cream); color: var(--dark); border-color: var(--cream);
}
.masthead .btn-primary:hover {
  background: var(--bronze-hi); color: var(--dark); border-color: var(--bronze-hi);
}

.brand {
  display: inline-flex; align-items: center;
  line-height: 0;
}
.brand-mark {
  display: block;
  width: auto;
  height: 24px;
  max-width: 220px;
}

.nav { justify-self: center; }
.nav-list {
  display: flex; align-items: center;
  gap: var(--sp-12);
}
.nav-list a {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-1); letter-spacing: var(--track-ui-m);
  text-transform: uppercase; color: var(--ink-3);
  padding: var(--sp-3) 0;
  transition: color 160ms ease;
}
.nav-list a:hover { color: var(--bronze); }

.masthead-right {
  display: flex; align-items: center; gap: var(--sp-10);
}
.masthead-ig {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--bronze-hi);
  padding-right: var(--sp-10);
  border-right: var(--rule) solid var(--dark-4);
  transition: color 160ms ease;
}
.masthead-ig svg {
  width: 18px;
  height: 18px;
  display: block;
}
.masthead-ig:hover { color: var(--cream); }
.masthead-ig:focus-visible {
  outline: var(--rule) solid var(--bronze-hi);
  outline-offset: 3px;
}

/* ==========================================================
   01 — HERO
   ========================================================== */

.section-hero {
  position: relative;
  min-height: 75vh;
  display: flex;
  flex-direction: column;
  padding-top: 72px;
  padding-bottom: 34px;
}

/* Tabbed-folder section dividers: hairline edge + subtle upward shadow
   so adjacent sections read as overlapping sheets of paper.
   Each non-first section also protrudes a left-aligned tab (::before). */
.section { position: relative; }
.section + .section {
  border-top: 2px solid var(--hairline);
  /* Upward shadow whose blur extent stays entirely above the line.
     Offset (8) > blur (4) + inward spread (2), so the Gaussian fade
     terminates around y=-2; nothing bleeds into the section below. */
  box-shadow: 0 -6px 5px -2px rgba(0, 0, 0, 0.054);
  z-index: 1;
}
.section + [data-variant="dark"] { border-top-color: var(--dark-4); }

/* Folder-tab element (rendered as a real child of each non-first section).
   Shape: flat top + sharp top-left (off-screen) + rounded top-right +
   45° slope down into the section body. Drawn via inline SVG background
   so the border follows the slope. */
.folder-tab {
  position: absolute;
  top: -34px;
  /* Tab hugs the section's left edge always, extending 40px off-viewport. */
  left: -40px;
  /* Width grows with viewport so the right slope sits past the content column. */
  width: calc((100% - min(100%, var(--container-max))) / 2 + var(--container-pad) + 260px);
  height: 34px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  /* Text padding-left: off-screen extension + container gutter + container-pad.
     Puts the label at the exact x of the section's content column on any width. */
  padding-top: 14px;
  padding-left: calc(40px + (100% - min(100%, var(--container-max))) / 2 + var(--container-pad));
  padding-right: var(--sp-11);
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-2); letter-spacing: var(--track-ui-m);
  text-transform: uppercase; color: var(--ink-3);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 280 34' preserveAspectRatio='none'><path d='M 0 34 L 0 1 L 256 1 L 280 34 Z' fill='%23fbf8f4' stroke='none'/><path d='M 0 1 L 256 1 L 280 34' fill='none' stroke='rgba(26,26,26,0.10)' stroke-width='2' vector-effect='non-scaling-stroke' stroke-linecap='square' stroke-linejoin='miter'/></svg>");
  background-size: 100% 100%;
  background-repeat: no-repeat;
  white-space: nowrap;
  pointer-events: none;
  /* Tight upward drop-shadow — offset well above the blur so the Gaussian
     fade doesn't leak below the tab's bottom edge. */
  filter: drop-shadow(0 -5px 3px rgba(0, 0, 0, 0.054));
}
[data-variant="dark"] .folder-tab {
  color: var(--dark-3);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 280 34' preserveAspectRatio='none'><path d='M 0 34 L 0 1 L 256 1 L 280 34 Z' fill='%23150c0c' stroke='none'/><path d='M 0 1 L 256 1 L 280 34' fill='none' stroke='rgba(250,246,241,0.18)' stroke-width='2' vector-effect='non-scaling-stroke' stroke-linecap='square' stroke-linejoin='miter'/></svg>");
}

/* Light tab protruding UP into a DARK section above — swap the stroke
   to a cream tone so the top + slope outline reads against the dark backdrop. */
[data-variant="dark"] + .section:not([data-variant="dark"]) .folder-tab {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 280 34' preserveAspectRatio='none'><path d='M 0 34 L 0 1 L 256 1 L 280 34 Z' fill='%23fbf8f4' stroke='none'/><path d='M 0 1 L 256 1 L 280 34' fill='none' stroke='rgba(250,246,241,0.30)' stroke-width='2' vector-effect='non-scaling-stroke' stroke-linecap='square' stroke-linejoin='miter'/></svg>");
}

/* Dark tab protruding UP into a LIGHT section above — swap the stroke
   to an ink tone so the top + slope outline reads against the cream backdrop. */
.section:not([data-variant="dark"]) + [data-variant="dark"] .folder-tab {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 280 34' preserveAspectRatio='none'><path d='M 0 34 L 0 1 L 256 1 L 280 34 Z' fill='%23150c0c' stroke='none'/><path d='M 0 1 L 256 1 L 280 34' fill='none' stroke='rgba(26,26,26,0.25)' stroke-width='2' vector-effect='non-scaling-stroke' stroke-linecap='square' stroke-linejoin='miter'/></svg>");
}

/* Subtle pulsing outline on the bronze square inside each folder tab. */
@keyframes folder-tab-sq-pulse {
  0%   { box-shadow: 0 0 0 0   rgba(176, 114, 62, 0.55); }
  100% { box-shadow: 0 0 0 7px rgba(176, 114, 62, 0);    }
}
@keyframes folder-tab-sq-pulse-hi {
  0%   { box-shadow: 0 0 0 0   rgba(211, 152, 88, 0.55); }
  100% { box-shadow: 0 0 0 7px rgba(211, 152, 88, 0);    }
}
.folder-tab .sq,
.hero-mark .sq {
  animation: folder-tab-sq-pulse 2s ease-out infinite;
}
[data-variant="dark"] .folder-tab .sq,
[data-variant="dark"] .hero-mark .sq {
  animation-name: folder-tab-sq-pulse-hi;
}
@media (prefers-reduced-motion: reduce) {
  .folder-tab .sq,
  .hero-mark .sq { animation: none; }
}
.hero-grid {
  flex: 1;
  display: flex;
  flex-direction: column;
  row-gap: var(--sp-11);
}
.hero-content {
  margin-top: auto;
  margin-bottom: auto;
  display: grid;
  row-gap: var(--sp-11);
}


.hero-head { display: block; }

.hero-headline {
  font-family: var(--title); font-weight: 600;
  font-size: calc(var(--t-8) * 1.155);
  letter-spacing: var(--track-display);
  text-transform: uppercase;
  color: var(--cream);
  line-height: var(--lh-display);
  max-width: 1200px;
}
.hero-headline .accent { color: var(--bronze-hi); }

.hero-mark {
  display: inline-flex; align-items: center;
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-3); letter-spacing: var(--track-ui-s);
  text-transform: uppercase;
  color: var(--cream);
}

.hero-sub {
  font-family: var(--body); font-weight: 400;
  font-size: var(--t-4); line-height: var(--lh-body-lg);
  color: var(--dark-2);
  max-width: 720px;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-7);
  margin-top: var(--sp-5);
}
.btn-ghost {
  background: transparent;
  color: var(--cream);
  border-color: var(--dark-4);
}
.btn-ghost:hover {
  background: var(--cream);
  color: var(--dark);
  border-color: var(--cream);
}

/* Dossier 4-column grid — right-anchored so the folder tab on the
   left has its own clearance at the hero's bottom edge. */
.cover-dossier {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border-top: var(--rule) solid var(--dark-4);
  margin-left: 260px;
}
.dossier-cell {
  padding: var(--sp-10) var(--sp-10) var(--sp-13);
  border-right: var(--rule) solid var(--dark-4);
}
.dossier-cell:first-child { padding-left: 0; }
.dossier-cell:last-child { border-right: none; padding-right: 0; }

.dossier-cell dt.t-eyebrow { color: var(--bronze-hi); }

.dossier-val {
  display: block;
  margin-top: var(--sp-6);
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-5); letter-spacing: var(--track-display);
  text-transform: uppercase;
  color: var(--cream);
  line-height: 1.2;
}

/* ==========================================================
   02 — POSITIONING
   ========================================================== */

.section-positioning { padding-top: 120px; padding-bottom: 154px; }

/* Positioning panel — uses the shared .panel chassis (head/body/foot).
   Body stacks a 4-cell profile grid on top of the "Our Discipline" block. */

.profile-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border-bottom: var(--rule) solid var(--hairline);
}
.profile-cell {
  padding: var(--sp-10);
  border-right: var(--rule) solid var(--hairline);
}
.profile-cell:last-child { border-right: none; }
.profile-label {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-1); letter-spacing: var(--track-ui-m);
  text-transform: uppercase;
  color: var(--bronze);
}
.profile-value {
  display: block;
  margin-top: var(--sp-6);
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-5); letter-spacing: var(--track-display);
  text-transform: uppercase;
  color: var(--ink);
  line-height: 1.2;
}

.discipline-block {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--sp-12);
  padding: var(--sp-13);
  align-items: start;
}
.discipline-tag {
  display: inline-flex;
  align-items: center;
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-1); letter-spacing: var(--track-ui-s);
  text-transform: uppercase;
  color: var(--bronze);
  padding-top: 4px;
}
.discipline-body {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-6); letter-spacing: var(--track-display);
  text-transform: uppercase;
  color: var(--ink);
  line-height: var(--lh-tagline);
  max-width: 900px;
}

.strip {
  padding: var(--sp-13) var(--sp-12);
  border: var(--rule) solid var(--dark-4);
}
.strip-grid {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--sp-12);
  align-items: start;
}
.strip-tag { align-self: start; padding-top: 4px; }
.strip-body {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-6); letter-spacing: var(--track-display);
  text-transform: uppercase;
  color: var(--cream);
  line-height: var(--lh-tagline);
  max-width: 900px;
}

/* ==========================================================
   03 — PROOF / KPIs
   ========================================================== */

.section-proof { padding-top: 120px; padding-bottom: 154px; }

.kpi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
.kpi-cell {
  padding: var(--sp-13);
  border-right: var(--rule) solid var(--hairline);
  display: grid; grid-auto-rows: max-content;
  gap: var(--sp-6);
}
.kpi-cell:last-child { border-right: none; }

.kpi-label { display: block; letter-spacing: var(--track-ui-s); }

.kpi-num {
  font-family: var(--title); font-weight: 600;
  font-size: 72px; letter-spacing: var(--track-display-tight);
  line-height: 1;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  margin-top: var(--sp-5);
}

.kpi-name {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-5); letter-spacing: var(--track-display);
  text-transform: uppercase;
  color: var(--ink);
  line-height: 1.2;
  margin-top: var(--sp-3);
}

.kpi-desc {
  font-family: var(--body); font-weight: 400;
  font-size: var(--t-3); line-height: var(--lh-body);
  color: var(--ink-3);
  margin-top: var(--sp-4);
  max-width: 38ch;
}

/* ==========================================================
   04 — SERVICES PREVIEW
   ========================================================== */

.section-services { padding-top: 120px; padding-bottom: 154px; }

.services-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: var(--rule) solid var(--hairline);
}

.panel-service {
  display: flex; flex-direction: column;
  border-right: var(--rule) solid var(--hairline);
  border-bottom: var(--rule) solid var(--hairline);
  border-top: none;
  background: var(--surface);
  transition: background 200ms ease;
}
.panel-service:last-child { border-right: none; }
.panel-service:hover { background: var(--cream); }

.panel-service .rows { padding: var(--sp-5) var(--sp-10) var(--sp-10); flex: 1; }

/* Row pattern: 32px numeral col · label col · description col */
.rows .row {
  display: grid;
  grid-template-columns: 40px 220px 1fr;
  gap: var(--sp-10);
  align-items: start;
  padding: var(--sp-9) 0;
  border-top: var(--rule) solid var(--hairline);
}
.rows .row:first-child { border-top: none; }

.rows .row .n {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-3); letter-spacing: var(--track-ui-m);
  color: var(--bronze);
  font-variant-numeric: tabular-nums;
  padding-top: 2px;
}
.rows .row .lb {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-3); letter-spacing: 0.01em;
  text-transform: uppercase; color: var(--ink);
  line-height: 1.3;
}
.rows .row .dc {
  font-family: var(--body); font-weight: 400;
  font-size: var(--t-3); line-height: var(--lh-body);
  color: var(--ink-3);
}

/* ==========================================================
   05 — OUR WORK
   ========================================================== */

.section-work { padding-top: 120px; padding-bottom: 154px; }

.work-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  border-top: var(--rule) solid var(--hairline);
  border-bottom: var(--rule) solid var(--hairline);
}
.panel-work {
  display: flex; flex-direction: column;
  min-width: 0;
  border-right: var(--rule) solid var(--hairline);
  background: var(--surface);
  transition: background 200ms ease;
}
.panel-work:last-child { border-right: none; }
.panel-work:hover { background: var(--cream); }

/* Case-study cards use a stacked panel-head (tag / title / meta)
   so every card matches regardless of title length. */
.panel-work .panel-head {
  grid-template-columns: 1fr;
  align-items: start;
  gap: var(--sp-4);
  padding: var(--sp-10) var(--sp-10);
  min-height: 112px;
}
.panel-work .ph-title {
  font-size: var(--t-5);
  line-height: 1.2;
  letter-spacing: var(--track-display);
  word-break: break-word;
}
.panel-work .ph-meta {
  text-align: left;
  white-space: normal;
}

.work-media {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--cream);
  border-bottom: var(--rule) solid var(--hairline);
}
.work-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
}

.work-meta {
  padding: var(--sp-9) var(--sp-10);
  display: grid; gap: var(--sp-6);
  flex: 1;
}
.wm-row {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--sp-7);
  align-items: baseline;
  padding: var(--sp-4) 0;
  border-top: var(--rule) solid var(--hairline);
}
.wm-row:first-child { border-top: none; padding-top: 0; }
.wm-row dt {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-1); letter-spacing: var(--track-ui-m);
  text-transform: uppercase; color: var(--ink-3);
}
.wm-row dd {
  font-family: var(--body); font-weight: 400;
  font-size: var(--t-3); color: var(--ink);
}

.also-strip {
  margin-top: var(--sp-13);
  padding: var(--sp-9) var(--sp-10);
  border-top: var(--rule) solid var(--hairline);
  border-bottom: var(--rule) solid var(--hairline);
  display: flex; align-items: center; flex-wrap: wrap;
  gap: var(--sp-7);
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-1); letter-spacing: var(--track-ui-m);
  text-transform: uppercase;
}
.as-label { color: var(--bronze); }
.as-sep { color: var(--ink-4); }
.as-item { color: var(--ink); }
.as-loc { color: var(--ink-3); }

/* ==========================================================
   06 — FEATURED TESTIMONIAL (dark, pullquote)
   ========================================================== */

.section-testimonial { padding-top: 120px; padding-bottom: 154px; }

.panel-pullquote {
  background: rgba(250, 246, 241, 0.035);
  border: var(--rule) solid var(--dark-4);
}

.pullquote {
  padding: var(--sp-14) var(--sp-13);
}

.pullquote p {
  font-family: var(--title); font-weight: 500;
  font-size: var(--t-7); line-height: 1.4;
  letter-spacing: var(--track-display);
  color: var(--cream);
  max-width: 70ch;
}
.pullquote-sentence p { text-transform: none; }
.pullquote .accent { color: var(--bronze-hi); }

.pq-src {
  margin-top: var(--sp-12);
  padding-top: var(--sp-9);
  border-top: var(--rule) solid var(--dark-4);
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-1); letter-spacing: var(--track-ui-m);
  text-transform: uppercase;
  color: var(--bronze-hi);
}

/* ==========================================================
   07 — PROCESS TEASER (4-phase progress)
   ========================================================== */

.section-process { padding-top: 120px; padding-bottom: 154px; }

.panel-phases { background: var(--surface); }

.phases {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}

.phase {
  padding: var(--sp-13) var(--sp-10) var(--sp-13);
  border-right: var(--rule) solid var(--hairline);
  display: grid; grid-auto-rows: max-content;
  gap: var(--sp-4);
  position: relative;
}
.phase:last-child { border-right: none; }

.phase-rule {
  position: relative;
  height: 3px;
  background: var(--hairline);
  margin-bottom: var(--sp-9);
}
.phase-rule-fill {
  display: block;
  height: 100%;
  width: var(--prog, 0%);
  background: var(--bronze);
}

.phase-num { color: var(--bronze); }

.phase-name {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-7); letter-spacing: var(--track-display);
  text-transform: uppercase; color: var(--ink);
  line-height: 1.1;
  margin-top: var(--sp-2);
}
.phase-week {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-1); letter-spacing: var(--track-ui-m);
  text-transform: uppercase; color: var(--ink-3);
  font-variant-numeric: tabular-nums;
}
.phase-desc {
  font-family: var(--body); font-weight: 400;
  font-size: var(--t-3); line-height: var(--lh-body);
  color: var(--ink-3);
  margin-top: var(--sp-4);
}

/* ==========================================================
   08 — ABOUT TEASER (letter)
   ========================================================== */

.section-about { padding-top: 120px; padding-bottom: 154px; }

.panel-letter { background: var(--surface); }

.letter-body {
  padding: var(--sp-13) var(--sp-14) var(--sp-10);
  max-width: 80ch;
}
.letter-body p {
  font-family: var(--body); font-weight: 400;
  font-size: var(--t-5); line-height: var(--lh-letter);
  color: var(--ink);
  margin-bottom: var(--sp-10);
}
.letter-body p:last-child { margin-bottom: 0; }

.letter-signature {
  padding: var(--sp-10) var(--sp-14) var(--sp-13);
  display: grid;
  grid-auto-rows: max-content;
  gap: var(--sp-3);
}
.sig-rule {
  display: block;
  width: 60px; height: 2px;
  background: var(--bronze);
  margin-bottom: var(--sp-7);
}
.sig-name {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-5); letter-spacing: var(--track-display);
  color: var(--ink);
}
.sig-role { color: var(--ink-3); }

/* ==========================================================
   09 — FINAL CTA (dark closer)
   ========================================================== */

.section-cta {
  padding-top: 120px;
  padding-bottom: 154px;
}
.cta-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--sp-14);
  align-items: start;
}

.cta-content {
  display: grid;
  grid-auto-rows: max-content;
  gap: var(--sp-9);
}
.cta-eyebrow { color: var(--bronze-hi); }
.cta-headline {
  font-size: calc(var(--t-8) * 1.155);
  color: var(--cream);
}
.cta-headline .accent { color: var(--bronze-hi); }

.cta-sub {
  font-family: var(--body); font-weight: 400;
  font-size: var(--t-5); line-height: var(--lh-body-lg);
  color: var(--dark-2);
}

.cta-contacts {
  display: grid;
  grid-auto-rows: max-content;
  gap: var(--sp-5);
  list-style: none;
  padding: var(--sp-9) 0;
  border-top: var(--rule) solid var(--dark-4);
  border-bottom: var(--rule) solid var(--dark-4);
}
.contact-row {
  display: grid;
  grid-template-columns: 36px 100px 1fr;
  align-items: center;
  gap: var(--sp-7);
}
.contact-icon {
  width: 36px; height: 36px;
  display: inline-flex;
  align-items: center; justify-content: center;
  color: var(--bronze-hi);
  border: var(--rule) solid var(--dark-4);
  background: rgba(255, 255, 255, 0.03);
  flex-shrink: 0;
}
.contact-icon svg { width: 16px; height: 16px; display: block; }
.contact-label {
  color: var(--dark-3);
}
.contact-value {
  font-family: var(--body); font-weight: 400;
  font-size: var(--t-4); color: var(--cream);
  font-variant-numeric: tabular-nums;
  transition: color 160ms ease;
  min-width: 0;
  word-break: break-word;
}
.contact-value:hover { color: var(--bronze-hi); }

.cta-actions {
  display: flex;
}

.cta-stamp {
  display: flex; align-items: center; gap: var(--sp-7);
}
.cta-stamp-sep { color: var(--dark-4); }
.cta-stamp-val { color: var(--bronze-hi); }

/* ---------- Form (left column) ---------- */

.cta-form {
  display: flex;
  flex-direction: column;
  background: rgba(250, 246, 241, 0.035);
  border: var(--rule) solid var(--dark-4);
}

.form-head {
  display: grid;
  grid-template-columns: max-content 1fr max-content;
  align-items: baseline;
  gap: var(--sp-10);
  padding: var(--sp-9) var(--sp-10);
  background: rgba(255, 255, 255, 0.04);
  border-bottom: var(--rule) solid var(--dark-4);
}
.form-title {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-3); letter-spacing: var(--track-ui-xl);
  text-transform: uppercase; color: var(--cream);
  line-height: 1.2;
}
.form-meta {
  font-variant-numeric: tabular-nums;
  text-align: right;
}

.form-fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-11) var(--sp-10);
  padding: var(--sp-12) var(--sp-10);
}
.field {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  min-width: 0;
}
.field-full {
  grid-column: 1 / -1;
}
.field-label {
  font-family: var(--title); font-weight: 600;
  font-size: var(--t-1); letter-spacing: var(--track-ui-m);
  text-transform: uppercase; color: var(--bronze-hi);
}
.field-input {
  font-family: var(--body); font-weight: 400;
  font-size: var(--t-4); line-height: var(--lh-body);
  color: var(--cream);
  background: transparent;
  border: 0;
  border-bottom: var(--rule) solid var(--dark-4);
  border-radius: var(--r);
  padding: var(--sp-4) 0;
  width: 100%;
  transition: border-color 160ms ease;
}
.field-input:focus {
  outline: none;
  border-bottom-color: var(--bronze-hi);
}
.field-input::placeholder {
  color: var(--dark-3);
}

.field-select {
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  padding-right: var(--sp-9);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%23d39858' stroke-width='1.5' fill='none'/></svg>");
  background-repeat: no-repeat;
  background-position: right 2px center;
}
.field-select option {
  background: var(--dark);
  color: var(--cream);
}

.field-textarea {
  resize: vertical;
  min-height: 112px;
  padding: var(--sp-4) 0;
}

.form-foot {
  display: grid;
  grid-template-columns: 1fr max-content;
  align-items: center;
  gap: var(--sp-10);
  padding: var(--sp-7) var(--sp-10) var(--sp-9);
  border-top: var(--rule) solid var(--dark-4);
  background: rgba(255, 255, 255, 0.02);
}
.form-foot-note { color: var(--dark-3); }
.form-foot .btn { min-width: 200px; }

/* ==========================================================
   FOOTER (pfoot)
   ========================================================== */

.pfoot {
  padding-top: var(--sp-15);
  padding-bottom: var(--sp-12);
  border-top: var(--rule) solid var(--dark-4);
}

.pfoot-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1.2fr 1fr;
  gap: var(--sp-12);
  padding-bottom: var(--sp-14);
  border-bottom: var(--rule) solid var(--dark-4);
}

.pfoot-col { display: grid; grid-auto-rows: max-content; gap: var(--sp-7); }

.pfoot-mark-img {
  display: block;
  width: auto;
  height: 27px;
  max-width: 260px;
}
.pfoot-tag {
  font-family: var(--body); font-weight: 400;
  font-size: var(--t-3); line-height: var(--lh-body);
  color: var(--dark-2);
  max-width: 30ch;
}

.pfoot-head {
  color: var(--bronze-hi) !important;
  padding-bottom: var(--sp-3);
  border-bottom: var(--rule) solid var(--dark-4);
}

.pfoot-links {
  display: grid; grid-auto-rows: max-content;
  gap: var(--sp-4);
}
.pfoot-links a, .pfoot-links span {
  font-family: var(--body); font-weight: 400;
  font-size: var(--t-3); color: var(--cream);
  transition: color 160ms ease;
}
.pfoot-links a:hover { color: var(--bronze-hi); }
.pfoot-placeholder { color: var(--dark-3) !important; }
.pfoot-copy {
  color: var(--dark-3) !important;
  font-size: var(--t-2) !important;
  padding-top: var(--sp-3);
  border-top: var(--rule) solid var(--dark-4);
  margin-top: var(--sp-3);
}

.pfoot-bar {
  display: grid;
  grid-template-columns: 1fr max-content 1fr;
  align-items: center;
  gap: var(--sp-10);
  padding-top: var(--sp-10);
}
.pfoot-bar-l { justify-self: start; color: var(--dark-3) !important; }
.pfoot-bar-c {
  justify-self: center; color: var(--bronze-hi) !important;
  transition: color 160ms ease;
}
.pfoot-bar-c:hover { color: var(--cream) !important; }
.pfoot-bar-r { justify-self: end; color: var(--bronze-hi) !important; }

/* ==========================================================
   Responsive — lightweight breakpoints
   ========================================================== */

@media (max-width: 960px) {
  :root {
    --container-pad: 24px;
    --section-pad-y: 48px;
  }
  .hero-headline { font-size: calc(var(--t-7) * 1.05); }
  .masthead-grid { grid-template-columns: max-content 1fr; }
  .nav { display: none; }
  .section-head { grid-template-columns: 1fr; gap: var(--sp-10); }
  .profile-grid { grid-template-columns: 1fr 1fr; }
  .profile-cell:nth-child(2) { border-right: none; }
  .profile-cell:nth-child(1),
  .profile-cell:nth-child(2) {
    border-bottom: var(--rule) solid var(--hairline);
  }
  .discipline-block { grid-template-columns: 1fr; gap: var(--sp-7); padding: var(--sp-10) var(--sp-7); }
  .kpi-grid { grid-template-columns: 1fr; }
  .kpi-cell {
    border-right: none;
    border-bottom: var(--rule) solid var(--hairline);
  }
  .kpi-cell:last-child { border-bottom: none; }
  .services-grid { grid-template-columns: 1fr; }
  .panel-service { border-right: none; }
  .work-grid { grid-template-columns: 1fr; }
  .panel-work { border-right: none; }
  .rows .row { grid-template-columns: 32px 1fr; }
  .rows .row .lb { grid-column: 2; }
  .rows .row .dc { grid-column: 2; }
  .phases { grid-template-columns: 1fr 1fr; }
  .phase:nth-child(2) { border-right: none; }
  .phase:nth-child(1), .phase:nth-child(2) {
    border-bottom: var(--rule) solid var(--hairline);
  }
  .strip-grid { grid-template-columns: 1fr; }
  .pfoot-grid { grid-template-columns: 1fr 1fr; }
  .pfoot-bar { grid-template-columns: 1fr; gap: var(--sp-5); }
  .pfoot-bar-l, .pfoot-bar-c, .pfoot-bar-r { justify-self: start; }
  .panel-head { grid-template-columns: 1fr; gap: var(--sp-5); padding: var(--sp-7); }
  .ph-meta { text-align: left; }
  .panel-foot { padding: var(--sp-7); }

  .cta-grid { grid-template-columns: 1fr; gap: var(--sp-13); }
  .cta-form { order: 2; }
  .cta-content { order: 1; }
  .form-head { grid-template-columns: 1fr; gap: var(--sp-4); padding: var(--sp-7); }
  .form-meta { text-align: left; }
  .form-fields { grid-template-columns: 1fr; padding: var(--sp-10) var(--sp-7); gap: var(--sp-10); }
  .form-foot { grid-template-columns: 1fr; padding: var(--sp-7); gap: var(--sp-5); }
  .form-foot .btn { width: 100%; }
}

@media (max-width: 560px) {
  .phases { grid-template-columns: 1fr; }
  .phase { border-right: none; border-bottom: var(--rule) solid var(--hairline); }
  .phase:last-child { border-bottom: none; }
  .pfoot-grid { grid-template-columns: 1fr; }
  .hero-headline { font-size: calc(var(--t-6) * 1.05); }
  .cta-headline { font-size: calc(var(--t-7) * 1.05); }
}
