/* ==========================================================================
   ANN'S ENSEMBLE PICKS — ATELIER DESIGN SYSTEM
   Editorial luxury layer · Lenis/GSAP/Three.js ready · Mobile-first polish
   ========================================================================== */

:root {
  --color-ivory: #FAF7F2;
  --color-cream: #F5EDE3;
  --color-linen: #EAE0D0;
  --color-white: #FFFFFF;
  --color-sage-light: #EDF0E6;
  --color-olive-deep: #3D4F35;
  --color-olive-ink: #26301F;
  --color-gold: #C9A96E;
  --color-gold-deep: #AE8E51;
  --color-text-primary: #3A4033;
  --color-text-muted: #76796A;
  --font-heading: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'Nunito Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --border-radius: 2px;
  --container: 1280px;
  --ease-power4: cubic-bezier(0.25, 1, 0.5, 1);
  --transition-smooth: all 0.7s var(--ease-power4);
  --shadow-deep: 0 30px 60px -24px rgba(38, 48, 31, 0.22);
  --shadow-soft: 0 14px 34px -14px rgba(38, 48, 31, 0.14);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
body {
  font-family: var(--font-body);
  background: linear-gradient(135deg, var(--color-ivory) 0%, var(--color-cream) 50%, var(--color-sage-light) 100%) fixed;
  color: var(--color-text-primary);
  font-size: 16px;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
main { display: block; }
img, svg, video { max-width: 100%; vertical-align: middle; }
button { font-family: inherit; cursor: pointer; }
::selection { background: var(--color-gold); color: var(--color-white); }
::-webkit-scrollbar { width: 10px; }
::-webkit-scrollbar-track { background: var(--color-ivory); }
::-webkit-scrollbar-thumb { background: var(--color-linen); border-radius: 10px; border: 2px solid var(--color-ivory); }
::-webkit-scrollbar-thumb:hover { background: var(--color-gold); }

/* ---------- Split-text helpers (populated by main.js) ---------- */
.sw-w, .ch-w { display: inline-block; overflow: hidden; vertical-align: bottom; padding-bottom: 0.12em; margin-bottom: -0.12em; }
.sw-i, .ch-i { display: inline-block; will-change: transform; }

/* ---------- Ambient layers ---------- */
.fabric-overlay {
  position: fixed; inset: 0; z-index: 5; pointer-events: none; opacity: 0.5;
  background-image: radial-gradient(rgba(61, 79, 53, 0.035) 1px, transparent 1px);
  background-size: 3px 3px; mix-blend-mode: multiply;
}
#silk-canvas {
  position: fixed; inset: 0; width: 100%; height: 100%;
  z-index: 1600; pointer-events: none; mix-blend-mode: soft-light;
}

/* ---------- Custom cursor (fine pointers only) ---------- */
.cursor-dot, .cursor-ring {
  position: fixed; top: 0; left: 0; pointer-events: none; z-index: 2000;
  border-radius: 50%; opacity: 0; transition: opacity 0.4s ease;
}
body.cursor-on .cursor-dot, body.cursor-on .cursor-ring { opacity: 1; }
.cursor-dot { width: 6px; height: 6px; margin: -3px 0 0 -3px; background: var(--color-gold); }
.cursor-ring {
  width: 34px; height: 34px; margin: -17px 0 0 -17px;
  border: 1px solid rgba(201, 169, 110, 0.55);
  transition: width 0.4s var(--ease-power4), height 0.4s var(--ease-power4), margin 0.4s var(--ease-power4), opacity 0.4s ease, border-color 0.4s ease;
}
.cursor-ring.is-hot { width: 56px; height: 56px; margin: -28px 0 0 -28px; border-color: var(--color-gold); }
@media (pointer: coarse) { .cursor-dot, .cursor-ring { display: none; } }

/* ---------- Page transition veil ---------- */
.pt-veil { position: fixed; inset: 0; z-index: 1500; pointer-events: none; visibility: hidden; }
.pt-panel {
  position: absolute; left: 0; width: 100%; height: 100%; top: 0;
  transform: translateY(100%);
  will-change: transform;
}
.pt-panel--gold { background: var(--color-gold); }
.pt-panel--olive { background: var(--color-olive-ink); display: grid; place-items: center; }
.pt-mark { text-align: center; }
.pt-mark-serif { display: block; font-family: var(--font-heading); font-style: italic; font-weight: 500; font-size: clamp(30px, 5vw, 52px); color: var(--color-ivory); }
.pt-mark-caps { display: block; margin-top: 12px; font-size: 10px; font-weight: 800; letter-spacing: 5px; text-transform: uppercase; color: var(--color-gold); }

/* ---------- Header ---------- */
.main-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1200;
  border-bottom: 1px solid transparent;
  transition: background-color 0.5s ease, border-color 0.5s ease, box-shadow 0.5s ease;
}
.main-header.scrolled {
  background: rgba(250, 247, 242, 0.92) !important;
  -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(201, 169, 110, 0.14) !important;
  box-shadow: 0 10px 30px -18px rgba(38, 48, 31, 0.25);
}
.header-container {
  max-width: var(--container); margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; padding: 14px 48px;
}
.logo { display: inline-flex; align-items: center; }
.logo-img { height: 54px; width: auto; transition: opacity 0.4s ease; }
.desktop-nav { display: flex; gap: 30px; }
.nav-link {
  font-size: 11px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase;
  text-decoration: none; color: var(--color-text-primary); position: relative; padding: 6px 0;
  transition: color 0.4s ease;
}
.nav-link::after {
  content: ''; position: absolute; left: 0; bottom: 0; width: 100%; height: 1px;
  background: var(--color-gold); transform: scaleX(0); transform-origin: left center;
  transition: transform 0.6s var(--ease-power4);
}
.nav-link:hover { color: var(--color-gold-deep); }
.nav-link:hover::after, .nav-link.is-current::after { transform: scaleX(1); }
.nav-link.is-current { color: var(--color-gold-deep); }
.header-actions { display: flex; align-items: center; gap: 6px; }
.icon-btn { background: none; border: 0; color: inherit; width: 42px; height: 42px; display: grid; place-items: center; transition: color 0.4s ease; }
.icon-btn:hover { color: var(--color-gold-deep); }
.hamburger-menu { display: none; background: none; border: 0; width: 42px; height: 42px; position: relative; z-index: 1300; flex-direction: column; align-items: center; justify-content: center; gap: 7px; }
.hamburger-menu span { display: block; width: 24px; height: 1.6px; background: var(--color-olive-deep); transition: transform 0.5s var(--ease-power4), background-color 0.4s ease; }
.hamburger-menu.active span:first-child { transform: translateY(4.3px) rotate(45deg); }
.hamburger-menu.active span:last-child { transform: translateY(-4.3px) rotate(-45deg); }

/* Transparent header over the home hero */
body[data-page="home"] .main-header:not(.scrolled) { background: linear-gradient(180deg, rgba(20, 26, 15, 0.5), transparent); }
body[data-page="home"] .main-header:not(.scrolled) .nav-link { color: rgba(250, 247, 242, 0.88); }
body[data-page="home"] .main-header:not(.scrolled) .nav-link:hover,
body[data-page="home"] .main-header:not(.scrolled) .nav-link.is-current { color: var(--color-gold); }
body[data-page="home"] .main-header:not(.scrolled) .icon-btn { color: var(--color-ivory); }
body[data-page="home"] .main-header:not(.scrolled) .hamburger-menu span { background: var(--color-ivory); }

/* Drawer-open header treatment */
body.drawer-open .main-header { background: transparent !important; border-color: transparent !important; box-shadow: none !important; -webkit-backdrop-filter: none; backdrop-filter: none; }
body.drawer-open .hamburger-menu span { background: var(--color-ivory); }
body.drawer-open .icon-btn { color: var(--color-ivory); }
body.drawer-open .logo-img { opacity: 0; }

/* ---------- Mobile drawer ---------- */
.mobile-drawer {
  position: fixed; inset: 0; background: var(--color-olive-ink); z-index: 1100;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transition: opacity 0.6s var(--ease-power4), visibility 0.6s;
}
.mobile-drawer::after {
  content: 'Ann\2019s Ensemble Picks'; position: absolute; bottom: 34px; left: 0; right: 0;
  text-align: center; font-family: var(--font-heading); font-style: italic;
  font-size: 15px; color: rgba(201, 169, 110, 0.55); letter-spacing: 1px;
}
.mobile-drawer.active { opacity: 1; visibility: visible; }
.mobile-nav-links { display: flex; flex-direction: column; align-items: center; gap: clamp(8px, 2.2vh, 20px); }
.mobile-nav-link {
  font-family: var(--font-heading); font-weight: 500; line-height: 1.15;
  font-size: clamp(32px, 6.5vh, 50px); color: var(--color-ivory);
  text-decoration: none; transition: color 0.4s ease, letter-spacing 0.5s var(--ease-power4);
}
.mobile-nav-link:hover { color: var(--color-gold); letter-spacing: 2px; }

