/* ----- CHIC — Site Styles ----- */

/* Utility */
.container { width: 100%; max-width: var(--content-wide); margin-inline: auto; padding-inline: var(--gutter); }
.container-narrow { max-width: var(--content-default); margin-inline: auto; padding-inline: var(--gutter); }
.eyebrow {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--color-text-muted);
}
.text-link {
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--color-text);
  padding-bottom: 4px;
  border-bottom: 1px solid currentColor;
}
.text-link:hover { color: var(--color-text-muted); }

.divider { width: 100%; height: 1px; background: var(--color-divider); }

/* ----- Top Bar ----- */
.topbar {
  background: var(--color-text);
  color: var(--color-bg);
  text-align: center;
  font-size: var(--text-xs);
  font-weight: 400;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 10px 0;
}

/* ----- Header / Nav ----- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in oklab, var(--color-bg) 92%, transparent);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid var(--color-divider);
}
.nav {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding-block: var(--space-4);
  gap: var(--space-6);
}
.nav-left, .nav-right {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.2em;
}
.nav-right { justify-content: flex-end; }
.nav a { color: var(--color-text); position: relative; padding-block: 4px; }
.nav a:hover { color: var(--color-text-muted); }

.brand {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.5rem, 1rem + 1.5vw, 2rem);
  letter-spacing: 0.4em;
  text-align: center;
  padding-inline-start: 0.4em;
  white-space: nowrap;
  color: var(--color-text);
}
@media (max-width: 520px) {
  .brand { letter-spacing: 0.28em; font-size: 1.25rem; padding-inline-start: 0.28em; }
}

.nav-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  color: var(--color-text);
}
.nav-icon:hover { color: var(--color-text-muted); }

/* Mobile nav */
.menu-btn { display: none; }
@media (max-width: 880px) {
  .nav { grid-template-columns: 1fr auto 1fr; }
  .nav-left a:not(.menu-btn) { display: none; }
  .menu-btn { display: inline-flex; }
  .nav-right a:not(.nav-icon) { display: none; }
}

/* ----- Hero ----- */
.hero {
  position: relative;
  height: clamp(560px, 90vh, 880px);
  overflow: hidden;
  background: var(--color-surface-offset);
}
.hero-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(0.95);
}
.hero-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg,
      rgba(0,0,0,0) 0%,
      rgba(0,0,0,0) 60%,
      rgba(20,15,10,0.35) 100%),
    linear-gradient(90deg,
      rgba(20,15,10,0.18) 0%,
      rgba(0,0,0,0) 45%);
}
.hero-content {
  position: absolute;
  left: 0; right: 0; bottom: clamp(2.5rem, 6vw, 5rem);
  padding-inline: var(--gutter);
  color: #F4EFE8;
}
.hero-content .eyebrow { color: rgba(244,239,232,0.85); }
.hero-content h1 {
  font-size: var(--text-hero);
  font-style: italic;
  font-weight: 300;
  margin-top: var(--space-4);
  max-width: 14ch;
  letter-spacing: -0.01em;
}
.hero-content .hero-actions {
  margin-top: var(--space-8);
  display: flex; gap: var(--space-8); flex-wrap: wrap;
}
.hero-content .text-link { color: #F4EFE8; }
.hero-content .text-link:hover { color: rgba(244,239,232,0.7); }

/* ----- Sections ----- */
section {
  padding-block: clamp(4rem, 9vw, 8rem);
}
.section-header { text-align: center; margin-bottom: clamp(3rem, 6vw, 5rem); }
.section-header h2 {
  font-size: var(--text-2xl);
  font-style: italic;
  margin-top: var(--space-3);
}
.section-header p {
  margin: var(--space-4) auto 0;
  max-width: 52ch;
  color: var(--color-text-muted);
}

/* ----- Featured (3-col product grid) ----- */
.product-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.5rem, 3vw, 3rem) clamp(1.25rem, 2.5vw, 2.5rem);
}
@media (max-width: 880px) { .product-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .product-grid { grid-template-columns: 1fr; } }

.product-card { display: block; color: inherit; }
.product-card .media {
  position: relative;
  overflow: hidden;
  background: var(--color-surface-offset);
  aspect-ratio: 3/4;
}
.product-card .media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--transition-slow), opacity var(--transition-slow);
}
.product-card:hover .media img { transform: scale(1.035); }
.product-card .info {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-top: var(--space-4);
  font-size: var(--text-sm);
  font-weight: 300;
}
.product-card .info .name { font-family: var(--font-body); letter-spacing: 0.04em; }
.product-card .info .price { font-variant-numeric: tabular-nums; color: var(--color-text-muted); }
.product-card .meta {
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-top: 4px;
}

/* ----- Editorial diptych ----- */
.diptych {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: stretch;
  min-height: clamp(420px, 60vw, 720px);
}
@media (max-width: 880px) { .diptych { grid-template-columns: 1fr; } }
.diptych .media { overflow: hidden; }
.diptych .media img { width: 100%; height: 100%; object-fit: cover; }
.diptych .copy {
  padding: clamp(2rem, 6vw, 6rem);
  display: flex; flex-direction: column; justify-content: center;
  background: var(--color-surface);
}
.diptych .copy h3 {
  font-size: var(--text-2xl);
  font-style: italic;
  margin-top: var(--space-3);
}
.diptych .copy p {
  margin-top: var(--space-6);
  color: var(--color-text-muted);
}
.diptych .copy .text-link { margin-top: var(--space-8); align-self: flex-start; }

