/** Shopify CDN: Minification failed

Line 445:14 Expected identifier but found whitespace
Line 445:21 Unexpected ";"
Line 555:13 Expected identifier but found whitespace
Line 555:14 Unexpected "linear-gradient("

**/
/* ===== DML World — Shopify Site Design ===== */

:root {
  --ink: #1A1A1A;
  --accent: #2FA7FF;
  --accent-dark: #0094C7;
  --muted: #6C6C72;
  --line: #E8E8EB;
  --page: #F5F6F8;
  --card: #FFFFFF;
  --soft: #FAFBFD;
  --ink-05: rgba(26,26,26,0.05);
  --ink-10: rgba(26,26,26,0.10);

  --f-display: 'Poppins', -apple-system, BlinkMacSystemFont, sans-serif;
  --f-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --f-serif: 'Instrument Serif', Georgia, serif;
  --f-mono: 'JetBrains Mono', ui-monospace, monospace;

  --r-sm: 2px;
  --r-md: 4px;
  --r-lg: 8px;

  --pad-x: clamp(20px, 4vw, 64px);
  --max-w: 1440px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { background: var(--page); color: var(--ink); font-family: var(--f-body); font-size: 15px; line-height: 1.5; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; border: none; background: none; }

/* ===== Utility type ===== */
.mono { font-family: var(--f-mono); font-weight: 500; letter-spacing: -0.01em; }
.serif-i { font-family: var(--f-serif); font-style: italic; font-weight: 400; }
.eyebrow {
  font-family: var(--f-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-dark);
}
.eyebrow-ink { color: var(--ink); }
.eyebrow-muted { color: var(--muted); }

h1,h2,h3,h4 { font-family: var(--f-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.05; }
.caps { text-transform: uppercase; letter-spacing: -0.01em; }

/* ===== Buttons ===== */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  height: 46px; padding: 0 22px;
  border-radius: var(--r-sm);
  font-family: var(--f-body); font-size: 14px; font-weight: 600;
  letter-spacing: 0.01em;
  transition: transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
  white-space: nowrap;
}
.btn-primary { background: var(--ink); color: #fff; }
.btn-primary:hover { background: #000; transform: translateY(-1px); }
.btn-secondary { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
.btn-secondary:hover { background: var(--ink); color: #fff; }
.btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--line); }
.btn-ghost:hover { border-color: var(--ink); }
.btn-accent { background: var(--accent); color: #fff; }
.btn-accent:hover { background: var(--accent-dark); }
.btn-sm { height: 36px; padding: 0 14px; font-size: 13px; }
.btn-lg { height: 54px; padding: 0 28px; font-size: 15px; }
.btn .arr { display: inline-block; transition: transform .2s ease; }
.btn:hover .arr { transform: translateX(3px); }

/* ===== Layout ===== */
.wrap { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--pad-x); }
.wrap-wide { max-width: 1600px; margin: 0 auto; padding: 0 var(--pad-x); }

/* ===== Top Nav ===== */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
}
.nav-inner {
  display: grid; grid-template-columns: auto 1fr auto;
  align-items: center; gap: 32px;
  height: 72px;
  max-width: var(--max-w); margin: 0 auto; padding: 0 var(--pad-x);
}
.logo {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--f-display); font-weight: 700; font-size: 18px;
  letter-spacing: -0.02em;
}
.logo-mark {
  width: 28px; height: 28px; background: var(--ink); color: #fff;
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 13px; font-weight: 700;
}
.nav-links { display: flex; gap: 28px; justify-self: center; align-items: center; height: 72px; flex-wrap: nowrap; white-space: nowrap; }

.nav-links > a, .nav-link {
  font-size: 14px; font-weight: 500; color: var(--ink);
  position: relative; padding: 6px 0;
  display: inline-flex; align-items: center; gap: 4px;
  cursor: pointer;
}
/* Nav links: clean by default. Hover = ink full opacity. Active page = gold underline. */
.nav-links > a:hover, .nav-link:hover { color: var(--ink); opacity: 1; }
.nav-links > a:hover::after, .nav-link:hover::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -2px;
  height: 2px; background: #D9BD67;
}
.nav-links > a.active, .nav-link.active {
  color: var(--ink);
  position: relative;
}
.nav-links > a.active::after, .nav-link.active::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -2px;
  height: 2px; background: #D9BD67;
}
.nav-caret { transition: transform .2s ease, opacity .2s ease; opacity: 0; }
.nav-link:hover .nav-caret, .nav-item.has-mega.open .nav-caret { opacity: 0.7; }

/* ===== Mega menu ===== */
.nav-item.has-mega { position: static; }
.nav-item.has-mega .nav-link { cursor: pointer; }
.mega {
  --accent: #D9BD67;
  --accent-dark: #B8923C;
  position: absolute; top: 72px; left: 0; right: 0;
  background: #fff; border-bottom: 1px solid var(--line);
  box-shadow: 0 24px 48px -16px rgba(15,17,21,0.18);
  opacity: 0; visibility: hidden; transform: translateY(-8px);
  transition: opacity .2s ease, transform .2s ease, visibility .2s;
  z-index: 60;
}
.nav-item.has-mega.open .mega { opacity: 1; visibility: visible; transform: translateY(0); }
.nav-item.has-mega.open .nav-caret { transform: rotate(180deg); opacity: 1; }
.nav-item.has-mega.open > .nav-link::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -2px;
  height: 2px; background: #D9BD67;
}
.mega-inner {
  max-width: var(--max-w); margin: 0 auto;
  padding: 0;
}
/* TOP: axis tabs */
.mega-tabs {
  display: flex; gap: 0;
  padding: 0 32px;
  border-bottom: 1px solid var(--line);
  background: #fff;
}
.mega-tab {
  appearance: none; background: none; border: 0;
  padding: 18px 22px 16px;
  font-family: var(--f-mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--muted);
  cursor: pointer;
  position: relative;
  transition: color .15s ease;
}
.mega-tab:hover { color: var(--ink); }
.mega-tab.active { color: var(--ink); }
.mega-tab.active::after {
  content: '';
  position: absolute; left: 22px; right: 22px; bottom: -1px;
  height: 2px; background: #D9BD67;
}

.mega-tri {
  display: grid;
  grid-template-columns: 240px 1fr 260px;
  grid-template-rows: 1fr auto;
  grid-template-areas:
    "rail feat side"
    "cta  feat browse";
  min-height: 380px;
}
.mega-browse-card { grid-area: browse; }
.mega-axis-rail { grid-area: rail; }
.mega-feat { grid-area: feat; }
.mega-side { grid-area: side; }
.mega-cta-card-bottom { grid-area: cta; }

/* LEFT: legacy tier rail — superseded by .mega-axis-rail (kept empty for safety) */