/* ---------- Hero (upgraded, structure preserved) ---------- */
.hero-section {
  position: relative; min-height: 100svh; display: flex; align-items: center;
  overflow: hidden; background: transparent; color: var(--color-text-primary);
}
.hero-visual { position: absolute; inset: 0; z-index: 1; background-color: transparent; overflow: hidden; }
.video-container { position: absolute; inset: -4%; will-change: transform; }
.hero-bg-video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.desktop-video { display: block; }
.mobile-video { display: none; }
.video-overlay {
  position: absolute; inset: 0;
  background: radial-gradient(circle, transparent 20%, rgba(61, 79, 53, 0.05) 100%);
  pointer-events: none;
}
.hero-canvas {
  position: relative; z-index: 2; width: 100%; max-width: var(--container);
  margin: 0 auto; padding: 170px 48px 64px; min-height: 100svh;
  display: flex; flex-direction: column; justify-content: center; gap: 56px;
}
.canvas-content { max-width: 760px; }
.hero-title {
  font-family: var(--font-heading); font-weight: 500;
  font-size: clamp(56px, 8.6vw, 124px); line-height: 0.98; letter-spacing: -0.01em;
  color: #111b0d;
  text-shadow: 0.5px 0.5px 0px rgba(255, 255, 255, 0.85), 0px 1px 3px rgba(17, 27, 13, 0.06);
}
.title-italic { font-style: italic; color: var(--color-gold); }
.hero-divider { display: flex; align-items: center; gap: 18px; margin: 34px 0 26px; max-width: 420px; }
.divider-line { height: 1px; flex: 1; background: linear-gradient(90deg, transparent, rgba(201, 169, 110, 0.85)); transform-origin: left center; }
.hero-divider .divider-line:last-of-type { background: linear-gradient(90deg, rgba(201, 169, 110, 0.85), transparent); transform-origin: right center; }
.hero-tagline { font-family: var(--font-heading); font-style: italic; font-size: clamp(22px, 2.6vw, 32px); line-height: 1.25; color: var(--color-olive-deep); margin-bottom: 14px; }
.hero-description { font-size: 15px; font-weight: 300; letter-spacing: 0.02em; line-height: 1.85; color: var(--color-text-muted); margin-bottom: 38px; }
.hero-cta-wrapper { display: inline-block; }
.hero-cta-wrapper .cta-link { color: var(--color-text-primary); }
.pillars-container { max-width: 780px; }
.pillars-card {
  display: flex; align-items: stretch; gap: clamp(16px, 3vw, 36px);
  padding: 26px clamp(20px, 3vw, 36px);
  background: rgba(245, 237, 227, 0.6);
  backdrop-filter: blur(30px);
  -webkit-backdrop-filter: blur(30px);
  border: 1.5px solid rgba(255, 255, 255, 0.5);
  border-bottom: 2px solid rgba(201, 169, 110, 0.4);
  box-shadow: 0 12px 32px rgba(61, 79, 53, 0.06), inset 0 1px 0 rgba(255, 255, 255, 0.6);
}
.pillar-item { display: flex; align-items: center; gap: 14px; flex: 1; }
.pillar-icon { color: var(--color-gold); display: grid; place-items: center; width: 44px; height: 44px; border: 1px solid rgba(255, 255, 255, 0.2); background: rgba(255, 255, 255, 0.45); box-shadow: var(--shadow-soft); border-radius: 50%; flex-shrink: 0; }
.pillar-text h4 { font-size: 11px; font-weight: 800; letter-spacing: 2px; color: var(--color-olive-deep); }
.pillar-text p { font-size: 10px; font-weight: 600; letter-spacing: 1.6px; color: var(--color-text-muted); }
.pillar-divider { width: 1px; background: rgba(201, 169, 110, 0.25); }
.circular-badge-container {
  position: absolute; right: clamp(24px, 5vw, 72px); bottom: clamp(24px, 6vh, 64px);
  z-index: 3; width: 108px; height: 108px; display: grid; place-items: center; color: var(--color-ivory);
}
.circular-badge { position: absolute; inset: 0; width: 100%; height: 100%; }
.circular-badge text { font-family: var(--font-body); font-size: 8px; font-weight: 700; letter-spacing: 2.4px; text-transform: uppercase; fill: rgba(250, 247, 242, 0.85); }
.badge-center-icon { position: relative; }

/* ---------- CTA link ---------- */
.cta-link {
  display: inline-flex; align-items: center; gap: 14px;
  font-size: 12px; font-weight: 800; letter-spacing: 2.5px; text-transform: uppercase;
  text-decoration: none; color: var(--color-olive-deep);
  padding-bottom: 10px; position: relative; margin-top: 8px;
}
.cta-link::after {
  content: ''; position: absolute; left: 0; bottom: 0; width: 100%; height: 1px;
  background: var(--color-gold); transform: scaleX(0.35); transform-origin: left center;
  transition: transform 0.7s var(--ease-power4);
}
.cta-link:hover::after { transform: scaleX(1); }
.cta-arrow { color: var(--color-gold); transition: transform 0.5s var(--ease-power4); flex-shrink: 0; }
.cta-link:hover .cta-arrow { transform: translateX(6px); }
.bg-olive-deep .cta-link, .text-light .cta-link { color: var(--color-ivory); }

/* ---------- Sections & typography ---------- */
.section-container { max-width: var(--container); margin: 0 auto; padding: 0 48px; }
.editorial-section { position: relative; }
.padding-lg { padding: 120px 0; }
.padding-md { padding: 90px 0; }
.text-center { text-align: center; }
.margin-top-md { margin-top: 48px; }
.section-kicker { display: inline-block; font-size: 11px; font-weight: 800; letter-spacing: 3.5px; text-transform: uppercase; color: var(--color-gold-deep); margin-bottom: 18px; }
.gold-text { color: var(--color-gold) !important; }
.section-heading { font-family: var(--font-heading); font-weight: 500; font-size: clamp(34px, 4.6vw, 58px); line-height: 1.06; color: var(--color-olive-deep); margin-bottom: 8px; }
.light-text { color: var(--color-ivory) !important; }
.section-divider-small { width: 64px; height: 1.5px; background: var(--color-gold); margin: 22px 0 28px; }
.section-divider-center { width: 64px; height: 1.5px; background: var(--color-gold); margin: 22px auto 28px; }
.gold-bg { background: var(--color-gold) !important; }
.section-sub-copy { max-width: 640px; margin: 0 auto 40px; font-size: 15.5px; font-weight: 300; line-height: 1.85; color: var(--color-text-muted); }
.paragraph-lead { font-family: var(--font-heading); font-style: italic; font-size: 22px; line-height: 1.5; color: var(--color-olive-deep); margin-bottom: 20px; }
.paragraph-body { font-size: 15px; font-weight: 300; line-height: 1.9; color: var(--color-text-muted); margin-bottom: 18px; }
.bg-cream { background: var(--color-cream); }
.bg-sage-light { background: var(--color-sage-light); }
.bg-olive-deep { background: var(--color-olive-ink); }
.text-light { color: var(--color-ivory); }
.bg-olive-deep .section-sub-copy { color: rgba(250, 247, 242, 0.65); }

.section-spacer-stitch { padding: 10px 0; }
.stitch-pattern {
  height: 1px; width: min(420px, 70%); margin: 0 auto; position: relative;
  background-image: linear-gradient(90deg, rgba(201, 169, 110, 0.5) 0 6px, transparent 6px 12px);
  background-size: 12px 1px;
}
.stitch-pattern::after {
  content: ''; position: absolute; left: 50%; top: 50%; width: 7px; height: 7px;
  background: var(--color-ivory); border: 1px solid var(--color-gold);
  transform: translate(-50%, -50%) rotate(45deg);
}

/* ---------- Editorial grid ---------- */
.editorial-grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 80px; align-items: center; }
.atelier-meta-info { margin-top: 40px; padding-top: 28px; border-top: 1px dashed rgba(201, 169, 110, 0.4); display: flex; flex-direction: column; gap: 14px; }
.meta-row { display: flex; gap: 12px; align-items: flex-start; font-size: 13.5px; color: var(--color-text-muted); }
.meta-row svg { color: var(--color-gold); flex-shrink: 0; margin-top: 2px; }
.meta-row strong { color: var(--color-olive-deep); }
.visual-stack { display: flex; flex-direction: column; gap: 28px; }
.bni-frame-badge { background: var(--color-white); border: 1px solid rgba(201, 169, 110, 0.22); padding: 28px; text-align: center; box-shadow: var(--shadow-soft); }
.badge-label { display: block; font-size: 10px; font-weight: 800; letter-spacing: 2.5px; text-transform: uppercase; color: var(--color-gold-deep); margin-bottom: 14px; }
.bni-badge-img { max-width: 200px; width: 100%; height: auto; margin: 0 auto 10px; }
.bni-text { font-size: 12.5px; color: var(--color-text-muted); letter-spacing: 0.4px; }
.stitch-decorative-box { position: relative; background: var(--color-olive-ink); padding: 14px; box-shadow: var(--shadow-deep); }
.box-stitch-line { position: absolute; inset: 10px; border: 1px dashed rgba(201, 169, 110, 0.5); pointer-events: none; }
.box-content { padding: 34px 28px; text-align: center; }
.box-kicker { font-size: 10px; letter-spacing: 3px; font-weight: 800; color: var(--color-gold); text-transform: uppercase; }
.box-content h3 { font-family: var(--font-heading); font-size: 30px; color: var(--color-ivory); margin: 10px 0 8px; font-weight: 500; }
.box-tag { font-size: 13px; font-weight: 300; color: rgba(250, 247, 242, 0.6); line-height: 1.7; }