/* ----- Campaign banner ----- */
.campaign {
  position: relative;
  height: clamp(420px, 70vh, 720px);
  overflow: hidden;
}
.campaign img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.campaign .copy {
  position: absolute; left: 0; right: 0; bottom: clamp(2rem, 6vw, 5rem);
  text-align: center; color: #F4EFE8;
  text-shadow: 0 1px 24px rgba(0,0,0,0.25);
}
.campaign .copy .eyebrow { color: rgba(244,239,232,0.85); }
.campaign .copy h3 {
  font-size: var(--text-2xl);
  font-style: italic;
  margin-top: var(--space-3);
  max-width: 18ch; margin-inline: auto;
}
.campaign .copy .text-link { color: #F4EFE8; margin-top: var(--space-6); }

/* ----- Pillars (philosophy) ----- */
.pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(2rem, 4vw, 4rem);
}
@media (max-width: 720px) { .pillars { grid-template-columns: 1fr; } }
.pillar h4 {
  font-size: var(--text-lg);
  font-style: italic;
  margin-top: var(--space-4);
}
.pillar p { margin-top: var(--space-3); color: var(--color-text-muted); font-size: var(--text-sm); }
.pillar .num {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--color-text-faint);
  font-variant-numeric: tabular-nums;
}

/* ----- Journal grid ----- */
.journal-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.5rem, 3vw, 3rem); }
@media (max-width: 880px) { .journal-grid { grid-template-columns: 1fr; } }
.journal-card .media { aspect-ratio: 4/5; overflow: hidden; background: var(--color-surface-offset); }
.journal-card .media img { width: 100%; height: 100%; object-fit: cover; }
.journal-card h4 { font-size: var(--text-lg); font-style: italic; margin-top: var(--space-4); }
.journal-card .meta { font-size: var(--text-xs); letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-text-muted); margin-top: var(--space-2); }

/* ----- Newsletter ----- */
.newsletter { background: var(--color-surface-offset); }
.newsletter .container-narrow { text-align: center; }
.newsletter h3 { font-size: var(--text-xl); font-style: italic; }
.newsletter p { margin: var(--space-3) auto 0; color: var(--color-text-muted); max-width: 48ch; }
.newsletter form {
  display: flex; gap: 0; max-width: 480px; margin: var(--space-8) auto 0;
  border-bottom: 1px solid var(--color-text);
}
.newsletter input {
  flex: 1; background: transparent; border: 0; outline: none;
  padding: var(--space-3) 0;
  font-size: var(--text-sm); letter-spacing: 0.05em;
  color: var(--color-text);
}
.newsletter input::placeholder { color: var(--color-text-faint); }
.newsletter button {
  font-family: var(--font-body); font-size: var(--text-xs);
  text-transform: uppercase; letter-spacing: 0.22em;
  padding: var(--space-3) var(--space-4);
}
.newsletter button:hover { color: var(--color-text-muted); }

/* ----- Footer ----- */
.site-footer {
  background: var(--color-text);
  color: var(--color-bg);
  padding-block: var(--space-16) var(--space-8);
}
.site-footer a { color: var(--color-bg); }
.site-footer a:hover { color: var(--color-text-faint); }
.footer-grid {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: clamp(2rem, 4vw, 4rem);
}
@media (max-width: 720px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
.footer-grid h5 {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: rgba(244,239,232,0.6);
  margin-bottom: var(--space-5);
}
.footer-grid ul { list-style: none; display: flex; flex-direction: column; gap: var(--space-3); font-size: var(--text-sm); }
.footer-brand .mark {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.75rem;
  letter-spacing: 0.4em;
  padding-inline-start: 0.4em;
}
.footer-brand p { margin-top: var(--space-4); color: rgba(244,239,232,0.7); max-width: 32ch; font-size: var(--text-sm); }
.footer-bottom {
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--space-4);
  margin-top: var(--space-16);
  padding-top: var(--space-6);
  border-top: 1px solid rgba(244,239,232,0.15);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: rgba(244,239,232,0.6);
}

/* ----- Shop (PLP) ----- */
.plp-header {
  text-align: center;
  padding-block: var(--space-20) var(--space-12);
}
.plp-header .eyebrow { display: block; margin-bottom: var(--space-3); }
.plp-header h1 { font-size: var(--text-2xl); font-style: italic; }
.plp-header p { margin: var(--space-4) auto 0; max-width: 56ch; color: var(--color-text-muted); }

.plp-filters {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--space-4) 0;
  border-block: 1px solid var(--color-divider);
  margin-bottom: var(--space-12);
}
.plp-filters .group { display: flex; gap: var(--space-6); flex-wrap: wrap; }
.plp-filters .group button {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--color-text);
}
.plp-filters .group button:hover { color: var(--color-text-muted); }
@media (max-width: 520px) {
  .plp-filters { flex-direction: column; gap: var(--space-3); align-items: flex-start; }
  .plp-filters .group { gap: var(--space-4); }
}

/* ----- legacy PDP rules removed; see v2 below ----- */

.swatches { display: flex; gap: var(--space-3); margin-top: var(--space-8); }
.swatch {
  width: 28px; height: 28px; border-radius: 50%;
  border: 1px solid var(--color-border);
  cursor: pointer;
  outline-offset: 4px;
}
.swatch.active { outline: 1px solid var(--color-text); }