/* MIDDLE: featured */
.mega-feat {
  padding: 28px 36px 24px;
  position: relative;
  display: flex; flex-direction: column;
  min-height: 380px;
}
.mega-feat-grid {
  grid-template-rows: 130px 88px;
}
/* Footer row inside featured area: cross-tier links */
.mega-feat-footer {
  margin-top: auto;
  padding: 18px 0 24px;
  border-top: 1px solid var(--line);
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 8px;
}
.mega-feat-link {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  column-gap: 12px;
  padding: 12px 14px;
  text-decoration: none;
  color: var(--ink);
  border: 1px solid transparent;
  transition: background .12s ease, border-color .12s ease;
  position: relative;
}
.mega-feat-link:hover {
  background: rgba(217,189,103,0.06);
  border-color: rgba(217,189,103,0.45);
}
.mega-feat-link-primary {
  background: rgba(217,189,103,0.08);
  border-color: rgba(217,189,103,0.5);
}
.mega-feat-link-primary:hover {
  background: rgba(217,189,103,0.14);
  border-color: #D9BD67;
}
.mega-feat-link-label {
  grid-column: 1; grid-row: 1;
  font-size: 13px; font-weight: 600;
  color: var(--ink);
}
.mega-feat-link-primary .mega-feat-link-label { color: #B8923C; }
.mega-feat-link-meta {
  grid-column: 1; grid-row: 2;
  font-family: var(--f-mono); font-size: 10px;
  color: var(--muted);
  letter-spacing: 0.04em;
  margin-top: 2px;
}
.mega-feat-link-arrow {
  grid-column: 2; grid-row: 1 / span 2;
  align-self: center;
  font-family: var(--f-mono); font-size: 14px; font-weight: 600;
  color: rgba(184,146,60,0);
  transition: color .15s ease, transform .15s ease;
}
.mega-feat-link:hover .mega-feat-link-arrow {
  color: #B8923C;
  transform: translateX(2px);
}
.mega-panel {
  display: none;
  animation: megaPanelIn .25s ease;
}
.mega-panel.active { display: block; }
@keyframes megaPanelIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.mega-feat-head { margin-bottom: 22px; }
.mega-feat-eyebrow {
  display: block;
  font-family: var(--f-mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 6px;
}
.mega-feat-title {
  font-family: var(--f-display);
  font-size: 22px; font-weight: 600;
  color: var(--ink); letter-spacing: -0.01em;
  line-height: 1.2;
  margin: 0;
  max-width: 480px;
}
.mega-feat-sub {
  font-size: 12px; line-height: 1.5;
  color: var(--muted);
  margin: 8px 0 0;
  max-width: 520px;
}
.mega-feat-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
.mega-card {
  display: flex; flex-direction: column; justify-content: flex-end;
  position: relative;
  padding: 18px 16px 16px;
  min-height: 88px;
  background: #fff;
  border: 1px solid var(--line);
  transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
.mega-card:hover {
  border-color: #D9BD67;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px -2px rgba(217,189,103,0.25);
}
.mega-card-arrow {
  position: absolute; right: 14px; bottom: 14px;
  font-family: var(--f-mono); font-size: 14px; font-weight: 600;
  color: #B8923C;
  opacity: 0;
  transition: opacity .15s ease, transform .15s ease;
  pointer-events: none;
  line-height: 1;
}
.mega-card:hover .mega-card-arrow {
  opacity: 1;
  transform: translateX(2px);
}
.mega-card-hero .mega-card-arrow { color: #D9BD67; }
/* Placeholder (Coming Soon inline) */
.mega-card-placeholder {
  background: rgba(217,189,103,0.04);
  border-style: dashed;
  border-color: rgba(217,189,103,0.45);
}
.mega-card-placeholder .mega-card-name { color: rgba(26,26,26,0.6); }
.mega-card-placeholder:hover { background: rgba(217,189,103,0.08); border-style: solid; border-color: #D9BD67; }
/* View-all link card */
.mega-card-viewall {
  background: rgba(217,189,103,0.06);
  border-color: rgba(217,189,103,0.5);
}
.mega-card-viewall .mega-card-name { color: rgba(184,146,60,0.85); }
.mega-card-viewall:hover .mega-card-name { color: #B8923C; }
.mega-card-viewall:hover { background: rgba(217,189,103,0.12); border-color: #B8923C; }
/* Inline CTA card variant */
.mega-card-cta-inline {
  background: linear-gradient(135deg, rgba(217,189,103,0.12) 0%, rgba(217,189,103,0.04) 100%);
  border-color: #D9BD67;
}
.mega-card-cta-inline .mega-card-name { color: rgba(184,146,60,0.85); }
.mega-card-cta-inline:hover .mega-card-name { color: #B8923C; }
.mega-card-name {
  display: block;
  font-family: var(--f-mono); font-size: 14px; font-weight: 600;
  color: var(--ink); letter-spacing: 0.02em;
  margin-bottom: 2px;
}
.mega-card-meta {
  display: block;
  font-size: 11px; color: var(--muted);
  letter-spacing: 0.02em;
  line-height: 1.4;
}
.mega-card-tag {
  position: absolute; top: 0; right: 0;
  padding: 4px 10px;
  font-family: var(--f-mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  background: #D9BD67;
  color: var(--ink);
  z-index: 2;
}
.mega-card-hero {
  grid-column: span 2;
  min-height: 130px;
  height: 130px;
  padding-top: 28px;
  background: #0E0F12; color: #fff;
  border-color: #0E0F12;
  background-image:
    radial-gradient(ellipse at top right, rgba(217,189,103,0.22), transparent 60%);
}
.mega-card-hero:hover {
  background-color: #1A1C20;
  transform: translateY(-1px);
  border-color: #D9BD67;
  box-shadow: 0 4px 16px -4px rgba(217,189,103,0.4);
}
.mega-card-hero .mega-card-name { color: #fff; font-size: 18px; }
.mega-card-hero .mega-card-meta {
  color: rgba(255,255,255,0.78);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.mega-card-hero:hover .mega-card-arrow { opacity: 1; }
.mega-card-hero .mega-card-tag {
  background: #D9BD67;
  color: #0E0F12;
}

/* LEFT: axis rail (replaces single-tier rail) */
.mega-axis-rail {
  background: var(--card);
  padding: 32px 24px 24px;
  border-right: 1px solid var(--line);
  display: flex; flex-direction: column;
}
.mega-axis { display: none; }
.mega-axis.active { display: block; animation: megaPanelIn .25s ease; }
.mega-axis-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 1px;
}
.mega-axis-item > a {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: baseline;
  column-gap: 10px;
  padding: 11px 14px;
  text-decoration: none; color: var(--ink);
  border-left: 3px solid transparent;
  transition: background .12s ease, border-color .12s ease;
}
.mega-axis-item > a:hover { background: rgba(255,255,255,0.6); border-left-color: rgba(217,189,103,0.4); }
.mega-axis-item.active > a {
  background: #fff;
  border-left-color: #D9BD67;
  border-left-width: 4px;
  padding-left: 13px;
}
.mega-axis-num {
  font-family: var(--f-mono); font-size: 10px;
  color: var(--muted); letter-spacing: 0.08em;
}
.mega-axis-item.active .mega-axis-num { color: #B8923C; }
.mega-axis-name { font-size: 13px; font-weight: 600; line-height: 1.3; white-space: nowrap; }
.mega-axis-meta {
  font-family: var(--f-mono); font-size: 9px;
  color: var(--muted); letter-spacing: 0.04em;
  white-space: nowrap;
}
  white-space: nowrap;
}
/* Show meta only on Materials → Performance axis (e.g. temperature ranges). Hide everywhere else. */
.mega-axis-meta { display: none !important; }
#mega-materials .mega-axis[data-axis-panel="performance"] .mega-axis-meta { display: inline !important; }

/* image slot placeholder on every featured card */
.mega-card[data-img-slot]::before {
  content: '';
  position: absolute; inset: 0;
  background-image: var(--card-img, none);
  background-size: cover; background-position: center;
  opacity: 0.14;
  pointer-events: none;
  z-index: 0;
}
.mega-card[data-img-slot] > *:not(.mega-card-tag) { position: relative; z-index: 1; }
.mega-card-hero[data-img-slot]::before { opacity: 0.4; }

/* RIGHT: side panel (Coming Soon + Custom Inquiry CTA) */
.mega-side {
  background: var(--card);
  border-left: 1px solid var(--line);
  border-top: 2px solid #D9BD67;
  padding: 32px 28px 28px;
  display: flex; flex-direction: column;
  gap: 22px;
}
.mega-side-head {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--f-mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 4px;
}
.mega-side-pulse {
  width: 6px; height: 6px; border-radius: 50%;
  background: #D9BD67;
  box-shadow: 0 0 0 0 rgba(217,189,103,0.6);
  animation: sidePulse 2s ease-out infinite;
}
@keyframes sidePulse {
  0%   { box-shadow: 0 0 0 0 rgba(217,189,103,0.55); }
  70%  { box-shadow: 0 0 0 6px rgba(217,189,103,0); }
  100% { box-shadow: 0 0 0 0 rgba(217,189,103,0); }
}
.mega-side-sub {
  font-size: 11px; color: var(--muted);
  margin: 0 0 10px; line-height: 1.5;
}
.mega-side-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column;
}
.mega-side-list a {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: baseline;
  column-gap: 10px;
  padding: 9px 0;
  text-decoration: none; color: var(--ink);
  font-size: 13px; font-weight: 500;
  border-bottom: 1px solid var(--line);
  transition: color .12s ease, padding-left .12s ease;
}
.mega-side-list a:hover { color: #B8923C; padding-left: 4px; }
.mega-side-list li[hidden] { display: none; }
.mega-side-label { font-weight: 600; }
.mega-side-tags {
  font-family: var(--f-mono); font-size: 9px;
  color: var(--muted); letter-spacing: 0.04em;
  white-space: nowrap;
}
.mega-side-q {
  font-family: var(--f-mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.06em;
  color: #0E0F12;
  background: #D9BD67;
  padding: 3px 7px;
  border-radius: 1px;
  white-space: nowrap;
}
.mega-side-empty {
  font-size: 11px; color: var(--muted);
  margin: 14px 0 0; padding: 10px 0;
  font-style: italic;
  line-height: 1.5;
}

/* Custom Inquiry CTA card — gold-emphasized */
.mega-cta-card {
  display: block;
  margin-top: auto;
  padding: 18px 18px 16px;
  background: linear-gradient(135deg, #D9BD67 0%, #C9A24E 100%);
  color: var(--ink);
  text-decoration: none;
  position: relative; overflow: hidden;
  transition: transform .15s ease, box-shadow .15s ease;
}
/* When placed in left-bottom grid area, it sits in the rail column */
.mega-cta-card-bottom {
  margin: 0;
  padding: 18px 20px 18px;
  overflow: hidden;
  word-break: break-word;
}
.mega-cta-card-bottom .mega-cta-title { font-size: 14px; line-height: 1.2; margin-bottom: 6px; white-space: normal; }
.mega-cta-card-bottom .mega-cta-desc { font-size: 10px; line-height: 1.5; margin: 0 0 10px; white-space: normal; }
.mega-cta-card-bottom .mega-cta-link { font-size: 10px; }
  background: linear-gradient(135deg, #D9BD67 0%, #C9A24E 100%);
  border-top: 1px solid rgba(0,0,0,0.08);
}
.mega-cta-card::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at top right, rgba(255,255,255,0.35), transparent 60%);
  pointer-events: none;
}
.mega-cta-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(184,146,60,0.28);
}
.mega-cta-eyebrow {
  font-family: var(--f-mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(26,26,26,0.65);
  margin-bottom: 4px;
}
.mega-cta-title {
  font-family: var(--f-display);
  font-size: 16px; font-weight: 600; line-height: 1.25;
  color: var(--ink);
  margin-bottom: 8px;
}
.mega-cta-desc {
  font-size: 11px; line-height: 1.55;
  color: rgba(26,26,26,0.72);
  margin: 0 0 12px;
}
.mega-cta-link {
  display: inline-block;
  font-family: var(--f-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ink);
  border-bottom: 2px solid var(--ink);
  padding-bottom: 2px;
}
.mega-backdrop {
  position: fixed; top: 72px; left: 0; right: 0; bottom: 0;
  background: rgba(15,17,21,0.18);
  opacity: 0; visibility: hidden;
  transition: opacity .2s ease, visibility .2s;
  z-index: 40; pointer-events: none;
}
.nav.mega-open .mega-backdrop { opacity: 1; visibility: visible; }
@media (max-width: 1180px) {
  .nav-links { gap: 16px; }
  .mega-tri { grid-template-columns: 220px 1fr 240px; }
  .mega-feat { padding: 28px 28px 24px; }
  .mega-feat-grid { grid-template-columns: 1fr; }
  .mega-card-hero { grid-column: span 1; min-height: 100px; }
}
@media (max-width: 900px) {
  .mega-tri { grid-template-columns: 1fr; }
  .mega-axis-rail { border-right: none; border-bottom: 1px solid var(--line); padding: 20px 24px; }
  .mega-side { border-left: none; border-top: 1px solid var(--line); padding: 20px 24px; }
  .mega-feat { padding: 24px; }
  .mega-tabs { padding: 0 16px; overflow-x: auto; }
  .mega-tab { padding: 14px 14px 12px; white-space: nowrap; }
}
.nav-right { display: flex; align-items: center; gap: 14px; }
.nav-icon-btn {
  width: 38px; height: 38px; display: grid; place-items: center;
  border: 1px solid var(--line); border-radius: var(--r-sm);
  transition: border-color .15s ease;
}
.nav-icon-btn:hover { border-color: var(--ink); }
.nav-small {
  font-family: var(--f-mono); font-size: 11px; color: var(--muted);
  letter-spacing: 0.04em; text-transform: uppercase;
}

/* ===== Announcement bar ===== */
.announce {
  background: var(--ink); color: #fff;
  font-family: var(--f-mono); font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase;
  height: 32px; display: flex; align-items: center; justify-content: center;
  gap: 28px; overflow: hidden;
}
.announce .dot { color: var(--accent); }

/* ===== Page sections ===== */
section { padding: 88px 0; }
.section-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 24px; margin-bottom: 40px; flex-wrap: wrap;
}
.section-title { font-size: clamp(28px, 3.2vw, 44px); max-width: 700px; }
.section-sub { color: var(--muted); max-width: 420px; font-size: 14px; }

/* ===== Hero Slideshow (v2) ===== */
.hero-slideshow {
  position: relative;
  height: 75vh;
  min-height: 560px;
  max-height: 820px;
  background: var(--ink);
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.hero-slide {
  position: absolute; inset: 0;
  opacity: 0;
  transition: opacity .8s ease;
  pointer-events: none;
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.hero-slide.active { opacity: 1; pointer-events: auto; }
.hero-slide-text {
  padding: 80px var(--pad-x);
  display: flex; flex-direction: column; justify-content: center;
  background: var(--card);
  position: relative;
  z-index: 2;
}
.hero-slide-eyebrow {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--accent-dark);
}
.hero-slide-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(42px, 5vw, 72px);
  letter-spacing: -0.03em; line-height: 1.02;
  margin-top: 24px;
  max-width: 560px;
}
.hero-slide-body {
  margin-top: 20px;
  color: var(--muted);
  font-size: 16px;
  max-width: 440px;
}
.hero-slide-cta { margin-top: 36px; align-self: flex-start; }

.hero-slide-visual {
  position: relative;
  background: linear-gradient(180deg, #EEF2F6 0%, #DDE4EB 100%);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.hero-slide-visual::before {
  content: ''; position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(90deg, rgba(26,26,26,0.04) 0 1px, transparent 1px 80px),
    repeating-linear-gradient(0deg, rgba(26,26,26,0.04) 0 1px, transparent 1px 80px);
}
.hero-slide-visual.dark { background: linear-gradient(155deg, #2a2d33 0%, #111318 100%); }
.hero-slide-visual.dark::before {
  background-image:
    repeating-linear-gradient(90deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 80px),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 80px);
}
.hero-slide-visual.warm { background: linear-gradient(155deg, #f0ede5 0%, #d4cfc0 100%); }
.hero-slide-visual .object {
  position: relative; z-index: 2;
  width: 60%; aspect-ratio: 1;
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 11px;
  letter-spacing: 0.08em; color: var(--muted);
  text-transform: uppercase;
  background: rgba(255,255,255,0.5);
  border: 1px solid rgba(26,26,26,0.08);
}
.hero-slide-visual.dark .object {
  background: rgba(47,167,255,0.08);
  border-color: rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.5);
}
.hero-slide-visual .vis-tag {
  position: absolute; top: 24px; right: 24px;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--muted);
  padding: 6px 10px; background: rgba(255,255,255,0.9); border: 1px solid var(--line);
  z-index: 3;
}
.hero-slide-visual.dark .vis-tag { background: rgba(0,0,0,0.5); color: rgba(255,255,255,0.7); border-color: rgba(255,255,255,0.15); }

.hero-controls {
  position: absolute; bottom: 32px; left: 0; right: 0;
  display: flex; justify-content: space-between; align-items: center;
  padding: 0 var(--pad-x);
  z-index: 5;
  pointer-events: none;
}
.hero-dots { display: flex; gap: 10px; pointer-events: auto; }
.hero-dot {
  width: 32px; height: 2px;
  background: rgba(26,26,26,0.2);
  cursor: pointer;
  transition: background .3s ease;
  position: relative;
  overflow: hidden;
}
.hero-dot.active { background: rgba(26,26,26,0.15); }
.hero-dot.active::after {
  content: ''; position: absolute; inset: 0;
  background: var(--ink);
  animation: heroProgress 7s linear forwards;
}
.hero-slideshow.paused .hero-dot.active::after { animation-play-state: paused; }
@keyframes heroProgress { from { transform: translateX(-100%);} to { transform: translateX(0);} }

.hero-arrows { display: flex; gap: 8px; pointer-events: auto; }
.hero-arrow {
  width: 44px; height: 44px;
  border: 1px solid var(--line);
  background: var(--card);
  display: grid; place-items: center;
  border-radius: var(--r-sm);
  font-family: var(--f-mono); font-size: 16px; font-weight: 500;
  transition: background .15s ease;
}
.hero-arrow:hover { background: var(--ink); color: #fff; border-color: var(--ink); }
.hero-counter {
  font-family: var(--f-mono); font-size: 11px;
  color: var(--muted); letter-spacing: 0.08em;
  pointer-events: auto;
}
.hero-counter .cur { color: var(--ink); font-weight: 600; }

/* ===== Video + Interactive Timeline ===== */
.ecosystem {
  background: var(--ink); color: #fff;
  padding: 0;
  position: relative;
  overflow: hidden;
}
.ecosystem-inner {
  min-height: 75vh;
  display: grid; grid-template-rows: auto 1fr auto;
  padding: 64px var(--pad-x) 48px;
  max-width: var(--max-w);
  margin: 0 auto;
}
.ecosystem-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 32px; flex-wrap: wrap;
  margin-bottom: 48px;
}
.ecosystem-head .eyebrow { color: var(--accent); }
.ecosystem-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(32px, 3.8vw, 52px);
  letter-spacing: -0.03em; line-height: 1;
  max-width: 700px;
  margin-top: 12px;
}
.ecosystem-title .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
  letter-spacing: -0.02em;
  color: rgba(255,255,255,0.85);
}
.ecosystem-stage {
  position: relative;
  aspect-ratio: 16 / 8;
  background: #0a0a0a;
  border: 1px solid rgba(255,255,255,0.08);
  overflow: hidden;
  display: grid;
}
.eco-frame {
  grid-area: 1 / 1;
  position: relative;
  opacity: 0;
  transition: opacity .7s ease;
  pointer-events: none;
}
.eco-frame.active { opacity: 1; pointer-events: auto; }
.eco-frame-bg {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, #111318 0%, #1a1d24 100%);
}
.eco-frame-bg::before {
  content: ''; position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(45deg, rgba(255,255,255,0.02) 0 2px, transparent 2px 18px);
}
.eco-frame-bg.f2 { background: linear-gradient(135deg, #0a1420 0%, #1a2a38 100%); }
.eco-frame-bg.f3 { background: linear-gradient(135deg, #1a1d24 0%, #2a2028 100%); }
.eco-frame-bg.f4 { background: linear-gradient(135deg, #1a1a18 0%, #26241e 100%); }

.eco-placeholder-tag {
  position: absolute; top: 24px; left: 24px;
  font-family: var(--f-mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  padding: 6px 10px;
  border: 1px solid rgba(255,255,255,0.15);
  background: rgba(0,0,0,0.3);
  display: flex; align-items: center; gap: 8px;
}
.eco-placeholder-tag::before {
  content: ''; width: 6px; height: 6px; background: #ff4a4a; border-radius: 50%;
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }

.eco-stage-center {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 32%; aspect-ratio: 1;
  border: 1px solid rgba(255,255,255,0.15);
  background: rgba(47,167,255,0.06);
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 11px;
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.1em; text-transform: uppercase;
}

.eco-overlay {
  position: absolute; left: 48px; bottom: 48px; right: 48px;
  max-width: 520px;
  z-index: 2;
}
.eco-overlay .eyebrow { color: var(--accent); }
.eco-overlay .head {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(24px, 3vw, 36px);
  letter-spacing: -0.02em; line-height: 1.1;
  margin-top: 14px;
  color: #fff;
}
.eco-overlay .desc {
  margin-top: 12px;
  color: rgba(255,255,255,0.7);
  font-size: 15px;
}
.eco-overlay .explore {
  margin-top: 20px; display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--f-mono); font-size: 12px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: #fff;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--accent);
}
.eco-overlay .explore:hover { color: var(--accent); }

.ecosystem-timeline {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px; background: rgba(255,255,255,0.08);
  margin-top: 32px;
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.eco-node {
  background: var(--ink);
  padding: 24px 24px 28px;
  cursor: pointer;
  display: flex; flex-direction: column; gap: 10px;
  position: relative;
  transition: background .2s ease;
}
.eco-node:hover { background: #0a0a0a; }
.eco-node-num {
  font-family: var(--f-mono); font-size: 10px;
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.1em;
}
.eco-node-lab {
  font-family: var(--f-display); font-weight: 600;
  font-size: 22px; letter-spacing: -0.02em;
  color: rgba(255,255,255,0.5);
  transition: color .2s ease;
}
.eco-node.active .eco-node-lab { color: #fff; }
.eco-node-bar {
  position: absolute; top: 0; left: 0; right: 0;
  height: 2px; background: transparent;
  overflow: hidden;
}
.eco-node.active .eco-node-bar { background: rgba(47,167,255,0.15); }
.eco-node.active .eco-node-bar::after {
  content: ''; position: absolute; inset: 0;
  background: var(--accent);
  animation: ecoProgress 9s linear forwards;
}
.ecosystem.paused .eco-node.active .eco-node-bar::after { animation-play-state: paused; }
@keyframes ecoProgress { from { transform: translateX(-100%);} to { transform: translateX(0);} }

/* ===== Featured Carousel ===== */
.featured-carousel-section { padding: 88px 0 88px; background: var(--card); border-bottom: 1px solid var(--line); }
.featured-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 24px; flex-wrap: wrap;
  margin-bottom: 36px;
}
.featured-head .t {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(28px, 3.2vw, 44px);
  letter-spacing: -0.03em; line-height: 1;
  margin-top: 12px;
}
.featured-head .t .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
}
.featured-head-right {
  display: flex; gap: 12px; align-items: center;
}
.carousel-arrows { display: flex; gap: 6px; }
.carousel-arr {
  width: 40px; height: 40px;
  border: 1px solid var(--line);
  display: grid; place-items: center;
  background: var(--card);
  border-radius: var(--r-sm);
  font-family: var(--f-mono); font-size: 14px;
  transition: background .15s ease;
}
.carousel-arr:hover { background: var(--ink); color: #fff; border-color: var(--ink); }
.carousel-arr:disabled { opacity: 0.3; cursor: not-allowed; }

.carousel-track-wrap {
  position: relative;
  overflow: hidden;
}
.carousel-track {
  display: flex; gap: 20px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  padding-bottom: 4px;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.carousel-track::-webkit-scrollbar { display: none; }
.carousel-card {
  flex: 0 0 calc(25% - 15px);
  min-width: 260px;
  scroll-snap-align: start;
  background: var(--card);
  border: 1px solid var(--line);
  display: flex; flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease;
  cursor: pointer;
}
.carousel-card:hover { transform: translateY(-3px); box-shadow: 0 18px 40px -20px rgba(0,0,0,0.15); }
.carousel-card .prod-img { aspect-ratio: 4 / 5; }
.carousel-indicator {
  margin-top: 24px;
  height: 2px;
  background: var(--line);
  position: relative;
  max-width: 240px;
}
.carousel-indicator-fill {
  position: absolute; top: 0; left: 0; bottom: 0;
  background: var(--ink);
  width: 25%;
  transition: left .3s ease, width .3s ease;
}

/* ===== Partner Brand Block ===== */
.partner-section {
  padding: 96px 0;
  background: var(--soft);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  text-align: center;
}
.partner-inner { max-width: 680px; margin: 0 auto; padding: 0 var(--pad-x); }
.partner-inner .eyebrow { color: var(--accent-dark); }
.partner-logos {
  display: flex; justify-content: center; align-items: center;
  gap: 48px;
  margin: 32px 0 24px;
  flex-wrap: wrap;
}
.partner-logo {
  display: flex; align-items: center; justify-content: center;
  height: 56px;
  padding: 0 24px;
  border: 1px solid var(--line);
  background: var(--card);
  font-family: var(--f-display); font-weight: 700; font-size: 22px;
  letter-spacing: -0.02em; color: var(--ink);
  min-width: 140px;
}
.partner-logo.primary { border-color: var(--ink); border-width: 2px; font-size: 26px; height: 72px; }
.partner-logo.placeholder {
  color: var(--muted); font-weight: 500; font-size: 13px;
  letter-spacing: 0.08em; text-transform: uppercase;
  border-style: dashed; background: transparent;
  font-family: var(--f-mono);
}
.partner-desc {
  margin-top: 24px;
  color: var(--muted);
  font-size: 15px;
  max-width: 520px;
  margin-left: auto; margin-right: auto;
}
.partner-cta { margin-top: 28px; display: inline-flex; }

/* ===== Trust v2 (simplified) ===== */
.trust-v2 {
  background: var(--ink);
  color: #fff;
  padding: 48px 0;
}
.trust-v2-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  align-items: center;
}
.trust-v2-item {
  display: flex; align-items: center; gap: 18px;
  padding-right: 24px;
  border-right: 1px solid rgba(255,255,255,0.1);
}
.trust-v2-item:last-child { border-right: none; }
.trust-v2-ico {
  width: 44px; height: 44px; flex-shrink: 0;
  border: 1.5px solid #fff;
  display: grid; place-items: center;
  border-radius: var(--r-sm);
}
.trust-v2-ico svg { width: 22px; height: 22px; }
.trust-v2-text .lab {
  font-family: var(--f-display); font-size: 17px; font-weight: 500;
  letter-spacing: -0.01em; line-height: 1.15;
  display: block;
}
.trust-v2-text .sub {
  font-family: var(--f-mono); font-size: 11px;
  color: rgba(255,255,255,0.5);
  letter-spacing: 0.04em; text-transform: uppercase;
  margin-top: 3px;
  display: block;
}

/* ===== Hero — Variant A ===== */
.hero-a {
  background: var(--card);
  border-bottom: 1px solid var(--line);
}
.hero-a-grid {
  display: grid; grid-template-columns: 1.05fr 1fr;
  gap: 0;
  min-height: 640px;
}
.hero-a-left {
  padding: 72px var(--pad-x) 72px 0;
  padding-left: var(--pad-x);
  display: flex; flex-direction: column; justify-content: space-between;
  border-right: 1px solid var(--line);
}
.hero-a-meta {
  display: flex; gap: 24px; align-items: center;
  font-family: var(--f-mono); font-size: 11px; color: var(--muted);
  letter-spacing: 0.06em; text-transform: uppercase;
}
.hero-a-meta .dash { width: 24px; height: 1px; background: var(--ink); display: inline-block; }
.hero-a-title {
  font-size: clamp(56px, 7vw, 104px);
  font-weight: 600; line-height: 0.92;
  letter-spacing: -0.035em;
  text-transform: uppercase;
  margin-top: 48px;
}
.hero-a-title .italic {
  font-family: var(--f-serif); font-style: italic;
  font-weight: 400; text-transform: none;
  letter-spacing: -0.02em;
  color: var(--ink);
  display: inline-block;
  padding-right: 8px;
}
.hero-a-title .accent-word { color: var(--accent); }
.hero-a-body {
  margin-top: 32px;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 40px;
}
.hero-a-body p {
  font-size: 15px; color: var(--ink); max-width: 380px;
}
.hero-a-body p.muted { color: var(--muted); }
.hero-a-ctas { display: flex; gap: 12px; margin-top: 40px; flex-wrap: wrap; }

.hero-a-right {
  position: relative;
  background: linear-gradient(180deg, #EEF2F6 0%, #DDE4EB 100%);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.hero-a-right::before {
  content: ''; position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(90deg, rgba(26,26,26,0.04) 0 1px, transparent 1px 80px),
    repeating-linear-gradient(0deg, rgba(26,26,26,0.04) 0 1px, transparent 1px 80px);
}
.hero-machine {
  position: relative;
  width: 78%; aspect-ratio: 1 / 1.1;
  background: linear-gradient(155deg, #2a2d33 0%, #111318 100%);
  display: grid; place-items: center;
  box-shadow: 0 40px 80px -20px rgba(0,0,0,0.35);
  overflow: hidden;
}
.hero-machine::before {
  content: 'IEMAI HT-PRO';
  position: absolute; top: 20px; left: 20px;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.12em;
  color: rgba(255,255,255,0.4); text-transform: uppercase;
}
.hero-machine::after {
  content: ''; position: absolute;
  left: 14%; right: 14%; top: 22%; bottom: 22%;
  background:
    linear-gradient(180deg, rgba(47,167,255,0.15) 0%, transparent 60%),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 8px);
  border: 1px solid rgba(255,255,255,0.08);
}
.hero-machine-label {
  position: absolute; bottom: 20px; right: 20px;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.12em;
  color: rgba(255,255,255,0.6); text-transform: uppercase;
  text-align: right;
}
.hero-machine-center {
  position: relative; z-index: 2;
  width: 40%; aspect-ratio: 1;
  border: 1px solid rgba(255,255,255,0.2);
  display: grid; place-items: center;
  background: rgba(47,167,255,0.08);
}
.hero-machine-center span {
  font-family: var(--f-mono); font-size: 10px; color: rgba(255,255,255,0.5);
  letter-spacing: 0.1em; text-transform: uppercase;
}
.hero-badge {
  position: absolute; top: 40px; right: 40px;
  background: var(--card); padding: 14px 16px;
  border: 1px solid var(--line);
  font-family: var(--f-mono); font-size: 11px;
  letter-spacing: 0.04em;
  display: flex; flex-direction: column; gap: 2px;
  z-index: 3;
}
.hero-badge strong { color: var(--accent-dark); font-size: 13px; }
.hero-spec-card {
  position: absolute; bottom: 40px; left: 40px;
  background: var(--card); padding: 16px 20px;
  border: 1px solid var(--line);
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  z-index: 3;
}
.hero-spec-card > div { min-width: 70px; }
.hero-spec-card .lab { font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; }
.hero-spec-card .val { font-family: var(--f-display); font-weight: 600; font-size: 20px; margin-top: 2px; }
.hero-spec-card .val sup { font-size: 11px; font-weight: 500; color: var(--muted); }

/* ===== Business line tiles ===== */
.lines {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.line-tile {
  background: var(--card);
  padding: 36px 32px 32px;
  position: relative;
  display: flex; flex-direction: column;
  min-height: 340px;
  cursor: pointer;
  transition: background .2s ease;
}
.line-tile:hover { background: var(--soft); }
.line-tile:hover .line-tile-arr { transform: translateX(6px); }
.line-tile-num { font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.08em; }
.line-tile-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: 32px; letter-spacing: -0.02em;
  margin-top: 20px; line-height: 1;
}
.line-tile-desc {
  color: var(--muted); font-size: 14px;
  margin-top: 12px; max-width: 320px;
}
.line-tile-foot {
  margin-top: auto;
  display: flex; justify-content: space-between; align-items: flex-end;
  padding-top: 32px;
}
.line-tile-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.line-tile-tag {
  font-family: var(--f-mono); font-size: 10px; color: var(--muted);
  padding: 4px 8px; border: 1px solid var(--line);
  letter-spacing: 0.04em; text-transform: uppercase;
}
.line-tile-arr {
  font-size: 18px;
  transition: transform .2s ease;
}

/* Variant B — 4 equal tiles */
.lines-4 { grid-template-columns: repeat(4, 1fr); }

/* ===== Trust row ===== */
.trust {
  background: var(--ink);
  color: #fff;
  padding: 56px 0;
}
.trust-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px; background: rgba(255,255,255,0.08);
}
.trust-item {
  background: var(--ink);
  padding: 12px 28px 12px 0;
  display: flex; flex-direction: column; gap: 8px;
}
.trust-item .num {
  font-family: var(--f-mono); font-size: 11px; color: rgba(255,255,255,0.5);
  letter-spacing: 0.08em;
}
.trust-item .lab {
  font-family: var(--f-display); font-size: 22px; font-weight: 500;
  letter-spacing: -0.02em; line-height: 1.1;
}
.trust-item .sub {
  font-family: var(--f-mono); font-size: 11px; color: rgba(255,255,255,0.5);
  letter-spacing: 0.04em; text-transform: uppercase;
  margin-top: auto;
}

/* ===== Product grid ===== */
.products-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.prod-card {
  background: var(--card);
  border: 1px solid var(--line);
  display: flex; flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease;
  cursor: pointer;
}
.prod-card:hover { transform: translateY(-3px); box-shadow: 0 18px 40px -20px rgba(0,0,0,0.15); }
.prod-img {
  aspect-ratio: 4 / 3;
  background: var(--soft);
  position: relative; overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.prod-img .placeholder {
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(45deg, rgba(26,26,26,0.03) 0 2px, transparent 2px 14px);
}
.prod-img .ph-label {
  position: absolute; bottom: 10px; left: 10px;
  font-family: var(--f-mono); font-size: 10px; color: var(--muted);
  letter-spacing: 0.08em; text-transform: uppercase;
}
.prod-img .tag-badge {
  position: absolute; top: 12px; left: 12px;
  background: var(--ink); color: #fff;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.06em;
  padding: 4px 8px; text-transform: uppercase;
}
.prod-img.filament { background: linear-gradient(135deg, #1a1a1a 0%, #2a2a2a 100%); }
.prod-img.filament .placeholder { display: none; }
.prod-img.filament::before {
  content: ''; position: absolute; top: 50%; left: 50%;
  width: 55%; aspect-ratio: 1; border-radius: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle at 50% 30%, #fff 0%, #666 40%, #111 100%);
  box-shadow: inset 0 0 0 12px rgba(255,255,255,0.05), inset 0 0 0 13px rgba(0,0,0,0.3);
}
.prod-img.filament.blue::before { background: radial-gradient(circle at 50% 30%, #7ecaff 0%, #2FA7FF 40%, #0a3a5c 100%); }
.prod-img.filament.red::before { background: radial-gradient(circle at 50% 30%, #ff9a9a 0%, #d44 40%, #3a0a0a 100%); }
.prod-img.filament.green::before { background: radial-gradient(circle at 50% 30%, #9adba3 0%, #3a9a4a 40%, #0a2a1a 100%); }
/* fix 2026-06-04: 有真实产品图时隐藏 filament 占位灰球, 让图正常显示在最上层 */
.prod-img img { position: relative; z-index: 1; width: 100%; height: 100%; object-fit: contain; display: block; background: #fff; }
.prod-img.filament:has(img)::before { display: none; }
.prod-img.printed { background: linear-gradient(150deg, #f0ede5 0%, #d4cfc0 100%); }
.prod-img.printed .placeholder { opacity: 0.5; }

.prod-body { padding: 18px 18px 20px; display: flex; flex-direction: column; gap: 8px; }
.prod-cat { font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; }
.prod-title { font-family: var(--f-display); font-weight: 500; font-size: 16px; line-height: 1.25; letter-spacing: -0.01em; }
.prod-foot { display: flex; justify-content: space-between; align-items: center; margin-top: 6px; }
.prod-price { font-family: var(--f-mono); font-weight: 600; font-size: 15px; }
.prod-price .quote { color: var(--accent-dark); }
.prod-meta { font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; }

/* ===== Content teaser ===== */
.content-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.content-card {
  background: var(--card); border: 1px solid var(--line);
  padding: 28px; display: flex; flex-direction: column; gap: 16px;
  min-height: 260px;
  transition: border-color .2s ease;
}
.content-card:hover { border-color: var(--ink); }
.content-card .eyebrow { margin-bottom: 0; }
.content-card h3 { font-size: 22px; font-weight: 500; line-height: 1.2; }
.content-card .read {
  margin-top: auto;
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--accent-dark);
  display: flex; align-items: center; gap: 6px;
}

/* ===== Testimonials ===== */
.testi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.testi-card {
  background: var(--soft);
  padding: 32px 28px;
  border-left: 2px solid var(--accent);
  display: flex; flex-direction: column; gap: 20px;
}
.testi-card .q {
  font-family: var(--f-display); font-size: 20px; font-weight: 400;
  letter-spacing: -0.01em; line-height: 1.35;
}
.testi-card .q .quote-mark { color: var(--accent); font-family: var(--f-serif); font-style: italic; font-size: 32px; line-height: 0; }
.testi-card .who { display: flex; flex-direction: column; gap: 2px; margin-top: auto; }
.testi-card .who .name { font-weight: 600; font-size: 14px; }
.testi-card .who .role { font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; }

/* ===== Footer ===== */
.footer {
  background: var(--ink); color: #fff;
  padding: 80px 0 32px;
}
.footer-top {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr 1.2fr;
  gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(255,255,255,0.12);
}
.footer-brand .logo { color: #fff; }
.footer-brand .logo-mark { background: #fff; color: var(--ink); }
.footer-slogan {
  font-family: var(--f-serif); font-style: italic;
  font-size: 22px; margin-top: 20px; letter-spacing: -0.01em;
}
.footer-addr { font-family: var(--f-mono); font-size: 12px; color: rgba(255,255,255,0.6); letter-spacing: 0.02em; margin-top: 24px; line-height: 1.7; }
.footer h4 { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.5); margin-bottom: 20px; font-weight: 600; }
.footer ul { list-style: none; display: flex; flex-direction: column; gap: 12px; }
.footer ul a { font-size: 14px; color: rgba(255,255,255,0.85); }
.footer ul a:hover { color: var(--accent); }
.footer-news input {
  width: 100%; padding: 12px 14px;
  background: transparent; border: 1px solid rgba(255,255,255,0.2);
  color: #fff; font-family: var(--f-body); font-size: 14px;
  border-radius: var(--r-sm);
}
.footer-news input::placeholder { color: rgba(255,255,255,0.4); }
.footer-news button {
  margin-top: 10px; width: 100%;
  height: 42px; background: #fff; color: var(--ink);
  font-weight: 600; font-size: 13px;
  border-radius: var(--r-sm);
}
.footer-bot {
  padding-top: 28px;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 20px;
  font-family: var(--f-mono); font-size: 11px; color: rgba(255,255,255,0.5);
  letter-spacing: 0.04em; text-transform: uppercase;
}

/* ===== Variant B — Equal business lines ===== */
.hero-b {
  padding: 120px 0 80px;
  background: var(--card);
  border-bottom: 1px solid var(--line);
}
.hero-b-inner { max-width: 1000px; }
.hero-b-title {
  font-size: clamp(56px, 8vw, 120px);
  font-weight: 600; line-height: 0.95;
  letter-spacing: -0.04em;
  text-transform: uppercase;
}
.hero-b-title .italic { font-family: var(--f-serif); font-style: italic; font-weight: 400; text-transform: none; letter-spacing: -0.02em; }
.hero-b-title .accent { color: var(--accent); }
.hero-b-sub { margin-top: 32px; font-size: 18px; max-width: 640px; color: var(--muted); }
.hero-b-meta { display: flex; gap: 32px; margin-top: 40px; flex-wrap: wrap; }
.hero-b-meta > div { display: flex; flex-direction: column; gap: 4px; }
.hero-b-meta .lab { font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; }
.hero-b-meta .val { font-family: var(--f-display); font-size: 20px; font-weight: 500; }

/* ===== Variant C — Scrolling narrative ===== */
.hero-c {
  min-height: 80vh;
  background: var(--ink); color: #fff;
  display: flex; align-items: center;
  position: relative; overflow: hidden;
  padding: 120px 0;
}
.hero-c::before {
  content: ''; position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(90deg, rgba(255,255,255,0.03) 0 1px, transparent 1px 120px),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.03) 0 1px, transparent 1px 120px);
}
.hero-c-inner { position: relative; z-index: 2; max-width: 1100px; }
.hero-c-eyebrow { color: var(--accent); font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; display: flex; align-items: center; gap: 12px; }
.hero-c-eyebrow::before { content: ''; width: 40px; height: 1px; background: var(--accent); }
.hero-c-title {
  font-size: clamp(64px, 9vw, 140px);
  font-weight: 600; line-height: 0.9;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  margin-top: 32px;
}
.hero-c-title .italic { font-family: var(--f-serif); font-style: italic; font-weight: 400; text-transform: none; letter-spacing: -0.02em; color: rgba(255,255,255,0.8); }
.hero-c-sub {
  margin-top: 40px; max-width: 560px; font-size: 18px;
  color: rgba(255,255,255,0.7);
}
.hero-c-stats { display: grid; grid-template-columns: repeat(4, auto); gap: 48px; margin-top: 56px; }
.hero-c-stats .n { font-family: var(--f-display); font-size: 32px; font-weight: 500; }
.hero-c-stats .l { font-family: var(--f-mono); font-size: 10px; color: rgba(255,255,255,0.5); letter-spacing: 0.1em; text-transform: uppercase; margin-top: 4px; }

/* C narrative sections */
.narr-section {
  padding: 120px 0;
  border-bottom: 1px solid var(--line);
}
.narr-section:nth-child(even) { background: var(--card); }
.narr-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 64px; align-items: center; }
.narr-grid.reverse { grid-template-columns: 1.2fr 1fr; }
.narr-grid.reverse .narr-visual { order: -1; }
.narr-num { font-family: var(--f-mono); font-size: 12px; color: var(--accent-dark); letter-spacing: 0.1em; }
.narr-title { font-size: clamp(36px, 4.5vw, 64px); font-weight: 600; letter-spacing: -0.03em; margin-top: 16px; line-height: 1; }
.narr-title .italic { font-family: var(--f-serif); font-style: italic; font-weight: 400; letter-spacing: -0.015em; }
.narr-body { margin-top: 24px; color: var(--muted); font-size: 15px; max-width: 480px; }
.narr-visual {
  aspect-ratio: 4/3;
  background: var(--soft); border: 1px solid var(--line);
  position: relative; overflow: hidden;
}
.narr-visual .placeholder { position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(26,26,26,0.04) 0 2px, transparent 2px 18px); }
.narr-visual .ph-label { position: absolute; bottom: 16px; left: 16px; font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.06em; text-transform: uppercase; }

/* ===== PDP ===== */
.pdp-tag-switch {
  display: flex; gap: 0;
  border: 1px solid var(--line);
  background: var(--card);
  width: fit-content;
  border-radius: var(--r-sm);
  overflow: hidden;
  margin-bottom: 32px;
}
.pdp-tag-switch button {
  padding: 10px 20px;
  font-family: var(--f-mono); font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--muted);
  border-right: 1px solid var(--line);
  transition: background .15s ease, color .15s ease;
}
.pdp-tag-switch button:last-child { border-right: none; }
.pdp-tag-switch button.active { background: var(--ink); color: #fff; }

/* v2: cross-sell switcher — inactive shown grayed-out with hint text */
.pdp-tag-switch-v2 {
  display: flex; gap: 4px;
  border: 0; background: transparent;
  width: fit-content;
  margin-bottom: 32px;
}
.pdp-tag-switch-v2 button {
  display: flex; flex-direction: column; align-items: flex-start;
  gap: 4px;
  padding: 14px 22px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  text-align: left;
  opacity: 0.55;
  transition: opacity .15s ease, background .15s ease, border-color .15s ease, color .15s ease;
  cursor: pointer;
}
.pdp-tag-switch-v2 button:hover { opacity: 0.85; border-color: var(--ink); }
.pdp-tag-switch-v2 button.active {
  opacity: 1;
  background: var(--ink);
  border-color: var(--ink);
  color: #fff;
}
.pdp-tag-switch-v2 .pdp-tag-label {
  font-family: var(--f-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
}
.pdp-tag-switch-v2 .pdp-tag-hint {
  font-size: 10px;
  font-family: var(--f-sans);
  color: var(--muted);
  font-style: italic;
  letter-spacing: 0.02em;
  text-transform: none;
}
.pdp-tag-switch-v2 button.active .pdp-tag-hint { color: rgba(255,255,255,0.7); }

.pdp-top {
  display: grid; grid-template-columns: 58% 1fr;
  gap: 64px;
  padding: 48px 0 80px;
  border-bottom: 1px solid var(--line);
}
.pdp-gallery {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 16px;
}
.pdp-thumbs { display: flex; flex-direction: column; gap: 8px; }
.pdp-thumb {
  width: 88px; height: 88px;
  background: var(--soft); border: 1px solid var(--line);
  position: relative;
  cursor: pointer;
  transition: border-color .15s ease;
}
.pdp-thumb.active { border-color: var(--ink); }
.pdp-thumb .placeholder { position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(26,26,26,0.04) 0 2px, transparent 2px 10px); }
.pdp-main-img {
  aspect-ratio: 1; background: var(--soft); border: 1px solid var(--line);
  position: relative; overflow: hidden;
}
.pdp-main-img .placeholder { position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(26,26,26,0.03) 0 2px, transparent 2px 14px); }
.pdp-main-img .ph-label { position: absolute; bottom: 16px; left: 16px; font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; }
.pdp-main-img .tag-large { position: absolute; top: 20px; left: 20px; background: var(--ink); color: #fff; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; padding: 5px 10px; text-transform: uppercase; }

/* Machine main visual */
.pdp-main-img.machine { background: linear-gradient(155deg, #2a2d33 0%, #111318 100%); }
.pdp-main-img.machine .placeholder { display: none; }
.pdp-main-img.machine::before {
  content: ''; position: absolute;
  left: 15%; right: 15%; top: 18%; bottom: 22%;
  background:
    linear-gradient(180deg, rgba(47,167,255,0.12) 0%, transparent 60%),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 8px);
  border: 1px solid rgba(255,255,255,0.08);
}
.pdp-main-img.machine .ph-label { color: rgba(255,255,255,0.5); }

.pdp-main-img.filament { background: linear-gradient(135deg, #1a1a1a 0%, #2a2a2a 100%); }
.pdp-main-img.filament .placeholder { display: none; }
.pdp-main-img.filament::before {
  content: ''; position: absolute; top: 50%; left: 50%;
  width: 55%; aspect-ratio: 1; border-radius: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle at 50% 30%, #1a1a1a 0%, #0a0a0a 50%, #000 100%);
  box-shadow: inset 0 0 0 16px rgba(255,255,255,0.04), inset 0 0 0 17px rgba(255,255,255,0.1);
}
.pdp-main-img.filament .ph-label { color: rgba(255,255,255,0.5); }

.pdp-main-img.printed { background: linear-gradient(155deg, #f0ede5 0%, #d4cfc0 100%); }

.pdp-rail { display: flex; flex-direction: column; gap: 24px; }
.pdp-eyebrow-row { display: flex; justify-content: space-between; align-items: center; }
.pdp-sku { font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.04em; }
.pdp-title { font-size: clamp(32px, 3.5vw, 48px); font-weight: 600; letter-spacing: -0.02em; line-height: 1; }
.pdp-short { color: var(--muted); font-size: 15px; margin-top: -8px; }
.pdp-key-specs {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 20px 0;
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.pdp-key-specs > div .lab { font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 6px; }
.pdp-key-specs > div .val { font-family: var(--f-display); font-weight: 500; font-size: 20px; letter-spacing: -0.01em; }

.pdp-price-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 16px 0;
  border-bottom: 1px solid var(--line);
}
.pdp-price {
  font-family: var(--f-display); font-weight: 600;
  font-size: 36px; letter-spacing: -0.02em;
}
.pdp-price .cur { font-family: var(--f-mono); font-size: 14px; color: var(--muted); font-weight: 500; margin-right: 4px; }
.pdp-price.quote { color: var(--accent-dark); font-size: 24px; }
.pdp-stock { font-family: var(--f-mono); font-size: 11px; color: #1a8a3a; letter-spacing: 0.06em; text-transform: uppercase; display: flex; align-items: center; gap: 6px; }
.pdp-stock::before { content: ''; width: 6px; height: 6px; background: #1a8a3a; border-radius: 50%; }

.pdp-variants { display: flex; flex-direction: column; gap: 18px; }
.pdp-variant-group .lab-row { display: flex; justify-content: space-between; margin-bottom: 10px; }
.pdp-variant-group .lab { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; }
.pdp-variant-group .sel { font-family: var(--f-mono); font-size: 11px; color: var(--muted); }

.swatches { display: flex; gap: 8px; flex-wrap: wrap; }
.swatch {
  width: 36px; height: 36px; border-radius: 50%;
  border: 2px solid var(--line);
  cursor: pointer; position: relative;
  transition: border-color .15s ease;
}
.swatch.active { border-color: var(--ink); }
.swatch.oos { opacity: 0.3; }
.swatch.oos::after { content: ''; position: absolute; top: 50%; left: -4px; right: -4px; height: 1px; background: var(--ink); transform: rotate(-20deg); }

.tile-options { display: flex; gap: 8px; flex-wrap: wrap; }
.tile-opt {
  padding: 12px 16px;
  border: 1px solid var(--line);
  font-family: var(--f-mono); font-size: 12px;
  border-radius: var(--r-sm);
  cursor: pointer;
  transition: border-color .15s ease, background .15s ease;
}
.tile-opt.active { border-color: var(--ink); background: var(--ink); color: #fff; }
.tile-opt.oos { opacity: 0.4; text-decoration: line-through; pointer-events: none; }

.pdp-cta-row { display: flex; gap: 12px; margin-top: 8px; }
.pdp-cta-row .btn { flex: 1; justify-content: center; }

.pdp-mini-trust {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px 20px;
  margin-top: 12px;
  padding-top: 20px; border-top: 1px solid var(--line);
}
.pdp-mini-trust > div { font-size: 13px; display: flex; gap: 8px; align-items: flex-start; }
.pdp-mini-trust .ico { width: 16px; height: 16px; background: var(--ink); display: block; flex-shrink: 0; margin-top: 2px; }

/* Spec table */
.spec-table { background: var(--card); border: 1px solid var(--line); }
.spec-group {
  border-bottom: 1px solid var(--line);
}
.spec-group:last-child { border-bottom: none; }
.spec-group-head {
  padding: 20px 28px;
  display: flex; justify-content: space-between; align-items: center;
  cursor: pointer;
  transition: background .15s ease;
}
.spec-group-head:hover { background: var(--soft); }
.spec-group-head h4 {
  font-family: var(--f-display); font-weight: 600; font-size: 18px;
  letter-spacing: -0.01em;
  display: flex; align-items: center; gap: 14px;
}
.spec-group-head .gnum { font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.06em; font-weight: 500; }
.spec-group-head .chev { transition: transform .2s ease; font-family: var(--f-mono); font-size: 16px; color: var(--muted); }
.spec-group.open .spec-group-head .chev { transform: rotate(45deg); }
.spec-group-body {
  display: none;
  padding: 0 28px 24px;
}
.spec-group.open .spec-group-body { display: block; }
.spec-row {
  display: grid; grid-template-columns: 260px 1fr;
  padding: 12px 0;
  border-bottom: 1px dashed var(--line);
  gap: 16px;
}
.spec-row:last-child { border-bottom: none; }
.spec-row .k { font-family: var(--f-mono); font-size: 12px; color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; }
.spec-row .v { font-family: var(--f-mono); font-size: 13px; font-weight: 500; color: var(--ink); }
.spec-row .v .hi { color: var(--accent-dark); }

/* Downloads */
.downloads-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.dl-card {
  border: 1px solid var(--line); background: var(--card);
  padding: 20px; display: flex; gap: 14px; align-items: flex-start;
  cursor: pointer; transition: border-color .15s ease;
}
.dl-card:hover { border-color: var(--ink); }
.dl-icon { width: 36px; height: 44px; border: 1px solid var(--ink); display: grid; place-items: center; font-family: var(--f-mono); font-size: 9px; font-weight: 700; letter-spacing: 0.04em; flex-shrink: 0; }
.dl-meta { flex: 1; }
.dl-meta h5 { font-family: var(--f-display); font-weight: 500; font-size: 15px; }
.dl-meta p { font-family: var(--f-mono); font-size: 11px; color: var(--muted); margin-top: 4px; letter-spacing: 0.04em; }

/* Compatibility matrix */
.compat-wrap { background: var(--card); border: 1px solid var(--line); padding: 32px; }
.compat-legend { display: flex; gap: 24px; margin-bottom: 24px; flex-wrap: wrap; }
.compat-legend > div { display: flex; align-items: center; gap: 8px; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--muted); }
.compat-dot { width: 14px; height: 14px; border-radius: 50%; }
.compat-dot.full { background: #1a8a3a; }
.compat-dot.partial { background: #e8a82f; }
.compat-dot.none { background: var(--line); border: 1px solid var(--muted); }
.compat-table { width: 100%; border-collapse: collapse; }
.compat-table th, .compat-table td { padding: 14px 16px; text-align: left; border-bottom: 1px solid var(--line); }
.compat-table th {
  font-family: var(--f-mono); font-size: 10px; color: var(--muted);
  letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600;
}
.compat-table td .machine-name { font-family: var(--f-display); font-weight: 500; font-size: 15px; }
.compat-table td .brand-name { font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.04em; margin-top: 2px; }
.compat-table .dml-row { background: var(--soft); }
.compat-status { display: flex; align-items: center; gap: 10px; }
.compat-status .lab { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--muted); }

/* Material properties bars */
.mat-props { display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; background: var(--card); border: 1px solid var(--line); padding: 32px; }
.mat-prop { display: flex; flex-direction: column; gap: 8px; }
.mat-prop .row1 { display: flex; justify-content: space-between; align-items: baseline; }
.mat-prop .name { font-family: var(--f-display); font-weight: 500; font-size: 15px; }
.mat-prop .val { font-family: var(--f-mono); font-size: 12px; color: var(--accent-dark); font-weight: 600; }
.mat-prop .bar-track { height: 6px; background: var(--line); position: relative; }
.mat-prop .bar-fill { position: absolute; top: 0; left: 0; bottom: 0; background: var(--ink); }
.mat-prop .scale { display: flex; justify-content: space-between; font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.04em; margin-top: 2px; }

/* Print parameters */
.params-table { background: var(--card); border: 1px solid var(--line); padding: 24px 32px; }
.params-table h4 { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); font-weight: 600; margin-bottom: 16px; }
.params-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
.param { display: flex; flex-direction: column; gap: 6px; }
.param .p-lab { font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.06em; text-transform: uppercase; }
.param .p-val { font-family: var(--f-display); font-weight: 500; font-size: 24px; letter-spacing: -0.02em; }
.param .p-val .unit { font-family: var(--f-mono); font-size: 12px; color: var(--muted); font-weight: 500; margin-left: 2px; }

/* ROI / block */
.roi-block {
  background: var(--ink); color: #fff;
  padding: 48px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px;
  align-items: center;
}
.roi-block h3 { font-size: 32px; letter-spacing: -0.02em; }
.roi-block h3 .italic { font-family: var(--f-serif); font-style: italic; font-weight: 400; }
.roi-block p { color: rgba(255,255,255,0.7); font-size: 15px; margin-top: 16px; max-width: 420px; }
.roi-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.roi-stats > div .n { font-family: var(--f-display); font-size: 36px; font-weight: 500; letter-spacing: -0.02em; color: var(--accent); }
.roi-stats > div .l { font-family: var(--f-mono); font-size: 11px; color: rgba(255,255,255,0.6); letter-spacing: 0.06em; text-transform: uppercase; margin-top: 6px; }

/* FAQ */
.faq { max-width: 900px; }
.faq-item { border-bottom: 1px solid var(--line); padding: 20px 0; cursor: pointer; }
.faq-item:first-child { border-top: 1px solid var(--line); }
.faq-q { display: flex; justify-content: space-between; align-items: center; gap: 20px; }
.faq-q h4 { font-family: var(--f-display); font-weight: 500; font-size: 18px; letter-spacing: -0.01em; }
.faq-q .plus { font-family: var(--f-mono); font-size: 18px; color: var(--muted); transition: transform .2s ease; }
.faq-item.open .plus { transform: rotate(45deg); color: var(--ink); }
.faq-a { display: none; padding-top: 14px; color: var(--muted); font-size: 14px; max-width: 700px; }
.faq-item.open .faq-a { display: block; }

/* ===== Collection ===== */
.coll-head {
  padding: 72px 0 56px;
  border-bottom: 1px solid var(--line);
  background: var(--card);
}
.coll-head .eyebrow-row {
  display: flex; gap: 8px; font-family: var(--f-mono); font-size: 11px;
  color: var(--muted); letter-spacing: 0.06em; text-transform: uppercase;
}
.coll-title { font-size: clamp(48px, 6vw, 84px); font-weight: 600; letter-spacing: -0.03em; line-height: 0.95; margin-top: 24px; text-transform: uppercase; }
.coll-title .italic { font-family: var(--f-serif); font-style: italic; font-weight: 400; text-transform: none; letter-spacing: -0.02em; }
.coll-intro { margin-top: 24px; max-width: 640px; color: var(--muted); font-size: 16px; }
.coll-filter-chips { display: flex; gap: 8px; margin-top: 32px; flex-wrap: wrap; }
.chip {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
  padding: 8px 14px; border: 1px solid var(--line);
  background: transparent; color: var(--ink);
  text-transform: uppercase; cursor: pointer;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}
button.chip { line-height: 1; }
.chip.active { background: var(--ink); color: #fff; border-color: var(--ink); }
.chip:hover:not(.active) { border-color: var(--ink); }

.coll-body {
  display: grid; grid-template-columns: 240px 1fr;
  gap: 48px; padding: 48px 0;
}
.coll-filters h4 { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); margin-bottom: 12px; font-weight: 600; margin-top: 24px; }
.coll-filters h4:first-child { margin-top: 0; }
.coll-filters ul { list-style: none; }
.coll-filters li { padding: 6px 0; display: flex; justify-content: space-between; font-size: 13px; cursor: pointer; color: var(--ink); }
.coll-filters li:hover { color: var(--accent-dark); }
.coll-filters li .cnt { font-family: var(--f-mono); font-size: 11px; color: var(--muted); }
.coll-filters li.active { color: var(--accent-dark); font-weight: 600; }

.coll-results-head {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 20px; border-bottom: 1px solid var(--line); margin-bottom: 24px;
}
.coll-results-head .count { font-family: var(--f-mono); font-size: 12px; color: var(--muted); letter-spacing: 0.04em; }
.coll-sort { display: flex; align-items: center; gap: 10px; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; }
.coll-sort select { font-family: var(--f-mono); font-size: 11px; background: var(--card); border: 1px solid var(--line); padding: 6px 10px; letter-spacing: 0.04em; text-transform: uppercase; border-radius: var(--r-sm); }

.coll-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.coll-pag {
  margin-top: 48px; display: flex; justify-content: center; gap: 6px;
}
.coll-pag button {
  width: 36px; height: 36px; border: 1px solid var(--line);
  font-family: var(--f-mono); font-size: 12px; font-weight: 500;
  border-radius: var(--r-sm);
}
.coll-pag button.active { background: var(--ink); color: #fff; border-color: var(--ink); }

/* ===== POD Custom ===== */
.pod-hero {
  padding: 100px 0 80px;
  background: var(--card);
  border-bottom: 1px solid var(--line);
}
.pod-hero-inner { display: grid; grid-template-columns: 1.3fr 1fr; gap: 56px; align-items: end; }
.pod-hero-title {
  font-size: clamp(56px, 7.5vw, 112px);
  font-weight: 600; letter-spacing: -0.035em; line-height: 0.92;
  text-transform: uppercase;
}
.pod-hero-title .italic { font-family: var(--f-serif); font-style: italic; font-weight: 400; text-transform: none; letter-spacing: -0.02em; }
.pod-hero-title .accent { color: var(--accent); }
.pod-hero-sub { font-size: 17px; color: var(--muted); max-width: 420px; }
.pod-hero-sub + .btn { margin-top: 24px; }

.pod-steps {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--line);
  column-gap: 1px;
}
.pod-step {
  background: var(--card); padding: 40px 32px;
  display: flex; flex-direction: column; gap: 12px;
  min-height: 220px;
}
.pod-step .n { font-family: var(--f-mono); font-size: 12px; color: var(--accent-dark); letter-spacing: 0.08em; font-weight: 600; }
.pod-step h3 { font-family: var(--f-display); font-size: 26px; font-weight: 600; letter-spacing: -0.02em; }
.pod-step p { color: var(--muted); font-size: 14px; max-width: 280px; }

/* Upload UI */
.upload-widget {
  background: var(--card); border: 1px solid var(--line);
  display: grid; grid-template-columns: 1.3fr 1fr;
  min-height: 520px;
}
.upload-left {
  padding: 48px;
  display: flex; flex-direction: column;
  border-right: 1px solid var(--line);
}
.upload-dropzone {
  flex: 1;
  border: 2px dashed var(--line);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 20px; padding: 48px;
  text-align: center;
  transition: border-color .2s ease, background .2s ease;
  cursor: pointer;
  position: relative;
  background: var(--soft);
}
.upload-dropzone:hover, .upload-dropzone.drag { border-color: var(--accent); background: rgba(47,167,255,0.04); }
.upload-icon {
  width: 56px; height: 56px;
  border: 2px solid var(--ink);
  position: relative;
}
.upload-icon::before, .upload-icon::after {
  content: ''; position: absolute; background: var(--ink);
}
.upload-icon::before { top: 50%; left: 16px; right: 16px; height: 2px; transform: translateY(-50%); }
.upload-icon::after { left: 50%; top: 16px; bottom: 16px; width: 2px; transform: translateX(-50%); }

.upload-dropzone h3 { font-family: var(--f-display); font-size: 22px; font-weight: 500; letter-spacing: -0.01em; }
.upload-dropzone .formats { font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; }
.upload-dropzone .br { font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.06em; }
.upload-dropzone .browse { color: var(--accent-dark); text-decoration: underline; cursor: pointer; }
.upload-limits {
  margin-top: 20px; display: flex; gap: 24px;
  font-family: var(--f-mono); font-size: 11px; color: var(--muted);
  letter-spacing: 0.04em; text-transform: uppercase;
}
.upload-limits span { display: flex; align-items: center; gap: 6px; }
.upload-limits span::before { content: ''; width: 6px; height: 6px; background: var(--accent); display: inline-block; }

.upload-right { padding: 48px 40px; background: var(--soft); display: flex; flex-direction: column; gap: 28px; }
.upload-right h4 { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); font-weight: 600; }
.up-field { display: flex; flex-direction: column; gap: 10px; }
.up-field .lab { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink); font-weight: 600; }
.up-field .mat-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.up-field .mat-opt {
  padding: 10px 8px; border: 1px solid var(--line); background: var(--card);
  font-family: var(--f-mono); font-size: 11px; text-align: center;
  cursor: pointer; letter-spacing: 0.04em;
  border-radius: var(--r-sm);
}
.up-field .mat-opt.active { background: var(--ink); color: #fff; border-color: var(--ink); }
.up-field .qty-row { display: flex; align-items: center; gap: 0; }
.up-field .qty-row button {
  width: 40px; height: 40px; border: 1px solid var(--line); background: var(--card);
  font-family: var(--f-mono); font-size: 16px;
}
.up-field .qty-row input {
  width: 60px; height: 40px; border: 1px solid var(--line); border-left: none; border-right: none;
  text-align: center; font-family: var(--f-mono); font-size: 14px; background: var(--card);
}
.upload-estimate {
  margin-top: auto;
  padding: 20px; background: var(--ink); color: #fff;
  display: flex; flex-direction: column; gap: 10px;
}
.upload-estimate .lab { font-family: var(--f-mono); font-size: 10px; color: rgba(255,255,255,0.5); letter-spacing: 0.1em; text-transform: uppercase; }
.upload-estimate .val { font-family: var(--f-display); font-weight: 600; font-size: 32px; letter-spacing: -0.02em; }
.upload-estimate .val .cur { font-family: var(--f-mono); font-size: 14px; color: rgba(255,255,255,0.5); margin-right: 4px; font-weight: 500; }
.upload-estimate .range { font-family: var(--f-mono); font-size: 11px; color: rgba(255,255,255,0.6); letter-spacing: 0.04em; }
.upload-estimate .btn-accent { align-self: stretch; justify-content: center; margin-top: 8px; }

/* Material selector */
.mat-selector-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.mat-sel-card {
  background: var(--card); padding: 32px 28px;
  display: flex; flex-direction: column; gap: 14px;
  min-height: 320px;
  cursor: pointer; transition: background .15s ease;
}
.mat-sel-card:hover { background: var(--soft); }
.mat-sel-card .name { font-family: var(--f-display); font-size: 24px; font-weight: 600; letter-spacing: -0.02em; }
.mat-sel-card .price { font-family: var(--f-mono); font-size: 13px; color: var(--accent-dark); letter-spacing: 0.04em; }
.mat-sel-card .props { display: flex; flex-direction: column; gap: 6px; margin-top: 8px; padding-top: 14px; border-top: 1px solid var(--line); }
.mat-sel-card .props > div { display: flex; justify-content: space-between; font-family: var(--f-mono); font-size: 11px; }
.mat-sel-card .props .k { color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; }
.mat-sel-card .props .v { font-weight: 600; color: var(--ink); }
.mat-sel-card .use { color: var(--muted); font-size: 13px; margin-top: auto; }

/* POD quote examples */
.pod-eg-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.pod-eg-card {
  background: var(--card); border: 1px solid var(--line);
  overflow: hidden;
}
.pod-eg-img { aspect-ratio: 1; background: var(--soft); position: relative; }
.pod-eg-img .placeholder { position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(26,26,26,0.04) 0 2px, transparent 2px 12px); }
.pod-eg-img .ph-label { position: absolute; bottom: 10px; left: 10px; font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; }
.pod-eg-body { padding: 16px; display: flex; justify-content: space-between; align-items: center; }
.pod-eg-body .t { font-size: 13px; font-weight: 500; }
.pod-eg-body .p { font-family: var(--f-mono); font-size: 12px; color: var(--accent-dark); font-weight: 600; }

/* ===== Quote Modal ===== */
.modal-backdrop {
  position: fixed; inset: 0; background: rgba(26,26,26,0.7);
  display: none; align-items: flex-start; justify-content: center;
  z-index: 100; padding: 40px 20px; overflow-y: auto;
}
.modal-backdrop.open { display: flex; }
.modal {
  background: var(--card); max-width: 760px; width: 100%;
  border: 1px solid var(--line);
  display: flex; flex-direction: column;
  max-height: 90vh;
}
.modal-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 24px 32px; border-bottom: 1px solid var(--line);
}
.modal-head .mtitle { font-family: var(--f-display); font-weight: 600; font-size: 22px; letter-spacing: -0.02em; }
.modal-head .mclose { font-family: var(--f-mono); font-size: 20px; width: 32px; height: 32px; display: grid; place-items: center; }
.modal-steps {
  display: flex; gap: 0; padding: 20px 32px; border-bottom: 1px solid var(--line);
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase;
}
.modal-steps > div { flex: 1; display: flex; align-items: center; gap: 10px; color: var(--muted); }
.modal-steps > div.active { color: var(--ink); font-weight: 600; }
.modal-steps > div.done { color: var(--accent-dark); }
.modal-steps > div .snum {
  width: 22px; height: 22px; border: 1px solid currentColor; border-radius: 50%;
  display: grid; place-items: center; font-size: 10px;
}
.modal-body { padding: 32px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px 24px; overflow-y: auto; }
.modal-body.full { grid-template-columns: 1fr; }
.mfield { display: flex; flex-direction: column; gap: 8px; }
.mfield.full-w { grid-column: 1 / -1; }
.mfield .lab { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); font-weight: 600; }
.mfield input, .mfield select, .mfield textarea {
  padding: 12px 14px; border: 1px solid var(--line); font-family: var(--f-body); font-size: 14px;
  background: var(--card); border-radius: var(--r-sm); color: var(--ink);
}
.mfield textarea { resize: vertical; min-height: 100px; }
.mfield input:focus, .mfield select:focus, .mfield textarea:focus { outline: none; border-color: var(--ink); }
.modal-foot {
  padding: 20px 32px; border-top: 1px solid var(--line);
  display: flex; justify-content: space-between; gap: 12px;
}

/* ===== Tweaks panel ===== */
.tweaks-panel {
  position: fixed; right: 20px; bottom: 20px; z-index: 90;
  background: var(--card); border: 1px solid var(--ink);
  width: 280px;
  font-family: var(--f-body); font-size: 13px;
  box-shadow: 0 20px 40px -20px rgba(0,0,0,0.25);
  display: none;
}
.tweaks-panel.open { display: block; }
.tweaks-head {
  padding: 14px 16px; border-bottom: 1px solid var(--line);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600;
}
.tweaks-body { padding: 16px; display: flex; flex-direction: column; gap: 18px; }
.tweaks-group .tglab { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); font-weight: 600; margin-bottom: 8px; }
.tweaks-opts { display: flex; flex-direction: column; gap: 4px; }
.tweaks-opts button {
  text-align: left; padding: 8px 10px; border: 1px solid var(--line);
  font-size: 12px; border-radius: var(--r-sm);
  transition: background .15s ease, border-color .15s ease;
}
.tweaks-opts button.active { background: var(--ink); color: #fff; border-color: var(--ink); }
.tweaks-opts button:hover:not(.active) { border-color: var(--ink); }

/* Page switcher pill */
.page-switcher {
  position: fixed; left: 50%; bottom: 20px; transform: translateX(-50%);
  background: var(--ink); padding: 6px;
  display: flex; gap: 2px;
  border-radius: 4px;
  z-index: 80;
  box-shadow: 0 10px 30px -10px rgba(0,0,0,0.3);
}
.page-switcher button {
  padding: 8px 14px; color: rgba(255,255,255,0.6);
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600;
  border-radius: var(--r-sm);
  transition: background .15s ease, color .15s ease;
}
.page-switcher button.active { background: #fff; color: var(--ink); }
.page-switcher button:hover:not(.active) { color: #fff; }

/* Page containers */



.variant.active { display: block; }

/* Responsive */
@media (max-width: 860px) {
  .hero-slide { grid-template-columns: 1fr; }
  .hero-slide-visual { min-height: 320px; order: -1; }
  .hero-slideshow { height: auto; min-height: 0; max-height: none; }
  .hero-slide-text { padding: 48px var(--pad-x); }
  .hero-controls { position: static; padding: 20px var(--pad-x); background: var(--card); border-top: 1px solid var(--line); }
  .ecosystem-timeline { grid-template-columns: repeat(2, 1fr); }
  .ecosystem-stage { aspect-ratio: 16 / 10; }
  .eco-overlay { left: 24px; right: 24px; bottom: 24px; }
  .trust-v2-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .trust-v2-item { border-right: none; padding-right: 0; }
  .carousel-card { flex-basis: calc(50% - 10px); }
  .hero-a-grid { grid-template-columns: 1fr; min-height: auto; }
  .hero-a-left { border-right: none; border-bottom: 1px solid var(--line); padding: 48px var(--pad-x); }
  .hero-a-right { min-height: 500px; }
  .lines { grid-template-columns: repeat(2, 1fr); }
  .lines-4 { grid-template-columns: repeat(2, 1fr); }
  .products-grid { grid-template-columns: repeat(2, 1fr); }
  .coll-grid { grid-template-columns: repeat(2, 1fr); }
  .pod-steps { grid-template-columns: repeat(2, 1fr); }
  .content-grid, .testi-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 32px; }
  .trust-grid { grid-template-columns: repeat(2, 1fr); }
  .pdp-top { grid-template-columns: 1fr; }
  .coll-body { grid-template-columns: 1fr; }
  .upload-widget { grid-template-columns: 1fr; }
  .roi-block { grid-template-columns: 1fr; padding: 32px; }
  .narr-grid, .narr-grid.reverse { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .nav-links { display: none; }
  .section-head { flex-direction: column; align-items: flex-start; }
  .products-grid, .coll-grid, .lines, .lines-4, .content-grid, .testi-grid, .pod-steps, .trust-grid, .downloads-grid, .footer-top, .pod-eg-grid { grid-template-columns: 1fr; }
  .hero-a-body { grid-template-columns: 1fr; }
  .modal-body { grid-template-columns: 1fr; }
  .params-grid, .mat-props { grid-template-columns: 1fr; }
}


/* ===== v2 TRUST ROW ===== */
.v2-trust {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--card);
}
.v2-trust-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 40px var(--pad-x);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
}
.v2-trust-item {
  display: flex; gap: 16px; align-items: flex-start;
  padding-right: 24px;
  border-right: 1px solid var(--line);
}
.v2-trust-item:last-child { border-right: none; }
.v2-trust-num {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  color: var(--accent);
  letter-spacing: 0.1em;
  padding-top: 2px;
}
.v2-trust-lab {
  font-family: var(--f-display); font-weight: 600;
  font-size: 15px; color: var(--ink);
  letter-spacing: -0.01em;
  margin-bottom: 4px;
}
.v2-trust-sub {
  font-size: 12px; color: var(--muted);
  line-height: 1.5;
}

/* ===== v2 LIVE FROM FLOOR ===== */
.v2-floor {
  padding: 96px 0;
  border-bottom: 1px solid var(--line);
}
.v2-floor-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.v2-floor-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 32px; flex-wrap: wrap;
  margin-bottom: 48px;
}
.v2-floor-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(36px, 4vw, 56px);
  letter-spacing: -0.03em; line-height: 1;
  margin-top: 12px;
  max-width: 720px;
}
.v2-floor-title .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
  letter-spacing: -0.02em;
}
.v2-floor-status {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em;
  color: var(--ink);
  padding: 10px 16px;
  background: var(--card);
  border: 1px solid var(--line);
}
.v2-pulse {
  width: 8px; height: 8px;
  background: #10b981;
  border-radius: 50%;
  animation: v2pulse 1.6s ease-in-out infinite;
  box-shadow: 0 0 0 0 rgba(16,185,129,0.6);
}
@keyframes v2pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(16,185,129,0.6); }
  50%      { box-shadow: 0 0 0 8px rgba(16,185,129,0); }
}
.v2-floor-status-lab { color: var(--ink); }
.v2-floor-status-sep { color: var(--line); }
.v2-floor-status-time { color: var(--muted); font-weight: 500; }

.v2-floor-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 16px;
}
.v2-floor-card {
  background: var(--card);
  border: 1px solid var(--line);
  padding: 20px;
  display: flex; flex-direction: column; gap: 16px;
  position: relative;
}
.v2-floor-tag {
  font-family: var(--f-mono);
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.12em;
  color: var(--muted);
}
.v2-floor-img {
  background: #e8e5df; /* warm placeholder */
  color: var(--muted);
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 10px;
  aspect-ratio: 16 / 9;
  letter-spacing: 0.08em;
  flex: 1;
  position: relative;
}
.v2-floor-img.sm { aspect-ratio: 4 / 3; }
.v2-floor-img::after {
  content: '';
  position: absolute;
  inset: 12px;
  border: 1px dashed var(--line);
  pointer-events: none;
}
.v2-floor-card.big .v2-floor-img {
  background: #1a1a1a;
  color: #666;
}
.v2-floor-card.big .v2-floor-img::after {
  border-color: rgba(255,255,255,0.1);
}
.v2-floor-meta {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  padding-top: 4px;
  border-top: 1px solid var(--line);
  padding-top: 16px;
}
.v2-floor-meta.two { grid-template-columns: repeat(2, 1fr); }
.v2-floor-lab {
  display: block;
  font-family: var(--f-mono); font-size: 10px;
  color: var(--muted); letter-spacing: 0.1em;
  margin-bottom: 4px; text-transform: uppercase;
}
.v2-floor-val {
  display: block;
  font-family: var(--f-mono); font-size: 16px;
  font-weight: 600; color: var(--ink);
  letter-spacing: -0.01em;
}
.v2-floor-bar {
  height: 4px; background: var(--line);
  position: relative; overflow: hidden;
}
.v2-floor-bar-fill {
  height: 100%; background: var(--accent);
  transition: width .6s ease;
}

/* ===== v2 FEATURED with TABS ===== */
.v2-featured {
  padding: 96px 0;
  background: var(--card);
  border-bottom: 1px solid var(--line);
}
.v2-featured-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.v2-featured-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 32px; flex-wrap: wrap;
  margin-bottom: 48px;
}
.v2-featured-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(36px, 4vw, 56px);
  letter-spacing: -0.03em; line-height: 1;
  margin-top: 12px;
}
.v2-featured-title .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
}
.v2-featured-tabs {
  display: inline-flex;
  border: 1px solid var(--line);
  background: var(--bg);
  padding: 3px;
}
.v2-featured-tabs button {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 10px 18px;
  background: transparent;
  color: var(--muted);
  border: none; cursor: pointer;
  transition: all .15s ease;
}
.v2-featured-tabs button:hover { color: var(--ink); }
.v2-featured-tabs button.active {
  background: var(--ink); color: #fff;
}
.v2-featured-foot {
  margin-top: 32px;
  display: flex; justify-content: center;
  padding-top: 24px;
  border-top: 1px solid var(--line);
}

/* ===== v2 STORIES ===== */
.v2-stories {
  padding: 96px 0;
  border-bottom: 1px solid var(--line);
}
.v2-stories-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.v2-stories-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 32px; flex-wrap: wrap;
  margin-bottom: 48px;
}
.v2-stories-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(36px, 4vw, 56px);
  letter-spacing: -0.03em; line-height: 1;
  margin-top: 12px;
}
.v2-stories-title .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
}
.v2-stories-sub {
  max-width: 420px;
  font-size: 14px; color: var(--muted);
  line-height: 1.6;
}
.v2-stories-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 24px;
}
.v2-story-card {
  display: block;
  background: var(--card);
  border: 1px solid var(--line);
  text-decoration: none; color: inherit;
  transition: border-color .2s ease, transform .2s ease;
}
.v2-story-card:hover { border-color: var(--ink); }
.v2-story-card.hero-card {
  display: grid;
  grid-template-rows: 1fr auto;
}
.v2-story-img {
  aspect-ratio: 4 / 3;
  background: #e8e5df;
  color: var(--muted);
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 10px;
  letter-spacing: 0.08em;
  position: relative;
}
.v2-story-img.sm { aspect-ratio: 16 / 10; }
.v2-story-img::after {
  content: ''; position: absolute; inset: 12px;
  border: 1px dashed var(--line);
}
.v2-story-body {
  padding: 28px;
  display: flex; flex-direction: column; gap: 12px;
}
.v2-story-meta {
  font-family: var(--f-mono);
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--accent);
}
.v2-story-card h3 {
  font-family: var(--f-display); font-weight: 600;
  font-size: 22px; line-height: 1.25;
  letter-spacing: -0.02em;
  color: var(--ink);
  text-wrap: pretty;
}
.v2-story-card.hero-card h3 { font-size: 28px; }
.v2-story-desc {
  font-size: 14px; color: var(--muted); line-height: 1.6;
}
.v2-story-read {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink);
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 4px;
}
.v2-stories-col {
  display: grid; gap: 24px;
  grid-template-rows: 1fr 1fr;
}

/* ===== v2 HANDCRAFT ===== */
.v2-handcraft {
  padding: 96px 0;
  background: var(--card);
  border-bottom: 1px solid var(--line);
}
.v2-handcraft-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 64px;
  align-items: center;
}
.v2-handcraft-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(36px, 4vw, 56px);
  letter-spacing: -0.03em; line-height: 1;
  margin-top: 12px;
  margin-bottom: 24px;
}
.v2-handcraft-title .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
}
.v2-handcraft-body {
  font-size: 15px; color: var(--muted);
  line-height: 1.65; max-width: 440px;
  margin-bottom: 32px;
}
.v2-handcraft-meta {
  display: flex; gap: 40px;
  border-top: 1px solid var(--line);
  padding-top: 24px;
}
.v2-handcraft-meta .lab {
  display: block;
  font-family: var(--f-mono); font-size: 10px;
  color: var(--muted); letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.v2-handcraft-meta .val {
  display: block;
  font-family: var(--f-display); font-weight: 600;
  font-size: 24px; color: var(--ink);
  letter-spacing: -0.02em;
}
.v2-handcraft-gallery {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 220px 220px;
  gap: 12px;
}
.v2-handcraft-tile {
  background: #e8e5df;
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 10px;
  color: var(--muted); letter-spacing: 0.08em;
  position: relative;
  transition: transform .3s ease;
}
.v2-handcraft-tile::after {
  content: ''; position: absolute; inset: 10px;
  border: 1px dashed var(--line);
}
.v2-handcraft-tile:hover { transform: translateY(-2px); }
.v2-handcraft-tile.a { background: #ede8df; }
.v2-handcraft-tile.b { background: var(--ink); color: #555; }
.v2-handcraft-tile.b::after { border-color: rgba(255,255,255,0.08); }
.v2-handcraft-tile.c { background: #f0e4d3; }
.v2-handcraft-tile.d { background: #dfd9cc; }

/* ===== v2 NEWSLETTER ===== */
.v2-news {
  background: var(--ink);
  color: #fff;
  padding: 96px 0;
}
.v2-news-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 80px;
  align-items: center;
}
.v2-news-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(36px, 4vw, 56px);
  letter-spacing: -0.03em; line-height: 1;
  margin-top: 12px;
  margin-bottom: 20px;
  color: #fff;
}
.v2-news-title .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
  color: var(--accent);
}
.v2-news-desc {
  font-size: 15px; color: rgba(255,255,255,0.65);
  line-height: 1.65; max-width: 460px;
}
.v2-news-form {
  display: flex; flex-direction: column; gap: 12px;
}
.v2-news-lab {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}
.v2-news-input {
  display: flex; gap: 0;
  border: 1px solid rgba(255,255,255,0.2);
  background: rgba(255,255,255,0.04);
}
.v2-news-input input {
  flex: 1;
  background: transparent;
  border: none;
  color: #fff;
  padding: 18px 20px;
  font-family: var(--f-body);
  font-size: 14px;
  outline: none;
}
.v2-news-input input::placeholder { color: rgba(255,255,255,0.3); }
.v2-news-input button {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--accent);
  color: #fff;
  border: none; cursor: pointer;
  padding: 0 28px;
  display: flex; align-items: center; gap: 8px;
  transition: background .15s ease;
}
.v2-news-input button:hover { background: var(--accent-dark); }
.v2-news-foot {
  font-family: var(--f-mono);
  font-size: 10px; color: rgba(255,255,255,0.4);
  letter-spacing: 0.08em; text-transform: uppercase;
  margin-top: 4px;
}

@media (max-width: 960px) {
  .v2-trust-inner { grid-template-columns: 1fr 1fr; }
  .v2-trust-item:nth-child(2) { border-right: none; }
  .v2-floor-grid { grid-template-columns: 1fr; }
  .v2-stories-grid { grid-template-columns: 1fr; }
  .v2-stories-col { grid-template-rows: auto auto; }
  .v2-handcraft-inner { grid-template-columns: 1fr; gap: 48px; }
  .v2-news-inner { grid-template-columns: 1fr; gap: 48px; }
  .v2-handcraft-meta { gap: 24px; flex-wrap: wrap; }
}


/* ===== Hero slide CTAs (multiple buttons) ===== */
.hero-slide-ctas {
  margin-top: 36px;
  display: flex; gap: 12px; flex-wrap: wrap;
}

/* ===== TIMELINE · continuous banner ===== */
.tlb {
  padding: 112px 0 112px;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
}
.tlb-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.tlb-head {
  text-align: center;
  margin-bottom: 56px;
  max-width: 720px;
  margin-left: auto; margin-right: auto;
}
.tlb-head .eyebrow {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  display: block;
}
.tlb-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(40px, 4.5vw, 64px);
  letter-spacing: -0.03em; line-height: 1;
  margin-top: 16px;
}
.tlb-title .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
}

/* The banner itself — a single continuous strip */
.tlb-banner {
  position: relative;
  height: clamp(500px, 58vw, 700px);
  overflow: hidden;
  background: #0b0d11;
  isolation: isolate;
}
.tlb-video-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 15% 40%, rgba(217,85,43,0.22) 0%, transparent 42%),
    radial-gradient(ellipse at 42% 60%, rgba(47,167,255,0.14) 0%, transparent 40%),
    radial-gradient(ellipse at 72% 35%, rgba(217,85,43,0.10) 0%, transparent 40%),
    linear-gradient(180deg, #14171c 0%, #0b0d11 100%);
  z-index: 0;
}
.tlb-video-bg::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(0deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 48px),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 48px);
  pointer-events: none;
}
.tlb-video-tag {
  position: absolute;
  top: 20px; left: 20px;
  z-index: 3;
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  padding: 8px 12px;
  background: rgba(0,0,0,0.5);
  border: 1px solid rgba(255,255,255,0.1);
}
.tlb-video-label {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  font-family: var(--f-mono);
  font-size: 12px; letter-spacing: 0.08em;
  color: rgba(255,255,255,0.25);
  z-index: 1;
  white-space: nowrap;
}

/* Segments overlay — 4 equal hover zones */
.tlb-segments {
  position: absolute; inset: 0;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
}
.tlb-seg {
  position: relative;
  cursor: pointer;
  display: flex;
  align-items: flex-end;
  padding: 40px 32px;
  border-right: 1px solid rgba(255,255,255,0.08);
  background: rgba(0,0,0,0.35);
  transition: background .35s ease;
}
.tlb-seg:last-child { border-right: none; }

/* Default state: all dimmed EQUALLY — a medium overlay across the whole banner */
.tlb-seg::before {
  content: '';
  position: absolute; inset: 0;
  background: rgba(11,13,17,0);
  transition: background .35s ease;
  pointer-events: none;
}

/* Hover the banner: dim non-hovered segments; brighten hovered */
.tlb-banner:hover .tlb-seg::before {
  background: rgba(11,13,17,0.55);
}
.tlb-banner:hover .tlb-seg:hover::before {
  background: rgba(11,13,17,0);
}

/* Segment content */
.tlb-seg-inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 260px;
  transition: transform .35s ease;
}
.tlb-banner:hover .tlb-seg:hover .tlb-seg-inner {
  transform: translateY(-4px);
}
.tlb-num {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em;
  color: rgba(255,255,255,0.45);
  transition: color .35s ease;
}
.tlb-seg:hover .tlb-num { color: var(--accent); }

.tlb-seg-title {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 32px;
  letter-spacing: -0.02em;
  color: #fff;
  margin: 0;
  line-height: 1.05;
}
.tlb-seg-desc {
  font-size: 13px;
  line-height: 1.5;
  color: rgba(255,255,255,0.55);
  margin: 4px 0 0;
  /* hidden by default, revealed on hover */
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height .4s ease, opacity .3s ease, margin .4s ease;
}
.tlb-seg-link {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: #fff;
  margin-top: 0;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .3s ease, transform .3s ease;
}
.tlb-seg:hover .tlb-seg-desc {
  max-height: 80px;
  opacity: 1;
  margin-top: 4px;
}
.tlb-seg:hover .tlb-seg-link {
  opacity: 1;
  transform: translateY(0);
  margin-top: 14px;
}

/* Accent top bar on hovered segment */
.tlb-seg::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform .4s ease;
  z-index: 3;
}
.tlb-seg:hover::after { transform: scaleX(1); }

@media (max-width: 860px) {
  .tlb-segments { grid-template-columns: 1fr; }
  .tlb-seg { border-bottom: 1px solid rgba(255,255,255,0.08); border-right: none; }
  .tlb-banner { height: auto; aspect-ratio: 1; }
}

/* ===== PARTNERS strip ===== */
.partners {
  padding: 96px 0;
  background: var(--card);
  border-bottom: 1px solid var(--line);
}
.partner-strip {
  margin-top: 48px;
  overflow: hidden;
  position: relative;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
}
.partner-track {
  display: flex;
  gap: 24px;
  width: max-content;
  animation: partnerScroll 40s linear infinite;
}
@keyframes partnerScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.partner-logo {
  flex: 0 0 180px;
  height: 88px;
  border: 1px solid var(--line);
  background: var(--bg);
  display: grid; place-items: center;
  font-family: var(--f-mono);
  font-size: 10px; letter-spacing: 0.1em;
  color: var(--muted);
  text-transform: uppercase;
}

@media (max-width: 860px) {
  .timeline-stages {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .tl-connector { display: none; }
  .hero-slide { grid-template-columns: 1fr; }
  .hero-slide-visual { min-height: 320px; }
}


/* ===== CASE STUDIES (home) ===== */
.cs {
  padding: 112px 0 112px;
  background: var(--card);
  border-bottom: 1px solid var(--line);
}
.cs-head {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: end;
  gap: 48px;
  margin-bottom: 32px;
}
.cs-intro {
  color: var(--muted);
  font-size: 15px;
  max-width: 420px;
  justify-self: end;
  text-align: right;
  line-height: 1.55;
}
.cs-industries {
  display: flex;
  gap: 8px;
  margin-bottom: 32px;
  flex-wrap: wrap;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--line);
}
.cs-ind {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 10px 16px;
  background: transparent;
  border: 1px solid var(--line);
  color: var(--muted);
  cursor: pointer;
  transition: all .15s ease;
}
.cs-ind:hover { color: var(--ink); border-color: var(--ink); }
.cs-ind.active {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}

.cs-rail-wrap {
  position: relative;
  margin: 0 calc(var(--pad-x) * -1);
  padding: 0 var(--pad-x);
}
.cs-rail {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-padding-left: var(--pad-x);
  padding: 4px 0 28px;
  scrollbar-width: none;
}
.cs-rail::-webkit-scrollbar { display: none; }
.cs-card {
  flex: 0 0 auto;
  width: clamp(320px, 38vw, 460px);
  scroll-snap-align: start;
  cursor: pointer;
  background: var(--bg);
  border: 1px solid var(--line);
  transition: transform .25s ease, box-shadow .25s ease;
  display: flex;
  flex-direction: column;
}
.cs-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px -12px rgba(0,0,0,0.18);
}
.cs-card-img {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #e8e8e8;
}
.cs-card-img .cs-ph {
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(135deg, rgba(26,26,26,0.04) 0 2px, transparent 2px 14px);
}
.cs-card-img .cs-tag {
  position: absolute;
  top: 16px; left: 16px;
  font-family: var(--f-mono);
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 6px 10px;
  background: var(--ink);
  color: #fff;
}
.cs-card-img .cs-industry {
  position: absolute;
  bottom: 16px; left: 16px;
  font-family: var(--f-mono);
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(26,26,26,0.6);
}
.cs-card-img.dark { background: #1a1d23; }
.cs-card-img.dark .cs-ph {
  background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 14px);
}
.cs-card-img.dark .cs-industry { color: rgba(255,255,255,0.55); }
.cs-card-img.warm { background: #d8cdb8; }
.cs-card-img.steel { background: #8a9099; }
.cs-card-img.steel .cs-industry { color: rgba(255,255,255,0.75); }
.cs-card-img.blue { background: #2d3a5f; }
.cs-card-img.blue .cs-ph {
  background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 14px);
}
.cs-card-img.blue .cs-industry { color: rgba(255,255,255,0.55); }

.cs-card-body {
  padding: 24px 24px 28px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.cs-card-title {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 20px;
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 0;
}
.cs-card-client {
  font-family: var(--f-mono);
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--muted);
}
.cs-card-desc {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.55;
  margin: 4px 0 12px;
}
.cs-card-meta {
  display: flex;
  gap: 16px;
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}
.cs-card-meta .mk { color: var(--ink); }

.cs-rail-nav {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 16px;
}
.cs-arrow {
  width: 48px; height: 48px;
  background: transparent;
  border: 1px solid var(--line);
  color: var(--ink);
  font-size: 18px;
  cursor: pointer;
  transition: all .15s ease;
}
.cs-arrow:hover { background: var(--ink); color: #fff; border-color: var(--ink); }

.cs-foot {
  display: flex;
  justify-content: center;
  margin-top: 40px;
}

/* ===== CASE STUDY detail page ===== */
.case-hero {
  padding: 48px 0 0;
  background: var(--bg);
}
.case-hero .breadcrumbs { margin-bottom: 40px; }
.case-hero-meta {
  display: flex;
  gap: 24px;
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 20px;
}
.case-hero-meta span.accent { color: var(--accent-dark); }
.case-hero h1 {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(42px, 5.5vw, 76px);
  letter-spacing: -0.03em;
  line-height: 1.02;
  margin: 0;
  max-width: 900px;
}
.case-hero .italic {
  font-family: var(--f-serif);
  font-style: italic;
  font-weight: 400;
}
.case-hero-sub {
  font-size: 18px;
  color: var(--muted);
  max-width: 640px;
  margin-top: 24px;
  line-height: 1.5;
}

.case-cover {
  margin-top: 56px;
  aspect-ratio: 16 / 8;
  position: relative;
  overflow: hidden;
  background: #1a1d23;
  border-bottom: 1px solid var(--line);
}
.case-cover .cs-ph {
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 14px);
}
.case-cover-label {
  position: absolute;
  bottom: 24px; left: 24px;
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}

.case-body {
  padding: 96px 0;
}
.case-grid {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 80px;
}
.case-side {
  position: sticky;
  top: 120px;
  align-self: start;
  display: flex;
  flex-direction: column;
  gap: 32px;
  font-family: var(--f-mono);
  font-size: 12px;
}
.case-side dt {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 6px;
  font-weight: 600;
}
.case-side dd {
  color: var(--ink);
  font-size: 14px;
  font-family: var(--f-body);
  margin: 0;
  line-height: 1.45;
}
.case-side-block + .case-side-block {
  padding-top: 28px;
  border-top: 1px solid var(--line);
}

.case-main {
  display: flex;
  flex-direction: column;
  gap: 48px;
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink);
}
.case-main h2 {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 32px;
  letter-spacing: -0.02em;
  margin: 24px 0 4px;
  line-height: 1.1;
}
.case-main p { margin: 0; color: #3d3d3d; }
.case-main blockquote {
  margin: 16px 0;
  padding: 32px 0 28px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  font-family: var(--f-serif);
  font-style: italic;
  font-size: 28px;
  line-height: 1.3;
  color: var(--ink);
}
.case-main blockquote cite {
  display: block;
  margin-top: 20px;
  font-family: var(--f-mono);
  font-style: normal;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}

.case-figure {
  aspect-ratio: 16 / 10;
  background: #e8e8e8;
  position: relative;
  overflow: hidden;
  margin: 16px 0;
}
.case-figure.dark { background: #1a1d23; }
.case-figure.steel { background: #8a9099; }
.case-figure .cs-ph {
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(135deg, rgba(26,26,26,0.05) 0 2px, transparent 2px 14px);
}
.case-figure.dark .cs-ph {
  background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 14px);
}
.case-figure .cs-cap {
  position: absolute;
  bottom: 16px; left: 16px;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(0,0,0,0.5);
}
.case-figure.dark .cs-cap { color: rgba(255,255,255,0.4); }

.case-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin: 32px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.case-stat {
  padding: 32px 24px 32px 0;
  border-right: 1px solid var(--line);
}
.case-stat:last-child { border-right: none; padding-right: 0; }
.case-stat .kn {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 42px;
  letter-spacing: -0.02em;
  color: var(--accent-dark);
  line-height: 1;
}
.case-stat .lb {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 10px;
  display: block;
}

.case-nextprev {
  border-top: 1px solid var(--line);
  padding: 48px 0 96px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
}
.case-nextprev a {
  text-decoration: none;
  color: var(--ink);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.case-nextprev .lab {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}
.case-nextprev .ti {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.01em;
}
.case-nextprev .next { text-align: right; align-items: flex-end; }

@media (max-width: 960px) {
  .cs-head { grid-template-columns: 1fr; gap: 16px; }
  .cs-intro { justify-self: start; text-align: left; }
  .case-grid { grid-template-columns: 1fr; gap: 32px; }
  .case-side { position: static; }
  .case-stats { grid-template-columns: 1fr 1fr; }
  .case-stat:nth-child(2) { border-right: none; }
}


/* RIGHT-BOTTOM: Browse all materials card (mega menu) */
.mega-browse-card {
  display: flex; flex-direction: column;
  padding: 18px 22px;
  background: var(--ink);
  color: #fff;
  text-decoration: none;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
  transition: background .15s ease;
  position: relative;
  min-height: 120px;
}
.mega-browse-card:hover { background: #1A1C20; }
.mega-browse-eyebrow {
  font-family: var(--f-mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: #D9BD67;
  margin-bottom: 6px;
}
.mega-browse-title {
  font-size: 16px; font-weight: 600;
  letter-spacing: -0.01em;
  white-space: normal;
  line-height: 1.25;
  word-break: break-word;
  color: #fff;
  margin-bottom: 8px;
}
.mega-browse-meta {
  font-family: var(--f-mono); font-size: 9px;
  letter-spacing: 0.04em;
  white-space: normal;
  line-height: 1.4;
  color: rgba(255,255,255,0.65);
  margin-bottom: 14px;
}
.mega-browse-link {
  margin-top: auto;
  font-family: var(--f-mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: #D9BD67;
  transition: transform .15s ease;
  display: inline-block;
}
.mega-browse-card:hover .mega-browse-link { transform: translateX(3px); }


/* ===== Mini mega menu (Printers, Industries) ===== */
.mega-mini-inner {
  padding: 28px 32px 32px;
  max-width: 1100px;
}
.mega-mini-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  gap: 12px;
  grid-auto-rows: minmax(96px, auto);
}
.mega-mini-card {
  display: flex; flex-direction: column; justify-content: flex-end; gap: 4px;
  padding: 18px 18px 16px;
  background: #fff;
  border: 1px solid var(--line);
  position: relative;
  transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
  text-decoration: none;
}
.mega-mini-card:hover {
  border-color: #D9BD67;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px -2px rgba(217,189,103,0.25);
}
.mega-mini-name {
  font-family: var(--f-mono); font-size: 14px; font-weight: 600;
  color: var(--ink); letter-spacing: 0.02em;
}
.mega-mini-meta {
  font-size: 11px; color: var(--muted);
  letter-spacing: 0.02em; line-height: 1.4;
}
.mega-mini-tag {
  position: absolute; top: 0; right: 0;
  padding: 4px 10px;
  font-family: var(--f-mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  background: #D9BD67; color: var(--ink);
}
.mega-mini-hero {
  grid-row: span 2;
  background: #0E0F12; color: #fff;
  border-color: #0E0F12;
  padding: 28px 22px 22px;
  background-image: radial-gradient(ellipse at top right, rgba(217,189,103,0.22), transparent 60%);
}
.mega-mini-hero:hover { background-color: #1A1C20; border-color: #D9BD67; }
.mega-mini-hero .mega-mini-name { color: #fff; font-size: 20px; }
.mega-mini-hero .mega-mini-meta { color: rgba(255,255,255,0.78); }
.mega-mini-browse {
  background: rgba(217,189,103,0.06);
  border-color: rgba(217,189,103,0.5);
}
.mega-mini-browse:hover { background: rgba(217,189,103,0.12); border-color: #B8923C; }
.mega-mini-browse .mega-mini-name { color: #B8923C; }
  body { background: var(--bg); }

  /* ===== HERO ===== */
  .ind-hero {
    position: relative;
    padding: 80px 0 96px;
    background: #0E0F12;
    color: #fff;
    overflow: hidden;
  }
  .ind-hero::before {
    content: '';
    position: absolute; inset: 0;
    background:
      radial-gradient(ellipse at 20% 20%, rgba(217,189,103,0.15), transparent 50%),
      radial-gradient(ellipse at 80% 80%, rgba(217,189,103,0.08), transparent 60%);
    pointer-events: none;
  }
  .ind-hero-inner {
    max-width: 1200px; margin: 0 auto; padding: 0 32px;
    position: relative; z-index: 2;
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 80px;
    align-items: center;
  }
  @media (max-width: 920px) {
    .ind-hero-inner { grid-template-columns: 1fr; gap: 40px; }
  }
  .ind-eyebrow {
    font-family: var(--f-mono); font-size: 11px; font-weight: 700;
    letter-spacing: 0.18em; text-transform: uppercase;
    color: #D9BD67; margin-bottom: 18px;
    display: inline-flex; align-items: center; gap: 8px;
  }
  .ind-eyebrow::before {
    content: ''; width: 24px; height: 1px; background: #D9BD67;
  }
  .ind-hero h1 {
    font-family: var(--f-display); font-weight: 600;
    font-size: clamp(40px, 5.6vw, 68px); line-height: 1.05;
    letter-spacing: -0.03em;
    color: #fff;
    margin: 0 0 22px;
  }
  .ind-hero h1 em {
    font-family: var(--f-serif); font-style: italic; font-weight: 400;
    color: #D9BD67;
  }
  .ind-hero-lede {
    font-size: 17px; line-height: 1.55;
    color: rgba(255,255,255,0.78);
    max-width: 540px;
    margin: 0 0 32px;
  }
  .ind-hero-meta {
    display: flex; flex-wrap: wrap; gap: 8px;
    margin-bottom: 32px;
  }
  .ind-hero-pill {
    font-family: var(--f-mono); font-size: 10px; font-weight: 600;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: rgba(255,255,255,0.85);
    padding: 6px 12px;
    border: 1px solid rgba(255,255,255,0.18);
    background: rgba(255,255,255,0.04);
  }
  .ind-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }
  .ind-cta-primary {
    appearance: none; border: 0; text-decoration: none;
    background: linear-gradient(135deg, #D9BD67, #C9A24E);
    color: #0E0F12;
    font-family: var(--f-mono); font-size: 12px; font-weight: 700;
    letter-spacing: 0.12em; text-transform: uppercase;
    padding: 16px 26px;
    transition: transform .12s ease, box-shadow .12s ease;
    cursor: pointer;
  }
  .ind-cta-primary:hover { transform: translateY(-1px); box-shadow: 0 8px 24px -8px rgba(217,189,103,0.65); }
  .ind-cta-secondary {
    appearance: none; text-decoration: none;
    background: transparent; color: #fff;
    border: 1px solid rgba(255,255,255,0.3);
    font-family: var(--f-mono); font-size: 12px; font-weight: 700;
    letter-spacing: 0.12em; text-transform: uppercase;
    padding: 15px 22px;
    transition: background .12s ease, border-color .12s ease;
    cursor: pointer;
  }
  .ind-cta-secondary:hover { background: rgba(255,255,255,0.06); border-color: #D9BD67; }

  /* Stats column */
  .ind-hero-stats {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 1px;
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.12);
  }
  .ind-stat {
    background: #0E0F12;
    padding: 22px 20px;
  }
  .ind-stat-num {
    font-family: var(--f-display); font-size: 32px; font-weight: 600;
    color: #D9BD67; letter-spacing: -0.02em;
    margin-bottom: 4px;
  }
  .ind-stat-label {
    font-family: var(--f-mono); font-size: 10px; font-weight: 600;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: rgba(255,255,255,0.6);
  }

  /* ===== SECTION COMMON ===== */
  .ind-section { padding: 88px 0; }
  .ind-section-inner {
    max-width: 1200px; margin: 0 auto; padding: 0 32px;
  }
  .ind-section-head {
    display: flex; align-items: flex-end; justify-content: space-between;
    gap: 32px; margin-bottom: 36px;
    flex-wrap: wrap;
  }
  .ind-section-eyebrow {
    font-family: var(--f-mono); font-size: 11px; font-weight: 700;
    letter-spacing: 0.14em; text-transform: uppercase;
    color: #B8923C; margin-bottom: 10px;
  }
  .ind-section-title {
    font-family: var(--f-display); font-weight: 600;
    font-size: clamp(28px, 3.4vw, 40px); line-height: 1.1;
    letter-spacing: -0.025em;
    color: var(--ink); margin: 0;
  }
  .ind-section-link {
    font-family: var(--f-mono); font-size: 11px; font-weight: 700;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--ink); text-decoration: none;
    border-bottom: 2px solid #D9BD67;
    padding-bottom: 4px;
  }
  .ind-section-link:hover { color: #B8923C; }

  /* ===== RECOMMENDED MATERIALS ===== */
  .ind-mats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
  }
  @media (max-width: 920px) { .ind-mats { grid-template-columns: repeat(2, 1fr); } }
  @media (max-width: 560px) { .ind-mats { grid-template-columns: 1fr; } }

  .ind-mat-card {
    position: relative;
    display: flex; flex-direction: column;
    padding: 22px 20px 20px;
    background: #fff;
    border: 1px solid var(--line);
    text-decoration: none;
    color: var(--ink);
    transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
    min-height: 200px;
  }
  .ind-mat-card:hover {
    border-color: #D9BD67;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px -12px rgba(217,189,103,0.4);
  }
  .ind-mat-tag {
    position: absolute; top: 0; right: 0;
    padding: 4px 10px;
    font-family: var(--f-mono); font-size: 9px; font-weight: 700;
    letter-spacing: 0.12em; text-transform: uppercase;
    background: #D9BD67; color: #0E0F12;
  }
  .ind-mat-fit {
    font-family: var(--f-mono); font-size: 9px; font-weight: 700;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: #B8923C;
    margin-bottom: 12px;
  }
  .ind-mat-name {
    font-family: var(--f-mono); font-size: 18px; font-weight: 600;
    letter-spacing: 0.01em;
    color: var(--ink);
    margin: 0 0 6px;
  }
  .ind-mat-tagline {
    font-size: 13px; line-height: 1.5;
    color: var(--muted);
    margin: 0 0 16px;
  }
  .ind-mat-specs {
    margin-top: auto;
    padding-top: 14px;
    border-top: 1px solid var(--line);
    display: flex; flex-wrap: wrap; gap: 6px 14px;
  }
  .ind-mat-spec {
    font-family: var(--f-mono); font-size: 10px;
    color: var(--muted); letter-spacing: 0.04em;
  }
  .ind-mat-spec strong { color: var(--ink); font-weight: 600; }
  .ind-mat-arrow {
    position: absolute; right: 18px; bottom: 18px;
    color: #B8923C; font-size: 14px;
    opacity: 0; transition: opacity .15s ease, transform .15s ease;
  }
  .ind-mat-card:hover .ind-mat-arrow { opacity: 1; transform: translateX(2px); }
  .ind-mat-hero { background: #0E0F12; color: #fff; border-color: #0E0F12; }
  .ind-mat-hero:hover { border-color: #D9BD67; }
  .ind-mat-hero .ind-mat-name { color: #fff; }
  .ind-mat-hero .ind-mat-tagline { color: rgba(255,255,255,0.78); }
  .ind-mat-hero .ind-mat-specs { border-top-color: rgba(255,255,255,0.15); }
  .ind-mat-hero .ind-mat-spec { color: rgba(255,255,255,0.6); }
  .ind-mat-hero .ind-mat-spec strong { color: #D9BD67; }

  /* ===== CASE STUDIES ===== */
  .ind-cases-section { background: #FAFAF7; }
  .ind-cases { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
  @media (max-width: 760px) { .ind-cases { grid-template-columns: 1fr; } }

  .ind-case-card {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: 0;
    background: #fff;
    border: 1px solid var(--line);
    text-decoration: none;
    transition: border-color .15s ease, transform .15s ease;
  }
  @media (max-width: 560px) {
    .ind-case-card { grid-template-columns: 1fr; }
  }
  .ind-case-card:hover { border-color: #D9BD67; transform: translateY(-2px); }
  .ind-case-img {
    background: linear-gradient(135deg, #2A2D33, #0E0F12);
    min-height: 200px;
    position: relative;
    display: flex; align-items: flex-end;
    padding: 18px;
  }
  .ind-case-img::after {
    content: '';
    position: absolute; inset: 0;
    background: radial-gradient(ellipse at top right, rgba(217,189,103,0.18), transparent 60%);
    pointer-events: none;
  }
  .ind-case-img-tag {
    position: relative; z-index: 2;
    font-family: var(--f-mono); font-size: 9px; font-weight: 700;
    letter-spacing: 0.12em; text-transform: uppercase;
    color: #D9BD67;
    background: rgba(14,15,18,0.7);
    padding: 4px 8px;
  }
  .ind-case-body { padding: 22px 24px 20px; display: flex; flex-direction: column; }
  .ind-case-meta {
    font-family: var(--f-mono); font-size: 10px; font-weight: 600;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--muted); margin-bottom: 8px;
  }
  .ind-case-title {
    font-family: var(--f-display); font-size: 18px; font-weight: 600;
    color: var(--ink); margin: 0 0 8px; line-height: 1.3;
  }
  .ind-case-result {
    font-size: 13px; color: var(--muted); line-height: 1.5;
    margin: 0 0 14px;
  }
  .ind-case-link {
    font-family: var(--f-mono); font-size: 10px; font-weight: 700;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: #B8923C; margin-top: auto;
  }

  /* ===== APPLICATIONS ===== */
  .ind-apps {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
  }
  @media (max-width: 760px) { .ind-apps { grid-template-columns: 1fr; } }

  .ind-app {
    background: #fff;
    border: 1px solid var(--line);
    padding: 22px 22px 20px;
    display: flex; flex-direction: column; gap: 10px;
  }
  .ind-app-num {
    font-family: var(--f-mono); font-size: 11px; font-weight: 700;
    color: #B8923C; letter-spacing: 0.1em;
  }
  .ind-app-title {
    font-family: var(--f-display); font-size: 17px; font-weight: 600;
    color: var(--ink); margin: 0;
    line-height: 1.3;
  }
  .ind-app-desc {
    font-size: 13px; color: var(--muted); line-height: 1.5;
    margin: 0;
  }
  .ind-app-mats {
    margin-top: 8px;
    padding-top: 12px;
    border-top: 1px solid var(--line);
    display: flex; flex-wrap: wrap; gap: 6px;
  }
  .ind-app-mat {
    font-family: var(--f-mono); font-size: 10px; font-weight: 600;
    letter-spacing: 0.04em;
    color: var(--ink);
    padding: 4px 10px;
    background: rgba(217,189,103,0.12);
    border: 1px solid rgba(217,189,103,0.4);
    text-decoration: none;
    transition: background .12s ease;
  }
  .ind-app-mat:hover { background: rgba(217,189,103,0.25); }

  /* ===== BOTTOM CTA ===== */
  .ind-cta-band {
    background: #0E0F12;
    color: #fff;
    padding: 64px 32px;
    text-align: center;
    position: relative;
    overflow: hidden;
  }
  .ind-cta-band::before {
    content: '';
    position: absolute; inset: 0;
    background:
      radial-gradient(ellipse at center, rgba(217,189,103,0.12), transparent 60%);
  }
  .ind-cta-inner { position: relative; z-index: 2; max-width: 680px; margin: 0 auto; }
  .ind-cta-band h2 {
    font-family: var(--f-display); font-weight: 600;
    font-size: clamp(28px, 3.4vw, 38px); line-height: 1.15;
    letter-spacing: -0.02em;
    color: #fff; margin: 0 0 16px;
  }
  .ind-cta-band p {
    font-size: 15px; color: rgba(255,255,255,0.7);
    margin: 0 0 28px;
  }
  body { background: var(--bg); }
  .inq-shell { max-width: 760px; margin: 0 auto; padding: 0 24px 80px; }
  .inq-back {
    display: inline-flex; align-items: center; gap: 6px;
    font-family: var(--f-mono); font-size: 11px; font-weight: 600;
    letter-spacing: 0.12em; text-transform: uppercase;
    color: var(--muted); text-decoration: none;
    margin: 28px 0 24px;
  }
  .inq-back:hover { color: var(--ink); }

  .inq-hero { text-align: center; margin-bottom: 24px; }
  .inq-eyebrow {
    font-family: var(--f-mono); font-size: 11px; font-weight: 700;
    letter-spacing: 0.18em; text-transform: uppercase;
    color: #B8923C; margin-bottom: 14px;
  }
  .inq-title {
    font-family: var(--f-display); font-weight: 600;
    font-size: clamp(30px, 4vw, 44px); line-height: 1.1;
    letter-spacing: -0.025em; margin: 0 0 14px; color: var(--ink);
  }
  .inq-lede {
    font-size: 15px; line-height: 1.6;
    color: var(--muted); margin: 0 auto;
    max-width: 540px;
  }

  /* Top tabs */
  .inq-tabs {
    display: grid; grid-template-columns: repeat(3, 1fr);
    border: 1px solid var(--line);
    background: #fff;
    margin-bottom: 28px;
  }
  @media (max-width: 560px) {
    .inq-tabs { grid-template-columns: 1fr 1fr; }
  }
  .inq-tab {
    appearance: none; border: 0; background: transparent;
    padding: 16px 12px;
    font-family: var(--f-mono); font-size: 11px; font-weight: 700;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--muted);
    cursor: pointer;
    border-right: 1px solid var(--line);
    border-bottom: 3px solid transparent;
    transition: color .12s ease, border-color .12s ease, background .12s ease;
  }
  .inq-tab:last-child { border-right: 0; }
  @media (max-width: 560px) {
    .inq-tab { border-right: 0; border-bottom-width: 0; }
    .inq-tab.is-active { border-bottom-width: 3px; }
  }
  .inq-tab:hover { color: var(--ink); background: rgba(217,189,103,0.04); }
  .inq-tab.is-active {
    color: var(--ink);
    border-bottom-color: #D9BD67;
    background: rgba(217,189,103,0.08);
  }

  /* Progress strip */
  .inq-progress {
    display: flex; justify-content: center; gap: 8px;
    margin-bottom: 24px;
  }
  .inq-prog-dot {
    width: 32px; height: 3px;
    background: var(--line);
    transition: background .2s ease;
  }
  .inq-prog-dot.is-done { background: #D9BD67; }
  .inq-prog-dot.is-current { background: var(--ink); }

  /* Form card */
  .inq-card {
    background: #fff;
    border: 1px solid var(--line);
    box-shadow: 0 24px 48px -24px rgba(15,17,21,0.08);
  }
  .inq-step {
    padding: 32px 36px 28px;
    border-bottom: 1px solid var(--line);
  }
  .inq-step:last-of-type { border-bottom: 0; }
  @media (max-width: 560px) { .inq-step { padding: 24px 20px; } }

  .inq-step-head {
    display: flex; align-items: baseline; gap: 12px;
    margin-bottom: 18px;
  }
  .inq-step-num {
    font-family: var(--f-mono); font-size: 11px; font-weight: 700;
    color: #B8923C; letter-spacing: 0.14em;
    flex-shrink: 0;
  }
  .inq-step-title {
    font-family: var(--f-display); font-size: 18px; font-weight: 600;
    letter-spacing: -0.01em; color: var(--ink);
    line-height: 1.3;
  }
  .inq-step-help { font-size: 12px; color: var(--muted); margin-top: 2px; }

  .inq-field { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
  .inq-field:last-child { margin-bottom: 0; }
  .inq-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 16px; }
  .inq-row .inq-field { margin-bottom: 0; }
  @media (max-width: 560px) { .inq-row { grid-template-columns: 1fr; } }

  .inq-label {
    font-family: var(--f-mono); font-size: 10px; font-weight: 600;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--ink);
  }
  .inq-label-opt::after {
    content: ' · optional';
    color: var(--muted); font-weight: 400; letter-spacing: 0.04em;
  }
  .inq-input, .inq-select, .inq-textarea {
    font-family: var(--f-body); font-size: 14px;
    color: var(--ink); background: #fff;
    border: 1px solid var(--line);
    padding: 12px 14px; width: 100%;
    transition: border-color .12s ease, box-shadow .12s ease;
  }
  .inq-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%231A1A1A' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
  }
  .inq-input:focus, .inq-select:focus, .inq-textarea:focus {
    outline: none; border-color: #B8923C;
    box-shadow: 0 0 0 3px rgba(217,189,103,0.18);
  }
  .inq-textarea { min-height: 110px; resize: vertical; line-height: 1.5; }

  /* Footer */
  .inq-foot {
    padding: 24px 36px 28px;
    background: rgba(217,189,103,0.06);
    display: flex; align-items: center; justify-content: space-between;
    gap: 16px; flex-wrap: wrap;
  }
  @media (max-width: 560px) { .inq-foot { padding: 20px; } }
  .inq-privacy {
    font-size: 11px; color: var(--muted); max-width: 320px; line-height: 1.5;
  }
  .inq-submit {
    appearance: none; border: 0;
    background: linear-gradient(135deg, #D9BD67, #C9A24E);
    color: var(--ink);
    font-family: var(--f-mono); font-size: 12px; font-weight: 700;
    letter-spacing: 0.12em; text-transform: uppercase;
    padding: 16px 32px;
    cursor: pointer;
    transition: transform .12s ease, box-shadow .12s ease;
  }
  .inq-submit:hover { transform: translateY(-1px); box-shadow: 0 8px 24px -8px rgba(217,189,103,0.65); }

  .inq-thanks { text-align: center; padding: 80px 24px; }
  .inq-thanks h2 {
    font-family: var(--f-display); font-size: 32px; font-weight: 600;
    color: var(--ink); margin: 0 0 14px;
  }
  .inq-thanks p {
    font-size: 14px; color: var(--muted); max-width: 440px; margin: 0 auto;
  }

  .inq-source-banner {
    background: #0E0F12;
    color: #fff;
    padding: 12px 20px;
    margin-bottom: 16px;
    display: flex; align-items: center; justify-content: space-between;
    gap: 16px;
    font-family: var(--f-mono); font-size: 11px; font-weight: 600;
    letter-spacing: 0.08em;
  }
  .inq-source-banner .src-label {
    color: rgba(255,255,255,0.6);
    text-transform: uppercase;
    letter-spacing: 0.14em;
  }
  .inq-source-banner .src-tag {
    background: #D9BD67; color: #0E0F12;
    padding: 4px 10px;
    text-transform: uppercase;
  }
  .inq-priority-badge {
    display: inline-flex; align-items: center; gap: 6px;
  }
  .inq-priority-badge::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%;
    background: #D9BD67;
  }



/* ============================================ */
/* Auto-extracted from v11 sections inline styles */
/* ============================================ */

/* === from sections\collection-main.liquid === */
.coll-hero { padding: 64px var(--pad-x) 48px; background: var(--bg); border-bottom: 1px solid var(--line); }
.coll-hero-inner { max-width: var(--max-w); margin: 0 auto; }
.coll-hero-title { font-family: var(--f-display); font-weight: 600; font-size: clamp(40px, 5vw, 64px); letter-spacing: -0.03em; line-height: 1.05; margin: 0 0 14px; }
.coll-hero-lede { font-size: 16px; color: var(--muted); max-width: 640px; margin: 0 0 18px; line-height: 1.6; }
.coll-meta { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--muted); display: flex; gap: 18px; }
.coll-section { padding: 48px var(--pad-x) 96px; background: var(--bg); }
.coll-layout { max-width: var(--max-w); margin: 0 auto; display: grid; grid-template-columns: 240px 1fr; gap: 40px; }
@media (max-width: 760px) { .coll-layout { grid-template-columns: 1fr; } }
.coll-filters {  }
.coll-filter-head { display: flex; justify-content: space-between; align-items: center; padding-bottom: 12px; border-bottom: 1px solid var(--line); margin-bottom: 16px; font-family: var(--f-mono); font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; }
.coll-clear { color: var(--accent-dark); text-decoration: none; }
.coll-filter-group { padding: 12px 0; border-bottom: 1px solid var(--line); }
.coll-filter-group summary { cursor: pointer; font-family: var(--f-mono); font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; padding: 6px 0; list-style: none; }
.coll-filter-group summary::-webkit-details-marker { display: none; }
.coll-filter-list { list-style: none; padding: 10px 0 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.coll-filter-item { display: flex; justify-content: space-between; padding: 6px 0; font-size: 13px; color: var(--ink); text-decoration: none; transition: color .12s ease; }
.coll-filter-item:hover, .coll-filter-item.active { color: var(--accent-dark); }
.coll-count { color: var(--muted); font-family: var(--f-mono); font-size: 11px; }
.coll-side-cta { display: block; margin-top: 24px; padding: 20px; background: var(--accent); color: var(--ink); text-decoration: none; }
.coll-side-cta-eyebrow { font-family: var(--f-mono); font-size: 10px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 8px; }
.coll-side-cta-title { font-family: var(--f-display); font-weight: 600; font-size: 16px; margin-bottom: 16px; line-height: 1.3; }
.coll-side-cta-link { font-family: var(--f-mono); font-size: 11px; font-weight: 700; letter-spacing: 0.1em; border-bottom: 1px solid var(--ink); padding-bottom: 2px; }
.coll-sort-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; padding-bottom: 16px; border-bottom: 1px solid var(--line); }
.coll-result-count { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--muted); }
.coll-sort-form { display: flex; gap: 10px; align-items: center; }
.coll-sort-label { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--muted); }
.coll-sort-select { font-family: var(--f-mono); font-size: 12px; padding: 6px 12px; border: 1px solid var(--line); background: var(--bg); color: var(--ink); }
.coll-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 920px) { .coll-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .coll-grid { grid-template-columns: 1fr; } }
.coll-card { display: block; background: var(--card); border: 1px solid var(--line); text-decoration: none; color: var(--ink); transition: border-color .15s ease, transform .15s ease; }
.coll-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.coll-card-img { aspect-ratio: 4/3; background: var(--soft); position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.coll-card-img img { width: 100%; height: 100%; object-fit: cover; }
.coll-card-placeholder { font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.08em; }
.coll-card-status { position: absolute; top: 8px; left: 8px; font-family: var(--f-mono); font-size: 9px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; padding: 3px 8px; }
.status-coming { background: var(--soft); color: var(--muted); }
.status-eval { background: rgba(106,91,203,0.18); color: #6A5BCB; }
.status-bto { background: var(--accent); color: var(--ink); }
.coll-card-body { padding: 16px 18px; }
.coll-card-family { font-family: var(--f-mono); font-size: 10px; font-weight: 700; letter-spacing: 0.12em; color: var(--accent-dark); margin-bottom: 6px; }
.coll-card-title { font-family: var(--f-display); font-weight: 600; font-size: 17px; letter-spacing: -0.01em; margin: 0 0 6px; line-height: 1.3; }
.coll-card-tagline { font-size: 12px; color: var(--muted); line-height: 1.4; margin: 0 0 12px; }
.coll-card-foot { display: flex; justify-content: space-between; align-items: center; padding-top: 12px; border-top: 1px solid var(--line); }
.coll-card-price { font-family: var(--f-mono); font-weight: 600; font-size: 14px; }
.coll-card-price-alt { font-family: var(--f-mono); font-size: 11px; font-weight: 700; letter-spacing: 0.06em; color: var(--accent-dark); }
.coll-card-arrow { color: var(--accent-dark); }
.coll-empty { padding: 64px; text-align: center; color: var(--muted); font-family: var(--f-mono); }
.coll-pagination { display: flex; gap: 8px; justify-content: center; align-items: center; padding-top: 48px; }
.coll-pagination a, .coll-pagination span { font-family: var(--f-mono); font-size: 12px; padding: 8px 14px; border: 1px solid var(--line); color: var(--ink); text-decoration: none; }
.coll-pagination .active { background: var(--ink); color: #fff; border-color: var(--ink); }

/* === from sections\custom-print-page.liquid === */
.cp-hero { padding: 96px var(--pad-x) 64px; background: var(--ink); color: #fff; position: relative; overflow: hidden; }
.cp-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 30% 30%, rgba(217,189,103,0.18), transparent 55%); }
.cp-hero-inner { position: relative; z-index: 2; max-width: var(--max-w); margin: 0 auto; }
.cp-hero-title { font-family: var(--f-display); font-weight: 600; font-size: clamp(40px, 6vw, 72px); letter-spacing: -0.03em; line-height: 1.05; margin: 0 0 20px; color: #fff; }
.cp-hero-lede { font-size: 17px; color: rgba(255,255,255,0.78); max-width: 540px; margin: 0 0 32px; }
.cp-steps-section, .cp-mats { padding: 80px var(--pad-x); }
.cp-steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
@media (max-width: 760px) { .cp-steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .cp-steps { grid-template-columns: 1fr; } }
.cp-step { background: #fff; border: 1px solid var(--line); padding: 26px 22px; }
.cp-step-num { font-family: var(--f-mono); font-size: 11px; font-weight: 700; color: var(--accent-dark); letter-spacing: 0.12em; }
.cp-step-title { font-family: var(--f-display); font-weight: 600; font-size: 18px; margin: 10px 0 6px; }
.cp-step-desc { font-size: 13px; color: var(--muted); line-height: 1.55; margin: 0; }

/* === from sections\footer.liquid === */
.footer {
    background: var(--ink);
    color: rgba(255,255,255,0.85);
    padding: 64px var(--pad-x) 32px;
    font-family: var(--f-body);
  }
  .footer-inner {
    max-width: var(--max-w); margin: 0 auto;
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1fr 1fr;
    gap: 32px;
    padding-bottom: 48px;
    border-bottom: 1px solid rgba(255,255,255,0.12);
  }
  @media (max-width: 920px) {
    .footer-inner { grid-template-columns: 1fr 1fr; gap: 28px; }
  }
  @media (max-width: 560px) {
    .footer-inner { grid-template-columns: 1fr; }
  }
  .footer-logo {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--f-display); font-weight: 700; font-size: 16px;
    color: #fff; text-decoration: none; margin-bottom: 12px;
  }
  .footer-logo .logo-mark {
    width: 24px; height: 24px;
    background: var(--accent); color: var(--ink);
    display: inline-flex; align-items: center; justify-content: center;
    font-family: var(--f-mono); font-size: 13px; font-weight: 700;
  }
  .footer-logo .logo-sub { color: var(--accent); font-weight: 500; }
  .footer-tagline {
    font-family: var(--f-serif); font-style: italic;
    font-size: 16px; color: rgba(255,255,255,0.75);
    margin: 0 0 14px;
    max-width: 280px;
  }
  .footer-address {
    font-size: 12px; line-height: 1.6;
    color: rgba(255,255,255,0.55);
    margin: 0;
    white-space: pre-line;
  }
  .footer-h {
    font-family: var(--f-mono); font-size: 10px; font-weight: 700;
    letter-spacing: 0.14em; text-transform: uppercase;
    color: var(--accent);
    margin: 0 0 14px;
  }
  .footer-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
  .footer-list a {
    color: rgba(255,255,255,0.75); text-decoration: none;
    font-size: 13px;
    transition: color .12s ease;
  }
  .footer-list a:hover { color: var(--accent); }
  .footer-bottom {
    max-width: var(--max-w); margin: 0 auto;
    padding-top: 24px;
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 16px;
  }
  .footer-meta {
    font-family: var(--f-mono); font-size: 11px;
    color: rgba(255,255,255,0.45);
    letter-spacing: 0.04em;
  }
  .footer-legal { list-style: none; padding: 0; margin: 0; display: flex; gap: 18px; }
  .footer-legal a {
    color: rgba(255,255,255,0.45); text-decoration: none;
    font-family: var(--f-mono); font-size: 11px;
    letter-spacing: 0.06em; text-transform: uppercase;
    transition: color .12s ease;
  }
  .footer-legal a:hover { color: var(--accent); }

/* === from sections\product-main.liquid === */
.pdp-main { padding: 64px var(--pad-x); background: var(--bg); }
.pdp-grid { max-width: var(--max-w); margin: 0 auto; display: grid; grid-template-columns: 1.2fr 1fr; gap: 56px; }
@media (max-width: 920px) { .pdp-grid { grid-template-columns: 1fr; gap: 32px; } }
.pdp-hero-img { width: 100%; aspect-ratio: 4/3; object-fit: cover; background: var(--soft); border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; color: var(--muted); font-family: var(--f-mono); font-size: 12px; }
.pdp-thumbs { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; margin-top: 12px; }
.pdp-thumbs img { width: 100%; aspect-ratio: 1; object-fit: cover; border: 1px solid var(--line); cursor: pointer; }
.pdp-eyebrow { font-family: var(--f-mono); font-size: 11px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-dark); margin-bottom: 12px; }
.pdp-title { font-family: var(--f-display); font-weight: 600; font-size: clamp(32px, 4vw, 48px); letter-spacing: -0.025em; line-height: 1.05; margin: 0 0 14px; }
.pdp-tagline { font-size: 16px; color: var(--muted); line-height: 1.6; margin: 0 0 20px; }
.pdp-status { font-family: var(--f-mono); font-size: 12px; font-weight: 600; letter-spacing: 0.08em; padding: 8px 12px; display: inline-block; margin-bottom: 24px; border: 1px solid var(--line); }
.pdp-status-stock { color: #2D6A4F; background: #E8F4ED; border-color: #B2D8C0; }
.pdp-status-bto { color: #B8923C; background: rgba(217,189,103,0.12); border-color: var(--accent); }
.pdp-status-eval { color: #6A5BCB; background: rgba(106,91,203,0.08); border-color: #C5BCEC; }
.pdp-status-coming { color: var(--muted); background: var(--soft); }
.pdp-status-request { color: var(--ink); background: var(--soft); }
.pdp-specs { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 24px; padding: 20px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin: 0 0 28px; }
.pdp-spec-key { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); display: block; margin-bottom: 4px; }
.pdp-spec-val { font-family: var(--f-mono); font-size: 14px; font-weight: 600; color: var(--ink); }
.pdp-actions { display: flex; flex-direction: column; gap: 14px; margin-bottom: 28px; }
.pdp-price { font-family: var(--f-display); font-size: 36px; font-weight: 600; color: var(--ink); margin-bottom: 12px; }
.pdp-compare { font-size: 18px; color: var(--muted); text-decoration: line-through; margin-left: 8px; }
.pdp-sample-link { font-family: var(--f-mono); font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent-dark); text-decoration: none; align-self: flex-start; }
.pdp-description { font-size: 14px; line-height: 1.6; color: var(--ink); }

/* ============ shopify-final design overrides ============ */
/* ===== DML World — Shopify Site Design ===== */

:root {
  --ink: #1A1A1A;
  --accent: #2FA7FF;
  --accent-dark: #0094C7;
  --muted: #6C6C72;
  --line: #E8E8EB;
  --page: #F5F6F8;
  --card: #FFFFFF;
  --soft: #FAFBFD;
  --ink-05: rgba(26,26,26,0.05);
  --ink-10: rgba(26,26,26,0.10);

  --f-display: 'Poppins', -apple-system, BlinkMacSystemFont, sans-serif;
  --f-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --f-serif: 'Instrument Serif', Georgia, serif;
  --f-mono: 'JetBrains Mono', ui-monospace, monospace;

  --r-sm: 2px;
  --r-md: 4px;
  --r-lg: 8px;

  --pad-x: clamp(20px, 4vw, 64px);
  --max-w: 1440px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { background: var(--page); color: var(--ink); font-family: var(--f-body); font-size: 15px; line-height: 1.5; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; border: none; background: none; }

/* ===== Utility type ===== */
.mono { font-family: var(--f-mono); font-weight: 500; letter-spacing: -0.01em; }
.serif-i { font-family: var(--f-serif); font-style: italic; font-weight: 400; }
.eyebrow {
  font-family: var(--f-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-dark);
}
.eyebrow-ink { color: var(--ink); }
.eyebrow-muted { color: var(--muted); }

h1,h2,h3,h4 { font-family: var(--f-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.05; }
.caps { text-transform: uppercase; letter-spacing: -0.01em; }

/* ===== Buttons ===== */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  height: 46px; padding: 0 22px;
  border-radius: var(--r-sm);
  font-family: var(--f-body); font-size: 14px; font-weight: 600;
  letter-spacing: 0.01em;
  transition: transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
  white-space: nowrap;
}
.btn-primary { background: var(--ink); color: #fff; }
.btn-primary:hover { background: #000; transform: translateY(-1px); }
.btn-secondary { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
.btn-secondary:hover { background: var(--ink); color: #fff; }
.btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--line); }
.btn-ghost:hover { border-color: var(--ink); }
.btn-accent { background: var(--accent); color: #fff; }
.btn-accent:hover { background: var(--accent-dark); }
.btn-sm { height: 36px; padding: 0 14px; font-size: 13px; }
.btn-lg { height: 54px; padding: 0 28px; font-size: 15px; }
.btn .arr { display: inline-block; transition: transform .2s ease; }
.btn:hover .arr { transform: translateX(3px); }

/* ===== Layout ===== */
.wrap { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--pad-x); }
.wrap-wide { max-width: 1600px; margin: 0 auto; padding: 0 var(--pad-x); }

/* ===== Top Nav ===== */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
}
.nav-inner {
  display: grid; grid-template-columns: auto 1fr auto;
  align-items: center; gap: 32px;
  height: 72px;
  max-width: var(--max-w); margin: 0 auto; padding: 0 var(--pad-x);
}
.logo {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--f-display); font-weight: 700; font-size: 18px;
  letter-spacing: -0.02em;
}
.logo-mark {
  width: 28px; height: 28px; background: var(--ink); color: #fff;
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 13px; font-weight: 700;
}
/* nav-links / nav-link / nav-right / nav-icon-btn: defer to v11 mega-menu rules above */
.nav-small {
  font-family: var(--f-mono); font-size: 11px; color: var(--muted);
  letter-spacing: 0.04em; text-transform: uppercase;
}

/* ===== Announcement bar ===== */
.announce {
  background: var(--ink); color: #fff;
  font-family: var(--f-mono); font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase;
  height: 32px; display: flex; align-items: center; justify-content: center;
  gap: 28px; overflow: hidden;
}
.announce .dot { color: var(--accent); }

/* ===== Page sections ===== */
section { padding: 88px 0; }
.section-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 24px; margin-bottom: 40px; flex-wrap: wrap;
}
.section-title { font-size: clamp(28px, 3.2vw, 44px); max-width: 700px; }
.section-sub { color: var(--muted); max-width: 420px; font-size: 14px; }

/* ===== Hero Slideshow (v2) ===== */
.hero-slideshow {
  position: relative;
  height: 75vh;
  min-height: 560px;
  max-height: 820px;
  background: var(--ink);
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.hero-slide {
  position: absolute; inset: 0;
  opacity: 0;
  transition: opacity .8s ease;
  pointer-events: none;
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.hero-slide.active { opacity: 1; pointer-events: auto; }
.hero-slide-text {
  padding: 80px var(--pad-x);
  display: flex; flex-direction: column; justify-content: center;
  background: var(--card);
  position: relative;
  z-index: 2;
}
.hero-slide-eyebrow {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--accent-dark);
}
.hero-slide-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(42px, 5vw, 72px);
  letter-spacing: -0.03em; line-height: 1.02;
  margin-top: 24px;
  max-width: 560px;
}
.hero-slide-body {
  margin-top: 20px;
  color: var(--muted);
  font-size: 16px;
  max-width: 440px;
}
.hero-slide-cta { margin-top: 36px; align-self: flex-start; }

.hero-slide-visual {
  position: relative;
  background: linear-gradient(180deg, #EEF2F6 0%, #DDE4EB 100%);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.hero-slide-visual::before {
  content: ''; position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(90deg, rgba(26,26,26,0.04) 0 1px, transparent 1px 80px),
    repeating-linear-gradient(0deg, rgba(26,26,26,0.04) 0 1px, transparent 1px 80px);
}
.hero-slide-visual.dark { background: linear-gradient(155deg, #2a2d33 0%, #111318 100%); }
.hero-slide-visual.dark::before {
  background-image:
    repeating-linear-gradient(90deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 80px),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 80px);
}
.hero-slide-visual.warm { background: linear-gradient(155deg, #f0ede5 0%, #d4cfc0 100%); }
.hero-slide-visual .object {
  position: relative; z-index: 2;
  width: 60%; aspect-ratio: 1;
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 11px;
  letter-spacing: 0.08em; color: var(--muted);
  text-transform: uppercase;
  background: rgba(255,255,255,0.5);
  border: 1px solid rgba(26,26,26,0.08);
}
.hero-slide-visual.dark .object {
  background: rgba(47,167,255,0.08);
  border-color: rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.5);
}
.hero-slide-visual .vis-tag {
  position: absolute; top: 24px; right: 24px;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--muted);
  padding: 6px 10px; background: rgba(255,255,255,0.9); border: 1px solid var(--line);
  z-index: 3;
}
.hero-slide-visual.dark .vis-tag { background: rgba(0,0,0,0.5); color: rgba(255,255,255,0.7); border-color: rgba(255,255,255,0.15); }

.hero-controls {
  position: absolute; bottom: 32px; left: 0; right: 0;
  z-index: 10;
  display: flex; justify-content: space-between; align-items: center;
  padding: 0 var(--pad-x);
  pointer-events: none;
}
.hero-dots { display: flex; gap: 10px; pointer-events: auto; }
.hero-dot {
  width: 40px; height: 3px;
  background: rgba(26,26,26,0.25);
  border: 0; padding: 0; cursor: pointer;
  position: relative;
  cursor: pointer;
  transition: background .3s ease;
  position: relative;
  overflow: hidden;
}
.hero-dot.active { background: rgba(26,26,26,0.25); }
.hero-dot.active::after {
  content: ''; position: absolute; inset: 0;
  background: var(--ink);
  transform-origin: left center;
  animation: heroProgress 7s linear forwards;
}
.hero-slideshow.paused .hero-dot.active::after { animation-play-state: paused; }
@keyframes heroProgress { from { transform: scaleX(0);} to { transform: scaleX(1);} }

.hero-arrows { display: flex; gap: 8px; pointer-events: auto; }
.hero-arrow {
  width: 44px; height: 44px;
  border: 1px solid var(--line);
  background: var(--card);
  display: grid; place-items: center;
  border-radius: var(--r-sm);
  font-family: var(--f-mono); font-size: 16px; font-weight: 500;
  transition: background .15s ease;
}
.hero-arrow:hover { background: var(--ink); color: #fff; border-color: var(--ink); }
.hero-counter {
  font-family: var(--f-mono); font-size: 11px;
  color: var(--muted); letter-spacing: 0.08em;
  pointer-events: auto;
}
.hero-counter .cur { color: var(--ink); font-weight: 600; }

/* ===== Video + Interactive Timeline ===== */
.ecosystem {
  background: var(--ink); color: #fff;
  padding: 0;
  position: relative;
  overflow: hidden;
}
.ecosystem-inner {
  min-height: 75vh;
  display: grid; grid-template-rows: auto 1fr auto;
  padding: 64px var(--pad-x) 48px;
  max-width: var(--max-w);
  margin: 0 auto;
}
.ecosystem-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 32px; flex-wrap: wrap;
  margin-bottom: 48px;
}
.ecosystem-head .eyebrow { color: var(--accent); }
.ecosystem-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(32px, 3.8vw, 52px);
  letter-spacing: -0.03em; line-height: 1;
  max-width: 700px;
  margin-top: 12px;
}
.ecosystem-title .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
  letter-spacing: -0.02em;
  color: rgba(255,255,255,0.85);
}
.ecosystem-stage {
  position: relative;
  aspect-ratio: 16 / 8;
  background: #0a0a0a;
  border: 1px solid rgba(255,255,255,0.08);
  overflow: hidden;
  display: grid;
}
.eco-frame {
  grid-area: 1 / 1;
  position: relative;
  opacity: 0;
  transition: opacity .7s ease;
  pointer-events: none;
}
.eco-frame.active { opacity: 1; pointer-events: auto; }
.eco-frame-bg {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, #111318 0%, #1a1d24 100%);
}
.eco-frame-bg::before {
  content: ''; position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(45deg, rgba(255,255,255,0.02) 0 2px, transparent 2px 18px);
}
.eco-frame-bg.f2 { background: linear-gradient(135deg, #0a1420 0%, #1a2a38 100%); }
.eco-frame-bg.f3 { background: linear-gradient(135deg, #1a1d24 0%, #2a2028 100%); }
.eco-frame-bg.f4 { background: linear-gradient(135deg, #1a1a18 0%, #26241e 100%); }

.eco-placeholder-tag {
  position: absolute; top: 24px; left: 24px;
  font-family: var(--f-mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  padding: 6px 10px;
  border: 1px solid rgba(255,255,255,0.15);
  background: rgba(0,0,0,0.3);
  display: flex; align-items: center; gap: 8px;
}
.eco-placeholder-tag::before {
  content: ''; width: 6px; height: 6px; background: #ff4a4a; border-radius: 50%;
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }

.eco-stage-center {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 32%; aspect-ratio: 1;
  border: 1px solid rgba(255,255,255,0.15);
  background: rgba(47,167,255,0.06);
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 11px;
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.1em; text-transform: uppercase;
}

.eco-overlay {
  position: absolute; left: 48px; bottom: 48px; right: 48px;
  max-width: 520px;
  z-index: 2;
}
.eco-overlay .eyebrow { color: var(--accent); }
.eco-overlay .head {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(24px, 3vw, 36px);
  letter-spacing: -0.02em; line-height: 1.1;
  margin-top: 14px;
  color: #fff;
}
.eco-overlay .desc {
  margin-top: 12px;
  color: rgba(255,255,255,0.7);
  font-size: 15px;
}
.eco-overlay .explore {
  margin-top: 20px; display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--f-mono); font-size: 12px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: #fff;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--accent);
}
.eco-overlay .explore:hover { color: var(--accent); }

.ecosystem-timeline {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px; background: rgba(255,255,255,0.08);
  margin-top: 32px;
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.eco-node {
  background: var(--ink);
  padding: 24px 24px 28px;
  cursor: pointer;
  display: flex; flex-direction: column; gap: 10px;
  position: relative;
  transition: background .2s ease;
}
.eco-node:hover { background: #0a0a0a; }
.eco-node-num {
  font-family: var(--f-mono); font-size: 10px;
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.1em;
}
.eco-node-lab {
  font-family: var(--f-display); font-weight: 600;
  font-size: 22px; letter-spacing: -0.02em;
  color: rgba(255,255,255,0.5);
  transition: color .2s ease;
}
.eco-node.active .eco-node-lab { color: #fff; }
.eco-node-bar {
  position: absolute; top: 0; left: 0; right: 0;
  height: 2px; background: transparent;
  overflow: hidden;
}
.eco-node.active .eco-node-bar { background: rgba(47,167,255,0.15); }
.eco-node.active .eco-node-bar::after {
  content: ''; position: absolute; inset: 0;
  background: var(--accent);
  animation: ecoProgress 9s linear forwards;
}
.ecosystem.paused .eco-node.active .eco-node-bar::after { animation-play-state: paused; }
@keyframes ecoProgress { from { transform: translateX(-100%);} to { transform: translateX(0);} }

/* ===== Featured Carousel ===== */
.featured-carousel-section { padding: 88px 0 88px; background: var(--card); border-bottom: 1px solid var(--line); }
.featured-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 24px; flex-wrap: wrap;
  margin-bottom: 36px;
}
.featured-head .t {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(28px, 3.2vw, 44px);
  letter-spacing: -0.03em; line-height: 1;
  margin-top: 12px;
}
.featured-head .t .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
}
.featured-head-right {
  display: flex; gap: 12px; align-items: center;
}
.carousel-arrows { display: flex; gap: 6px; }
.carousel-arr {
  width: 40px; height: 40px;
  border: 1px solid var(--line);
  display: grid; place-items: center;
  background: var(--card);
  border-radius: var(--r-sm);
  font-family: var(--f-mono); font-size: 14px;
  transition: background .15s ease;
}
.carousel-arr:hover { background: var(--ink); color: #fff; border-color: var(--ink); }
.carousel-arr:disabled { opacity: 0.3; cursor: not-allowed; }

.carousel-track-wrap {
  position: relative;
  overflow: hidden;
}
.carousel-track {
  display: flex; gap: 20px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  padding-bottom: 4px;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.carousel-track::-webkit-scrollbar { display: none; }
.carousel-card {
  flex: 0 0 calc(25% - 15px);
  min-width: 260px;
  scroll-snap-align: start;
  background: var(--card);
  border: 1px solid var(--line);
  display: flex; flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease;
  cursor: pointer;
}
.carousel-card:hover { transform: translateY(-3px); box-shadow: 0 18px 40px -20px rgba(0,0,0,0.15); }
.carousel-card .prod-img { aspect-ratio: 4 / 5; }
.carousel-indicator {
  margin-top: 24px;
  height: 2px;
  background: var(--line);
  position: relative;
  max-width: 240px;
}
.carousel-indicator-fill {
  position: absolute; top: 0; left: 0; bottom: 0;
  background: var(--ink);
  width: 25%;
  transition: left .3s ease, width .3s ease;
}

/* ===== Partner Brand Block ===== */
.partner-section {
  padding: 96px 0;
  background: var(--soft);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  text-align: center;
}
.partner-inner { max-width: 680px; margin: 0 auto; padding: 0 var(--pad-x); }
.partner-inner .eyebrow { color: var(--accent-dark); }
.partner-logos {
  display: flex; justify-content: center; align-items: center;
  gap: 48px;
  margin: 32px 0 24px;
  flex-wrap: wrap;
}
.partner-logo {
  display: flex; align-items: center; justify-content: center;
  height: 56px;
  padding: 0 24px;
  border: 1px solid var(--line);
  background: var(--card);
  font-family: var(--f-display); font-weight: 700; font-size: 22px;
  letter-spacing: -0.02em; color: var(--ink);
  min-width: 140px;
}
.partner-logo.primary { border-color: var(--ink); border-width: 2px; font-size: 26px; height: 72px; }
.partner-logo.placeholder {
  color: var(--muted); font-weight: 500; font-size: 13px;
  letter-spacing: 0.08em; text-transform: uppercase;
  border-style: dashed; background: transparent;
  font-family: var(--f-mono);
}
.partner-desc {
  margin-top: 24px;
  color: var(--muted);
  font-size: 15px;
  max-width: 520px;
  margin-left: auto; margin-right: auto;
}
.partner-cta { margin-top: 28px; display: inline-flex; }

/* ===== Trust v2 (simplified) ===== */
.trust-v2 {
  background: var(--ink);
  color: #fff;
  padding: 48px 0;
}
.trust-v2-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  align-items: center;
}
.trust-v2-item {
  display: flex; align-items: center; gap: 18px;
  padding-right: 24px;
  border-right: 1px solid rgba(255,255,255,0.1);
}
.trust-v2-item:last-child { border-right: none; }
.trust-v2-ico {
  width: 44px; height: 44px; flex-shrink: 0;
  border: 1.5px solid #fff;
  display: grid; place-items: center;
  border-radius: var(--r-sm);
}
.trust-v2-ico svg { width: 22px; height: 22px; }
.trust-v2-text .lab {
  font-family: var(--f-display); font-size: 17px; font-weight: 500;
  letter-spacing: -0.01em; line-height: 1.15;
  display: block;
}
.trust-v2-text .sub {
  font-family: var(--f-mono); font-size: 11px;
  color: rgba(255,255,255,0.5);
  letter-spacing: 0.04em; text-transform: uppercase;
  margin-top: 3px;
  display: block;
}

/* ===== Hero — Variant A ===== */
.hero-a {
  background: var(--card);
  border-bottom: 1px solid var(--line);
}
.hero-a-grid {
  display: grid; grid-template-columns: 1.05fr 1fr;
  gap: 0;
  min-height: 640px;
}
.hero-a-left {
  padding: 72px var(--pad-x) 72px 0;
  padding-left: var(--pad-x);
  display: flex; flex-direction: column; justify-content: space-between;
  border-right: 1px solid var(--line);
}
.hero-a-meta {
  display: flex; gap: 24px; align-items: center;
  font-family: var(--f-mono); font-size: 11px; color: var(--muted);
  letter-spacing: 0.06em; text-transform: uppercase;
}
.hero-a-meta .dash { width: 24px; height: 1px; background: var(--ink); display: inline-block; }
.hero-a-title {
  font-size: clamp(56px, 7vw, 104px);
  font-weight: 600; line-height: 0.92;
  letter-spacing: -0.035em;
  text-transform: uppercase;
  margin-top: 48px;
}
.hero-a-title .italic {
  font-family: var(--f-serif); font-style: italic;
  font-weight: 400; text-transform: none;
  letter-spacing: -0.02em;
  color: var(--ink);
  display: inline-block;
  padding-right: 8px;
}
.hero-a-title .accent-word { color: var(--accent); }
.hero-a-body {
  margin-top: 32px;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 40px;
}
.hero-a-body p {
  font-size: 15px; color: var(--ink); max-width: 380px;
}
.hero-a-body p.muted { color: var(--muted); }
.hero-a-ctas { display: flex; gap: 12px; margin-top: 40px; flex-wrap: wrap; }

.hero-a-right {
  position: relative;
  background: linear-gradient(180deg, #EEF2F6 0%, #DDE4EB 100%);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.hero-a-right::before {
  content: ''; position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(90deg, rgba(26,26,26,0.04) 0 1px, transparent 1px 80px),
    repeating-linear-gradient(0deg, rgba(26,26,26,0.04) 0 1px, transparent 1px 80px);
}
.hero-machine {
  position: relative;
  width: 78%; aspect-ratio: 1 / 1.1;
  background: linear-gradient(155deg, #2a2d33 0%, #111318 100%);
  display: grid; place-items: center;
  box-shadow: 0 40px 80px -20px rgba(0,0,0,0.35);
  overflow: hidden;
}
.hero-machine::before {
  content: 'IEMAI HT-PRO';
  position: absolute; top: 20px; left: 20px;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.12em;
  color: rgba(255,255,255,0.4); text-transform: uppercase;
}
.hero-machine::after {
  content: ''; position: absolute;
  left: 14%; right: 14%; top: 22%; bottom: 22%;
  background:
    linear-gradient(180deg, rgba(47,167,255,0.15) 0%, transparent 60%),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 8px);
  border: 1px solid rgba(255,255,255,0.08);
}
.hero-machine-label {
  position: absolute; bottom: 20px; right: 20px;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.12em;
  color: rgba(255,255,255,0.6); text-transform: uppercase;
  text-align: right;
}
.hero-machine-center {
  position: relative; z-index: 2;
  width: 40%; aspect-ratio: 1;
  border: 1px solid rgba(255,255,255,0.2);
  display: grid; place-items: center;
  background: rgba(47,167,255,0.08);
}
.hero-machine-center span {
  font-family: var(--f-mono); font-size: 10px; color: rgba(255,255,255,0.5);
  letter-spacing: 0.1em; text-transform: uppercase;
}
.hero-badge {
  position: absolute; top: 40px; right: 40px;
  background: var(--card); padding: 14px 16px;
  border: 1px solid var(--line);
  font-family: var(--f-mono); font-size: 11px;
  letter-spacing: 0.04em;
  display: flex; flex-direction: column; gap: 2px;
  z-index: 3;
}
.hero-badge strong { color: var(--accent-dark); font-size: 13px; }
.hero-spec-card {
  position: absolute; bottom: 40px; left: 40px;
  background: var(--card); padding: 16px 20px;
  border: 1px solid var(--line);
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  z-index: 3;
}
.hero-spec-card > div { min-width: 70px; }
.hero-spec-card .lab { font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; }
.hero-spec-card .val { font-family: var(--f-display); font-weight: 600; font-size: 20px; margin-top: 2px; }
.hero-spec-card .val sup { font-size: 11px; font-weight: 500; color: var(--muted); }

/* ===== Business line tiles ===== */
.lines {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.line-tile {
  background: var(--card);
  padding: 36px 32px 32px;
  position: relative;
  display: flex; flex-direction: column;
  min-height: 340px;
  cursor: pointer;
  transition: background .2s ease;
}
.line-tile:hover { background: var(--soft); }
.line-tile:hover .line-tile-arr { transform: translateX(6px); }
.line-tile-num { font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.08em; }
.line-tile-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: 32px; letter-spacing: -0.02em;
  margin-top: 20px; line-height: 1;
}
.line-tile-desc {
  color: var(--muted); font-size: 14px;
  margin-top: 12px; max-width: 320px;
}
.line-tile-foot {
  margin-top: auto;
  display: flex; justify-content: space-between; align-items: flex-end;
  padding-top: 32px;
}
.line-tile-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.line-tile-tag {
  font-family: var(--f-mono); font-size: 10px; color: var(--muted);
  padding: 4px 8px; border: 1px solid var(--line);
  letter-spacing: 0.04em; text-transform: uppercase;
}
.line-tile-arr {
  font-size: 18px;
  transition: transform .2s ease;
}

/* Variant B — 4 equal tiles */
.lines-4 { grid-template-columns: repeat(4, 1fr); }

/* ===== Trust row ===== */
.trust {
  background: var(--ink);
  color: #fff;
  padding: 56px 0;
}
.trust-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px; background: rgba(255,255,255,0.08);
}
.trust-item {
  background: var(--ink);
  padding: 12px 28px 12px 0;
  display: flex; flex-direction: column; gap: 8px;
}
.trust-item .num {
  font-family: var(--f-mono); font-size: 11px; color: rgba(255,255,255,0.5);
  letter-spacing: 0.08em;
}
.trust-item .lab {
  font-family: var(--f-display); font-size: 22px; font-weight: 500;
  letter-spacing: -0.02em; line-height: 1.1;
}
.trust-item .sub {
  font-family: var(--f-mono); font-size: 11px; color: rgba(255,255,255,0.5);
  letter-spacing: 0.04em; text-transform: uppercase;
  margin-top: auto;
}

/* ===== Product grid ===== */
.products-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.prod-card {
  background: var(--card);
  border: 1px solid var(--line);
  display: flex; flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease;
  cursor: pointer;
}
.prod-card:hover { transform: translateY(-3px); box-shadow: 0 18px 40px -20px rgba(0,0,0,0.15); }
.prod-img {
  aspect-ratio: 4 / 3;
  background: var(--soft);
  position: relative; overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.prod-img .placeholder {
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(45deg, rgba(26,26,26,0.03) 0 2px, transparent 2px 14px);
}
.prod-img .ph-label {
  position: absolute; bottom: 10px; left: 10px;
  font-family: var(--f-mono); font-size: 10px; color: var(--muted);
  letter-spacing: 0.08em; text-transform: uppercase;
}
.prod-img .tag-badge {
  position: absolute; top: 12px; left: 12px;
  background: var(--ink); color: #fff;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.06em;
  padding: 4px 8px; text-transform: uppercase;
}
.prod-img.filament { background: linear-gradient(135deg, #1a1a1a 0%, #2a2a2a 100%); }
.prod-img.filament .placeholder { display: none; }
.prod-img.filament::before {
  content: ''; position: absolute; top: 50%; left: 50%;
  width: 55%; aspect-ratio: 1; border-radius: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle at 50% 30%, #fff 0%, #666 40%, #111 100%);
  box-shadow: inset 0 0 0 12px rgba(255,255,255,0.05), inset 0 0 0 13px rgba(0,0,0,0.3);
}
.prod-img.filament.blue::before { background: radial-gradient(circle at 50% 30%, #7ecaff 0%, #2FA7FF 40%, #0a3a5c 100%); }
.prod-img.filament.red::before { background: radial-gradient(circle at 50% 30%, #ff9a9a 0%, #d44 40%, #3a0a0a 100%); }
.prod-img.filament.green::before { background: radial-gradient(circle at 50% 30%, #9adba3 0%, #3a9a4a 40%, #0a2a1a 100%); }
/* fix 2026-06-04: 有真实产品图时隐藏 filament 占位灰球, 让图正常显示在最上层 */
.prod-img img { position: relative; z-index: 1; width: 100%; height: 100%; object-fit: contain; display: block; background: #fff; }
.prod-img.filament:has(img)::before { display: none; }
.prod-img.printed { background: linear-gradient(150deg, #f0ede5 0%, #d4cfc0 100%); }
.prod-img.printed .placeholder { opacity: 0.5; }

.prod-body { padding: 18px 18px 20px; display: flex; flex-direction: column; gap: 8px; }
.prod-cat { font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; }
.prod-title { font-family: var(--f-display); font-weight: 500; font-size: 16px; line-height: 1.25; letter-spacing: -0.01em; }
.prod-foot { display: flex; justify-content: space-between; align-items: center; margin-top: 6px; }
.prod-price { font-family: var(--f-mono); font-weight: 600; font-size: 15px; }
.prod-price .quote { color: var(--accent-dark); }
.prod-meta { font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; }

/* ===== Content teaser ===== */
.content-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.content-card {
  background: var(--card); border: 1px solid var(--line);
  padding: 28px; display: flex; flex-direction: column; gap: 16px;
  min-height: 260px;
  transition: border-color .2s ease;
}
.content-card:hover { border-color: var(--ink); }
.content-card .eyebrow { margin-bottom: 0; }
.content-card h3 { font-size: 22px; font-weight: 500; line-height: 1.2; }
.content-card .read {
  margin-top: auto;
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--accent-dark);
  display: flex; align-items: center; gap: 6px;
}

/* ===== Testimonials ===== */
.testi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.testi-card {
  background: var(--soft);
  padding: 32px 28px;
  border-left: 2px solid var(--accent);
  display: flex; flex-direction: column; gap: 20px;
}
.testi-card .q {
  font-family: var(--f-display); font-size: 20px; font-weight: 400;
  letter-spacing: -0.01em; line-height: 1.35;
}
.testi-card .q .quote-mark { color: var(--accent); font-family: var(--f-serif); font-style: italic; font-size: 32px; line-height: 0; }
.testi-card .who { display: flex; flex-direction: column; gap: 2px; margin-top: auto; }
.testi-card .who .name { font-weight: 600; font-size: 14px; }
.testi-card .who .role { font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; }

/* ===== Footer ===== */
.footer {
  background: var(--ink); color: #fff;
  padding: 80px 0 32px;
}
.footer-top {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr 1.2fr;
  gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(255,255,255,0.12);
}
.footer-brand .logo { color: #fff; }
.footer-brand .logo-mark { background: #fff; color: var(--ink); }
.footer-slogan {
  font-family: var(--f-serif); font-style: italic;
  font-size: 22px; margin-top: 20px; letter-spacing: -0.01em;
}
.footer-addr { font-family: var(--f-mono); font-size: 12px; color: rgba(255,255,255,0.6); letter-spacing: 0.02em; margin-top: 24px; line-height: 1.7; }
.footer h4 { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.5); margin-bottom: 20px; font-weight: 600; }
.footer ul { list-style: none; display: flex; flex-direction: column; gap: 12px; }
.footer ul a { font-size: 14px; color: rgba(255,255,255,0.85); }
.footer ul a:hover { color: var(--accent); }
.footer-news input {
  width: 100%; padding: 12px 14px;
  background: transparent; border: 1px solid rgba(255,255,255,0.2);
  color: #fff; font-family: var(--f-body); font-size: 14px;
  border-radius: var(--r-sm);
}
.footer-news input::placeholder { color: rgba(255,255,255,0.4); }
.footer-news button {
  margin-top: 10px; width: 100%;
  height: 42px; background: #fff; color: var(--ink);
  font-weight: 600; font-size: 13px;
  border-radius: var(--r-sm);
}
.footer-bot {
  padding-top: 28px;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 20px;
  font-family: var(--f-mono); font-size: 11px; color: rgba(255,255,255,0.5);
  letter-spacing: 0.04em; text-transform: uppercase;
}

/* ===== Variant B — Equal business lines ===== */
.hero-b {
  padding: 120px 0 80px;
  background: var(--card);
  border-bottom: 1px solid var(--line);
}
.hero-b-inner { max-width: 1000px; }
.hero-b-title {
  font-size: clamp(56px, 8vw, 120px);
  font-weight: 600; line-height: 0.95;
  letter-spacing: -0.04em;
  text-transform: uppercase;
}
.hero-b-title .italic { font-family: var(--f-serif); font-style: italic; font-weight: 400; text-transform: none; letter-spacing: -0.02em; }
.hero-b-title .accent { color: var(--accent); }
.hero-b-sub { margin-top: 32px; font-size: 18px; max-width: 640px; color: var(--muted); }
.hero-b-meta { display: flex; gap: 32px; margin-top: 40px; flex-wrap: wrap; }
.hero-b-meta > div { display: flex; flex-direction: column; gap: 4px; }
.hero-b-meta .lab { font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; }
.hero-b-meta .val { font-family: var(--f-display); font-size: 20px; font-weight: 500; }

/* ===== Variant C — Scrolling narrative ===== */
.hero-c {
  min-height: 80vh;
  background: var(--ink); color: #fff;
  display: flex; align-items: center;
  position: relative; overflow: hidden;
  padding: 120px 0;
}
.hero-c::before {
  content: ''; position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(90deg, rgba(255,255,255,0.03) 0 1px, transparent 1px 120px),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.03) 0 1px, transparent 1px 120px);
}
.hero-c-inner { position: relative; z-index: 2; max-width: 1100px; }
.hero-c-eyebrow { color: var(--accent); font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; display: flex; align-items: center; gap: 12px; }
.hero-c-eyebrow::before { content: ''; width: 40px; height: 1px; background: var(--accent); }
.hero-c-title {
  font-size: clamp(64px, 9vw, 140px);
  font-weight: 600; line-height: 0.9;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  margin-top: 32px;
}
.hero-c-title .italic { font-family: var(--f-serif); font-style: italic; font-weight: 400; text-transform: none; letter-spacing: -0.02em; color: rgba(255,255,255,0.8); }
.hero-c-sub {
  margin-top: 40px; max-width: 560px; font-size: 18px;
  color: rgba(255,255,255,0.7);
}
.hero-c-stats { display: grid; grid-template-columns: repeat(4, auto); gap: 48px; margin-top: 56px; }
.hero-c-stats .n { font-family: var(--f-display); font-size: 32px; font-weight: 500; }
.hero-c-stats .l { font-family: var(--f-mono); font-size: 10px; color: rgba(255,255,255,0.5); letter-spacing: 0.1em; text-transform: uppercase; margin-top: 4px; }

/* C narrative sections */
.narr-section {
  padding: 120px 0;
  border-bottom: 1px solid var(--line);
}
.narr-section:nth-child(even) { background: var(--card); }
.narr-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 64px; align-items: center; }
.narr-grid.reverse { grid-template-columns: 1.2fr 1fr; }
.narr-grid.reverse .narr-visual { order: -1; }
.narr-num { font-family: var(--f-mono); font-size: 12px; color: var(--accent-dark); letter-spacing: 0.1em; }
.narr-title { font-size: clamp(36px, 4.5vw, 64px); font-weight: 600; letter-spacing: -0.03em; margin-top: 16px; line-height: 1; }
.narr-title .italic { font-family: var(--f-serif); font-style: italic; font-weight: 400; letter-spacing: -0.015em; }
.narr-body { margin-top: 24px; color: var(--muted); font-size: 15px; max-width: 480px; }
.narr-visual {
  aspect-ratio: 4/3;
  background: var(--soft); border: 1px solid var(--line);
  position: relative; overflow: hidden;
}
.narr-visual .placeholder { position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(26,26,26,0.04) 0 2px, transparent 2px 18px); }
.narr-visual .ph-label { position: absolute; bottom: 16px; left: 16px; font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.06em; text-transform: uppercase; }

/* ===== PDP ===== */
.pdp-tag-switch {
  display: flex; gap: 0;
  border: 1px solid var(--line);
  background: var(--card);
  width: fit-content;
  border-radius: var(--r-sm);
  overflow: hidden;
  margin-bottom: 32px;
}
.pdp-tag-switch button {
  padding: 10px 20px;
  font-family: var(--f-mono); font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--muted);
  border-right: 1px solid var(--line);
  transition: background .15s ease, color .15s ease;
}
.pdp-tag-switch button:last-child { border-right: none; }
.pdp-tag-switch button.active { background: var(--ink); color: #fff; }

.pdp-top {
  display: grid; grid-template-columns: 58% 1fr;
  gap: 64px;
  padding: 48px 0 80px;
  border-bottom: 1px solid var(--line);
}
.pdp-gallery {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 16px;
}
.pdp-thumbs { display: flex; flex-direction: column; gap: 8px; }
.pdp-thumb {
  width: 88px; height: 88px;
  background: var(--soft); border: 1px solid var(--line);
  position: relative;
  cursor: pointer;
  transition: border-color .15s ease;
}
.pdp-thumb.active { border-color: var(--ink); }
.pdp-thumb .placeholder { position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(26,26,26,0.04) 0 2px, transparent 2px 10px); }
.pdp-main-img {
  aspect-ratio: 1; background: var(--soft); border: 1px solid var(--line);
  position: relative; overflow: hidden;
}
.pdp-main-img .placeholder { position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(26,26,26,0.03) 0 2px, transparent 2px 14px); }
.pdp-main-img .ph-label { position: absolute; bottom: 16px; left: 16px; font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; }
.pdp-main-img .tag-large { position: absolute; top: 20px; left: 20px; background: var(--ink); color: #fff; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; padding: 5px 10px; text-transform: uppercase; }

/* Machine main visual */
.pdp-main-img.machine { background: linear-gradient(155deg, #2a2d33 0%, #111318 100%); }
.pdp-main-img.machine .placeholder { display: none; }
.pdp-main-img.machine::before {
  content: ''; position: absolute;
  left: 15%; right: 15%; top: 18%; bottom: 22%;
  background:
    linear-gradient(180deg, rgba(47,167,255,0.12) 0%, transparent 60%),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 8px);
  border: 1px solid rgba(255,255,255,0.08);
}
.pdp-main-img.machine .ph-label { color: rgba(255,255,255,0.5); }

.pdp-main-img.filament { background: linear-gradient(135deg, #1a1a1a 0%, #2a2a2a 100%); }
.pdp-main-img.filament .placeholder { display: none; }
.pdp-main-img.filament::before {
  content: ''; position: absolute; top: 50%; left: 50%;
  width: 55%; aspect-ratio: 1; border-radius: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle at 50% 30%, #1a1a1a 0%, #0a0a0a 50%, #000 100%);
  box-shadow: inset 0 0 0 16px rgba(255,255,255,0.04), inset 0 0 0 17px rgba(255,255,255,0.1);
}
.pdp-main-img.filament .ph-label { color: rgba(255,255,255,0.5); }

.pdp-main-img.printed { background: linear-gradient(155deg, #f0ede5 0%, #d4cfc0 100%); }

.pdp-rail { display: flex; flex-direction: column; gap: 24px; }
.pdp-eyebrow-row { display: flex; justify-content: space-between; align-items: center; }
.pdp-sku { font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.04em; }
.pdp-title { font-size: clamp(32px, 3.5vw, 48px); font-weight: 600; letter-spacing: -0.02em; line-height: 1; }
.pdp-short { color: var(--muted); font-size: 15px; margin-top: -8px; }
.pdp-key-specs {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 20px 0;
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 20px 16px;
}
.pdp-key-specs > div { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.pdp-key-specs > div .lab {
  display: block;
  font-family: var(--f-mono); font-size: 10px; color: var(--muted);
  letter-spacing: 0.08em; text-transform: uppercase;
  white-space: nowrap;
}
.pdp-key-specs > div .val {
  display: block;
  font-family: var(--f-display); font-weight: 600;
  font-size: 16px; letter-spacing: -0.01em; line-height: 1.25;
  color: var(--ink);
  word-break: break-word;
}
@media (max-width: 720px) {
  .pdp-key-specs { grid-template-columns: repeat(2, 1fr); }
}

.pdp-price-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 16px 0;
  border-bottom: 1px solid var(--line);
}
.pdp-price {
  font-family: var(--f-display); font-weight: 600;
  font-size: 36px; letter-spacing: -0.02em;
}
.pdp-price .cur { font-family: var(--f-mono); font-size: 14px; color: var(--muted); font-weight: 500; margin-right: 4px; }
.pdp-price.quote { color: var(--accent-dark); font-size: 24px; }
.pdp-stock { font-family: var(--f-mono); font-size: 11px; color: #1a8a3a; letter-spacing: 0.06em; text-transform: uppercase; display: flex; align-items: center; gap: 6px; }
.pdp-stock::before { content: ''; width: 6px; height: 6px; background: #1a8a3a; border-radius: 50%; }

.pdp-variants { display: flex; flex-direction: column; gap: 18px; }
.pdp-variant-group .lab-row { display: flex; justify-content: space-between; margin-bottom: 10px; }
.pdp-variant-group .lab { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; }
.pdp-variant-group .sel { font-family: var(--f-mono); font-size: 11px; color: var(--muted); }

.swatches { display: flex; gap: 8px; flex-wrap: wrap; }
.swatch {
  width: 36px; height: 36px; border-radius: 50%;
  border: 2px solid var(--line);
  cursor: pointer; position: relative;
  transition: border-color .15s ease;
}
.swatch.active { border-color: var(--ink); }
.swatch.oos { opacity: 0.3; }
.swatch.oos::after { content: ''; position: absolute; top: 50%; left: -4px; right: -4px; height: 1px; background: var(--ink); transform: rotate(-20deg); }

.tile-options { display: flex; gap: 8px; flex-wrap: wrap; }
.tile-opt {
  padding: 12px 16px;
  border: 1px solid var(--line);
  font-family: var(--f-mono); font-size: 12px;
  border-radius: var(--r-sm);
  cursor: pointer;
  transition: border-color .15s ease, background .15s ease;
}
.tile-opt.active { border-color: var(--ink); background: var(--ink); color: #fff; }
.tile-opt.oos { opacity: 0.4; text-decoration: line-through; pointer-events: none; }

.pdp-cta-row { display: flex; gap: 12px; margin-top: 8px; }
.pdp-cta-row .btn { flex: 1; justify-content: center; }

.pdp-mini-trust {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px 20px;
  margin-top: 12px;
  padding-top: 20px; border-top: 1px solid var(--line);
}
.pdp-mini-trust > div { font-size: 13px; display: flex; gap: 8px; align-items: flex-start; }
.pdp-mini-trust .ico { width: 16px; height: 16px; background: var(--ink); display: block; flex-shrink: 0; margin-top: 2px; }

/* Spec table */
.spec-table { background: var(--card); border: 1px solid var(--line); }
.spec-group {
  border-bottom: 1px solid var(--line);
}
.spec-group:last-child { border-bottom: none; }
.spec-group-head {
  padding: 20px 28px;
  display: flex; justify-content: space-between; align-items: center;
  cursor: pointer;
  transition: background .15s ease;
}
.spec-group-head:hover { background: var(--soft); }
.spec-group-head h4 {
  font-family: var(--f-display); font-weight: 600; font-size: 18px;
  letter-spacing: -0.01em;
  display: flex; align-items: center; gap: 14px;
}
.spec-group-head .gnum { font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.06em; font-weight: 500; }
.spec-group-head .chev { transition: transform .2s ease; font-family: var(--f-mono); font-size: 16px; color: var(--muted); }
.spec-group.open .spec-group-head .chev { transform: rotate(45deg); }
.spec-group-body {
  display: none;
  padding: 0 28px 24px;
}
.spec-group.open .spec-group-body { display: block; }
.spec-row {
  display: grid; grid-template-columns: 260px 1fr;
  padding: 12px 0;
  border-bottom: 1px dashed var(--line);
  gap: 16px;
}
.spec-row:last-child { border-bottom: none; }
.spec-row .k { font-family: var(--f-mono); font-size: 12px; color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; }
.spec-row .v { font-family: var(--f-mono); font-size: 13px; font-weight: 500; color: var(--ink); }
.spec-row .v .hi { color: var(--accent-dark); }

/* Downloads */
.downloads-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.dl-card {
  border: 1px solid var(--line); background: var(--card);
  padding: 20px; display: flex; gap: 14px; align-items: flex-start;
  cursor: pointer; transition: border-color .15s ease;
}
.dl-card:hover { border-color: var(--ink); }
.dl-icon { width: 36px; height: 44px; border: 1px solid var(--ink); display: grid; place-items: center; font-family: var(--f-mono); font-size: 9px; font-weight: 700; letter-spacing: 0.04em; flex-shrink: 0; }
.dl-meta { flex: 1; }
.dl-meta h5 { font-family: var(--f-display); font-weight: 500; font-size: 15px; }
.dl-meta p { font-family: var(--f-mono); font-size: 11px; color: var(--muted); margin-top: 4px; letter-spacing: 0.04em; }

/* Compatibility matrix */
.compat-wrap { background: var(--card); border: 1px solid var(--line); padding: 32px; }
.compat-legend { display: flex; gap: 24px; margin-bottom: 24px; flex-wrap: wrap; }
.compat-legend > div { display: flex; align-items: center; gap: 8px; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--muted); }
.compat-dot { width: 14px; height: 14px; border-radius: 50%; }
.compat-dot.full { background: #1a8a3a; }
.compat-dot.partial { background: #e8a82f; }
.compat-dot.none { background: var(--line); border: 1px solid var(--muted); }
.compat-table { width: 100%; border-collapse: collapse; }
.compat-table th, .compat-table td { padding: 14px 16px; text-align: left; border-bottom: 1px solid var(--line); }
.compat-table th {
  font-family: var(--f-mono); font-size: 10px; color: var(--muted);
  letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600;
}
.compat-table td .machine-name { font-family: var(--f-display); font-weight: 500; font-size: 15px; }
.compat-table td .brand-name { font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.04em; margin-top: 2px; }
.compat-table .dml-row { background: var(--soft); }
.compat-status { display: flex; align-items: center; gap: 10px; }
.compat-status .lab { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--muted); }

/* Material properties bars */
.mat-props { display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; background: var(--card); border: 1px solid var(--line); padding: 32px; }
.mat-prop { display: flex; flex-direction: column; gap: 8px; }
.mat-prop .row1 { display: flex; justify-content: space-between; align-items: baseline; }
.mat-prop .name { font-family: var(--f-display); font-weight: 500; font-size: 15px; }
.mat-prop .val { font-family: var(--f-mono); font-size: 12px; color: var(--accent-dark); font-weight: 600; }
.mat-prop .bar-track { height: 6px; background: var(--line); position: relative; }
.mat-prop .bar-fill { position: absolute; top: 0; left: 0; bottom: 0; background: var(--ink); }
.mat-prop .scale { display: flex; justify-content: space-between; font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.04em; margin-top: 2px; }

/* Print parameters */
.params-table { background: var(--card); border: 1px solid var(--line); padding: 24px 32px; }
.params-table h4 { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); font-weight: 600; margin-bottom: 16px; }
.params-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
.param { display: flex; flex-direction: column; gap: 6px; }
.param .p-lab { font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.06em; text-transform: uppercase; }
.param .p-val { font-family: var(--f-display); font-weight: 500; font-size: 24px; letter-spacing: -0.02em; }
.param .p-val .unit { font-family: var(--f-mono); font-size: 12px; color: var(--muted); font-weight: 500; margin-left: 2px; }

/* ROI / block */
.roi-block {
  background: var(--ink); color: #fff;
  padding: 48px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px;
  align-items: center;
}
.roi-block h3 { font-size: 32px; letter-spacing: -0.02em; }
.roi-block h3 .italic { font-family: var(--f-serif); font-style: italic; font-weight: 400; }
.roi-block p { color: rgba(255,255,255,0.7); font-size: 15px; margin-top: 16px; max-width: 420px; }
.roi-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.roi-stats > div .n { font-family: var(--f-display); font-size: 36px; font-weight: 500; letter-spacing: -0.02em; color: var(--accent); }
.roi-stats > div .l { font-family: var(--f-mono); font-size: 11px; color: rgba(255,255,255,0.6); letter-spacing: 0.06em; text-transform: uppercase; margin-top: 6px; }

/* FAQ */
.faq { max-width: 900px; }
.faq-item { border-bottom: 1px solid var(--line); padding: 20px 0; cursor: pointer; }
.faq-item:first-child { border-top: 1px solid var(--line); }
.faq-q { display: flex; justify-content: space-between; align-items: center; gap: 20px; }
.faq-q h4 { font-family: var(--f-display); font-weight: 500; font-size: 18px; letter-spacing: -0.01em; }
.faq-q .plus { font-family: var(--f-mono); font-size: 18px; color: var(--muted); transition: transform .2s ease; }
.faq-item.open .plus { transform: rotate(45deg); color: var(--ink); }
.faq-a { display: none; padding-top: 14px; color: var(--muted); font-size: 14px; max-width: 700px; }
.faq-item.open .faq-a { display: block; }

/* ===== Collection ===== */
.coll-head {
  padding: 72px 0 56px;
  border-bottom: 1px solid var(--line);
  background: var(--card);
}
.coll-head .eyebrow-row {
  display: flex; gap: 8px; font-family: var(--f-mono); font-size: 11px;
  color: var(--muted); letter-spacing: 0.06em; text-transform: uppercase;
}
.coll-title { font-size: clamp(48px, 6vw, 84px); font-weight: 600; letter-spacing: -0.03em; line-height: 0.95; margin-top: 24px; text-transform: uppercase; }
.coll-title .italic { font-family: var(--f-serif); font-style: italic; font-weight: 400; text-transform: none; letter-spacing: -0.02em; }
.coll-intro { margin-top: 24px; max-width: 640px; color: var(--muted); font-size: 16px; }
.coll-filter-chips { display: flex; gap: 8px; margin-top: 32px; flex-wrap: wrap; }
.chip {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
  padding: 8px 14px; border: 1px solid var(--line);
  background: transparent; color: var(--ink);
  text-transform: uppercase; cursor: pointer;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}
button.chip { line-height: 1; }
.chip.active { background: var(--ink); color: #fff; border-color: var(--ink); }
.chip:hover:not(.active) { border-color: var(--ink); }

.coll-body {
  display: grid; grid-template-columns: 240px 1fr;
  gap: 48px; padding: 48px 0;
}
.coll-filters h4 { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); margin-bottom: 12px; font-weight: 600; margin-top: 24px; }
.coll-filters h4:first-child { margin-top: 0; }
.coll-filters ul { list-style: none; }
.coll-filters li { padding: 6px 0; display: flex; justify-content: space-between; font-size: 13px; cursor: pointer; color: var(--ink); }
.coll-filters li:hover { color: var(--accent-dark); }
.coll-filters li .cnt { font-family: var(--f-mono); font-size: 11px; color: var(--muted); }
.coll-filters li.active { color: var(--accent-dark); font-weight: 600; }

.coll-results-head {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 20px; border-bottom: 1px solid var(--line); margin-bottom: 24px;
}
.coll-results-head .count { font-family: var(--f-mono); font-size: 12px; color: var(--muted); letter-spacing: 0.04em; }
.coll-sort { display: flex; align-items: center; gap: 10px; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; }
.coll-sort select { font-family: var(--f-mono); font-size: 11px; background: var(--card); border: 1px solid var(--line); padding: 6px 10px; letter-spacing: 0.04em; text-transform: uppercase; border-radius: var(--r-sm); }

.coll-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.coll-pag {
  margin-top: 48px; display: flex; justify-content: center; gap: 6px;
}
.coll-pag button {
  width: 36px; height: 36px; border: 1px solid var(--line);
  font-family: var(--f-mono); font-size: 12px; font-weight: 500;
  border-radius: var(--r-sm);
}
.coll-pag button.active { background: var(--ink); color: #fff; border-color: var(--ink); }

/* ===== POD Custom ===== */
.pod-hero {
  padding: 100px 0 80px;
  background: var(--card);
  border-bottom: 1px solid var(--line);
}
.pod-hero-inner { display: grid; grid-template-columns: 1.3fr 1fr; gap: 56px; align-items: end; }
.pod-hero-title {
  font-size: clamp(56px, 7.5vw, 112px);
  font-weight: 600; letter-spacing: -0.035em; line-height: 0.92;
  text-transform: uppercase;
}
.pod-hero-title .italic { font-family: var(--f-serif); font-style: italic; font-weight: 400; text-transform: none; letter-spacing: -0.02em; }
.pod-hero-title .accent { color: var(--accent); }
.pod-hero-sub { font-size: 17px; color: var(--muted); max-width: 420px; }
.pod-hero-sub + .btn { margin-top: 24px; }

.pod-steps {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--line);
  column-gap: 1px;
}
.pod-step {
  background: var(--card); padding: 40px 32px;
  display: flex; flex-direction: column; gap: 12px;
  min-height: 220px;
}
.pod-step .n { font-family: var(--f-mono); font-size: 12px; color: var(--accent-dark); letter-spacing: 0.08em; font-weight: 600; }
.pod-step h3 { font-family: var(--f-display); font-size: 26px; font-weight: 600; letter-spacing: -0.02em; }
.pod-step p { color: var(--muted); font-size: 14px; max-width: 280px; }

/* Upload UI */
.upload-widget {
  background: var(--card); border: 1px solid var(--line);
  display: grid; grid-template-columns: 1.3fr 1fr;
  min-height: 520px;
}
.upload-left {
  padding: 48px;
  display: flex; flex-direction: column;
  border-right: 1px solid var(--line);
}
.upload-dropzone {
  flex: 1;
  border: 2px dashed var(--line);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 20px; padding: 48px;
  text-align: center;
  transition: border-color .2s ease, background .2s ease;
  cursor: pointer;
  position: relative;
  background: var(--soft);
}
.upload-dropzone:hover, .upload-dropzone.drag { border-color: var(--accent); background: rgba(47,167,255,0.04); }
.upload-icon {
  width: 56px; height: 56px;
  border: 2px solid var(--ink);
  position: relative;
}
.upload-icon::before, .upload-icon::after {
  content: ''; position: absolute; background: var(--ink);
}
.upload-icon::before { top: 50%; left: 16px; right: 16px; height: 2px; transform: translateY(-50%); }
.upload-icon::after { left: 50%; top: 16px; bottom: 16px; width: 2px; transform: translateX(-50%); }

.upload-dropzone h3 { font-family: var(--f-display); font-size: 22px; font-weight: 500; letter-spacing: -0.01em; }
.upload-dropzone .formats { font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; }
.upload-dropzone .br { font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.06em; }
.upload-dropzone .browse { color: var(--accent-dark); text-decoration: underline; cursor: pointer; }
.upload-limits {
  margin-top: 20px; display: flex; gap: 24px;
  font-family: var(--f-mono); font-size: 11px; color: var(--muted);
  letter-spacing: 0.04em; text-transform: uppercase;
}
.upload-limits span { display: flex; align-items: center; gap: 6px; }
.upload-limits span::before { content: ''; width: 6px; height: 6px; background: var(--accent); display: inline-block; }

.upload-right { padding: 48px 40px; background: var(--soft); display: flex; flex-direction: column; gap: 28px; }
.upload-right h4 { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); font-weight: 600; }
.up-field { display: flex; flex-direction: column; gap: 10px; }
.up-field .lab { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink); font-weight: 600; }
.up-field .mat-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.up-field .mat-opt {
  padding: 10px 8px; border: 1px solid var(--line); background: var(--card);
  font-family: var(--f-mono); font-size: 11px; text-align: center;
  cursor: pointer; letter-spacing: 0.04em;
  border-radius: var(--r-sm);
}
.up-field .mat-opt.active { background: var(--ink); color: #fff; border-color: var(--ink); }
.up-field .qty-row { display: flex; align-items: center; gap: 0; }
.up-field .qty-row button {
  width: 40px; height: 40px; border: 1px solid var(--line); background: var(--card);
  font-family: var(--f-mono); font-size: 16px;
}
.up-field .qty-row input {
  width: 60px; height: 40px; border: 1px solid var(--line); border-left: none; border-right: none;
  text-align: center; font-family: var(--f-mono); font-size: 14px; background: var(--card);
}
.upload-estimate {
  margin-top: auto;
  padding: 20px; background: var(--ink); color: #fff;
  display: flex; flex-direction: column; gap: 10px;
}
.upload-estimate .lab { font-family: var(--f-mono); font-size: 10px; color: rgba(255,255,255,0.5); letter-spacing: 0.1em; text-transform: uppercase; }
.upload-estimate .val { font-family: var(--f-display); font-weight: 600; font-size: 32px; letter-spacing: -0.02em; }
.upload-estimate .val .cur { font-family: var(--f-mono); font-size: 14px; color: rgba(255,255,255,0.5); margin-right: 4px; font-weight: 500; }
.upload-estimate .range { font-family: var(--f-mono); font-size: 11px; color: rgba(255,255,255,0.6); letter-spacing: 0.04em; }
.upload-estimate .btn-accent { align-self: stretch; justify-content: center; margin-top: 8px; }

/* Material selector */
.mat-selector-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.mat-sel-card {
  background: var(--card); padding: 32px 28px;
  display: flex; flex-direction: column; gap: 14px;
  min-height: 320px;
  cursor: pointer; transition: background .15s ease;
}
.mat-sel-card:hover { background: var(--soft); }
.mat-sel-card .name { font-family: var(--f-display); font-size: 24px; font-weight: 600; letter-spacing: -0.02em; }
.mat-sel-card .price { font-family: var(--f-mono); font-size: 13px; color: var(--accent-dark); letter-spacing: 0.04em; }
.mat-sel-card .props { display: flex; flex-direction: column; gap: 6px; margin-top: 8px; padding-top: 14px; border-top: 1px solid var(--line); }
.mat-sel-card .props > div { display: flex; justify-content: space-between; font-family: var(--f-mono); font-size: 11px; }
.mat-sel-card .props .k { color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; }
.mat-sel-card .props .v { font-weight: 600; color: var(--ink); }
.mat-sel-card .use { color: var(--muted); font-size: 13px; margin-top: auto; }

/* POD quote examples */
.pod-eg-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.pod-eg-card {
  background: var(--card); border: 1px solid var(--line);
  overflow: hidden;
}
.pod-eg-img { aspect-ratio: 1; background: var(--soft); position: relative; }
.pod-eg-img .placeholder { position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(26,26,26,0.04) 0 2px, transparent 2px 12px); }
.pod-eg-img .ph-label { position: absolute; bottom: 10px; left: 10px; font-family: var(--f-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; }
.pod-eg-body { padding: 16px; display: flex; justify-content: space-between; align-items: center; }
.pod-eg-body .t { font-size: 13px; font-weight: 500; }
.pod-eg-body .p { font-family: var(--f-mono); font-size: 12px; color: var(--accent-dark); font-weight: 600; }

/* ===== Quote Modal ===== */
.modal-backdrop {
  position: fixed; inset: 0; background: rgba(26,26,26,0.7);
  display: none; align-items: flex-start; justify-content: center;
  z-index: 100; padding: 40px 20px; overflow-y: auto;
}
.modal-backdrop.open { display: flex; }
.modal {
  background: var(--card); max-width: 760px; width: 100%;
  border: 1px solid var(--line);
  display: flex; flex-direction: column;
  max-height: 90vh;
}
.modal-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 24px 32px; border-bottom: 1px solid var(--line);
}
.modal-head .mtitle { font-family: var(--f-display); font-weight: 600; font-size: 22px; letter-spacing: -0.02em; }
.modal-head .mclose { font-family: var(--f-mono); font-size: 20px; width: 32px; height: 32px; display: grid; place-items: center; }
.modal-steps {
  display: flex; gap: 0; padding: 20px 32px; border-bottom: 1px solid var(--line);
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase;
}
.modal-steps > div { flex: 1; display: flex; align-items: center; gap: 10px; color: var(--muted); }
.modal-steps > div.active { color: var(--ink); font-weight: 600; }
.modal-steps > div.done { color: var(--accent-dark); }
.modal-steps > div .snum {
  width: 22px; height: 22px; border: 1px solid currentColor; border-radius: 50%;
  display: grid; place-items: center; font-size: 10px;
}
.modal-body { padding: 32px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px 24px; overflow-y: auto; }
.modal-body.full { grid-template-columns: 1fr; }
.mfield { display: flex; flex-direction: column; gap: 8px; }
.mfield.full-w { grid-column: 1 / -1; }
.mfield .lab { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); font-weight: 600; }
.mfield input, .mfield select, .mfield textarea {
  padding: 12px 14px; border: 1px solid var(--line); font-family: var(--f-body); font-size: 14px;
  background: var(--card); border-radius: var(--r-sm); color: var(--ink);
}
.mfield textarea { resize: vertical; min-height: 100px; }
.mfield input:focus, .mfield select:focus, .mfield textarea:focus { outline: none; border-color: var(--ink); }
.modal-foot {
  padding: 20px 32px; border-top: 1px solid var(--line);
  display: flex; justify-content: space-between; gap: 12px;
}

/* ===== Tweaks panel ===== */
.tweaks-panel {
  position: fixed; right: 20px; bottom: 20px; z-index: 90;
  background: var(--card); border: 1px solid var(--ink);
  width: 280px;
  font-family: var(--f-body); font-size: 13px;
  box-shadow: 0 20px 40px -20px rgba(0,0,0,0.25);
  display: none;
}
.tweaks-panel.open { display: block; }
.tweaks-head {
  padding: 14px 16px; border-bottom: 1px solid var(--line);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600;
}
.tweaks-body { padding: 16px; display: flex; flex-direction: column; gap: 18px; }
.tweaks-group .tglab { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); font-weight: 600; margin-bottom: 8px; }
.tweaks-opts { display: flex; flex-direction: column; gap: 4px; }
.tweaks-opts button {
  text-align: left; padding: 8px 10px; border: 1px solid var(--line);
  font-size: 12px; border-radius: var(--r-sm);
  transition: background .15s ease, border-color .15s ease;
}
.tweaks-opts button.active { background: var(--ink); color: #fff; border-color: var(--ink); }
.tweaks-opts button:hover:not(.active) { border-color: var(--ink); }

/* Page switcher pill */
.page-switcher {
  position: fixed; left: 50%; bottom: 20px; transform: translateX(-50%);
  background: var(--ink); padding: 6px;
  display: flex; gap: 2px;
  border-radius: 4px;
  z-index: 80;
  box-shadow: 0 10px 30px -10px rgba(0,0,0,0.3);
}
.page-switcher button {
  padding: 8px 14px; color: rgba(255,255,255,0.6);
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600;
  border-radius: var(--r-sm);
  transition: background .15s ease, color .15s ease;
}
.page-switcher button.active { background: #fff; color: var(--ink); }
.page-switcher button:hover:not(.active) { color: #fff; }

/* Page containers */
.page { display: none; }
.page.active { display: block; }
.variant { display: none; }
.variant.active { display: block; }

/* Responsive */
@media (max-width: 860px) {
  .hero-slide { grid-template-columns: 1fr; }
  .hero-slide-visual { min-height: 320px; order: -1; }
  .hero-slideshow { height: auto; min-height: 0; max-height: none; }
  .hero-slide-text { padding: 48px var(--pad-x); }
  .hero-controls { position: static; padding: 20px var(--pad-x); background: var(--card); border-top: 1px solid var(--line); }
  .ecosystem-timeline { grid-template-columns: repeat(2, 1fr); }
  .ecosystem-stage { aspect-ratio: 16 / 10; }
  .eco-overlay { left: 24px; right: 24px; bottom: 24px; }
  .trust-v2-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .trust-v2-item { border-right: none; padding-right: 0; }
  .carousel-card { flex-basis: calc(50% - 10px); }
  .hero-a-grid { grid-template-columns: 1fr; min-height: auto; }
  .hero-a-left { border-right: none; border-bottom: 1px solid var(--line); padding: 48px var(--pad-x); }
  .hero-a-right { min-height: 500px; }
  .lines { grid-template-columns: repeat(2, 1fr); }
  .lines-4 { grid-template-columns: repeat(2, 1fr); }
  .products-grid { grid-template-columns: repeat(2, 1fr); }
  .coll-grid { grid-template-columns: repeat(2, 1fr); }
  .pod-steps { grid-template-columns: repeat(2, 1fr); }
  .content-grid, .testi-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 32px; }
  .trust-grid { grid-template-columns: repeat(2, 1fr); }
  .pdp-top { grid-template-columns: 1fr; }
  .coll-body { grid-template-columns: 1fr; }
  .upload-widget { grid-template-columns: 1fr; }
  .roi-block { grid-template-columns: 1fr; padding: 32px; }
  .narr-grid, .narr-grid.reverse { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .nav-links { display: none; }
  .section-head { flex-direction: column; align-items: flex-start; }
  .products-grid, .coll-grid, .lines, .lines-4, .content-grid, .testi-grid, .pod-steps, .trust-grid, .downloads-grid, .footer-top, .pod-eg-grid { grid-template-columns: 1fr; }
  .hero-a-body { grid-template-columns: 1fr; }
  .modal-body { grid-template-columns: 1fr; }
  .params-grid, .mat-props { grid-template-columns: 1fr; }
}


/* ===== v2 TRUST ROW ===== */
.v2-trust {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--card);
}
.v2-trust-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 40px var(--pad-x);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
}
.v2-trust-item {
  display: flex; gap: 16px; align-items: flex-start;
  padding-right: 24px;
  border-right: 1px solid var(--line);
}
.v2-trust-item:last-child { border-right: none; }
.v2-trust-num {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  color: var(--accent);
  letter-spacing: 0.1em;
  padding-top: 2px;
}
.v2-trust-lab {
  font-family: var(--f-display); font-weight: 600;
  font-size: 15px; color: var(--ink);
  letter-spacing: -0.01em;
  margin-bottom: 4px;
}
.v2-trust-sub {
  font-size: 12px; color: var(--muted);
  line-height: 1.5;
}

/* ===== v2 LIVE FROM FLOOR ===== */
.v2-floor {
  padding: 96px 0;
  border-bottom: 1px solid var(--line);
}
.v2-floor-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.v2-floor-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 32px; flex-wrap: wrap;
  margin-bottom: 48px;
}
.v2-floor-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(36px, 4vw, 56px);
  letter-spacing: -0.03em; line-height: 1;
  margin-top: 12px;
  max-width: 720px;
}
.v2-floor-title .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
  letter-spacing: -0.02em;
}
.v2-floor-status {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em;
  color: var(--ink);
  padding: 10px 16px;
  background: var(--card);
  border: 1px solid var(--line);
}
.v2-pulse {
  width: 8px; height: 8px;
  background: #10b981;
  border-radius: 50%;
  animation: v2pulse 1.6s ease-in-out infinite;
  box-shadow: 0 0 0 0 rgba(16,185,129,0.6);
}
@keyframes v2pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(16,185,129,0.6); }
  50%      { box-shadow: 0 0 0 8px rgba(16,185,129,0); }
}
.v2-floor-status-lab { color: var(--ink); }
.v2-floor-status-sep { color: var(--line); }
.v2-floor-status-time { color: var(--muted); font-weight: 500; }

.v2-floor-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 16px;
}
.v2-floor-card {
  background: var(--card);
  border: 1px solid var(--line);
  padding: 20px;
  display: flex; flex-direction: column; gap: 16px;
  position: relative;
}
.v2-floor-tag {
  font-family: var(--f-mono);
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.12em;
  color: var(--muted);
}
.v2-floor-img {
  background: #e8e5df; /* warm placeholder */
  color: var(--muted);
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 10px;
  aspect-ratio: 16 / 9;
  letter-spacing: 0.08em;
  flex: 1;
  position: relative;
}
.v2-floor-img.sm { aspect-ratio: 4 / 3; }
.v2-floor-img::after {
  content: '';
  position: absolute;
  inset: 12px;
  border: 1px dashed var(--line);
  pointer-events: none;
}
.v2-floor-card.big .v2-floor-img {
  background: #1a1a1a;
  color: #666;
}
.v2-floor-card.big .v2-floor-img::after {
  border-color: rgba(255,255,255,0.1);
}
.v2-floor-meta {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  padding-top: 4px;
  border-top: 1px solid var(--line);
  padding-top: 16px;
}
.v2-floor-meta.two { grid-template-columns: repeat(2, 1fr); }
.v2-floor-lab {
  display: block;
  font-family: var(--f-mono); font-size: 10px;
  color: var(--muted); letter-spacing: 0.1em;
  margin-bottom: 4px; text-transform: uppercase;
}
.v2-floor-val {
  display: block;
  font-family: var(--f-mono); font-size: 16px;
  font-weight: 600; color: var(--ink);
  letter-spacing: -0.01em;
}
.v2-floor-bar {
  height: 4px; background: var(--line);
  position: relative; overflow: hidden;
}
.v2-floor-bar-fill {
  height: 100%; background: var(--accent);
  transition: width .6s ease;
}

/* ===== v2 FEATURED with TABS ===== */
.v2-featured {
  padding: 96px 0;
  background: var(--card);
  border-bottom: 1px solid var(--line);
}
.v2-featured-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.v2-featured-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 32px; flex-wrap: wrap;
  margin-bottom: 48px;
}
.v2-featured-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(36px, 4vw, 56px);
  letter-spacing: -0.03em; line-height: 1;
  margin-top: 12px;
}
.v2-featured-title .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
}
.v2-featured-tabs {
  display: inline-flex;
  border: 1px solid var(--line);
  background: var(--bg);
  padding: 3px;
}
.v2-featured-tabs button {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 10px 18px;
  background: transparent;
  color: var(--muted);
  border: none; cursor: pointer;
  transition: all .15s ease;
}
.v2-featured-tabs button:hover { color: var(--ink); }
.v2-featured-tabs button.active {
  background: var(--ink); color: #fff;
}
.v2-featured-foot {
  margin-top: 32px;
  display: flex; justify-content: center;
  padding-top: 24px;
  border-top: 1px solid var(--line);
}

/* ===== v2 STORIES ===== */
.v2-stories {
  padding: 96px 0;
  border-bottom: 1px solid var(--line);
}
.v2-stories-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.v2-stories-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 32px; flex-wrap: wrap;
  margin-bottom: 48px;
}
.v2-stories-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(36px, 4vw, 56px);
  letter-spacing: -0.03em; line-height: 1;
  margin-top: 12px;
}
.v2-stories-title .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
}
.v2-stories-sub {
  max-width: 420px;
  font-size: 14px; color: var(--muted);
  line-height: 1.6;
}
.v2-stories-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 24px;
}
.v2-story-card {
  display: block;
  background: var(--card);
  border: 1px solid var(--line);
  text-decoration: none; color: inherit;
  transition: border-color .2s ease, transform .2s ease;
}
.v2-story-card:hover { border-color: var(--ink); }
.v2-story-card.hero-card {
  display: grid;
  grid-template-rows: 1fr auto;
}
.v2-story-img {
  aspect-ratio: 4 / 3;
  background: #e8e5df;
  color: var(--muted);
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 10px;
  letter-spacing: 0.08em;
  position: relative;
}
.v2-story-img.sm { aspect-ratio: 16 / 10; }
.v2-story-img::after {
  content: ''; position: absolute; inset: 12px;
  border: 1px dashed var(--line);
}
.v2-story-body {
  padding: 28px;
  display: flex; flex-direction: column; gap: 12px;
}
.v2-story-meta {
  font-family: var(--f-mono);
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--accent);
}
.v2-story-card h3 {
  font-family: var(--f-display); font-weight: 600;
  font-size: 22px; line-height: 1.25;
  letter-spacing: -0.02em;
  color: var(--ink);
  text-wrap: pretty;
}
.v2-story-card.hero-card h3 { font-size: 28px; }
.v2-story-desc {
  font-size: 14px; color: var(--muted); line-height: 1.6;
}
.v2-story-read {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink);
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 4px;
}
.v2-stories-col {
  display: grid; gap: 24px;
  grid-template-rows: 1fr 1fr;
}

/* ===== v2 HANDCRAFT ===== */
.v2-handcraft {
  padding: 96px 0;
  background: var(--card);
  border-bottom: 1px solid var(--line);
}
.v2-handcraft-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 64px;
  align-items: center;
}
.v2-handcraft-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(36px, 4vw, 56px);
  letter-spacing: -0.03em; line-height: 1;
  margin-top: 12px;
  margin-bottom: 24px;
}
.v2-handcraft-title .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
}
.v2-handcraft-body {
  font-size: 15px; color: var(--muted);
  line-height: 1.65; max-width: 440px;
  margin-bottom: 32px;
}
.v2-handcraft-meta {
  display: flex; gap: 40px;
  border-top: 1px solid var(--line);
  padding-top: 24px;
}
.v2-handcraft-meta .lab {
  display: block;
  font-family: var(--f-mono); font-size: 10px;
  color: var(--muted); letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.v2-handcraft-meta .val {
  display: block;
  font-family: var(--f-display); font-weight: 600;
  font-size: 24px; color: var(--ink);
  letter-spacing: -0.02em;
}
.v2-handcraft-gallery {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 220px 220px;
  gap: 12px;
}
.v2-handcraft-tile {
  background: #e8e5df;
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 10px;
  color: var(--muted); letter-spacing: 0.08em;
  position: relative;
  transition: transform .3s ease;
}
.v2-handcraft-tile::after {
  content: ''; position: absolute; inset: 10px;
  border: 1px dashed var(--line);
}
.v2-handcraft-tile:hover { transform: translateY(-2px); }
.v2-handcraft-tile.a { background: #ede8df; }
.v2-handcraft-tile.b { background: var(--ink); color: #555; }
.v2-handcraft-tile.b::after { border-color: rgba(255,255,255,0.08); }
.v2-handcraft-tile.c { background: #f0e4d3; }
.v2-handcraft-tile.d { background: #dfd9cc; }

/* ===== v2 NEWSLETTER ===== */
.v2-news {
  background: var(--ink);
  color: #fff;
  padding: 96px 0;
}
.v2-news-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 80px;
  align-items: center;
}
.v2-news-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(36px, 4vw, 56px);
  letter-spacing: -0.03em; line-height: 1;
  margin-top: 12px;
  margin-bottom: 20px;
  color: #fff;
}
.v2-news-title .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
  color: var(--accent);
}
.v2-news-desc {
  font-size: 15px; color: rgba(255,255,255,0.65);
  line-height: 1.65; max-width: 460px;
}
.v2-news-form {
  display: flex; flex-direction: column; gap: 12px;
}
.v2-news-lab {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}
.v2-news-input {
  display: flex; gap: 0;
  border: 1px solid rgba(255,255,255,0.2);
  background: rgba(255,255,255,0.04);
}
.v2-news-input input {
  flex: 1;
  background: transparent;
  border: none;
  color: #fff;
  padding: 18px 20px;
  font-family: var(--f-body);
  font-size: 14px;
  outline: none;
}
.v2-news-input input::placeholder { color: rgba(255,255,255,0.3); }
.v2-news-input button {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--accent);
  color: #fff;
  border: none; cursor: pointer;
  padding: 0 28px;
  display: flex; align-items: center; gap: 8px;
  transition: background .15s ease;
}
.v2-news-input button:hover { background: var(--accent-dark); }
.v2-news-foot {
  font-family: var(--f-mono);
  font-size: 10px; color: rgba(255,255,255,0.4);
  letter-spacing: 0.08em; text-transform: uppercase;
  margin-top: 4px;
}

@media (max-width: 960px) {
  .v2-trust-inner { grid-template-columns: 1fr 1fr; }
  .v2-trust-item:nth-child(2) { border-right: none; }
  .v2-floor-grid { grid-template-columns: 1fr; }
  .v2-stories-grid { grid-template-columns: 1fr; }
  .v2-stories-col { grid-template-rows: auto auto; }
  .v2-handcraft-inner { grid-template-columns: 1fr; gap: 48px; }
  .v2-news-inner { grid-template-columns: 1fr; gap: 48px; }
  .v2-handcraft-meta { gap: 24px; flex-wrap: wrap; }
}


/* ===== Hero slide CTAs (multiple buttons) ===== */
.hero-slide-ctas {
  margin-top: 36px;
  display: flex; gap: 12px; flex-wrap: wrap;
}

/* ===== TIMELINE · continuous banner ===== */
.tlb {
  padding: 112px 0 112px;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
}
.tlb-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.tlb-head {
  text-align: center;
  margin-bottom: 56px;
  max-width: 720px;
  margin-left: auto; margin-right: auto;
}
.tlb-head .eyebrow {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  display: block;
}
.tlb-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(40px, 4.5vw, 64px);
  letter-spacing: -0.03em; line-height: 1;
  margin-top: 16px;
}
.tlb-title .italic {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
}

/* The banner itself — a single continuous strip */
.tlb-banner {
  position: relative;
  height: clamp(500px, 58vw, 700px);
  overflow: hidden;
  background: #0b0d11;
  isolation: isolate;
}
.tlb-video-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 15% 40%, rgba(217,85,43,0.22) 0%, transparent 42%),
    radial-gradient(ellipse at 42% 60%, rgba(47,167,255,0.14) 0%, transparent 40%),
    radial-gradient(ellipse at 72% 35%, rgba(217,85,43,0.10) 0%, transparent 40%),
    linear-gradient(180deg, #14171c 0%, #0b0d11 100%);
  z-index: 0;
}
.tlb-video-bg::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(0deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 48px),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 48px);
  pointer-events: none;
}
.tlb-video-tag {
  position: absolute;
  top: 20px; left: 20px;
  z-index: 3;
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  padding: 8px 12px;
  background: rgba(0,0,0,0.5);
  border: 1px solid rgba(255,255,255,0.1);
}
.tlb-video-label {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  font-family: var(--f-mono);
  font-size: 12px; letter-spacing: 0.08em;
  color: rgba(255,255,255,0.25);
  z-index: 1;
  white-space: nowrap;
}

/* Segments overlay — 4 equal hover zones */
.tlb-segments {
  position: absolute; inset: 0;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
}
.tlb-seg {
  position: relative;
  cursor: pointer;
  display: flex;
  align-items: flex-end;
  padding: 40px 32px;
  border-right: 1px solid rgba(255,255,255,0.08);
  background: rgba(0,0,0,0.35);
  transition: background .35s ease;
}
.tlb-seg:last-child { border-right: none; }

/* Default state: all dimmed EQUALLY — a medium overlay across the whole banner */
.tlb-seg::before {
  content: '';
  position: absolute; inset: 0;
  background: rgba(11,13,17,0);
  transition: background .35s ease;
  pointer-events: none;
}

/* Hover the banner: dim non-hovered segments; brighten hovered */
.tlb-banner:hover .tlb-seg::before {
  background: rgba(11,13,17,0.55);
}
.tlb-banner:hover .tlb-seg:hover::before {
  background: rgba(11,13,17,0);
}

/* Segment content */
.tlb-seg-inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 260px;
  transition: transform .35s ease;
}
.tlb-banner:hover .tlb-seg:hover .tlb-seg-inner {
  transform: translateY(-4px);
}
.tlb-num {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em;
  color: rgba(255,255,255,0.45);
  transition: color .35s ease;
}
.tlb-seg:hover .tlb-num { color: var(--accent); }

.tlb-seg-title {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 32px;
  letter-spacing: -0.02em;
  color: #fff;
  margin: 0;
  line-height: 1.05;
}
.tlb-seg-desc {
  font-size: 13px;
  line-height: 1.5;
  color: rgba(255,255,255,0.55);
  margin: 4px 0 0;
  /* hidden by default, revealed on hover */
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height .4s ease, opacity .3s ease, margin .4s ease;
}
.tlb-seg-link {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: #fff;
  margin-top: 0;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .3s ease, transform .3s ease;
}
.tlb-seg:hover .tlb-seg-desc {
  max-height: 80px;
  opacity: 1;
  margin-top: 4px;
}
.tlb-seg:hover .tlb-seg-link {
  opacity: 1;
  transform: translateY(0);
  margin-top: 14px;
}

/* Accent top bar on hovered segment */
.tlb-seg::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform .4s ease;
  z-index: 3;
}
.tlb-seg:hover::after { transform: scaleX(1); }

@media (max-width: 860px) {
  .tlb-segments { grid-template-columns: 1fr 1fr; }
  .tlb-seg { border-bottom: 1px solid rgba(255,255,255,0.08); }
  .tlb-seg:nth-child(2) { border-right: none; }
  .tlb-banner { height: auto; aspect-ratio: 1; }
}

/* ===== PARTNERS strip ===== */
.partners {
  padding: 96px 0;
  background: var(--card);
  border-bottom: 1px solid var(--line);
}
.partner-strip {
  margin-top: 48px;
  overflow: hidden;
  position: relative;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
}
.partner-track {
  display: flex;
  gap: 24px;
  width: max-content;
  animation: partnerScroll 40s linear infinite;
}
@keyframes partnerScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.partner-logo {
  flex: 0 0 180px;
  height: 88px;
  border: 1px solid var(--line);
  background: var(--bg);
  display: grid; place-items: center;
  font-family: var(--f-mono);
  font-size: 10px; letter-spacing: 0.1em;
  color: var(--muted);
  text-transform: uppercase;
}

@media (max-width: 860px) {
  .timeline-stages {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .tl-connector { display: none; }
  .hero-slide { grid-template-columns: 1fr; }
  .hero-slide-visual { min-height: 320px; }
}


/* ===== CASE STUDIES (home) ===== */
.cs {
  padding: 112px 0 112px;
  background: var(--card);
  border-bottom: 1px solid var(--line);
}
.cs-head {
  display: flex;
  align-items: baseline;
  gap: 24px;
  margin-bottom: 32px;
  flex-wrap: wrap;
}
.cs-title {
  font-family: var(--f-display);
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin: 0;
}
.cs-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 32px;
  flex-wrap: wrap;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--line);
}
.cs-industries {
  display: flex;
  gap: 8px;
  margin-bottom: 32px;
  flex-wrap: wrap;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--line);
}
.cs-ind {
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 10px 16px;
  background: transparent;
  border: 1px solid var(--line);
  color: var(--muted);
  cursor: pointer;
  transition: all .15s ease;
}
.cs-ind:hover { color: var(--ink); border-color: var(--ink); }
.cs-ind.active {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}

.cs-rail-wrap {
  position: relative;
}
.cs-rail {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  padding: 4px 0 28px;
}
.cs-rail::-webkit-scrollbar { display: none; }
.cs-card {
  cursor: pointer;
  background: var(--bg);
  border: 1px solid var(--line);
  transition: transform .25s ease, box-shadow .25s ease;
  display: flex;
  flex-direction: column;
}
.cs-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px -12px rgba(0,0,0,0.18);
}
.cs-card-img {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #e8e8e8;
}
.cs-card-img .cs-ph {
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(135deg, rgba(26,26,26,0.04) 0 2px, transparent 2px 14px);
}
.cs-card-img .cs-tag {
  position: absolute;
  top: 16px; left: 16px;
  font-family: var(--f-mono);
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 6px 10px;
  background: var(--ink);
  color: #fff;
}
.cs-card-img .cs-industry {
  position: absolute;
  bottom: 16px; left: 16px;
  font-family: var(--f-mono);
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(26,26,26,0.6);
}
.cs-card-img.dark { background: #1a1d23; }
.cs-card-img.dark .cs-ph {
  background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 14px);
}
.cs-card-img.dark .cs-industry { color: rgba(255,255,255,0.55); }
.cs-card-img.warm { background: #d8cdb8; }
.cs-card-img.steel { background: #8a9099; }
.cs-card-img.steel .cs-industry { color: rgba(255,255,255,0.75); }
.cs-card-img.blue { background: #2d3a5f; }
.cs-card-img.blue .cs-ph {
  background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 14px);
}
.cs-card-img.blue .cs-industry { color: rgba(255,255,255,0.55); }

.cs-card-body {
  padding: 24px 24px 28px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.cs-card-title {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 20px;
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 0;
}
.cs-card-client {
  font-family: var(--f-mono);
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--muted);
}
.cs-card-desc {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.55;
  margin: 4px 0 12px;
}
.cs-card-meta {
  display: flex;
  gap: 16px;
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}
.cs-card-meta .mk { color: var(--ink); }

.cs-rail-nav {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 16px;
}
.cs-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 48px; height: 48px;
  background: rgba(255,255,255,0.95);
  border: 1px solid var(--line);
  color: var(--ink);
  font-size: 18px;
  cursor: pointer;
  transition: all .15s ease;
}
.cs-arrow:hover { background: var(--ink); color: #fff; border-color: var(--ink); }
.cs-arrow.prev { left: 12px; }
.cs-arrow.next { right: 12px; }

.cs-foot {
  display: flex;
  justify-content: center;
  margin-top: 40px;
}

/* ===== CASE STUDY detail page ===== */
.case-hero {
  padding: 48px 0 0;
  background: var(--bg);
}
.case-hero .breadcrumbs { margin-bottom: 40px; }
.case-hero-meta {
  display: flex;
  gap: 24px;
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 20px;
}
.case-hero-meta span.accent { color: var(--accent-dark); }
.case-hero h1 {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(42px, 5.5vw, 76px);
  letter-spacing: -0.03em;
  line-height: 1.02;
  margin: 0;
  max-width: 900px;
}
.case-hero .italic {
  font-family: var(--f-serif);
  font-style: italic;
  font-weight: 400;
}
.case-hero-sub {
  font-size: 18px;
  color: var(--muted);
  max-width: 640px;
  margin-top: 24px;
  line-height: 1.5;
}

.case-cover {
  margin-top: 56px;
  aspect-ratio: 16 / 8;
  position: relative;
  overflow: hidden;
  background: #1a1d23;
  border-bottom: 1px solid var(--line);
}
.case-cover .cs-ph {
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 14px);
}
.case-cover-label {
  position: absolute;
  bottom: 24px; left: 24px;
  font-family: var(--f-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}

.case-body {
  padding: 96px 0;
}
.case-grid {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 80px;
}
.case-side {
  position: sticky;
  top: 120px;
  align-self: start;
  display: flex;
  flex-direction: column;
  gap: 32px;
  font-family: var(--f-mono);
  font-size: 12px;
}
.case-side dt {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 6px;
  font-weight: 600;
}
.case-side dd {
  color: var(--ink);
  font-size: 14px;
  font-family: var(--f-body);
  margin: 0;
  line-height: 1.45;
}
.case-side-block + .case-side-block {
  padding-top: 28px;
  border-top: 1px solid var(--line);
}

.case-main {
  display: flex;
  flex-direction: column;
  gap: 48px;
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink);
}
.case-main h2 {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 32px;
  letter-spacing: -0.02em;
  margin: 24px 0 4px;
  line-height: 1.1;
}
.case-main p { margin: 0; color: #3d3d3d; }
.case-main blockquote {
  margin: 16px 0;
  padding: 32px 0 28px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  font-family: var(--f-serif);
  font-style: italic;
  font-size: 28px;
  line-height: 1.3;
  color: var(--ink);
}
.case-main blockquote cite {
  display: block;
  margin-top: 20px;
  font-family: var(--f-mono);
  font-style: normal;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}

.case-figure {
  aspect-ratio: 16 / 10;
  background: #e8e8e8;
  position: relative;
  overflow: hidden;
  margin: 16px 0;
}
.case-figure.dark { background: #1a1d23; }
.case-figure.steel { background: #8a9099; }
.case-figure .cs-ph {
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(135deg, rgba(26,26,26,0.05) 0 2px, transparent 2px 14px);
}
.case-figure.dark .cs-ph {
  background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 14px);
}
.case-figure .cs-cap {
  position: absolute;
  bottom: 16px; left: 16px;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(0,0,0,0.5);
}
.case-figure.dark .cs-cap { color: rgba(255,255,255,0.4); }

.case-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin: 32px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.case-stat {
  padding: 32px 24px 32px 0;
  border-right: 1px solid var(--line);
}
.case-stat:last-child { border-right: none; padding-right: 0; }
.case-stat .kn {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 42px;
  letter-spacing: -0.02em;
  color: var(--accent-dark);
  line-height: 1;
}
.case-stat .lb {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 10px;
  display: block;
}

.case-nextprev {
  border-top: 1px solid var(--line);
  padding: 48px 0 96px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
}
.case-nextprev a {
  text-decoration: none;
  color: var(--ink);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.case-nextprev .lab {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}
.case-nextprev .ti {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.01em;
}
.case-nextprev .next { text-align: right; align-items: flex-end; }

@media (max-width: 960px) {
  .cs-head { grid-template-columns: 1fr; gap: 16px; }
  .cs-intro { justify-self: start; text-align: left; }
  .case-grid { grid-template-columns: 1fr; gap: 32px; }
  .cs-rail { grid-template-columns: 1fr; }
  .case-side { position: static; }
  .case-stats { grid-template-columns: 1fr 1fr; }
  .case-stat:nth-child(2) { border-right: none; }
}

/* ============================================================
   DML — Shopify theme integration additions
   ============================================================ */

/* Skeleton section wrapper: let our .wrap constrain */
.shopify-section { display: block; }

/* Keep footer pinned to bottom when content is short */
body { display: flex; flex-direction: column; min-height: 100svh; }
main { flex: 1 0 auto; }

/* Skip link */
.skip-link { position: absolute; left: -9999px; }
.skip-link:focus { position: static; display: inline-block; padding: 8px 12px; background: var(--ink); color: #fff; }
.visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }

/* Remove decorative-only prototype artefacts that don't apply in Shopify */
.page-switcher, .tweaks-panel { display: none !important; }


/* ============================================================
   Global RTE (rich text editor) styles — used by page.liquid,
   main-product.liquid body_html, article.liquid content, etc.
   ============================================================ */
.wrap-narrow { max-width: 820px; margin: 0 auto; padding: 0 var(--pad-x); }

.rte { font-size: 16px; line-height: 1.6; color: var(--ink); }
.rte p { margin-bottom: 1.2em; }
.rte .lead {
  font-family: var(--f-serif); font-style: italic;
  font-size: 22px; line-height: 1.4;
  color: var(--muted);
  margin-bottom: 1.4em;
}
.rte h2 {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(24px, 2.5vw, 32px);
  letter-spacing: -0.02em; line-height: 1.15;
  margin-top: 2em; margin-bottom: 0.6em;
}
.rte h3 {
  font-family: var(--f-display); font-weight: 600;
  font-size: 20px; letter-spacing: -0.01em;
  margin-top: 1.8em; margin-bottom: 0.5em;
}
.rte h4 {
  font-family: var(--f-mono); font-size: 11px;
  font-weight: 600; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--muted);
  margin-top: 1.8em; margin-bottom: 0.8em;
}
.rte ul, .rte ol { margin: 1em 0 1.4em 1.4em; padding-left: 0.5em; }
.rte ul { list-style: disc; }
.rte ol { list-style: decimal; }
.rte li { margin-bottom: 0.4em; line-height: 1.5; }
.rte a { color: var(--ink); border-bottom: 1px solid var(--accent); text-decoration: none; padding-bottom: 1px; }
.rte a:hover { color: var(--accent-dark); border-color: var(--accent-dark); }
.rte strong { font-weight: 600; }
.rte em { font-style: italic; }
.rte code { font-family: var(--f-mono); font-size: 0.9em; background: var(--ink-05); padding: 2px 6px; border-radius: var(--r-sm); }
.rte blockquote {
  border-left: 3px solid var(--accent);
  padding: 8px 0 8px 24px;
  margin: 1.6em 0;
  font-family: var(--f-serif); font-style: italic;
  font-size: 22px; line-height: 1.3;
  color: var(--ink);
}
.rte table {
  width: 100%; border-collapse: collapse;
  margin: 1.4em 0;
  font-size: 14px;
}
.rte th, .rte td {
  text-align: left; padding: 10px 14px;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
}
.rte th {
  font-family: var(--f-mono); font-size: 10px;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--muted); background: var(--soft);
  white-space: nowrap;
}
.rte hr { border: 0; border-top: 1px solid var(--line); margin: 2em 0; }
.rte img { margin: 1.2em 0; border: 1px solid var(--line); }

/* ===== Active filter bar (above results) ===== */
.coll-active-filters {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: 10px; padding: 14px 16px; margin-bottom: 20px;
  background: var(--card); border: 1px solid var(--line); border-radius: var(--r-sm);
}
.coll-active-filters .af-label {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--muted);
}
.coll-active-filters .af-chips { display: flex; flex-wrap: wrap; gap: 8px; flex: 1; }
.coll-active-filters .af-chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 10px 6px 12px;
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--ink);
  background: #fff; border: 1px solid var(--ink); border-radius: 2px;
  cursor: pointer; transition: background .15s ease, color .15s ease;
}
.coll-active-filters .af-chip:hover { background: var(--ink); color: #fff; }
.coll-active-filters .af-chip > span { font-size: 14px; line-height: 1; }
.coll-active-filters .af-clear {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--accent-dark);
  background: transparent; border: none; cursor: pointer; padding: 6px 4px;
  text-decoration: underline; text-underline-offset: 3px;
}
.coll-active-filters .af-clear:hover { color: var(--ink); }

/* Empty-filter suggestion buttons reuse .chip styling */
.coll-empty-filter .ef-suggestions .chip { display: inline-flex; }

/* ===== Filter search input ===== */
.filter-search-wrap { margin-bottom: 20px; }
.filter-search {
  width: 100%; padding: 8px 12px;
  font-family: var(--f-body); font-size: 13px;
  background: #fff; color: var(--ink);
  border: 1px solid var(--line); border-radius: var(--r-sm);
  transition: border-color .15s ease;
}
.filter-search:focus { outline: none; border-color: var(--ink); }
.filter-search::placeholder { color: var(--muted); }

/* ===== Sidebar accordion ===== */
.filter-accordion .acc-group { margin-bottom: 4px; }
.filter-accordion .acc-head {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 0; cursor: pointer;
  font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.04em;
  text-transform: uppercase; color: var(--ink); font-weight: 600;
  transition: color .15s ease;
}
.filter-accordion .acc-head:hover { color: var(--accent-dark); }
.filter-accordion .acc-head .acc-caret {
  display: inline-block; width: 10px; font-size: 9px;
  transform: rotate(-90deg); transition: transform .18s ease;
  color: var(--muted);
}
.filter-accordion .acc-group.open .acc-head .acc-caret { transform: rotate(0deg); }
.filter-accordion .acc-head .acc-label { flex: 1; }
.filter-accordion .acc-head .cnt {
  font-family: var(--f-mono); font-size: 11px;
  color: var(--muted); font-weight: 500;
}
.filter-accordion .acc-body {
  max-height: 0; overflow: hidden;
  transition: max-height .25s ease;
  margin: 0; padding: 0 0 0 16px;
  border-left: 1px solid var(--line); margin-left: 4px;
}
.filter-accordion .acc-group.open .acc-body {
  max-height: 600px;
}
.filter-accordion .acc-body li {
  padding: 5px 0; font-size: 12px;
  display: flex; justify-content: space-between;
  cursor: pointer; color: var(--ink);
  list-style: none;
}
.filter-accordion .acc-body li:hover { color: var(--accent-dark); }
.filter-accordion .acc-body li.active { color: var(--accent-dark); font-weight: 600; }
.filter-accordion .acc-body li .cnt {
  font-family: var(--f-mono); font-size: 10px; color: var(--muted);
}

/* ===== PDP top relationship switch (3 tabs above hero) ===== */
.pdp-tag-switch {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  width: 100%;          /* override v11 .pdp-tag-switch { width: fit-content } */
  max-width: 720px;
  margin: 32px auto 24px;  /* center horizontally */
  border: 0;
  background: transparent;
  border-radius: 0;
  overflow: visible;
}
.pdp-tag-card {
  display: flex; flex-direction: column; gap: 2px;
  padding: 14px 18px;
  border: 1px solid var(--line);
  background: #fff; color: var(--ink);
  text-decoration: none;
  cursor: pointer;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.pdp-tag-card + .pdp-tag-card { border-left: none; }
.pdp-tag-card:hover { border-color: var(--ink); background: var(--card); }
.pdp-tag-card.active {
  background: var(--ink); color: #fff; border-color: var(--ink); cursor: default;
}
.pdp-tag-card.disabled { color: var(--muted); cursor: default; opacity: 0.7; }
.pdp-tag-card .ts-label {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; font-weight: 700;
}
.pdp-tag-card .ts-sub {
  font-family: var(--f-serif); font-style: italic;
  font-size: 13px; opacity: 0.8;
  margin-top: 2px;
}
.pdp-tag-card.active .ts-sub { opacity: 0.7; }

@media (max-width: 640px) {
  .pdp-tag-switch { max-width: 100%; }
  .pdp-tag-card { padding: 10px 12px; }
  .pdp-tag-card .ts-label { font-size: 10px; }
  .pdp-tag-card .ts-sub { font-size: 11px; }
}

/* ===== Filter search suggestions dropdown ===== */
.filter-search-wrap { position: relative; margin-bottom: 20px; }
.filter-suggest {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  box-shadow: 0 6px 18px rgba(0,0,0,0.06);
  z-index: 100;
  max-height: 360px; overflow-y: auto;
}
.filter-suggest .fs-item {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-bottom: 1px solid var(--line);
  color: var(--ink); text-decoration: none;
  transition: background .12s ease;
}
.filter-suggest .fs-item:last-child { border-bottom: none; }
.filter-suggest .fs-item:hover { background: var(--card); }
.filter-suggest .fs-thumb {
  width: 36px; height: 36px;
  object-fit: cover;
  background: var(--soft);
  display: block;
  border-radius: 2px;
}
.filter-suggest .fs-thumb.placeholder { background-image: repeating-linear-gradient(45deg, rgba(26,26,26,0.06) 0 2px, transparent 2px 8px); }
.filter-suggest .fs-meta { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.filter-suggest .fs-title {
  font-size: 13px; color: var(--ink);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.filter-suggest .fs-title mark { background: rgba(217,189,103,0.35); color: inherit; padding: 0 1px; }
.filter-suggest .fs-tag {
  font-family: var(--f-mono); font-size: 10px; color: var(--muted);
  letter-spacing: 0.06em; text-transform: uppercase;
}
.filter-suggest .fs-arrow {
  font-family: var(--f-mono); font-size: 14px; color: var(--muted);
}
.filter-suggest .fs-item:hover .fs-arrow { color: var(--accent-dark); }
.filter-suggest .fs-empty {
  padding: 12px 14px;
  font-size: 13px; color: var(--muted); font-style: italic;
}