/* ---------- Disciplines ---------- */
.disciplines-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin: 48px 0; text-align: center; }
.discipline-card { position: relative; overflow: hidden; background: var(--color-white); border: 1px solid rgba(201, 169, 110, 0.16); padding: 38px 26px; transition: translate 0.7s var(--ease-power4), box-shadow 0.7s var(--ease-power4), border-color 0.7s ease; }
.discipline-card:hover { translate: 0 -8px; box-shadow: var(--shadow-deep); border-color: rgba(201, 169, 110, 0.45); }
.disc-icon { display: grid; place-items: center; width: 64px; height: 64px; margin: 0 auto 20px; border: 1px solid rgba(201, 169, 110, 0.3); border-radius: 50%; transition: var(--transition-smooth); }
.discipline-card:hover .disc-icon { transform: rotate(8deg) scale(1.06); border-color: var(--color-gold); }
.discipline-card h3 { font-family: var(--font-heading); font-size: 22px; font-weight: 600; color: var(--color-olive-deep); margin-bottom: 10px; }
.discipline-card p { font-size: 13.5px; font-weight: 300; line-height: 1.75; color: var(--color-text-muted); }

/* ---------- Collections (4 framed cards — framing preserved) ---------- */
.collections-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 40px; margin: 56px 0; text-align: left; }
.collection-card { position: relative; background: var(--color-white); border: 1px solid rgba(201, 169, 110, 0.16); display: flex; flex-direction: column; transition: translate 0.7s var(--ease-power4), box-shadow 0.7s var(--ease-power4), border-color 0.7s ease; }
.collection-card:hover { translate: 0 -8px; box-shadow: var(--shadow-deep); border-color: rgba(201, 169, 110, 0.45); }
.coll-img-wrap { position: relative; aspect-ratio: 4 / 3; overflow: hidden; background: var(--color-linen); }
.coll-img { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
.coll-badge {
  position: absolute; top: 16px; left: 16px; z-index: 2;
  background: rgba(38, 48, 31, 0.85); color: var(--color-ivory);
  font-size: 10px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase;
  padding: 8px 14px; -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
}
.coll-content { padding: 30px 30px 34px; display: flex; flex-direction: column; flex: 1; }
.coll-content h3 { font-family: var(--font-heading); font-size: 26px; font-weight: 600; color: var(--color-olive-deep); line-height: 1.2; }
.coll-price { font-size: 11px; font-weight: 800; letter-spacing: 2px; color: var(--color-gold-deep); text-transform: uppercase; margin: 6px 0 14px; }
.coll-desc { font-size: 14px; font-weight: 300; line-height: 1.8; color: var(--color-text-muted); margin-bottom: 24px; flex: 1; }
.coll-enquire-btn {
  align-self: flex-start; display: inline-flex; align-items: center; gap: 12px;
  border: 1px solid rgba(201, 169, 110, 0.4); padding: 13px 24px;
  font-size: 11px; font-weight: 800; letter-spacing: 1.8px; text-transform: uppercase;
  text-decoration: none; color: var(--color-olive-deep); transition: var(--transition-smooth);
}
.coll-enquire-btn:hover { background: var(--color-olive-ink); border-color: var(--color-olive-ink); color: var(--color-ivory); }
.coll-enquire-btn svg { color: var(--color-gold); }

/* ---------- Promise grid (dark) ---------- */
.promise-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 54px; text-align: left; }
.promise-card {
  border: 1px solid rgba(201, 169, 110, 0.25); padding: 34px 28px;
  display: flex; gap: 20px; align-items: flex-start;
  background: rgba(250, 247, 242, 0.03);
  transition: translate 0.7s var(--ease-power4), border-color 0.7s ease, background-color 0.7s ease;
}
.promise-card:hover { border-color: rgba(201, 169, 110, 0.6); background: rgba(250, 247, 242, 0.06); translate: 0 -6px; }
.promise-num { font-family: var(--font-heading); font-style: italic; font-size: 40px; color: var(--color-gold); line-height: 1; }
.promise-card-content h3 { font-family: var(--font-heading); font-size: 21px; font-weight: 600; color: var(--color-ivory); margin-bottom: 8px; }
.promise-card-content p { font-size: 13.5px; font-weight: 300; line-height: 1.75; color: rgba(250, 247, 242, 0.6); }

/* ---------- Process timeline ---------- */
.process-timeline { display: flex; align-items: flex-start; gap: 18px; margin-top: 56px; }
.process-step { flex: 1; text-align: center; padding: 0 12px; }
.step-circle {
  width: 56px; height: 56px; border-radius: 50%; border: 1px solid var(--color-gold);
  display: grid; place-items: center; margin: 0 auto 18px;
  font-family: var(--font-heading); font-size: 22px; color: var(--color-gold-deep);
  background: var(--color-white);
}
.process-step h3 { font-family: var(--font-heading); font-size: 21px; font-weight: 600; color: var(--color-olive-deep); margin-bottom: 8px; }
.process-step p { font-size: 13.5px; font-weight: 300; color: var(--color-text-muted); line-height: 1.7; max-width: 260px; margin: 0 auto; }
.process-line {
  flex: 1 1 auto; max-width: 90px; height: 1px; margin-top: 28px;
  background-image: linear-gradient(90deg, var(--color-gold) 0 4px, transparent 4px 8px);
  background-size: 8px 1px;
}

/* ---------- Testimonials ---------- */
.reviews-aggregate { display: flex; align-items: baseline; justify-content: center; gap: 12px; margin-bottom: 30px; flex-wrap: wrap; }
.rating-num { font-family: var(--font-heading); font-size: 54px; color: var(--color-olive-deep); line-height: 1; }
.rating-stars { color: var(--color-gold); font-size: 18px; letter-spacing: 3px; }
.rating-context { width: 100%; text-align: center; font-size: 12px; color: var(--color-text-muted); letter-spacing: 0.5px; }
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 30px; text-align: left; }
.testimonial-card { background: var(--color-white); border: 1px solid rgba(201, 169, 110, 0.16); padding: 32px 28px; transition: translate 0.7s var(--ease-power4), box-shadow 0.7s var(--ease-power4); }
.testimonial-card:hover { translate: 0 -6px; box-shadow: var(--shadow-deep); }
.t-header { display: flex; gap: 14px; align-items: center; margin-bottom: 18px; }
.t-avatar { width: 52px; height: 52px; border-radius: 50%; object-fit: cover; border: 1px solid rgba(201, 169, 110, 0.35); }
.t-user-info h4 { font-size: 15px; font-weight: 700; color: var(--color-olive-deep); }
.t-user-info p { font-size: 11.5px; color: var(--color-text-muted); }
.t-stars { font-size: 12px; color: var(--color-gold); margin-top: 2px; }
.badge-verified { font-size: 10px; background: var(--color-sage-light); padding: 2px 8px; border-radius: 20px; color: var(--color-olive-deep); font-weight: 700; }
.t-quote { font-size: 13.5px; font-weight: 300; line-height: 1.85; color: var(--color-text-muted); font-style: italic; }
.reviews-link-btn {
  display: inline-block; border: 1px solid rgba(201, 169, 110, 0.45); padding: 15px 34px;
  font-size: 11px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase;
  color: var(--color-olive-deep); text-decoration: none;
  transition: background-color 0.7s ease, border-color 0.7s ease, color 0.7s ease;
}
.reviews-link-btn:hover { background: var(--color-olive-ink); border-color: var(--color-olive-ink); color: var(--color-ivory); }

/* ---------- Social pills ---------- */
.social-links-wrapper { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; margin-top: 36px; }
.social-link-pill {
  padding: 15px 30px; border: 1px solid rgba(201, 169, 110, 0.4); border-radius: 50px;
  font-size: 11px; font-weight: 800; letter-spacing: 1.8px; text-transform: uppercase;
  text-decoration: none; color: var(--color-olive-deep); background: var(--color-white);
  transition: var(--transition-smooth);
}
.social-link-pill:hover { background: var(--color-olive-ink); border-color: var(--color-olive-ink); color: var(--color-ivory); transform: translateY(-3px); }