.size-row { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: var(--space-6); }
.size {
  min-width: 48px; padding: 10px 14px;
  font-size: var(--text-xs); letter-spacing: 0.18em; text-transform: uppercase;
  border: 1px solid var(--color-border);
  background: transparent;
}
.size:hover { border-color: var(--color-text); }
.size.active { background: var(--color-text); color: var(--color-bg); border-color: var(--color-text); }

.atc {
  display: block; width: 100%;
  margin-top: var(--space-8);
  padding: var(--space-4);
  background: var(--color-text); color: var(--color-bg);
  font-family: var(--font-body);
  font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.3em;
  border: 1px solid var(--color-text);
}
.atc:hover { background: transparent; color: var(--color-text); }

.accordion { margin-top: var(--space-10); border-top: 1px solid var(--color-divider); }
.accordion details {
  border-bottom: 1px solid var(--color-divider);
}
.accordion summary {
  cursor: pointer;
  list-style: none;
  padding: var(--space-5) 0;
  display: flex; justify-content: space-between; align-items: center;
  font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.22em;
}
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary::after { content: '+'; font-family: var(--font-display); font-size: 1.25rem; }
.accordion details[open] summary::after { content: '–'; }
.accordion .acc-body {
  padding: 0 0 var(--space-6);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.accordion .acc-body ul { padding-left: 1.2em; }
.accordion .acc-body li { margin-bottom: 4px; }

/* ----- About ----- */
.about-hero { text-align: center; padding-block: var(--space-24) var(--space-12); }
.about-hero h1 { font-size: var(--text-2xl); font-style: italic; max-width: 22ch; margin: var(--space-3) auto 0; }
.about-hero p { margin: var(--space-6) auto 0; color: var(--color-text-muted); max-width: 56ch; }

.about-quote {
  text-align: center;
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-xl);
  max-width: 30ch;
  margin: 0 auto;
  line-height: 1.3;
  color: var(--color-text);
}
.about-quote .attribution { display: block; font-family: var(--font-body); font-style: normal; font-size: var(--text-xs); letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-text-muted); margin-top: var(--space-6); }

/* ----- Reveal on scroll ----- */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity 800ms cubic-bezier(.2,.7,.2,1), transform 800ms cubic-bezier(.2,.7,.2,1); }
.reveal.visible { opacity: 1; transform: none; }

/* ============================================================
   v2 additions — full collection, PDP redesign, bag, cinematic
   ============================================================ */

/* Hero video */
.hero-video-wrap {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 560px;
  max-height: 880px;
  overflow: hidden;
  background: #1a1612;
}
.hero-video-wrap video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(0.92) contrast(1.02);
}
/* Desktop default: hide mobile video, show desktop video */
.hero-video-wrap .hero-mobile-video { display: none; }
.hero-video-wrap .hero-desktop-video { display: block; }
.hero-video-wrap::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(20,16,12,0.05) 0%, rgba(20,16,12,0) 30%, rgba(20,16,12,0.55) 100%);
  pointer-events: none;
}
.hero-video-copy {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 0 var(--gutter) var(--space-16);
  color: #F4EFE8;
  display: flex; flex-direction: column; align-items: flex-start;
  gap: var(--space-3);
}
.hero-video-copy .eyebrow { color: rgba(244,239,232,0.78); }
.hero-video-copy h1 {
  font-family: var(--font-display); font-style: italic; font-weight: 300;
  font-size: var(--text-hero); line-height: 0.96; letter-spacing: -0.01em;
  max-width: 14ch; margin: 0;
}
.hero-video-copy .lead { max-width: 56ch; opacity: 0.86; font-size: var(--text-lg); }
.hero-video-copy .ctas { display: flex; gap: var(--space-3); margin-top: var(--space-4); flex-wrap: wrap; }

/* Filters — color swatches */
.plp-filters .group button { display: inline-flex; align-items: center; gap: 0.5em; }
.plp-filters .group button .swatch {
  display: inline-block; width: 14px; height: 14px; border-radius: 50%;
  background: var(--sw); border: 1px solid rgba(0,0,0,0.18);
}
.plp-filters .group button.is-active { color: var(--color-text); border-bottom-color: var(--color-text); }
.plp-filters .group button:not(.is-active) { color: var(--color-text-muted); }

/* Set strip */
.set-strip { margin: var(--space-24) 0 var(--space-16); }
.set-strip-header { text-align: center; margin-bottom: var(--space-12); }
.set-strip-header h2 {
  font-family: var(--font-display); font-style: italic; font-weight: 300;
  font-size: var(--text-2xl); line-height: 1; letter-spacing: -0.01em;
  margin: var(--space-3) 0 var(--space-3);
}
.set-strip-header p { color: var(--color-text-muted); max-width: 52ch; margin: 0 auto; }
.set-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6) var(--space-6);
}
.set-card { color: inherit; text-decoration: none; display: block; }
.set-card .media {
  aspect-ratio: 3/4; overflow: hidden; background: var(--color-surface-offset);
  margin-bottom: var(--space-3);
}
.set-card .media img {
  width: 100%; height: 100%; object-fit: cover; transition: transform 1200ms cubic-bezier(.2,.7,.2,1);
}
.set-card:hover .media img { transform: scale(1.04); }
.set-card .info { display: flex; justify-content: space-between; gap: var(--space-2); font-size: var(--text-base); }
.set-card .name { font-family: var(--font-display); font-style: italic; font-weight: 400; }
.set-card .meta { color: var(--color-text-muted); font-size: var(--text-sm); margin-top: 2px; }