/* ---------- Footer ---------- */
.atelier-footer { background: var(--color-olive-ink); color: rgba(250, 247, 242, 0.7); position: relative; }
.footer-stitch { height: 1px; background-image: linear-gradient(90deg, rgba(201, 169, 110, 0.55) 0 8px, transparent 8px 16px); background-size: 16px 1px; }
.footer-container { max-width: var(--container); margin: 0 auto; padding: 72px 48px 36px; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 48px; padding-bottom: 48px; border-bottom: 1px solid rgba(250, 247, 242, 0.08); }
.footer-logo-img { height: 58px; width: auto; margin-bottom: 18px; border-radius: var(--border-radius); }
.footer-brand-desc { font-size: 13.5px; font-weight: 300; line-height: 1.8; margin-bottom: 20px; max-width: 300px; }
.footer-bni-badge { max-width: 130px; background: var(--color-ivory); padding: 8px; border-radius: var(--border-radius); }
.footer-col h4 { font-family: var(--font-heading); color: var(--color-gold); font-size: 19px; font-weight: 600; margin-bottom: 18px; letter-spacing: 0.4px; }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 11px; }
.footer-col a { font-size: 13.5px; color: rgba(250, 247, 242, 0.65); text-decoration: none; transition: color 0.4s ease, padding-left 0.4s var(--ease-power4); }
.footer-col a:hover { color: var(--color-gold); padding-left: 6px; }
.gstin-label { font-size: 12px; letter-spacing: 0.5px; color: rgba(250, 247, 242, 0.45); }
.footer-bottom { padding-top: 28px; text-align: center; }
.footer-copy { font-size: 12px; color: rgba(250, 247, 242, 0.45); }
.footer-copy a { color: var(--color-gold); text-decoration: none; }

/* ---------- Inner pages chrome ---------- */
.header-padding { padding-top: 150px; }
.breadcrumbs { display: flex; align-items: center; gap: 12px; padding: 6px 0 34px; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; font-weight: 700; }
.breadcrumbs a { color: var(--color-text-muted); text-decoration: none; transition: color 0.3s ease; }
.breadcrumbs a:hover { color: var(--color-gold-deep); }
.breadcrumbs .separator { width: 26px; height: 1px; background: var(--color-gold); }
.breadcrumbs span:last-child { color: var(--color-gold-deep); }
@keyframes pageFade { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
.animate-fade-in { animation: pageFade 0.9s var(--ease-power4) both; }

/* ---------- Lookbook (uncropped masonry) ---------- */
.lookbook-filters { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; margin: 10px 0 56px; }
.filter-btn {
  border: 1px solid rgba(201, 169, 110, 0.35); background: transparent; border-radius: 40px;
  padding: 11px 22px; font-size: 11px; font-weight: 800; letter-spacing: 1.6px; text-transform: uppercase;
  color: var(--color-text-muted); transition: var(--transition-smooth);
}
.filter-btn:hover { color: var(--color-olive-deep); border-color: var(--color-gold); }
.filter-btn.active { background: var(--color-olive-ink); border-color: var(--color-olive-ink); color: var(--color-ivory); }
.lookbook-grid { columns: 3 300px; column-gap: 26px; padding-bottom: 110px; }
.lookbook-card {
  break-inside: avoid; -webkit-column-break-inside: avoid; page-break-inside: avoid;
  margin-bottom: 26px; background: var(--color-white);
  border: 1px solid rgba(201, 169, 110, 0.16); cursor: pointer;
  transition: translate 0.7s var(--ease-power4), box-shadow 0.7s var(--ease-power4), border-color 0.7s ease;
}
.lookbook-card:hover { translate: 0 -6px; box-shadow: var(--shadow-deep); border-color: rgba(201, 169, 110, 0.5); }
.lookbook-img-wrap { background: var(--color-linen); }
.lookbook-img { width: 100%; height: auto; display: block; } /* natural ratio — never cropped */
.lookbook-info { display: flex; justify-content: space-between; align-items: flex-end; gap: 14px; padding: 18px 20px 20px; }
.lookbook-info p { font-size: 10px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: var(--color-gold-deep); margin-bottom: 6px; }
.lookbook-info h3 { font-family: var(--font-heading); font-size: 19px; font-weight: 600; color: var(--color-olive-deep); line-height: 1.25; }
.lookbook-action { display: inline-flex; align-items: center; gap: 8px; font-size: 10px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; color: var(--color-text-muted); text-decoration: none; white-space: nowrap; transition: color 0.4s ease; }
.lookbook-action svg { color: var(--color-gold); }
.lookbook-card:hover .lookbook-action { color: var(--color-olive-deep); }

/* ---------- Lightbox ---------- */
.lightbox-modal {
  position: fixed; inset: 0; z-index: 1450; padding: 24px;
  background: rgba(24, 30, 18, 0.92);
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  display: grid; place-items: center;
  opacity: 0; visibility: hidden;
  transition: opacity 0.5s var(--ease-power4), visibility 0.5s;
}
.lightbox-modal.active { opacity: 1; visibility: visible; }
.lightbox-content-wrap { position: relative; max-width: min(920px, 94vw); text-align: center; }
.lightbox-img { max-width: 100%; max-height: 66vh; width: auto; height: auto; object-fit: contain; box-shadow: var(--shadow-deep); }
.lightbox-caption { margin: 20px 0 16px; color: var(--color-ivory); }
.lightbox-caption h3 { font-family: var(--font-heading); font-size: 26px; font-weight: 500; }
.lightbox-caption p { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--color-gold); margin-top: 6px; }
.lightbox-close { position: fixed; top: 18px; right: 26px; z-index: 2; background: none; border: 0; color: var(--color-ivory); font-size: 44px; line-height: 1; font-weight: 300; transition: color 0.3s ease, transform 0.4s var(--ease-power4); }
.lightbox-close:hover { color: var(--color-gold); transform: rotate(90deg); }
.lightbox-inquiry-btn {
  display: inline-block; background: var(--color-gold); color: var(--color-olive-ink);
  padding: 15px 34px; font-size: 11px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase;
  text-decoration: none; transition: var(--transition-smooth);
}
.lightbox-inquiry-btn:hover { background: var(--color-ivory); }

/* ---------- Procurement (shop) scrollytelling chrome ---------- */
.procure-marquee { overflow: hidden; pointer-events: none; padding: 26px 0 6px; white-space: nowrap; }
.procure-marquee-track { display: inline-flex; will-change: transform; }
.procure-marquee-track span {
  font-family: var(--font-heading); font-style: italic; font-weight: 500; line-height: 1;
  font-size: clamp(64px, 11vw, 150px); color: transparent;
  -webkit-text-stroke: 1px rgba(201, 169, 110, 0.45);
}
@media (min-width: 1024px) {
  .procure-marquee-track span {
    -webkit-text-stroke: 1px rgba(61, 79, 53, 0.7);
  }
}
.procure-rail {
  position: fixed; left: clamp(14px, 2.6vw, 40px); top: 50%; transform: translateY(-50%);
  z-index: 900; display: flex; gap: 18px; align-items: stretch;
  opacity: 0; visibility: hidden;
  transition: opacity 0.6s var(--ease-power4), visibility 0.6s;
}
.procure-rail.is-visible { opacity: 1; visibility: visible; }
.rail-line { width: 1px; background: rgba(201, 169, 110, 0.25); position: relative; }
.rail-line i { position: absolute; inset: 0; background: var(--color-gold); transform: scaleY(0); transform-origin: top center; }
.procure-rail ol { list-style: none; display: flex; flex-direction: column; justify-content: space-between; gap: 30px; padding: 4px 0; }
.procure-rail li { font-size: 10px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: var(--color-text-muted); display: flex; flex-direction: column; gap: 2px; transition: color 0.4s ease; }
.procure-rail li span { font-family: var(--font-heading); font-style: italic; font-size: 16px; color: rgba(201, 169, 110, 0.55); letter-spacing: 0; transition: color 0.4s ease; }
.procure-rail li.active { color: var(--color-olive-deep); }
.procure-rail li.active span { color: var(--color-gold-deep); }
@media (max-width: 1100px) { .procure-rail { display: none; } }

/* ---------- Forms ---------- */
.enquiry-form-wrapper { max-width: 780px; margin: 30px auto 0; }
.editorial-form { display: flex; flex-direction: column; gap: 30px; background: var(--color-white); border: 1px solid rgba(201, 169, 110, 0.18); padding: clamp(28px, 5vw, 56px); text-align: left; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; }
.form-field { display: flex; flex-direction: column; gap: 10px; }
.form-field label { font-size: 11px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: var(--color-olive-deep); }
.form-field input, .form-field select, .form-field textarea {
  background: transparent; border: 0; border-bottom: 1px solid rgba(201, 169, 110, 0.4);
  border-radius: 0; padding: 12px 2px;
  font-family: var(--font-body); font-size: 15px; color: var(--color-text-primary);
  outline: none; transition: border-color 0.4s ease; resize: vertical;
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { border-bottom-color: var(--color-olive-deep); }
.form-submit-btn {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--color-olive-ink); color: var(--color-ivory);
  border: 1px solid var(--color-olive-ink);
  font-size: 12px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase;
  transition: var(--transition-smooth);
}
.form-submit-btn:hover { background: var(--color-gold); border-color: var(--color-gold); color: var(--color-olive-ink); }