@media (max-width: 880px) {
  .set-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }
}
@media (max-width: 540px) {
  .set-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   PDP v2
   ============================================================ */
.pdp { padding-top: var(--space-8); }
.pdp-crumbs {
  display: flex; gap: 0.5em; align-items: center;
  font-size: var(--text-sm); color: var(--color-text-muted);
  margin-bottom: var(--space-6); padding-top: var(--space-4);
}
.pdp-crumbs a { color: inherit; text-decoration: none; }
.pdp-crumbs a:hover { color: var(--color-text); }

.pdp-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 460px);
  gap: var(--space-12);
  align-items: start;
  padding-bottom: var(--space-20);
}
.pdp-gallery { position: sticky; top: var(--space-10); width: 100%; min-width: 0; }
.pdp-hero {
  aspect-ratio: 3/4; overflow: hidden; background: var(--color-surface-offset);
  position: relative;
}
.pdp-hero img {
  width: 100%; height: 100%; object-fit: cover;
  transition: opacity 220ms ease, transform 1600ms cubic-bezier(.2,.7,.2,1);
}
.pdp-thumbs {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-3);
  margin-top: var(--space-3);
}
.pdp-thumb {
  background: transparent; border: 1px solid transparent; padding: 0; cursor: pointer;
  aspect-ratio: 3/4; overflow: hidden;
  transition: border-color var(--transition-interactive);
}
.pdp-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pdp-thumb.is-active { border-color: var(--color-text); }
.pdp-thumb:hover { border-color: var(--color-border); }

.pdp-info .eyebrow { letter-spacing: 0.18em; text-transform: uppercase; font-size: var(--text-xs); color: var(--color-text-muted); }
.pdp-info h1 {
  font-family: var(--font-display); font-style: italic; font-weight: 300;
  font-size: var(--text-2xl); line-height: 1.02; letter-spacing: -0.01em;
  margin: var(--space-2) 0 var(--space-3);
}
.pdp-price-row { display: flex; gap: var(--space-4); align-items: baseline; margin-bottom: var(--space-4); }
.pdp-price-row .price-large { font-size: var(--text-lg); font-weight: 400; }
.pdp-price-row .color-name { color: var(--color-text-muted); font-size: var(--text-sm); }
.pdp-lead { color: var(--color-text-muted); font-size: var(--text-base); max-width: 52ch; margin-bottom: var(--space-6); }

.pdp-option { margin-bottom: var(--space-5); }
.opt-row {
  display: flex; justify-content: space-between; align-items: baseline;
  font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.16em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-2);
}
.opt-row .opt-value { color: var(--color-text); letter-spacing: 0.04em; text-transform: none; font-size: var(--text-sm); }
.opt-link { color: var(--color-text-muted); text-decoration: underline; text-underline-offset: 3px; }

.swatches { display: flex; gap: var(--space-3); }
.swatch-lg {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 50%;
  border: 1px solid var(--color-border);
  text-decoration: none;
  transition: transform var(--transition-interactive), border-color var(--transition-interactive);
}
.swatch-lg .sw {
  display: block; width: 28px; height: 28px; border-radius: 50%;
  background: var(--sw); border: 1px solid rgba(0,0,0,0.10);
}
.swatch-lg:hover { transform: translateY(-1px); }
.swatch-lg.is-active { border-color: var(--color-text); border-width: 1.5px; }

.toggle-pair {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  border: 1px solid var(--color-border);
}
.toggle-pair button {
  padding: 0.85rem 1rem;
  background: transparent; border: 0;
  font-family: var(--font-body); font-size: var(--text-sm);
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--color-text-muted); cursor: pointer;
  transition: background var(--transition-interactive), color var(--transition-interactive);
}
.toggle-pair button + button { border-left: 1px solid var(--color-border); }
.toggle-pair button:hover { color: var(--color-text); }
.toggle-pair button.is-active { background: var(--color-text); color: var(--color-text-inverse); }

.size-grid {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--space-2);
}
.size-grid button {
  padding: 0.8rem 0;
  background: transparent; border: 1px solid var(--color-border);
  font-family: var(--font-body); font-size: var(--text-sm); letter-spacing: 0.08em;
  color: var(--color-text); cursor: pointer;
  transition: all var(--transition-interactive);
}
.size-grid button:hover { border-color: var(--color-text); }
.size-grid button.is-active {
  background: var(--color-text); color: var(--color-text-inverse); border-color: var(--color-text);
}

.pdp-actions { display: grid; gap: var(--space-3); margin: var(--space-6) 0 var(--space-6); }
.btn-block { width: 100%; }
.btn-ghost {
  display: flex; flex-direction: column; align-items: center; gap: 0.15em;
  background: transparent; color: var(--color-text);
  border: 1px solid var(--color-text);
  padding: 0.9rem 1rem;
  font-family: var(--font-body); font-size: var(--text-sm); letter-spacing: 0.12em;
  text-transform: uppercase; cursor: pointer;
  transition: background var(--transition-interactive), color var(--transition-interactive);
}
.btn-ghost:hover { background: var(--color-text); color: var(--color-text-inverse); }
.btn-ghost .set-sub { font-size: 0.7rem; letter-spacing: 0.08em; opacity: 0.7; text-transform: none; }
.btn-ghost:hover .set-sub { opacity: 0.85; }

.pdp-accordion { list-style: none; padding: 0; margin: var(--space-6) 0 0; border-top: 1px solid var(--color-divider); }
.pdp-accordion li { border-bottom: 1px solid var(--color-divider); }
.pdp-accordion summary {
  list-style: none; cursor: pointer; padding: var(--space-4) 0;
  display: flex; justify-content: space-between; align-items: center;
  font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.18em;
}
.pdp-accordion summary::-webkit-details-marker { display: none; }
.pdp-accordion summary::after { content: '+'; font-size: 1rem; transition: transform 200ms ease; }
.pdp-accordion details[open] summary::after { content: '−'; }
.pdp-accordion p { padding: 0 0 var(--space-4); color: var(--color-text-muted); font-size: var(--text-sm); max-width: 60ch; }

/* Editorial / set teaser sections */
.pdp-editorial, .pdp-set { padding: var(--space-20) 0; }
.pdp-editorial { background: var(--color-surface-offset); }
.editorial-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-12);
  align-items: center;
}
.editorial-grid figure { margin: 0; overflow: hidden; aspect-ratio: 4/5; }
.editorial-grid figure img { width: 100%; height: 100%; object-fit: cover; }
.editorial-copy h2.display {
  font-family: var(--font-display); font-style: italic; font-weight: 300;
  font-size: var(--text-2xl); line-height: 1.02; letter-spacing: -0.01em;
  margin: var(--space-3) 0 var(--space-4);
}
.editorial-copy p { color: var(--color-text-muted); max-width: 50ch; }

.set-teaser {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-12);
  align-items: center;
}
.set-teaser figure { margin: 0; overflow: hidden; aspect-ratio: 3/4; }
.set-teaser figure img { width: 100%; height: 100%; object-fit: cover; }
.set-teaser h2.display {
  font-family: var(--font-display); font-style: italic; font-weight: 300;
  font-size: var(--text-2xl); line-height: 1.02; letter-spacing: -0.01em;
  margin: var(--space-3) 0 var(--space-4);
}
.set-teaser p { color: var(--color-text-muted); max-width: 52ch; }
.set-members {
  display: grid; grid-template-columns: 1fr; gap: var(--space-3);
  margin: var(--space-6) 0;
}
.set-member {
  display: flex; gap: var(--space-4); align-items: center;
  padding: var(--space-3) 0; border-top: 1px solid var(--color-divider);
  text-decoration: none; color: inherit;
}
.set-member:last-child { border-bottom: 1px solid var(--color-divider); }
.set-member img { width: 70px; height: 88px; object-fit: cover; }
.set-member div { display: flex; flex-direction: column; flex: 1; }
.set-member .name { font-family: var(--font-display); font-style: italic; font-size: var(--text-base); }
.set-member .price { color: var(--color-text-muted); font-size: var(--text-sm); }

@media (max-width: 1024px) {
  .pdp-grid { grid-template-columns: 1fr; gap: var(--space-8); }
  .pdp-gallery { position: static; }
  .editorial-grid, .set-teaser { grid-template-columns: 1fr; gap: var(--space-6); }
}

/* ============================================================
   Cinematic motion — Ken Burns + parallax
   ============================================================ */
.kenburns { overflow: hidden; position: relative; }
.kenburns img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 14s cubic-bezier(.2,.7,.2,1), opacity 600ms ease;
  transform: scale(1.0);
  opacity: 0;
}
.kenburns.visible img,
.kenburns img.loaded {
  opacity: 1;
}
.kenburns.visible img {
  transform: scale(1.08);
}

/* Continuous loop variant */
@keyframes kenburns-loop {
  0%   { transform: scale(1.0)  translate3d(0%, 0%, 0); }
  50%  { transform: scale(1.08) translate3d(-1.5%, -1%, 0); }
  100% { transform: scale(1.0)  translate3d(0%, 0%, 0); }
}
.kenburns-loop img {
  animation: kenburns-loop 22s ease-in-out infinite;
}

/* Product card hover — softly zoom */
.product-card .media img {
  transition: transform 1200ms cubic-bezier(.2,.7,.2,1), opacity 220ms ease;
}
.product-card:hover .media img { transform: scale(1.04); }

/* ============================================================
   Bag drawer
   ============================================================ */
.bag-count {
  position: absolute; top: 4px; right: 4px;
  background: var(--color-text); color: var(--color-text-inverse);
  font-size: 10px; line-height: 1;
  min-width: 16px; height: 16px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0 4px;
  font-family: var(--font-body); letter-spacing: 0;
}
@keyframes pulse-once {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.35); }
  100% { transform: scale(1); }
}
.bag-count.pulse { animation: pulse-once 380ms ease-out; }
.nav-icon[data-bag-toggle] { position: relative; }