/* ---------- Invoice / payments ---------- */
.payment-tag-card { max-width: 980px; margin: 0 auto; }
.tag-body { display: grid; grid-template-columns: 1fr 1.3fr; gap: clamp(28px, 5vw, 64px); align-items: center; }
.tag-qr-section { text-align: center; }
.qr-container { background: var(--color-ivory); padding: 18px; display: inline-block; border: 1px solid rgba(201, 169, 110, 0.35); }
.payment-qr-img { width: 230px; max-width: 64vw; height: auto; display: block; }
.qr-caption { margin-top: 14px; font-size: 12.5px; color: rgba(250, 247, 242, 0.6); }
.upi-id-badge {
  display: inline-flex; align-items: center; gap: 12px; margin-top: 14px;
  border: 1px dashed rgba(201, 169, 110, 0.6); padding: 11px 18px;
  font-size: 13px; color: var(--color-ivory); letter-spacing: 0.5px; cursor: pointer;
  transition: var(--transition-smooth);
}
.upi-id-badge:hover { border-style: solid; background: rgba(201, 169, 110, 0.12); }
.upi-id-badge span { font-size: 10px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; color: var(--color-gold); }
.tag-bank-details h3 { font-family: var(--font-heading); font-size: 28px; color: var(--color-ivory); margin-bottom: 22px; font-weight: 500; }
.bank-detail-item { display: grid; grid-template-columns: 160px 1fr auto; gap: 12px; align-items: center; padding: 13px 0; border-bottom: 1px solid rgba(250, 247, 242, 0.1); font-size: 14px; }
.detail-label { font-size: 11px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(250, 247, 242, 0.5); }
.detail-value { color: var(--color-ivory); font-weight: 600; word-break: break-all; }
.mono { font-family: 'SF Mono', Consolas, Menlo, monospace; letter-spacing: 1px; font-weight: 400; }
.copy-hint {
  font-size: 10px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--color-gold); cursor: pointer; border: 1px solid rgba(201, 169, 110, 0.4);
  padding: 6px 12px; transition: var(--transition-smooth);
}
.copy-hint:hover { background: var(--color-gold); color: var(--color-olive-ink); }

/* ---------- Contact ---------- */
.contact-details-block h2 { font-family: var(--font-heading); font-size: 32px; color: var(--color-olive-deep); font-weight: 500; margin-bottom: 6px; }
.contact-details-block .bni-frame-badge { margin-top: 36px; display: flex; align-items: center; gap: 18px; text-align: left; }
.contact-details-block .bni-badge-img { max-width: 110px; margin: 0; }

/* ---------- Legal ---------- */
.legal-content { max-width: 820px; margin: 0 auto 100px; }

/* ---------- Search overlay ---------- */
.search-overlay {
  position: fixed; inset: 0; z-index: 1400;
  background: rgba(250, 247, 242, 0.97);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  opacity: 0; visibility: hidden;
  transition: opacity 0.5s var(--ease-power4), visibility 0.5s;
}
.search-overlay.active { opacity: 1; visibility: visible; }
.search-close-btn { position: absolute; top: 26px; right: 34px; font-size: 40px; background: none; border: 0; color: var(--color-olive-deep); font-weight: 300; transition: color 0.3s ease, transform 0.4s var(--ease-power4); }
.search-close-btn:hover { color: var(--color-gold-deep); transform: rotate(90deg); }
.search-content-box { width: min(820px, 92vw); margin: 0 auto; padding: 120px 0 40px; height: 100%; display: flex; flex-direction: column; }
.search-header-text span { display: inline-block; font-size: 11px; font-weight: 800; letter-spacing: 3.5px; text-transform: uppercase; color: var(--color-gold-deep); margin-bottom: 12px; }
.search-header-text h2 { font-family: var(--font-heading); font-weight: 500; font-size: clamp(28px, 4vw, 44px); color: var(--color-olive-deep); margin-bottom: 28px; }
.search-input-wrap { display: flex; align-items: center; gap: 16px; border-bottom: 1px solid rgba(201, 169, 110, 0.5); padding-bottom: 14px; color: var(--color-gold-deep); }
.search-input-field { flex: 1; border: 0; background: none; outline: none; font-family: var(--font-heading); font-size: clamp(20px, 3vw, 30px); color: var(--color-olive-deep); }
.search-input-field::placeholder { color: rgba(118, 121, 106, 0.55); font-style: italic; }
.search-results-container { overflow-y: auto; flex: 1; margin-top: 28px; }
.search-result-item { display: flex; align-items: center; gap: 16px; padding: 14px 10px; text-decoration: none; border-bottom: 1px solid rgba(201, 169, 110, 0.12); transition: background-color 0.3s ease; }
.search-result-item:hover { background: var(--color-cream); }
.search-result-thumb-container { width: 54px; height: 54px; flex: 0 0 54px; display: grid; place-items: center; background: var(--color-cream); overflow: hidden; }
.search-result-thumb { width: 100%; height: 100%; object-fit: cover; }
.search-result-icon { color: var(--color-gold); }
.search-result-info { flex: 1; min-width: 0; }
.search-result-category { font-size: 10px; font-weight: 800; letter-spacing: 1.6px; text-transform: uppercase; color: var(--color-gold-deep); }
.search-result-title { font-family: var(--font-heading); font-size: 18px; color: var(--color-olive-deep); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.search-result-item > svg { color: var(--color-gold); flex-shrink: 0; }
.search-no-results { padding: 40px 0; text-align: center; color: var(--color-text-muted); font-style: italic; font-family: var(--font-heading); font-size: 20px; }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 1023px) {
  .desktop-nav { display: none; }
  .hamburger-menu { display: flex; }
  .header-container { padding: 12px 24px; }
  .section-container { padding: 0 24px; }
  .editorial-grid { grid-template-columns: 1fr; gap: 48px; }
  .disciplines-grid { grid-template-columns: repeat(2, 1fr); }
  .promise-grid { grid-template-columns: repeat(2, 1fr); }
  .testimonials-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
  .footer-container { padding: 56px 24px 30px; }
}

@media (max-width: 860px) {
  .tag-body { grid-template-columns: 1fr; }
  .bank-detail-item { grid-template-columns: 1fr auto; }
  .bank-detail-item .detail-label { grid-column: 1 / -1; padding-bottom: 2px; }
}

@media (max-width: 767px) {
  .padding-lg { padding: 76px 0; }
  .padding-md { padding: 58px 0; }
  .header-padding { padding-top: 118px; }
  .logo-img { height: 44px; }
  .desktop-video { display: none; }
  .mobile-video { display: block; }
  .hero-canvas { padding: 128px 22px 96px; gap: 38px; }
  .hero-title { font-size: clamp(48px, 14vw, 64px); }
  .hero-divider { margin: 26px 0 20px; }
  .hero-description { margin-bottom: 30px; }
  .pillars-card { flex-direction: column; align-items: stretch; gap: 18px; padding: 22px; }
  .pillar-divider { width: 100%; height: 1px; }
  .circular-badge-container { width: 84px; height: 84px; right: 16px; bottom: 16px; }
  .collections-grid { grid-template-columns: 1fr; gap: 28px; }
  .process-timeline { flex-direction: column; align-items: center; gap: 6px; }
  .process-line { width: 1px; height: 44px; max-width: none; margin: 6px 0; background-image: linear-gradient(180deg, var(--color-gold) 0 4px, transparent 4px 8px); background-size: 1px 8px; }
  .form-row { grid-template-columns: 1fr; }
  .lookbook-grid { columns: 2 160px; column-gap: 14px; }
  .lookbook-card { margin-bottom: 14px; }
  .lookbook-info { padding: 12px 14px 14px; }
  .lookbook-info h3 { font-size: 15px; }
  .lookbook-action span { display: none; }
  .search-close-btn { top: 16px; right: 18px; }
  .search-content-box { padding-top: 90px; }
}