.bag-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(420px, 100%);
  background: var(--color-surface);
  border-left: 1px solid var(--color-divider);
  transform: translateX(100%);
  transition: transform 380ms cubic-bezier(.2,.7,.2,1);
  z-index: 60;
  display: flex; flex-direction: column;
}
.bag-drawer[data-open] { transform: translateX(0); }
.bag-scrim {
  position: fixed; inset: 0; background: rgba(20,16,12,0.42);
  z-index: 55; backdrop-filter: blur(2px);
}
.bag-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--space-5) var(--space-6); border-bottom: 1px solid var(--color-divider);
}
.bag-head .eyebrow { letter-spacing: 0.22em; }
.bag-close {
  background: transparent; border: 0; font-size: 1.5rem; cursor: pointer; color: var(--color-text);
  width: 32px; height: 32px; line-height: 1;
}
.bag-items { flex: 1; overflow-y: auto; padding: var(--space-4) var(--space-6); }
.bag-empty { color: var(--color-text-muted); font-style: italic; text-align: center; padding: var(--space-12) 0; }
.bag-item {
  display: grid; grid-template-columns: 72px 1fr; gap: var(--space-4);
  padding: var(--space-4) 0; border-bottom: 1px solid var(--color-divider);
}
.bag-item img { width: 72px; height: 90px; object-fit: cover; }
.bag-item-info { display: flex; flex-direction: column; gap: 4px; }
.bag-item-name { font-family: var(--font-display); font-style: italic; font-size: var(--text-base); line-height: 1.2; }
.bag-item-color { color: var(--color-text-muted); font-size: var(--text-xs); letter-spacing: 0.08em; }
.bag-item-row { display: flex; justify-content: space-between; align-items: center; margin-top: auto; padding-top: var(--space-2); }
.bag-item-price { font-size: var(--text-sm); }
.bag-item-remove {
  background: transparent; border: 0; padding: 0;
  font-size: var(--text-xs); letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--color-text-muted); cursor: pointer; text-decoration: underline; text-underline-offset: 3px;
}
.bag-item-remove:hover { color: var(--color-text); }
.bag-foot { padding: var(--space-5) var(--space-6); border-top: 1px solid var(--color-divider); }
.bag-total {
  display: flex; justify-content: space-between; font-size: var(--text-base);
  margin-bottom: var(--space-4);
}




/* ── Blend selector ─────────────────────────────────────── */
.pdp-price-row { display: flex; align-items: baseline; gap: var(--space-3); flex-wrap: wrap; }
.price-strike {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  text-decoration: line-through;
  font-feature-settings: "tnum";
}
.blend-option { margin-top: var(--space-5); }
.blend-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
}
.blend-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  padding: var(--space-4);
  background: transparent;
  border: 1px solid var(--color-divider);
  border-radius: 2px;
  text-align: left;
  cursor: pointer;
  transition: border-color 200ms ease, background 200ms ease, transform 200ms ease;
  font-family: var(--font-body);
  color: var(--color-text);
}
.blend-card:hover { border-color: var(--color-text); }
.blend-card.is-active {
  border-color: var(--color-text);
  background: rgba(43, 35, 28, 0.04);
}
.blend-card .blend-name {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-lg);
  line-height: 1.1;
}
.blend-card .blend-tagline {
  font-size: var(--text-xs);
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  line-height: 1.4;
}
.blend-card .blend-price {
  font-size: var(--text-sm);
  font-feature-settings: "tnum";
  margin-top: 2px;
}
.blend-card .blend-price s {
  color: var(--color-text-muted);
  margin-left: 6px;
  font-size: 0.85em;
}
@media (max-width: 540px) {
  .blend-grid { grid-template-columns: 1fr; }
}

/* ── Material accordion — fibre story ───────────────────── */
.material-detail { display: flex; flex-direction: column; gap: var(--space-4); padding-top: var(--space-2); }
.material-detail .material-comp {
  font-size: var(--text-sm);
  color: var(--color-text);
  margin: 0;
}
.material-detail .material-comp strong {
  font-weight: 500;
  letter-spacing: 0.01em;
}
.material-detail .material-lede {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--text-lg);
  line-height: 1.5;
  color: var(--color-text);
  margin: 0;
  padding: var(--space-4) 0;
  border-top: 1px solid var(--color-divider);
  border-bottom: 1px solid var(--color-divider);
}
.fibre-trio {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.fibre {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.fibre .fibre-name {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-xl);
  line-height: 1.1;
  color: var(--color-text);
}
.fibre .fibre-source {
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}
.fibre p {
  font-size: var(--text-sm);
  line-height: 1.65;
  color: var(--color-text);
  margin: 6px 0 0;
}
.material-foot {
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin: 0;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-divider);
}

/* fibre plant images */
.fibre-img {
  margin: 0 0 var(--space-3);
  background: rgba(43, 35, 28, 0.04);
  overflow: hidden;
  border-radius: 2px;
  aspect-ratio: 4 / 3;
}
.fibre-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 800ms cubic-bezier(.2,.6,.2,1);
}
.fibre:hover .fibre-img img { transform: scale(1.03); }

/* Grid out the fibre trio on wider screens */
@media (min-width: 768px) {
  .fibre-trio {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-5);
  }
}


/* -- Hero -- mobile editorial still ------------------------
   Mobile shows the static portrait (loads instantly).
   Gentle ken-burns adds cinematic motion. A strong gradient
   panel under the headline guarantees text legibility.
   --------------------------------------------------------- */
@media (max-width: 768px) {
  .hero-video-wrap {
    height: 100svh;
    min-height: 640px;
    max-height: 920px;
  }
  /* Swap: hide desktop video, show the looping portrait */
  .hero-video-wrap .hero-desktop-video { display: none !important; }
  .hero-video-wrap .hero-mobile-video {
    display: block;
    object-fit: cover;
    object-position: 50% 32%; /* keep model's face in frame */
  }
  .hero-video-wrap::after {
    background:
      linear-gradient(180deg,
        rgba(20,16,12,0.18) 0%,
        rgba(20,16,12,0.00) 18%,
        rgba(20,16,12,0.00) 38%,
        rgba(20,16,12,0.55) 58%,
        rgba(20,16,12,0.88) 80%,
        rgba(20,16,12,0.96) 100%);
  }
  .hero-video-copy {
    padding: var(--space-16) var(--gutter) calc(env(safe-area-inset-bottom, 0) + var(--space-10));
    gap: var(--space-2);
    background: linear-gradient(180deg,
      rgba(20,16,12,0) 0%,
      rgba(20,16,12,0.55) 30%,
      rgba(20,16,12,0.88) 70%,
      rgba(20,16,12,0.98) 100%);
  }
  .hero-video-copy .eyebrow {
    color: rgba(255,255,255,0.95);
    text-shadow: 0 1px 12px rgba(0,0,0,0.7);
  }
  .hero-video-copy h1 {
    font-size: clamp(2.6rem, 12vw, 4.2rem);
    max-width: 100%;
    line-height: 1.0;
    color: #FFFFFF;
    text-shadow: 0 2px 24px rgba(0,0,0,0.85), 0 1px 4px rgba(0,0,0,0.7);
  }
  .hero-video-copy .lead {
    font-size: var(--text-base);
    max-width: 36ch;
    color: #FFFFFF;
    opacity: 1;
    text-shadow: 0 1px 16px rgba(0,0,0,0.85), 0 1px 4px rgba(0,0,0,0.7);
  }
  .hero-video-copy .text-link {
    color: #FFFFFF;
    border-bottom-color: rgba(255,255,255,0.7);
    text-shadow: 0 1px 8px rgba(0,0,0,0.6);
  }
}
@keyframes heroKenMobile {
  0%   { transform: scale(1.04) translateY(0); }
  100% { transform: scale(1.10) translateY(-1.0%); }
}
@keyframes heroKen {
  0%   { transform: scale(1.04) translateY(0); }
  100% { transform: scale(1.10) translateY(-1.5%); }
}
@media (prefers-reduced-motion: reduce) {
  .hero-video-wrap video { animation: none; transform: none; }
  .hero-video-wrap .hero-mobile-video { animation: none; }
}

/* ============================================================
   FABRIC BLENDS GRID — 4-up cloth showcase
   ============================================================ */
.fabric-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
}
.fabric-card { margin: 0; }
.fabric-card .media {
  aspect-ratio: 3/4;
  overflow: hidden;
  background: var(--color-surface-offset);
  margin-bottom: var(--space-4);
}
.fabric-card .media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1600ms cubic-bezier(.2,.7,.2,1);
}
.fabric-card:hover .media img { transform: scale(1.05); }
.fabric-card figcaption {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 0 2px;
}
.fabric-card .name {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: var(--text-lg);
  letter-spacing: -0.005em;
  color: var(--color-text);
}
.fabric-card .note {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.5;
}

@media (max-width: 1080px) {
  .fabric-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }
}
@media (max-width: 540px) {
  .fabric-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   BAG: free shipping progress bar
   ============================================================ */
.bag-shipping {
  padding: var(--space-4) var(--space-6) var(--space-5);
  border-bottom: 1px solid var(--color-divider);
  background: var(--color-surface);
}
.bag-shipping-msg {
  font-size: var(--text-sm);
  color: var(--color-text);
  margin: 0 0 var(--space-3);
  letter-spacing: 0.01em;
  line-height: 1.45;
}
.bag-shipping-msg b { font-weight: 500; }
.bag-shipping-track {
  height: 3px;
  background: rgba(43, 35, 28, 0.10);
  border-radius: 999px;
  overflow: hidden;
}
.bag-shipping-fill {
  display: block;
  height: 100%;
  width: 0%;
  background: var(--color-text);
  border-radius: 999px;
  transition: width 600ms cubic-bezier(.2,.7,.2,1);
}
.bag-shipping[data-unlocked] .bag-shipping-fill {
  background: linear-gradient(90deg, #b8956a 0%, #d4ae7e 50%, #b8956a 100%);
}
.bag-shipping[data-unlocked] .bag-shipping-msg {
  color: #6b4f2a;
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-base);
}

.bag-foot { display: flex; flex-direction: column; gap: var(--space-3); }
.bag-foot .btn-primary { display: block; text-align: center; text-decoration: none; }
.bag-foot-note {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-align: center;
  letter-spacing: 0.04em;
}

/* ============================================================
   BAG: rotating upsells carousel
   ============================================================ */
.bag-upsells {
  border-top: 1px solid var(--color-divider);
  padding: var(--space-5) 0 var(--space-4);
  background: var(--color-surface-offset);
}
.bag-upsells-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 var(--space-6) var(--space-3);
}
.bag-upsells-head .eyebrow {
  letter-spacing: 0.22em;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.bag-upsells-dots {
  display: flex; gap: 6px;
}
.bag-upsells-dots .upsell-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: rgba(43, 35, 28, 0.18);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: all 240ms ease;
}
.bag-upsells-dots .upsell-dot.is-active {
  background: var(--color-text);
  width: 18px;
  border-radius: 999px;
}
.bag-upsells-track {
  display: flex;
  width: 100%;
  transition: transform 600ms cubic-bezier(.2,.7,.2,1);
}
.upsell-card {
  flex: 0 0 100%;
  display: grid;
  grid-template-columns: 84px 1fr;
  gap: var(--space-4);
  padding: 0 var(--space-6);
  align-items: center;
}
.upsell-media {
  display: block;
  width: 84px;
  height: 105px;
  overflow: hidden;
  background: var(--color-surface);
}
.upsell-media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 800ms cubic-bezier(.2,.7,.2,1);
}
.upsell-media:hover img { transform: scale(1.04); }
.upsell-info {
  display: flex; flex-direction: column; gap: 2px;
  min-width: 0;
}
.upsell-name {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-base);
  line-height: 1.2;
  color: var(--color-text);
  overflow: hidden; text-overflow: ellipsis;
}
.upsell-color {
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}
.upsell-row {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: var(--space-2);
  gap: var(--space-3);
}
.upsell-price {
  font-size: var(--text-sm);
  color: var(--color-text);
}
.upsell-add {
  background: var(--color-text);
  color: var(--color-surface);
  border: none;
  padding: 8px 14px;
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 240ms ease;
  font-family: inherit;
}
.upsell-add:hover { background: #1a140f; }
.upsell-add.is-added {
  background: #6b4f2a;
  color: var(--color-surface);
}

/* ============================================================
   PILLARS — 6-column variant
   ============================================================ */
.pillars-6 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(2rem, 4vw, 3.5rem) clamp(2rem, 4vw, 3rem);
}
@media (max-width: 880px) {
  .pillars-6 { grid-template-columns: repeat(2, 1fr); gap: clamp(1.75rem, 4vw, 2.5rem); }
}
@media (max-width: 540px) {
  .pillars-6 { grid-template-columns: 1fr; }
}