@media (max-width: 600px) {
  .promise-grid { grid-template-columns: 1fr; }
  .disciplines-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   Homepage flagship layer
   ========================================================================== */

/* shop scrub imagery: CSS transitions must never fight ScrollTrigger scrub */
.block-large-img img, .split-item-img img, .block-full-img img { transition: none !important; }

/* vertical side label */
.side-label {
  position: absolute; top: 150px; right: 36px; z-index: 2;
  writing-mode: vertical-rl;
  font-size: 10px; font-weight: 800; letter-spacing: 4px; text-transform: uppercase;
  color: rgba(174, 142, 81, 0.55);
}

/* editorial drop cap */
.dropcap::first-letter {
  float: left; font-size: 3.1em; line-height: 0.82;
  padding: 6px 12px 0 0; color: var(--color-gold-deep); font-style: normal;
}

/* atelier stats strip */
.stats-strip {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
  margin-top: 80px; padding-top: 48px;
  border-top: 1px solid rgba(201, 169, 110, 0.25);
}
.stat-item { text-align: center; }
.stat-num {
  display: block; font-family: var(--font-heading); font-style: italic;
  font-size: clamp(40px, 4.6vw, 64px); line-height: 1; color: var(--color-olive-deep);
}
.stat-label {
  display: block; margin-top: 10px;
  font-size: 10px; font-weight: 800; letter-spacing: 2.5px; text-transform: uppercase;
  color: var(--color-text-muted);
}

/* outline craft marquee ribbon */
.craft-marquee {
  overflow: hidden; white-space: nowrap; padding: 34px 0;
  border-top: 1px solid rgba(201, 169, 110, 0.14);
  border-bottom: 1px solid rgba(201, 169, 110, 0.14);
}
.craft-marquee-track { display: inline-flex; will-change: transform; }
.craft-marquee-track span {
  font-family: var(--font-heading); font-style: italic; font-weight: 500; line-height: 1;
  font-size: clamp(40px, 6vw, 84px); color: transparent;
  -webkit-text-stroke: 1px rgba(201, 169, 110, 0.5);
}

/* discipline ghost numerals */
.disc-num {
  position: absolute; top: 8px; right: 16px; pointer-events: none;
  font-family: var(--font-heading); font-style: italic;
  font-size: 64px; line-height: 1; color: rgba(201, 169, 110, 0.16);
}

/* editorial offset collections */
.collections-grid--editorial { align-items: start; }
.collections-grid--editorial .collection-card:nth-child(even) { margin-top: 70px; }
.coll-index {
  display: block; font-family: var(--font-heading); font-style: italic;
  font-size: 30px; line-height: 1; color: rgba(174, 142, 81, 0.5); margin-bottom: 8px;
}

/* interactive WebGL loom interlude */
.loom-section {
  position: relative; height: min(78vh, 720px); min-height: 420px;
  background: var(--color-olive-ink);
  background-image: radial-gradient(ellipse at 50% 110%, rgba(201, 169, 110, 0.16), transparent 60%);
  overflow: hidden; display: grid; place-items: center;
}
#loom-canvas { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
.loom-overlay { position: relative; z-index: 2; text-align: center; pointer-events: none; padding: 0 24px; }
.loom-overlay .section-heading { text-shadow: 0 4px 30px rgba(0, 0, 0, 0.35); }
.loom-hint {
  margin-top: 6px; font-size: 11px; font-weight: 700; letter-spacing: 2.5px;
  text-transform: uppercase; color: rgba(250, 247, 242, 0.55);
}

/* concierge duo */
.duo-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.duo-card {
  padding: clamp(36px, 5vw, 64px);
  border: 1px solid rgba(201, 169, 110, 0.25);
  transition: translate 0.7s var(--ease-power4), box-shadow 0.7s var(--ease-power4);
}
.duo-card:hover { translate: 0 -6px; box-shadow: var(--shadow-deep); }
.duo-card h3 {
  font-family: var(--font-heading); font-weight: 500; line-height: 1.15;
  font-size: clamp(26px, 3vw, 38px); margin-bottom: 14px;
}
.duo-card p { font-size: 14.5px; font-weight: 300; line-height: 1.85; margin-bottom: 24px; max-width: 460px; }
.duo-card--dark { background: var(--color-olive-ink); color: rgba(250, 247, 242, 0.7); }
.duo-card--dark h3 { color: var(--color-ivory); }
.duo-card--dark .cta-link { color: var(--color-ivory); }
.duo-card--cream { background: var(--color-cream); color: var(--color-text-muted); }
.duo-card--cream h3 { color: var(--color-olive-deep); }

/* grand CTA banner */
.cta-banner { position: relative; overflow: hidden; background: var(--color-olive-ink); padding: 130px 0 140px; }
.cta-banner::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 130%, rgba(201, 169, 110, 0.2), transparent 62%);
}
.banner-title {
  position: relative; z-index: 2;
  font-family: var(--font-heading); font-weight: 500; line-height: 1;
  font-size: clamp(30px, 8.4vw, 128px); color: var(--color-ivory);
  margin: 6px 0 44px; white-space: nowrap;
}
.banner-title em { font-style: italic; color: var(--color-gold); }
.banner-btn {
  position: relative; z-index: 2; display: inline-block;
  border: 1px solid var(--color-gold); border-radius: 60px;
  color: var(--color-ivory); padding: 20px 46px;
  font-size: 12px; font-weight: 800; letter-spacing: 2.5px; text-transform: uppercase;
  text-decoration: none;
  transition: background-color 0.7s ease, color 0.7s ease;
}
.banner-btn:hover { background: var(--color-gold); color: var(--color-olive-ink); }

@media (max-width: 1023px) {
  .side-label { display: none; }
}
@media (max-width: 860px) {
  .duo-grid { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
  .stats-strip { grid-template-columns: repeat(2, 1fr); gap: 32px 16px; margin-top: 56px; padding-top: 36px; }
  .collections-grid--editorial .collection-card:nth-child(even) { margin-top: 0; }
  .craft-marquee { padding: 22px 0; }
  .cta-banner { padding: 90px 0 100px; }
  .loom-section { height: 62vh; min-height: 380px; }
}

/* ---------- Mobile quick-action bar ---------- */
.quick-bar {
  position: fixed; left: 14px; right: 14px;
  bottom: calc(12px + env(safe-area-inset-bottom, 0px));
  z-index: 1190;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px;
  background: rgba(38, 48, 31, 0.92);
  -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
  border: 1px solid rgba(201, 169, 110, 0.3);
  border-radius: 20px; padding: 8px;
  box-shadow: 0 18px 40px -16px rgba(0, 0, 0, 0.45);
  transition: transform 0.6s var(--ease-power4), opacity 0.6s ease;
}
.quick-bar.qb-hidden, body.drawer-open .quick-bar { transform: translateY(170%); }
.qb-item {
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px;
  padding: 8px 2px; border: 0; background: none; border-radius: 14px;
  color: rgba(250, 247, 242, 0.8); text-decoration: none;
  font-family: var(--font-body);
  font-size: 9px; font-weight: 800; letter-spacing: 1.2px; text-transform: uppercase;
}
.qb-item svg { width: 20px; height: 20px; }
.qb-item.active { color: var(--color-gold); }
.qb-item--wa { background: var(--color-gold); color: var(--color-olive-ink); }
body.has-quick-bar .footer-container { padding-bottom: 120px; }

/* ---------- Touch feedback (no-hover devices) ---------- */
@media (hover: none) {
  .collection-card:active, .lookbook-card:active, .discipline-card:active,
  .testimonial-card:active, .duo-card:active { translate: 0 -3px; }
  .coll-enquire-btn:active, .reviews-link-btn:active, .banner-btn:active,
  .form-submit-btn:active, .social-link-pill:active, .lightbox-inquiry-btn:active {
    background: var(--color-gold); color: var(--color-olive-ink); border-color: var(--color-gold);
  }
  .filter-btn:active { border-color: var(--color-gold); color: var(--color-olive-deep); }
}

/* ==========================================================================
   Flagship layer II — display type · preloader ritual · ambience
   · pinned craft chapters · WebGL drag gallery
   ========================================================================== */

/* ---------- Distinctive display face (Fraunces, injected by main.js) ---------- */
:root { --font-display: 'Fraunces', 'Cormorant Garamond', Georgia, serif; }
.hero-title, .section-heading, .banner-title, .chapter-title, .pt-mark-serif {
  font-family: var(--font-display); letter-spacing: -0.01em;
}

/* ---------- Preloader — wordmark stitching ritual ---------- */
body.is-preloading { overflow: hidden; }
.aep-preloader {
  position: fixed; inset: 0; z-index: 3000;
  background: var(--color-olive-ink);
  background-image: radial-gradient(ellipse at 50% 120%, rgba(201, 169, 110, 0.14), transparent 60%);
  display: grid; place-items: center;
}
.aep-preloader.is-done { transform: translateY(-100%); transition: transform 0.9s var(--ease-power4); }
.aep-preloader-inner { text-align: center; padding: 0 24px; }
.aep-wordmark { width: min(560px, 84vw); height: auto; overflow: visible; }
.aep-wordmark text {
  font-family: var(--font-heading); font-style: italic; font-weight: 500; font-size: 58px;
  fill: rgba(250, 247, 242, 0); stroke: var(--color-gold); stroke-width: 0.7;
  stroke-dasharray: 540; stroke-dashoffset: 540;
  animation: aepStitch 2.3s var(--ease-power4) 0.15s forwards;
}
@keyframes aepStitch {
  60% { fill: rgba(250, 247, 242, 0); }
  100% { stroke-dashoffset: 0; fill: rgba(250, 247, 242, 0.94); }
}
.aep-thread { width: min(300px, 58vw); height: 1px; margin: 30px auto 16px; background: rgba(201, 169, 110, 0.22); position: relative; }
.aep-thread i { position: absolute; inset: 0; background: var(--color-gold); transform: scaleX(0); transform-origin: left center; display: block; }
.aep-thread::after {
  content: ''; position: absolute; left: 50%; top: 50%; width: 6px; height: 6px;
  transform: translate(-50%, -50%) rotate(45deg);
  background: var(--color-olive-ink); border: 1px solid var(--color-gold);
}
.aep-count { font-size: 10px; font-weight: 800; letter-spacing: 5px; text-transform: uppercase; color: rgba(250, 247, 242, 0.5); }

/* ---------- Ambient audio toggle ---------- */
.ambience-toggle {
  position: fixed; left: 22px; bottom: 22px; z-index: 1290;
  display: inline-flex; align-items: center; gap: 10px;
  background: rgba(38, 48, 31, 0.85); color: rgba(250, 247, 242, 0.85);
  border: 1px solid rgba(201, 169, 110, 0.4); border-radius: 40px; padding: 10px 16px;
  font-size: 9px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase;
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  transition: border-color 0.5s ease, color 0.5s ease;
}
.ambience-toggle:hover { border-color: var(--color-gold); color: var(--color-ivory); }
.amb-bars { display: inline-flex; align-items: flex-end; gap: 2.5px; height: 12px; }
.amb-bars i { width: 2px; height: 3px; background: var(--color-gold); }
.ambience-toggle.is-on .amb-bars i { animation: ambBar 1.1s ease-in-out infinite alternate; }
.ambience-toggle.is-on .amb-bars i:nth-child(2) { animation-delay: 0.18s; }
.ambience-toggle.is-on .amb-bars i:nth-child(3) { animation-delay: 0.36s; }
.ambience-toggle.is-on .amb-bars i:nth-child(4) { animation-delay: 0.54s; }
@keyframes ambBar { from { height: 3px; } to { height: 12px; } }
body.has-quick-bar .ambience-toggle { bottom: calc(92px + env(safe-area-inset-bottom, 0px)); }

/* ---------- Pinned craft chapters (home) ---------- */
.chapter-stage { display: none; }
.craft-chapters.is-enhanced .chapter-stage { display: block; }
.craft-chapters.is-enhanced .chapter-fallback { display: none; }
.chapter-stage-inner {
  height: 100vh; padding-top: 90px; padding-bottom: 40px;
  display: flex; flex-direction: column; justify-content: center; position: relative;
}
.chapter-meta { display: flex; justify-content: space-between; align-items: baseline; }
.chapter-count { font-family: var(--font-display); font-style: italic; line-height: 1; }
.chapter-current { font-size: 46px; color: var(--color-gold-deep); }
.chapter-total { font-size: 15px; color: var(--color-text-muted); }
.chapter-slides { position: relative; min-height: 48vh; margin-top: 10px; }
.chapter-slide { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: center; }
.chapter-ghost {
  position: absolute; left: -1.5%; top: 50%; transform: translateY(-50%); z-index: 0;
  font-family: var(--font-display); font-style: italic; font-weight: 500; line-height: 1;
  font-size: clamp(110px, 16vw, 240px); color: transparent;
  -webkit-text-stroke: 1px rgba(201, 169, 110, 0.3);
  pointer-events: none; white-space: nowrap; user-select: none; -webkit-user-select: none;
}
.chapter-title {
  position: relative; z-index: 1;
  font-weight: 500; font-size: clamp(46px, 6.4vw, 96px); line-height: 1.02;
  color: var(--color-olive-deep); margin-left: clamp(0px, 8vw, 130px);
}
.chapter-desc {
  position: relative; z-index: 1; max-width: 480px;
  margin: 22px 0 0 clamp(0px, 8vw, 130px);
  font-size: 15px; font-weight: 300; line-height: 1.9; color: var(--color-text-muted);
}
.chapter-thread { height: 1px; background: rgba(201, 169, 110, 0.22); position: relative; margin: 26px 0 20px; }
.chapter-thread i { position: absolute; inset: 0; background: var(--color-gold); transform: scaleX(0); transform-origin: left center; display: block; }
.chapter-cta { align-self: flex-start; }
.chapter-svg {
  position: absolute; right: clamp(0px, 4vw, 60px); top: 50%; transform: translateY(-50%);
  z-index: 1; width: clamp(150px, 22vw, 280px); pointer-events: none;
  opacity: 0.92;
}
.chapter-svg svg { width: 100%; height: auto; display: block; filter: drop-shadow(0 14px 30px rgba(38, 48, 31, 0.12)); }
@media (max-width: 1100px) {
  .chapter-svg { width: clamp(120px, 20vw, 200px); opacity: 0.5; }
}

/* ---------- WebGL drag-canvas gallery (lookbook) ---------- */
.drag-gallery { display: none; margin: 14px 0 64px; }
body.js-enabled .drag-gallery { display: block; }
.drag-gallery.gl-failed { display: none !important; }
.drag-gallery-head { display: flex; justify-content: space-between; align-items: baseline; gap: 18px; margin-bottom: 16px; flex-wrap: wrap; }
.drag-gallery-head .section-kicker { margin-bottom: 0; }
.drag-hint { font-size: 10px; font-weight: 800; letter-spacing: 2.2px; text-transform: uppercase; color: var(--color-text-muted); }
#gallery-canvas {
  display: block; width: 100%; height: clamp(340px, 52vh, 560px);
  background: var(--color-olive-ink);
  background-image: radial-gradient(ellipse at 50% 120%, rgba(201, 169, 110, 0.12), transparent 60%);
  cursor: grab; touch-action: pan-y;
  border: 1px solid rgba(201, 169, 110, 0.25);
}
.drag-gallery.is-dragging #gallery-canvas { cursor: grabbing !important; }
.drag-progress { height: 1px; background: rgba(201, 169, 110, 0.22); margin-top: 16px; position: relative; overflow: hidden; }
.drag-progress i { position: absolute; top: 0; bottom: 0; left: 0; width: 18%; background: var(--color-gold); display: block; will-change: transform; }