/* ============================================================
   COMPARE TABLE — CHIC vs typical luxury linen
   ============================================================ */
.compare {
  max-width: 980px;
  margin: 0 auto;
  border-top: 1px solid var(--color-divider);
}
.compare-row {
  display: grid;
  grid-template-columns: 1.2fr 1.5fr 1.5fr;
  gap: clamp(1rem, 2vw, 2rem);
  padding: var(--space-5) var(--space-2);
  border-bottom: 1px solid var(--color-divider);
  align-items: start;
}
.compare-row.compare-head {
  padding-top: var(--space-3);
  padding-bottom: var(--space-3);
}
.compare-cell {
  font-size: var(--text-base);
  line-height: 1.55;
  color: var(--color-text);
}
.compare-cell.compare-label {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: var(--text-lg);
  color: var(--color-text);
  letter-spacing: -0.005em;
}
.compare-cell.compare-us {
  color: var(--color-text);
  font-weight: 400;
  position: relative;
  padding-left: var(--space-4);
}
.compare-cell.compare-us::before {
  content: '';
  position: absolute;
  left: 0; top: 0.6em;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #6b4f2a;
}
.compare-cell.compare-them {
  color: var(--color-text-muted);
  padding-left: var(--space-4);
  position: relative;
}
.compare-cell.compare-them::before {
  content: '';
  position: absolute;
  left: 0; top: 0.6em;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: rgba(43, 35, 28, 0.20);
}
.compare-head .compare-us .eyebrow,
.compare-head .compare-them .eyebrow {
  letter-spacing: 0.22em;
  font-size: var(--text-xs);
}
.compare-head .compare-us { font-family: var(--font-display); }
.compare-head .compare-us::before,
.compare-head .compare-them::before { display: none; }

@media (max-width: 760px) {
  .compare-row {
    grid-template-columns: 1fr;
    gap: var(--space-2);
    padding: var(--space-4) 0;
  }
  .compare-row.compare-head { display: none; }
  .compare-cell.compare-label {
    font-size: var(--text-base);
    color: var(--color-text-muted);
    margin-bottom: var(--space-1);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-family: var(--font-sans);
    font-style: normal;
  }
  .compare-cell.compare-us::before { top: 0.55em; }
  .compare-cell.compare-them::before { top: 0.55em; }
  .compare-cell.compare-us::after {
    content: 'CHIC';
    display: block;
    font-size: var(--text-xs);
    letter-spacing: 0.22em;
    color: #6b4f2a;
    margin-top: 4px;
  }
  .compare-cell.compare-them::after {
    content: 'Typical luxury linen';
    display: block;
    font-size: var(--text-xs);
    letter-spacing: 0.18em;
    color: var(--color-text-muted);
    margin-top: 4px;
    text-transform: uppercase;
  }
}

/* ============================================================
   TESTIMONIALS + press bar
   ============================================================ */
.testimonials {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(2rem, 4vw, 3.5rem);
  margin-top: var(--space-6);
}
.testimonial {
  margin: 0;
  display: flex; flex-direction: column;
  gap: var(--space-4);
}
.testimonial blockquote {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(1.1rem, 1.4vw, 1.4rem);
  line-height: 1.45;
  margin: 0;
  color: var(--color-text);
  letter-spacing: -0.005em;
  border: none;
  padding: 0;
}
.testimonial figcaption {
  display: flex; flex-direction: column;
  gap: 2px;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-divider);
}
.testimonial .t-name {
  font-size: var(--text-sm);
  color: var(--color-text);
  letter-spacing: 0.01em;
}
.testimonial .t-meta {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 0.08em;
}

@media (max-width: 880px) {
  .testimonials { grid-template-columns: 1fr; gap: var(--space-8); }
}

.press-bar {
  margin-top: var(--space-16);
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-divider);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
}
.press-bar .press-label {
  font-size: var(--text-xs);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}
.press-logos {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(1.5rem, 4vw, 3.5rem);
  justify-content: center;
  align-items: center;
}
.press-logos span {
  font-family: var(--font-display);
  font-size: clamp(0.95rem, 1.2vw, 1.15rem);
  letter-spacing: 0.1em;
  color: var(--color-text);
  opacity: 0.7;
  white-space: nowrap;
}