@media (max-width: 767px) {
  #gallery-canvas { height: 320px; }
  .ambience-toggle .amb-label { display: none; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ==========================================================================
   OLD-DESIGN REVERT — site-wide navigation bar + homepage hero (1:1)
   Scoped restore of the original header/nav (all pages) and the hero
   first-load area (homepage). Later-section enhancements are untouched.
   ========================================================================== */

/* ----- Navigation bar / header (site-wide) ----- */
.main-header {
  position: absolute !important;
  top: 0; left: 0; right: auto;
  width: 100%;
  padding: 28px 40px;
  z-index: 100;
  background: transparent !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  border-bottom: 1px solid rgba(201, 169, 110, 0.08) !important;
  box-shadow: none !important;
}
/* neutralize the newer scrolled / home-hero dark treatments */
.main-header.scrolled {
  background: transparent !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  border-bottom: 1px solid rgba(201, 169, 110, 0.08) !important;
  box-shadow: none !important;
}
body[data-page="home"] .main-header:not(.scrolled) { background: transparent !important; }
body[data-page="home"] .main-header:not(.scrolled) .nav-link { color: var(--color-text-muted) !important; }
body[data-page="home"] .main-header:not(.scrolled) .nav-link:hover,
body[data-page="home"] .main-header:not(.scrolled) .nav-link.is-current { color: #2A3824 !important; }
body[data-page="home"] .main-header:not(.scrolled) .icon-btn { color: var(--color-text-muted) !important; }
body[data-page="home"] .main-header:not(.scrolled) .hamburger-menu span { background: var(--color-text-primary) !important; }

.header-container { max-width: 1440px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; padding: 0; gap: 24px; }
.logo { display: flex; align-items: center; gap: 12px; text-decoration: none; color: #2A3824; }
.logo-img { height: 40px; width: auto; object-fit: contain; display: block; }
.logo:hover .logo-img { transform: scale(1.03); }
.desktop-nav { display: flex; gap: 36px; }
.nav-link {
  font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.8px;
  color: var(--color-text-muted); text-decoration: none; position: relative; padding: 8px 0;
}
.nav-link::after {
  content: ''; position: absolute; width: 100%; transform: scaleX(0); height: 1px; bottom: -2px; left: 0;
  background-color: var(--color-gold); transform-origin: bottom right;
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}
.nav-link:hover { color: #2A3824; }
.nav-link:hover::after, .nav-link.is-current::after { transform: scaleX(1); transform-origin: bottom left; }
.nav-link.is-current { color: #2A3824; }
.header-actions { display: flex; align-items: center; gap: 20px; }
.icon-btn { width: 40px; height: 40px; border-radius: 50%; color: var(--color-text-muted); display: flex; align-items: center; justify-content: center; }
.icon-btn:hover { background: rgba(122, 143, 107, 0.08); color: #2A3824; }
.hamburger-menu { display: none; flex-direction: column; justify-content: space-between; gap: 0; width: 24px; height: 14px; z-index: 101; }
.hamburger-menu span { display: block; width: 100%; height: 1.8px; background-color: var(--color-text-primary); }
.hamburger-menu.active span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.hamburger-menu.active span:nth-child(2) { transform: translateY(-6px) rotate(-45deg); }
/* old light mobile drawer */
.mobile-drawer { background-color: var(--color-ivory); }
.mobile-drawer::after { content: none; }
.mobile-nav-link { font-family: var(--font-heading); font-size: clamp(32px, 6.5vh, 50px); color: #2A3824; }
.mobile-nav-link:hover { color: var(--color-gold); letter-spacing: 0; }
body.drawer-open .hamburger-menu span { background: var(--color-text-primary); }
body.drawer-open .icon-btn { color: var(--color-text-muted); }
body.drawer-open .logo-img { opacity: 1; }

@media (max-width: 1024px) {
  .main-header { padding: 20px 24px; }
  .desktop-nav { display: none; }
  .hamburger-menu { display: flex; }
}

/* ----- Homepage hero (first-load) — old editorial design ----- */
.hero-section {
  position: relative; min-height: 100vh; display: flex; align-items: center;
  overflow: hidden; width: 100%; background: transparent; color: var(--color-text-primary);
}
.hero-canvas {
  width: 100%; max-width: 1440px; margin: 0 auto;
  display: flex; flex-direction: column; align-items: flex-start; justify-content: center;
  padding: 120px 8% 80px 10%; background: transparent; position: relative; z-index: 5; min-height: 100vh; gap: 0;
}
.canvas-content { max-width: 540px; }
.hero-title {
  font-family: var(--font-heading) !important;
  font-size: clamp(48px, 6vw, 76px); font-weight: 300; line-height: 0.95; letter-spacing: -0.025em;
  color: #111b0d;
  text-shadow: 0.5px 0.5px 0 rgba(255,255,255,0.85), 0 1px 3px rgba(17,27,13,0.06);
}
.hero-title .title-italic { font-style: italic; color: inherit; }
.hero-divider { display: flex; align-items: center; gap: 16px; margin: 28px 0; max-width: 320px; }
.divider-line { flex: 1; height: 1.5px; background: var(--color-gold); opacity: 1; }
.hero-divider .divider-line:last-of-type { background: var(--color-gold); }
.divider-icon { color: var(--color-gold); }
.hero-tagline {
  font-family: var(--font-heading); font-size: clamp(20px, 2.5vw, 28px); font-style: italic;
  color: var(--color-olive-deep); font-weight: 400; margin-bottom: 20px; letter-spacing: 0.02em;
}
.hero-description { font-size: 15px; line-height: 1.8; color: var(--color-text-muted); margin-bottom: 40px; font-weight: 300; max-width: 440px; }
.hero-cta-wrapper { display: flex; }
.hero-cta-wrapper .cta-link { color: var(--color-text-primary); }

/* old full-screen light video background (behind text) */
.hero-visual { position: absolute; top: 0; left: 0; width: 100vw; height: 100vh; max-width: none; z-index: 1; overflow: hidden; background: transparent; }
.video-container { position: absolute; inset: 0; width: 100%; height: 100%; }
.hero-bg-video { position: absolute; top: 0; left: 0; width: 100vw; height: 100vh; object-fit: cover; }
.video-overlay { position: absolute; inset: 0; background: radial-gradient(circle, transparent 20%, rgba(61, 79, 53, 0.05) 100%); pointer-events: none; }

/* old glassmorphism pillars bar */
.pillars-container { width: 100%; max-width: 540px; margin-top: 40px; z-index: 10; }
.pillars-card {
  background: rgba(245, 237, 227, 0.6);
  -webkit-backdrop-filter: blur(30px); backdrop-filter: blur(30px);
  border: 1.5px solid rgba(255, 255, 255, 0.5); border-bottom: 2px solid rgba(201, 169, 110, 0.4);
  box-shadow: 0 12px 32px rgba(61, 79, 53, 0.06), inset 0 1px 0 rgba(255, 255, 255, 0.6);
  border-radius: 0; padding: 16px 20px; display: flex; justify-content: space-between; align-items: center; gap: 16px;
}
.pillar-item { display: flex; flex-direction: row; align-items: center; gap: 12px; flex: initial; }
.pillar-icon { width: 34px; height: 34px; border-radius: 50%; background: rgba(255, 255, 255, 0.45); display: flex; align-items: center; justify-content: center; color: var(--color-gold); border: 1px solid rgba(255, 255, 255, 0.2); flex-shrink: 0; }
.pillar-icon svg { color: var(--color-gold); stroke: var(--color-gold); }
.pillar-text { display: flex; flex-direction: column; align-items: flex-start; }
.pillar-text h4 { font-family: var(--font-body); font-size: 11px; font-weight: 800; color: var(--color-olive-deep); letter-spacing: 0.5px; text-transform: uppercase; line-height: 1.2; }
.pillar-text p { font-size: 8px; font-weight: 700; letter-spacing: 0.8px; color: var(--color-text-muted); text-transform: uppercase; margin-top: 1px; line-height: 1.1; }
.pillar-divider { width: 1px; height: 24px; background: rgba(61, 79, 53, 0.08); }

/* old circular badge: bottom-left, gold on light */
.circular-badge-container { position: absolute; bottom: 40px; left: 40px; right: auto; top: auto; z-index: 15; width: 100px; height: 100px; display: flex; align-items: center; justify-content: center; pointer-events: none; color: var(--color-gold); }
.circular-badge { width: 100%; height: 100%; color: var(--color-gold); opacity: 0.95; }
.circular-badge text { fill: var(--color-gold); }
.badge-center-icon { position: absolute; color: var(--color-gold); }

@media (max-width: 768px) {
  .desktop-video { display: none !important; }
  .mobile-video { display: block !important; }
  .circular-badge-container { display: none !important; }
  .hero-canvas { flex-direction: column; justify-content: space-between; min-height: 100vh; padding: 95px 0 30px; width: 100%; max-width: none; }
  .canvas-content { width: 85%; max-width: none; margin: 0 auto; }
  .hero-title { font-size: clamp(48px, 12vw, 56px); margin-bottom: 8px; }
  .hero-divider { margin: 10px 0; max-width: 160px; }
  .hero-tagline { font-size: 19.5px; line-height: 1.25; margin-bottom: 12px; color: #2c3b24; }
  .hero-description { font-size: 11.5px; line-height: 1.5; margin-bottom: 20px; color: #2e302c; }
  .hero-cta-wrapper .cta-link { font-size: 9.5px; color: #111b0d; }
  .pillars-container { width: 90%; max-width: none; margin: 0 auto; }
  .pillars-card { flex-direction: row; justify-content: space-evenly; align-items: center; padding: 15px; gap: 6px; }
  .pillar-item { flex-direction: column; align-items: center; text-align: center; gap: 6px; flex: 1; }
  .pillar-icon { width: 38px; height: 38px; margin-bottom: 2px; }
  .pillar-text { align-items: center; text-align: center; }
  .pillar-divider { width: 1px; height: 24px; background: rgba(61, 79, 53, 0.12); }
}

/* ---------- Mobile Pinned Scrollytelling Refactor (max-width: 991px) ---------- */
@media (max-width: 991px) {
  /* Enable scrollytelling container layouts cleanly */
  .chapter-stage-inner {
    padding-top: 90px;
    padding-bottom: 20px;
    justify-content: flex-start;
  }
  .chapter-meta {
    margin-bottom: 12px;
  }
  .chapter-slides {
    min-height: 52vh;
    margin-top: 5px;
  }
  .chapter-slide {
    align-items: center;
    text-align: center;
    justify-content: flex-start;
    padding-top: 10px;
  }
  .chapter-svg {
    position: relative;
    right: auto;
    top: auto;
    transform: none;
    width: clamp(120px, 30vw, 150px);
    margin: 0 auto 16px;
    opacity: 1;
    display: block;
    z-index: 2;
  }
  .chapter-title {
    margin-left: 0;
    font-size: clamp(26px, 6vw, 36px);
    line-height: 1.1;
    text-align: center;
    width: 100%;
    z-index: 2;
  }
  .chapter-desc {
    margin: 12px auto 0;
    font-size: 13.5px;
    line-height: 1.7;
    text-align: center;
    max-width: 290px;
    width: 100%;
    z-index: 2;
  }
  .chapter-ghost {
    left: 50%;
    top: 30%;
    transform: translate(-50%, -50%);
    font-size: clamp(64px, 16vw, 100px);
    -webkit-text-stroke: 1px rgba(201, 169, 110, 0.1);
    z-index: 0;
    text-align: center;
    width: 100%;
  }
  .chapter-cta {
    align-self: center;
    margin: 18px auto 0;
  }
  .chapter-thread {
    margin: 16px 0 10px;
  }
}

