/** Shopify CDN: Minification failed

Line 2311:20 Unexpected "{"
Line 2311:29 Expected ":"
Line 2311:36 Unexpected "{"

**/
/* SHOPIFY_STYLESHEETS_VERSION: 1.0 */


/* CSS from section stylesheet tags */
/* START_SECTION:404 (INDEX:0) */
.error-page {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-height: 70vh;
    padding: 40px var(--page-margin, 48px) 80px;
    gap: 24px;
  }
  .error-page h1 { font-size: clamp(2rem, 4vw, 3.5rem); }
  .error-page__desc { font-size: 15px; color: var(--color-ink-soft); opacity: 0.65; }
/* END_SECTION:404 */

/* START_SECTION:about-us (INDEX:1) */
.about { color: var(--color-ink); }

  /* ── Shared ── */
  .about__eyebrow,
  .about__label {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.65;
    margin-bottom: 20px;
  }

  /* ── Hero ── */
  .about__hero {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 80vh;
    overflow: hidden;
  }
  .about__hero-inner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 100px var(--page-margin, 64px);
  }
  .about__hero-headline {
    font-family: var(--font-heading);
    font-size: clamp(2.8rem, 5vw, 5rem);
    font-weight: 300;
    letter-spacing: -0.02em;
    line-height: 1.06;
    color: var(--color-ink);
    margin-bottom: 28px;
  }
  .about__hero-sub {
    font-size: 16px;
    line-height: 1.75;
    color: var(--color-ink-soft);
    opacity: 0.7;
    max-width: 420px;
  }
  .about__hero-img {
    position: relative;
    overflow: hidden;
  }
  .about__hero-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .about__hero-img--placeholder {
    background: var(--color-stone, #e8e4df);
  }

  /* ── Mission strip ── */
  .about__mission {
    background: var(--color-ink);
    padding: 80px var(--page-margin, 64px);
  }
  .about__mission-inner {
    max-width: 860px;
    margin: 0 auto;
    text-align: center;
  }
  .about__mission-text {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 2.8vw, 2.4rem);
    font-weight: 300;
    line-height: 1.4;
    letter-spacing: -0.01em;
    color: var(--color-paper, #f5f3f0);
    opacity: 0.92;
  }

  /* ── Split sections ── */
  .about__split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 580px;
    overflow: hidden;
  }
  .about__split--flip { }
  .about__split-text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 80px 72px;
  }
  .about__split--flip .about__split-text { order: 2; }
  .about__split--flip .about__split-media { order: 1; }

  .about__split-headline {
    font-family: var(--font-heading);
    font-size: clamp(1.8rem, 3vw, 3rem);
    font-weight: 300;
    letter-spacing: -0.015em;
    line-height: 1.15;
    color: var(--color-ink);
    margin-bottom: 28px;
  }
  .about__split-body {
    display: flex;
    flex-direction: column;
    gap: 16px;
  }
  .about__split-body p {
    font-size: 15px;
    line-height: 1.8;
    color: var(--color-ink-soft);
    opacity: 0.75;
  }
  .about__split-media {
    position: relative;
    overflow: hidden;
    background: var(--color-stone, #e8e4df);
  }
  .about__split-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .about__media-placeholder {
    width: 100%;
    height: 100%;
    background: #e2deda;
    min-height: 520px;
  }
  .about__media-placeholder--dark { background: #d0ccc7; }

  /* ── Values ── */
  .about__values {
    background: var(--color-paper-warm, #f5f3f0);
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    padding: 80px var(--page-margin, 64px);
  }
  .about__values-inner {
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 64px;
  }
  .about__value { }
  .about__value-num {
    display: block;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.22em;
    color: var(--color-ink-soft);
    opacity: 0.4;
    margin-bottom: 20px;
  }
  .about__value-heading {
    font-family: var(--font-heading);
    font-size: 1.35rem;
    font-weight: 300;
    letter-spacing: -0.01em;
    line-height: 1.2;
    color: var(--color-ink);
    margin-bottom: 16px;
  }
  .about__value-text {
    font-size: 14px;
    line-height: 1.75;
    color: var(--color-ink-soft);
    opacity: 0.7;
  }

  /* ── Stats ── */
  .about__stats {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    padding: 72px var(--page-margin, 64px);
    border-bottom: 1px solid var(--color-border);
  }
  .about__stat {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    text-align: center;
  }
  .about__stat-num {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 3.5vw, 3rem);
    font-weight: 300;
    letter-spacing: -0.02em;
    color: var(--color-ink);
    line-height: 1;
  }
  .about__stat-label {
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.55;
  }
  .about__stat-divider {
    width: 1px;
    height: 60px;
    background: var(--color-border);
  }

  /* ── Pull quote ── */
  .about__quote {
    padding: 100px var(--page-margin, 64px);
    background: var(--color-paper-warm, #f5f3f0);
    border-bottom: 1px solid var(--color-border);
  }
  .about__quote-inner {
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
  }
  .about__quote-text {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 2.5vw, 2.2rem);
    font-weight: 300;
    line-height: 1.5;
    letter-spacing: -0.01em;
    color: var(--color-ink);
    font-style: italic;
    opacity: 0.85;
  }
  .about__quote-text::before { content: '\201C'; }
  .about__quote-text::after  { content: '\201D'; }

  /* ── CTA ── */
  .about__cta {
    padding: 100px var(--page-margin, 64px);
    text-align: center;
  }
  .about__cta-inner { max-width: 600px; margin: 0 auto; }
  .about__cta-headline {
    font-family: var(--font-heading);
    font-size: clamp(1.8rem, 3vw, 2.8rem);
    font-weight: 300;
    letter-spacing: -0.015em;
    line-height: 1.15;
    color: var(--color-ink);
    margin-bottom: 36px;
  }
  .about__cta-btn {
    display: inline-block;
    padding: 16px 40px;
    background: var(--color-ink);
    color: var(--color-paper, #f5f3f0);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    transition: opacity 0.2s ease;
  }
  .about__cta-btn:hover { opacity: 0.75; }

  /* ── Responsive ── */
  @media (max-width: 1024px) {
    .about__split-text { padding: 60px 48px; }
  }
  @media (max-width: 768px) {
    .about__hero { grid-template-columns: 1fr; min-height: auto; }
    .about__hero-inner { padding: 72px 24px 48px; }
    .about__hero-img { min-height: 300px; }
    .about__split { grid-template-columns: 1fr; }
    .about__split--flip .about__split-text { order: 1; }
    .about__split--flip .about__split-media { order: 2; }
    .about__split-text { padding: 48px 24px; }
    .about__split-media { min-height: 320px; }
    .about__values { padding: 60px 24px; }
    .about__values-inner { grid-template-columns: 1fr; gap: 40px; }
    .about__stats { flex-wrap: wrap; gap: 40px; padding: 60px 24px; }
    .about__stat-divider { display: none; }
    .about__stat { flex: 1 1 calc(50% - 20px); }
    .about__mission { padding: 60px 24px; }
    .about__quote { padding: 72px 24px; }
    .about__cta { padding: 72px 24px; }
  }
/* END_SECTION:about-us */

/* START_SECTION:brand-quote (INDEX:4) */
.brand-quote {
    padding: 120px var(--page-margin, 48px);
    background: var(--color-paper);
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
  }

  .brand-quote__inner {
    max-width: 780px;
    margin: 0 auto;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 32px;
  }

  .brand-quote__text {
    font-family: var(--font-heading);
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    font-weight: 300;
    font-style: italic;
    color: var(--color-ink);
    line-height: 1.4;
    letter-spacing: -0.01em;
  }

  .brand-quote__attribution {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.5;
  }

  .brand-quote__cta { margin-top: 8px; }

  @media (max-width: 640px) {
    .brand-quote { padding: 72px 20px; }
  }
/* END_SECTION:brand-quote */

/* START_SECTION:brand-strip (INDEX:5) */
.brand-strip {
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    background: var(--color-paper);
    padding: 32px var(--page-margin, 48px);
  }

  .brand-strip__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    text-align: center;
    max-width: 600px;
    margin: 0 auto;
  }

  .brand-strip__logo {
    display: block;
    height: auto;
    max-height: 48px;
    width: auto;
  }

  .brand-strip__wordmark {
    font-family: var(--font-heading);
    font-size: 22px;
    font-weight: 300;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: var(--color-ink);
  }

  .brand-strip__tagline {
    font-size: 13px;
    color: var(--color-ink-soft);
    opacity: 0.65;
    letter-spacing: 0.04em;
    max-width: 420px;
  }

  .brand-strip__trust {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 4px;
  }

  .brand-strip__trust-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.7;
  }

  .brand-strip__trust-sep {
    color: var(--color-border);
    font-size: 16px;
    line-height: 1;
  }

  @media (max-width: 640px) {
    .brand-strip { padding: 24px 20px; }
    .brand-strip__trust-sep { display: none; }
    .brand-strip__trust { gap: 10px 20px; }
  }
/* END_SECTION:brand-strip */

/* START_SECTION:cart-drawer (INDEX:6) */
/* ── Overlay ── */
  .cart-drawer__overlay {
    position: fixed;
    inset: 0;
    background: rgba(13, 13, 13, 0.4);
    z-index: 499;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 320ms ease, visibility 320ms ease;
  }
  .cart-drawer.is-open .cart-drawer__overlay {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  /* ── Panel ── */
  .cart-drawer__panel {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 460px;
    max-width: 100vw;
    background: var(--color-paper);
    z-index: 500;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 380ms cubic-bezier(0.16, 1, 0.3, 1);
    border-left: 1px solid var(--color-border);
  }
  .cart-drawer.is-open .cart-drawer__panel {
    transform: translateX(0);
  }

  /* ── Header ── */
  .cart-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 24px 28px;
    border-bottom: 1px solid var(--color-border);
    flex-shrink: 0;
  }
  .cart-drawer__title {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    font-weight: 300;
    color: var(--color-ink);
    letter-spacing: -0.01em;
  }
  .cart-drawer__close {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--color-ink);
    display: flex;
    padding: 6px;
    transition: opacity var(--transition-base);
  }
  .cart-drawer__close:hover { opacity: 0.45; }

  /* ── Scrollable body ── */
  .cart-drawer__body {
    flex: 1;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--color-border) transparent;
  }
  .cart-drawer__body::-webkit-scrollbar { width: 4px; }
  .cart-drawer__body::-webkit-scrollbar-thumb { background: var(--color-border); }

  /* ── Shipping bar ── */
  .cart-drawer__ship {
    padding: 18px 28px;
    border-bottom: 1px solid var(--color-border);
  }
  .cart-drawer__ship-track {
    height: 3px;
    background: var(--color-stone);
    margin-bottom: 10px;
    overflow: hidden;
  }
  .cart-drawer__ship-fill {
    height: 100%;
    background: var(--color-ink);
    transition: width 500ms ease;
  }
  .cart-drawer__ship-msg {
    font-size: 13px;
    text-align: center;
    color: var(--color-ink-soft);
    line-height: 1.5;
  }
  .cart-drawer__ship-msg strong { font-weight: 500; color: var(--color-ink); }

  /* ── Cart items ── */
  .cart-drawer__items { padding: 0 28px; }

  .cd-item {
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: 16px;
    padding: 24px 0;
    border-bottom: 1px solid var(--color-border);
  }
  .cd-item:last-child { border-bottom: none; }

  .cd-item__img-wrap {
    display: block;
    aspect-ratio: 1;
    overflow: hidden;
    background: var(--color-stone);
    flex-shrink: 0;
  }
  .cd-item__img { width: 100%; height: 100%; object-fit: cover; }
  .cd-item__img-placeholder { width: 100%; height: 100%; background: var(--color-stone); }

  .cd-item__info { display: flex; flex-direction: column; justify-content: space-between; gap: 12px; }

  .cd-item__row { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
  .cd-item__row--bottom { align-items: center; }

  .cd-item__title {
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 400;
    color: var(--color-ink);
    line-height: 1.4;
    display: block;
  }
  .cd-item__title:hover { opacity: 0.65; }
  .cd-item__variant {
    font-size: 12px;
    color: var(--color-ink-soft);
    opacity: 0.55;
    margin-top: 3px;
  }

  .cd-item__price {
    font-size: 14px;
    font-weight: 400;
    color: var(--color-ink);
    white-space: nowrap;
    flex-shrink: 0;
  }

  .cd-item__qty { display: flex; align-items: center; gap: 8px; }
  .cd-item__qty-label {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.6;
  }
  .cd-item__qty-ctrl {
    display: flex;
    align-items: center;
    border: 1px solid var(--color-border);
  }
  .cd-item__qty-btn {
    background: none;
    border: none;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 16px;
    font-weight: 300;
    color: var(--color-ink);
    transition: background var(--transition-base);
    line-height: 1;
  }
  .cd-item__qty-btn:hover { background: var(--color-stone); }
  .cd-item__qty-val {
    min-width: 28px;
    text-align: center;
    font-size: 13px;
    font-weight: 400;
    color: var(--color-ink);
    border-left: 1px solid var(--color-border);
    border-right: 1px solid var(--color-border);
    padding: 0 4px;
    line-height: 28px;
  }

  .cd-item__remove {
    background: none;
    border: none;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.45;
    cursor: pointer;
    border-bottom: 1px solid transparent;
    transition: opacity var(--transition-base), border-color var(--transition-base);
    padding: 0;
  }
  .cd-item__remove:hover { opacity: 0.9; border-color: var(--color-ink-soft); }

  /* ── Empty state ── */
  .cart-drawer__empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    padding: 64px 28px;
    text-align: center;
  }
  .cart-drawer__empty p {
    font-family: var(--font-heading);
    font-size: 1.25rem;
    font-weight: 300;
    color: var(--color-ink);
  }

  /* ── Recommendations ── */
  .cd-recs {
    border-top: 1px solid var(--color-border);
    padding: 24px 28px;
  }
  .cd-recs__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
  }
  .cd-recs__title {
    font-family: var(--font-heading);
    font-size: 1.2rem;
    font-weight: 300;
    color: var(--color-ink);
  }
  .cd-recs__nav { display: flex; gap: 6px; }
  .cd-recs__nav-btn {
    width: 34px;
    height: 34px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--color-border);
    background: none;
    cursor: pointer;
    color: var(--color-ink);
    transition: background var(--transition-base), border-color var(--transition-base);
  }
  .cd-recs__nav-btn:hover { background: var(--color-stone); border-color: var(--color-ink-soft); }

  .cd-recs__track {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    padding-bottom: 4px;
  }
  .cd-recs__track::-webkit-scrollbar { display: none; }

  .cd-rec {
    flex: 0 0 calc(100% - 16px);
    max-width: 360px;
    scroll-snap-align: start;
    background: var(--color-paper-warm);
    border: 1px solid var(--color-border);
    display: grid;
    grid-template-columns: 100px 1fr;
    gap: 16px;
    padding: 16px;
  }
  .cd-rec__img-wrap {
    display: block;
    aspect-ratio: 1;
    overflow: hidden;
    background: var(--color-stone);
  }
  .cd-rec__img { width: 100%; height: 100%; object-fit: cover; }
  .cd-rec__img-placeholder { width: 100%; height: 100%; background: var(--color-stone); }

  .cd-rec__info { display: flex; flex-direction: column; gap: 8px; justify-content: center; }
  .cd-rec__title {
    font-size: 13px;
    font-weight: 400;
    color: var(--color-ink);
    line-height: 1.35;
    display: block;
  }
  .cd-rec__title:hover { opacity: 0.65; }
  .cd-rec__price { font-size: 13px; color: var(--color-ink-soft); }
  .cd-rec__price-sale { color: var(--color-ink); margin-right: 6px; font-weight: 500; }
  .cd-rec__price-compare { text-decoration: line-through; opacity: 0.45; font-size: 12px; }
  .cd-rec__add { padding: 9px 16px; font-size: 11px; width: 100%; text-align: center; margin-top: 4px; }

  /* ── Footer ── */
  .cart-drawer__foot {
    flex-shrink: 0;
    border-top: 1px solid var(--color-border);
    padding: 20px 28px 28px;
    background: var(--color-paper);
  }
  .cart-drawer__subtotal {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 14px;
    font-weight: 400;
    color: var(--color-ink-soft);
    margin-bottom: 16px;
    letter-spacing: 0.02em;
  }
  #cd-total { font-weight: 500; color: var(--color-ink); font-size: 15px; }
  .cart-drawer__checkout {
    display: block;
    width: 100%;
    text-align: center;
    padding: 16px;
    font-size: 12px;
    letter-spacing: 0.2em;
    border: none;
    cursor: pointer;
  }

  @media (max-width: 480px) {
    .cart-drawer__panel { width: 100vw; }
    .cart-drawer__head,
    .cart-drawer__items,
    .cart-drawer__foot,
    .cd-recs,
    .cart-drawer__ship { padding-left: 20px; padding-right: 20px; }
  }
/* END_SECTION:cart-drawer */

/* START_SECTION:cart (INDEX:7) */
.cart-page {
    padding-top: 64px;
    padding-bottom: var(--section-spacing);
  }

  .cart-page__header {
    border-bottom: 1px solid var(--color-border);
    padding-bottom: 32px;
    margin-bottom: 0;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
  }

  .cart-page__count { margin-bottom: 0; }

  .cart-form {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 64px;
    align-items: start;
  }

  .cart-items { border-top: none; }

  .cart-item {
    display: grid;
    grid-template-columns: 120px 1fr auto;
    gap: 24px;
    align-items: start;
    padding: 32px 0;
    border-bottom: 1px solid var(--color-border);
  }

  .cart-item__image-wrap { display: block; aspect-ratio: 4 / 5; overflow: hidden; }
  .cart-item__image { width: 100%; height: 100%; object-fit: cover; }
  .cart-item__image-placeholder { width: 100%; height: 100%; background: var(--color-stone); }

  .cart-item__details {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 120px;
  }

  .cart-item__title {
    font-size: 1rem;
    font-weight: 300;
    margin-top: 6px;
    margin-bottom: 6px;
  }
  .cart-item__title a { color: var(--color-ink); }
  .cart-item__title a:hover { opacity: 0.6; }

  .cart-item__variant {
    font-size: 12px;
    color: var(--color-ink-soft);
    opacity: 0.6;
    letter-spacing: 0.05em;
  }

  .cart-item__actions {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-top: 16px;
  }

  .cart-item__qty { width: 64px; padding: 8px 10px; text-align: center; }

  .cart-item__remove {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.5;
    border-bottom: 1px solid transparent;
    padding-bottom: 1px;
    transition: opacity var(--transition-base), border-color var(--transition-base);
  }
  .cart-item__remove:hover { opacity: 1; border-color: var(--color-ink-soft); }

  .cart-item__price {
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.03em;
    white-space: nowrap;
    padding-top: 6px;
  }

  .cart-summary {
    position: sticky;
    top: calc(var(--header-height, 72px) + 32px);
    border: 1px solid var(--color-border);
    padding: 40px 32px;
  }

  .cart-summary__line {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    font-size: 15px;
    margin-bottom: 12px;
  }

  .cart-summary__note {
    font-size: 12px;
    color: var(--color-ink-soft);
    opacity: 0.55;
    margin-bottom: 32px;
    line-height: 1.5;
  }

  .cart-summary__btns { display: flex; flex-direction: column; gap: 10px; }
  .cart-summary__checkout,
  .cart-summary__update { width: 100%; text-align: center; }

  .cart-empty {
    text-align: center;
    padding: 80px 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 32px;
  }
  .cart-empty p { font-family: var(--font-heading); font-size: 1.5rem; font-weight: 300; }

  @media (max-width: 900px) {
    .cart-form { grid-template-columns: 1fr; gap: 40px; }
    .cart-summary { position: static; }
  }

  @media (max-width: 640px) {
    .cart-item { grid-template-columns: 88px 1fr; }
    .cart-item__price { grid-column: 1 / -1; }
  }
/* END_SECTION:cart */

/* START_SECTION:collection (INDEX:8) */
.collection-breadcrumb-wrap {
    padding: 20px var(--page-margin, 48px) 0;
  }
  .breadcrumb__list {
    list-style: none;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    margin: 0;
    padding: 0;
  }
  .breadcrumb__item {
    font-size: 11px;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
  }
  .breadcrumb__link {
    color: var(--color-ink-soft);
    text-decoration: none;
    transition: color var(--transition-base);
  }
  .breadcrumb__link:hover { color: var(--color-ink); }
  .breadcrumb__sep { opacity: 0.4; }
  .breadcrumb__current { color: var(--color-ink); }

  .collection-page {
    padding-top: 64px;
    padding-bottom: var(--section-spacing);
    padding-left: var(--page-margin, 48px);
    padding-right: var(--page-margin, 48px);
  }

  .collection-page__header {
    text-align: center;
    margin-bottom: 56px;
    padding-bottom: 48px;
    border-bottom: 1px solid var(--color-border);
  }

  .collection-page__header .eyebrow { margin-bottom: 12px; }
  .collection-page__header h1 { margin-bottom: 16px; }

  .collection-page__desc {
    max-width: 520px;
    margin: 0 auto;
    font-size: 14px;
    line-height: 1.7;
    color: var(--color-ink-soft);
    opacity: 0.75;
  }
/* END_SECTION:collection */

/* START_SECTION:collections (INDEX:9) */
.coll-list {
    padding: 80px var(--page-margin, 48px) var(--section-spacing);
  }

  .coll-list__header {
    text-align: center;
    margin-bottom: 64px;
  }
  .coll-list__header .eyebrow {
    margin-bottom: 16px;
  }
  .coll-list__heading {
    font-family: var(--font-heading);
    font-size: clamp(2.4rem, 5vw, 4rem);
    font-weight: 300;
    font-style: italic;
    color: var(--color-ink);
    margin: 0 0 16px;
    line-height: 1.1;
  }
  .coll-list__subhead {
    font-size: 15px;
    color: var(--color-ink-soft);
    max-width: 420px;
    margin: 0 auto;
    line-height: 1.6;
  }

  .coll-list__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
  }

  .coll-card {
    display: block;
    text-decoration: none;
    position: relative;
    overflow: hidden;
    border-radius: 2px;
  }

  .coll-card__img-wrap {
    position: relative;
    aspect-ratio: 3 / 4;
    overflow: hidden;
    background: var(--color-stone);
  }

  .coll-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 600ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  }
  .coll-card:hover .coll-card__img {
    transform: scale(1.05);
  }

  .coll-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(30, 24, 18, 0.72) 0%, rgba(30, 24, 18, 0.18) 50%, transparent 100%);
    transition: opacity 400ms ease;
  }
  .coll-card:hover .coll-card__overlay {
    opacity: 1.15;
  }

  .coll-card__img-placeholder {
    width: 100%;
    height: 100%;
    background: var(--color-stone);
  }

  .coll-card__text {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 28px 24px;
    color: #fff;
  }

  .coll-card__text .eyebrow {
    color: rgba(255, 255, 255, 0.7);
    margin-bottom: 8px;
    font-size: 10px;
  }

  .coll-card__title {
    font-family: var(--font-heading);
    font-size: clamp(1.4rem, 2.2vw, 1.9rem);
    font-weight: 300;
    font-style: italic;
    color: #fff;
    margin: 0 0 12px;
    line-height: 1.2;
  }

  .coll-card__cta {
    font-family: var(--font-body);
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.85);
    display: inline-block;
    border-bottom: 1px solid rgba(255, 255, 255, 0.4);
    padding-bottom: 2px;
    transform: translateY(4px);
    opacity: 0;
    transition: opacity 300ms ease, transform 300ms ease;
  }
  .coll-card:hover .coll-card__cta {
    opacity: 1;
    transform: translateY(0);
  }

  @media (max-width: 1024px) {
    .coll-list__grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  }
  @media (max-width: 640px) {
    .coll-list { padding: 48px var(--page-margin, 20px) 64px; }
    .coll-list__header { margin-bottom: 40px; }
    .coll-list__grid { grid-template-columns: 1fr 1fr; gap: 12px; }
    .coll-card__text { padding: 20px 16px; }
    .coll-card__title { font-size: 1.2rem; }
    .coll-card__cta { display: none; }
  }
/* END_SECTION:collections */

/* START_SECTION:contact-us (INDEX:10) */
.contact-page {
    padding: 80px var(--page-margin, 48px) var(--section-spacing);
    max-width: 1200px;
    margin: 0 auto;
  }

  /* ── Header ── */
  .contact-page__header {
    margin-bottom: 72px;
    max-width: 560px;
  }

  .contact-page__header .eyebrow { margin-bottom: 16px; }

  .contact-page__heading {
    font-size: clamp(2rem, 4vw, 3.2rem);
    font-weight: 300;
    color: var(--color-ink);
    margin-bottom: 18px;
    line-height: 1.1;
  }

  .contact-page__subtext {
    font-size: 14px;
    line-height: 1.75;
    color: var(--color-ink-soft);
    opacity: 0.7;
    max-width: 440px;
  }

  /* ── Body layout ── */
  .contact-page__body {
    display: grid;
    grid-template-columns: 1fr 1.6fr;
    gap: 80px;
    align-items: start;
  }

  /* ── Info column ── */
  .contact-page__info {
    display: flex;
    flex-direction: column;
    gap: 0;
    border-top: 1px solid var(--color-border);
  }

  .contact-info-block {
    padding: 28px 0;
    border-bottom: 1px solid var(--color-border);
  }

  .contact-info-block--faq {
    border-bottom: none;
    padding-bottom: 0;
  }

  .contact-info-block__label {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.5;
    margin-bottom: 8px;
  }

  .contact-info-block__value {
    font-size: 14px;
    line-height: 1.65;
    color: var(--color-ink-soft);
  }

  .contact-info-block__link {
    color: var(--color-ink);
    border-bottom: 1px solid var(--color-border);
    padding-bottom: 1px;
    transition: border-color var(--transition-base);
  }
  .contact-info-block__link:hover { border-color: var(--color-ink); }

  .contact-info-block__socials {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  .contact-social-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: var(--color-ink-soft);
    opacity: 0.7;
    transition: opacity var(--transition-base);
  }
  .contact-social-link:hover { opacity: 1; }

  /* ── Form ── */
  .contact-page__form-wrap {
    background: var(--color-paper);
    border: 1px solid var(--color-border);
    padding: 48px;
  }

  .contact-form {
    display: flex;
    flex-direction: column;
    gap: 24px;
  }

  .contact-form__row--2col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }

  .contact-form__field {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }

  .contact-form__label {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.7;
  }

  .contact-form__submit { align-self: flex-start; }

  .contact-form__error {
    font-size: 13px;
    color: #b94a3a;
    padding: 12px 16px;
    border: 1px solid #b94a3a;
    background: #fdf4f3;
  }

  /* ── Success state ── */
  .contact-form-success {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 16px;
    padding: 48px 24px;
    color: var(--color-ink);
  }

  .contact-form-success svg { color: var(--color-ink); opacity: 0.6; }

  .contact-form-success h3 {
    font-family: var(--font-heading);
    font-size: 1.6rem;
    font-weight: 300;
  }

  .contact-form-success p {
    font-size: 14px;
    color: var(--color-ink-soft);
    opacity: 0.7;
  }

  /* ── Responsive ── */
  @media (max-width: 960px) {
    .contact-page__body { grid-template-columns: 1fr; gap: 48px; }
    .contact-page__form-wrap { padding: 32px; }
  }

  @media (max-width: 640px) {
    .contact-page { padding: 56px 20px var(--section-spacing); }
    .contact-page__header { margin-bottom: 48px; }
    .contact-form__row--2col { grid-template-columns: 1fr; }
    .contact-page__form-wrap { padding: 24px; }
  }
/* END_SECTION:contact-us */

/* START_SECTION:custom-section (INDEX:11) */
.custom-section {
    position: relative;
    overflow: hidden;
    width: 100%;
  }
  .custom-section__background {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: -1;
    overflow: hidden;
  }
  .custom-section__background img {
    position: absolute;
    width: 100%;
    height: auto;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  .custom-section__content {
    display: grid;
    grid-template-columns: var(--content-grid);
  }
  .custom-section__content > * {
    grid-column: 2;
  }
/* END_SECTION:custom-section */

/* START_SECTION:faq-page (INDEX:12) */
/* ── Hero ── */
  .faq-hero {
    padding: 72px var(--page-margin, 48px) 56px;
    border-bottom: 1px solid var(--color-border);
  }

  .faq-hero .eyebrow { margin-bottom: 16px; }

  .faq-hero__heading {
    font-size: clamp(2.5rem, 5vw, 4.5rem);
    font-weight: 300;
    letter-spacing: -0.02em;
    line-height: 1.05;
    margin-bottom: 16px;
  }

  .faq-hero__sub {
    font-size: 15px;
    color: var(--color-ink-soft);
    opacity: 0.65;
    max-width: 480px;
  }

  /* ── Jump nav ── */
  .faq-nav {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 8px 14px;
    padding: 28px var(--page-margin, 48px);
    border-bottom: 1px solid var(--color-border);
  }

  .faq-nav__label {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.45;
    white-space: nowrap;
  }

  .faq-nav__links {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 4px 10px;
  }

  .faq-nav__link {
    font-size: 12px;
    font-weight: 400;
    letter-spacing: 0.06em;
    color: var(--color-ink-soft);
    opacity: 0.7;
    transition: opacity var(--transition-base);
  }
  .faq-nav__link:hover { opacity: 1; }

  .faq-nav__dot {
    font-size: 12px;
    color: var(--color-border);
  }

  /* ── FAQ body ── */
  .faq-body {
    max-width: 840px;
    margin: 0 auto;
    padding: 0 var(--page-margin, 48px) 80px;
  }

  /* ── Category heading ── */
  .faq-category {
    padding-top: 64px;
    margin-bottom: 8px;
  }

  .faq-category__heading {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 2.5vw, 2.25rem);
    font-weight: 300;
    color: var(--color-ink);
    letter-spacing: -0.01em;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--color-border);
  }

  /* ── Accordion items ── */
  .faq-item {
    border-bottom: 1px solid var(--color-border);
  }

  .faq-item__q {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 22px 0;
    cursor: pointer;
    list-style: none;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.01em;
    color: var(--color-ink);
    line-height: 1.5;
    transition: opacity var(--transition-base);
    user-select: none;
  }
  .faq-item__q::-webkit-details-marker { display: none; }
  .faq-item__q:hover { opacity: 0.7; }

  .faq-item__icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .faq-item__icon::before,
  .faq-item__icon::after {
    content: '';
    position: absolute;
    background: var(--color-ink);
    transition: transform 250ms ease, opacity 250ms ease;
  }
  .faq-item__icon::before { width: 12px; height: 1px; }
  .faq-item__icon::after  { width: 1px; height: 12px; }

  .faq-item[open] .faq-item__icon::after { transform: rotate(90deg); opacity: 0; }
  .faq-item[open] .faq-item__q { opacity: 1; }

  .faq-item__a {
    padding: 0 40px 24px 0;
    font-size: 14px;
    line-height: 1.85;
    color: var(--color-ink-soft);
    opacity: 0.75;
  }
  .faq-item__a p + p { margin-top: 0.75em; }
  .faq-item__a a { text-decoration: underline; }
  .faq-item__a ul { padding-left: 1.1em; margin-top: 0.5em; }
  .faq-item__a li { margin-bottom: 0.4em; }

  /* ── Contact CTA ── */
  .faq-contact {
    border-top: 1px solid var(--color-border);
    padding: 80px var(--page-margin, 48px);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 16px;
  }

  .faq-contact__heading {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 2.5vw, 2.25rem);
    font-weight: 300;
    color: var(--color-ink);
    max-width: 560px;
  }

  .faq-contact__text {
    font-size: 14px;
    line-height: 1.7;
    color: var(--color-ink-soft);
    opacity: 0.65;
    max-width: 420px;
    margin-bottom: 8px;
  }

  /* ── Responsive ── */
  @media (max-width: 640px) {
    .faq-hero { padding: 48px 20px 40px; }
    .faq-nav  { padding: 20px; }
    .faq-body { padding-left: 20px; padding-right: 20px; }
    .faq-contact { padding: 56px 20px; }
    .faq-item__a { padding-right: 0; }
  }
/* END_SECTION:faq-page */

/* START_SECTION:feature-callouts (INDEX:13) */
.shopify-section > .callouts { grid-column: 1 / -1; }

  .callouts {
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
  }

  .callouts__layout {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    min-height: 560px;
  }

  /* ── Left column ── */
  .callouts__left {
    padding: 72px var(--page-margin, 48px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 48px;
    border-right: 1px solid var(--color-border);
  }

  .callouts__header { display: flex; flex-direction: column; gap: 14px; }

  .callouts__heading {
    font-size: clamp(1.75rem, 3vw, 2.75rem);
    font-weight: 300;
    line-height: 1.12;
    letter-spacing: -0.01em;
  }

  .callouts__subtext {
    font-size: 14px;
    line-height: 1.7;
    color: var(--color-ink-soft);
    opacity: 0.65;
    max-width: 400px;
  }

  /* ── Feature list ── */
  .callouts__list {
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  .callout-row {
    display: grid;
    grid-template-columns: 56px 1fr;
    gap: 20px;
    align-items: start;
    padding: 24px 0;
    border-top: 1px solid var(--color-border);
  }
  .callout-row:last-child { border-bottom: 1px solid var(--color-border); }

  .callout-row__icon {
    width: 48px;
    height: 48px;
    border: 1px solid var(--color-border);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }

  .callout-row__icon span {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 300;
    color: var(--color-ink);
    line-height: 1;
  }

  .callout-row__icon--img {
    border: none;
    background: var(--color-stone);
    overflow: hidden;
  }
  .callout-row__icon--img img { width: 100%; height: 100%; object-fit: cover; }

  .callout-row__heading {
    font-family: var(--font-heading);
    font-size: clamp(1rem, 1.3vw, 1.2rem);
    font-weight: 300;
    color: var(--color-ink);
    margin-bottom: 6px;
    letter-spacing: -0.01em;
  }

  .callout-row__text {
    font-size: 13px;
    line-height: 1.75;
    color: var(--color-ink-soft);
    opacity: 0.65;
  }

  /* ── Right column: image ── */
  .callouts__right {
    position: relative;
    overflow: hidden;
    background: var(--color-stone);
  }

  .callouts__right--placeholder {
    background: var(--color-stone);
  }

  .callouts__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  /* ── Responsive ── */
  @media (max-width: 960px) {
    .callouts__layout {
      grid-template-columns: 1fr;
    }
    .callouts__left {
      border-right: none;
      border-bottom: 1px solid var(--color-border);
      padding: 56px var(--page-margin, 48px);
    }
    .callouts__right {
      min-height: 400px;
    }
  }

  @media (max-width: 640px) {
    .callouts__left { padding: 48px 20px; }
    .callouts__right { min-height: 280px; }
    .callout-row { grid-template-columns: 44px 1fr; gap: 14px; }
  }
/* END_SECTION:feature-callouts */

/* START_SECTION:featured-collection (INDEX:14) */
.featured-col { padding-bottom: var(--section-spacing); }

  .featured-col__footer {
    display: flex;
    justify-content: center;
    padding-top: 56px;
  }

  @media (max-width: 640px) {
    .featured-col__footer { padding-top: 32px; }
    .featured-col__footer .btn { width: 100%; text-align: center; }
  }
/* END_SECTION:featured-collection */

/* START_SECTION:footer (INDEX:15) */
.nourgate-footer {
    background: var(--color-paper);
    border-top: 1px solid var(--color-border);
    padding: 72px var(--page-margin, 48px) 40px;
  }

  .footer__main {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr 1.5fr;
    gap: 48px;
    align-items: start;
    padding-bottom: 64px;
    border-bottom: 1px solid var(--color-border);
    margin-bottom: 0;
  }
  .footer__brand,
  .footer__col,
  .footer__newsletter {
    align-self: start;
    margin-top: 0;
    padding-top: 0;
  }

  .footer__wordmark {
    display: block;
    font-family: var(--font-heading);
    font-size: 16px;
    font-weight: 300;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--color-ink);
    margin-bottom: 16px;
  }

  .footer__tagline {
    font-size: 13px;
    line-height: 1.65;
    color: var(--color-ink-soft);
    opacity: 0.6;
    max-width: 220px;
  }

  .footer__social {
    display: flex;
    gap: 16px;
    margin-top: 24px;
  }
  .footer__social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-ink-soft);
    opacity: 0.5;
    transition: opacity var(--transition-base);
  }
  .footer__social-link:hover { opacity: 1; }

  .footer__col-heading {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--color-ink);
    margin-top: 0;
    margin-bottom: 20px;
  }

  .footer__links {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  .footer__links a {
    font-size: 13px;
    color: var(--color-ink-soft);
    opacity: 0.7;
    transition: opacity var(--transition-base);
  }
  .footer__links a:hover { opacity: 1; }

  .footer__newsletter-desc {
    font-size: 13px;
    line-height: 1.6;
    color: var(--color-ink-soft);
    opacity: 0.6;
    margin-bottom: 20px;
  }

  .footer__form-row {
    display: flex;
    gap: 0;
    border: 1px solid var(--color-border);
  }

  .footer__form-row input {
    border: none;
    flex: 1;
    padding: 12px 14px;
    font-size: 13px;
    background: transparent;
  }

  .footer__form-btn {
    background: transparent;
    border: none;
    border-left: 1px solid var(--color-border);
    padding: 0 16px;
    font-size: 16px;
    cursor: pointer;
    color: var(--color-ink);
    transition: background var(--transition-base);
  }
  .footer__form-btn:hover { background: var(--color-ink); color: var(--color-paper-warm); }

  .footer__form-success {
    font-size: 12px;
    color: var(--color-ink-soft);
    opacity: 0.7;
    margin-top: 10px;
    letter-spacing: 0.05em;
  }

  .footer__logo-img {
    display: block;
    height: auto;
    max-height: 120px;
    width: auto;
    margin-bottom: 16px;
    opacity: 0.85;
  }

  .footer__contact {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 24px;
    padding: 28px 0;
    border-bottom: 1px solid var(--color-border);
    margin-bottom: 28px;
    font-size: 12px;
    color: var(--color-ink-soft);
  }

  .footer__contact-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    opacity: 0.7;
  }

  .footer__contact-item--text { opacity: 0.55; }

  .footer__contact-link {
    text-decoration: underline;
    text-underline-offset: 2px;
    text-decoration-color: var(--color-border);
    transition: opacity var(--transition-base);
    color: var(--color-ink-soft);
  }
  .footer__contact-link:hover { opacity: 1; }

  .footer__bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
  }

  .footer__copy {
    font-size: 12px;
    color: var(--color-ink-soft);
    opacity: 0.45;
    letter-spacing: 0.03em;
  }

  .footer__payment { display: flex; align-items: center; gap: 8px; }
  .footer__payment-icon { height: 20px; opacity: 0.4; }

  @media (max-width: 1100px) {
    .footer__main { grid-template-columns: 1fr 1fr 1fr; }
  }
  @media (max-width: 768px) {
    .footer__main { grid-template-columns: 1fr 1fr; }
  }

  @media (max-width: 640px) {
    .nourgate-footer { padding: 48px 20px 32px; }
    .footer__main { grid-template-columns: 1fr; gap: 36px; }
    .footer__bottom { flex-direction: column; align-items: flex-start; }
  }
/* END_SECTION:footer */

/* START_SECTION:header (INDEX:16) */
/* ── Base header ── */
  .nourgate-header {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 200;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    height: var(--header-height, 72px);
    padding: 0 var(--page-margin, 48px);
    background: transparent;
    transition: background 350ms ease, border-color 350ms ease;
    border-bottom: 1px solid transparent;
  }

  .nourgate-header.scrolled {
    background: var(--color-paper);
    border-bottom-color: var(--color-border);
  }

  /* ── Centre nav ── */
  .header__nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 28px;
  }

  .header__link {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 11px;
    font-weight: 400;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-ink);
    white-space: nowrap;
    transition: opacity var(--transition-base);
  }
  .header__link:hover { opacity: 0.45; }

  .header__chevron {
    transition: transform 250ms ease;
    flex-shrink: 0;
  }

  /* ── Nav item with dropdown ── */
  .header__item { position: static; }
  .header__item--has-drop { position: static; }

  /* ── Mega menu ── */
  .header__mega {
    position: fixed;
    top: var(--header-height, 72px);
    left: 0;
    right: 0;
    background: var(--color-paper);
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    padding: 20px var(--page-margin, 48px) 24px;
    z-index: 199;

    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    pointer-events: none;
    transition: opacity 200ms ease 180ms, transform 200ms ease 180ms, visibility 0ms linear 380ms;
  }

  /* Show mega on hover — managed by JS class */
  .header__item--has-drop.mega-open .header__mega,
  .header__item--has-drop:focus-within .header__mega {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
    transition: opacity 200ms ease, transform 200ms ease, visibility 0ms;
  }

  /* Rotate chevron when open */
  .header__item--has-drop.mega-open .header__chevron,
  .header__item--has-drop:focus-within .header__chevron {
    transform: rotate(180deg);
  }

  .header__mega-inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 24px 28px;
    max-width: var(--page-width, 1440px);
    margin: 0 auto;
  }

  /* ── Mega menu items ── */
  .header__mega-item {
    display: block;
    text-align: left;
    color: var(--color-ink);
  }

  .header__mega-item {
    width: 110px;
    flex-shrink: 0;
  }

  .header__mega-img-wrap {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--color-stone);
    margin-bottom: 8px;
  }

  .header__mega-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 500ms ease;
    display: block;
  }
  .header__mega-item:hover .header__mega-img { transform: scale(1.04); }

  .header__mega-img-placeholder {
    width: 100%;
    height: 100%;
    background: var(--color-stone);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-heading);
    font-size: 2rem;
    font-weight: 300;
    color: var(--color-border);
    text-transform: uppercase;
  }

  .header__mega-label {
    font-size: 13px;
    font-weight: 400;
    color: var(--color-ink-soft);
    line-height: 1.3;
    transition: color var(--transition-base);
  }
  .header__mega-item:hover .header__mega-label { color: var(--color-ink); }

  /* ── Backdrop ── */
  .header__backdrop {
    position: fixed;
    inset: 0;
    top: var(--header-height, 72px);
    background: rgba(13,13,13,0.18);
    z-index: 198;
    opacity: 0;
    visibility: hidden;
    transition: opacity 220ms ease, visibility 220ms ease;
    pointer-events: none;
  }

  .nourgate-header:has(.header__item--has-drop:hover) ~ .header__backdrop,
  .nourgate-header:has(.header__item--has-drop:focus-within) ~ .header__backdrop {
    opacity: 1;
    visibility: visible;
  }

  /* ── Wordmark ── */
  .header__wordmark {
    font-family: var(--font-heading);
    font-size: 17px;
    font-weight: 300;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--color-ink);
    white-space: nowrap;
    display: flex;
    align-items: center;
  }

  .header__logo-img {
    display: block;
    height: auto;
    max-height: 72px;
    width: auto;
  }

  /* ── Right icons ── */
  .header__right {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 20px;
  }

  .header__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-ink);
    transition: opacity var(--transition-base);
    position: relative;
  }
  .header__icon:hover { opacity: 0.45; }
  .header__icon svg { width: 18px; height: 18px; }

  .header__cart-count {
    position: absolute;
    top: -7px;
    right: -8px;
    font-family: var(--font-body);
    font-size: 9px;
    font-weight: 500;
    line-height: 1;
    background: var(--color-ink);
    color: var(--color-paper-warm);
    min-width: 15px;
    height: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 3px;
  }

  /* ── Hamburger button ── */
  .header__burger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 44px;
    height: 44px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    color: var(--color-ink);
    order: -1;
  }
  .header__burger span {
    display: block;
    width: 22px;
    height: 1.5px;
    background: currentColor;
    transition: transform 280ms ease, opacity 280ms ease;
  }
  .header__burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
  .header__burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .header__burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

  /* ── Mobile nav drawer ── */
  .mobile-nav {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: min(320px, 85vw);
    background: var(--color-paper);
    z-index: 400;
    display: flex;
    flex-direction: column;
    transform: translateX(-100%);
    transition: transform 320ms cubic-bezier(0.4, 0, 0.2, 1);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .mobile-nav.is-open { transform: translateX(0); }

  .mobile-nav__overlay {
    position: fixed;
    inset: 0;
    background: rgba(13, 13, 13, 0.5);
    z-index: 399;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 320ms ease, visibility 320ms ease;
  }
  .mobile-nav__overlay.is-open { opacity: 1; visibility: visible; pointer-events: auto; }

  .mobile-nav__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    height: 60px;
    border-bottom: 1px solid var(--color-border);
    flex-shrink: 0;
  }

  .mobile-nav__wordmark {
    font-family: var(--font-heading);
    font-size: 15px;
    font-weight: 300;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--color-ink);
  }

  .mobile-nav__close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--color-ink);
    margin-right: -8px;
  }

  .mobile-nav__links {
    flex: 1;
    padding: 12px 0;
    border-bottom: 1px solid var(--color-border);
  }

  .mobile-nav__link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 24px;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-ink);
    border-bottom: 1px solid var(--color-border);
  }
  .mobile-nav__link:last-child { border-bottom: none; }

  .mobile-nav__group { border-bottom: 1px solid var(--color-border); }
  .mobile-nav__group summary { list-style: none; }
  .mobile-nav__group summary::-webkit-details-marker { display: none; }
  .mobile-nav__link--parent { cursor: pointer; }
  .mobile-nav__group[open] .mobile-nav__link--parent svg { transform: rotate(180deg); }
  .mobile-nav__link--parent svg { transition: transform 200ms ease; flex-shrink: 0; }

  .mobile-nav__sub {
    background: var(--color-paper-warm);
    padding: 8px 0;
  }

  .mobile-nav__sublink {
    display: block;
    padding: 12px 24px 12px 36px;
    font-size: 13px;
    color: var(--color-ink-soft);
    border-bottom: 1px solid var(--color-border);
  }
  .mobile-nav__sublink:last-child { border-bottom: none; }

  .mobile-nav__footer {
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 16px;
  }

  .mobile-nav__util {
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.6;
  }

  /* ── Mobile overrides ── */
  @media (max-width: 768px) {
    .nourgate-header {
      padding: 0 20px;
      grid-template-columns: auto 1fr auto;
    }
    .header__nav { display: none; }
    .header__mega { display: none; }
    .header__backdrop { display: none; }
    .header__burger { display: flex; }
    .header__right { gap: 12px; }
    .header__icon svg { width: 20px; height: 20px; }
  }
/* END_SECTION:header */

/* START_SECTION:hello-world (INDEX:17) */
.welcome {
    display: grid;
    grid-template-columns: var(--content-grid);
    background-color: #f6f6f7;
    padding: 72px 0;
  }

  .welcome-content {
    grid-column: 2;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    width: 100%;
    padding: 0 24px;
  }

  .welcome-description {
    max-width: 80ch;
    line-height: 1.4;
    margin-top: 1.5rem;
  }

  .icon {
    width: 300px;
  }

  .highlights {
    display: grid;
    gap: 2rem;
    grid-template-columns: repeat(3, 1fr);
    margin-top: 50px;
  }

  @media (max-width: 1100px) {
    .highlights {
      grid-template-columns: 1fr;
    }
  }

  .highlight {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 24px;
    border-radius: 8px;
    background-color: #eef3ff;
    color: rgb(92, 95, 98);
    line-height: 1.4;
  }

  .highlight > * + * {
    margin-top: 1rem;
  }

  .highlight h3 {
    font-size: 1rem;
    color: rgb(32, 34, 35);
  }

  .highlight-description {
    flex: 1 1;
  }

  .highlight a {
    display: flex;
    width: fit-content;
    background-color: rgb(250, 251, 251);
    box-shadow: rgba(0, 0, 0, 0.2) 0px -3px 0px 0px inset, rgba(255, 255, 255, 0.9) 0px 2px 0px 0px inset;
    border: 1px solid rgb(140, 145, 150);
    border-radius: 4px;
    color: rgb(92, 95, 98);
    padding: 3px 10px 5px;
    text-decoration: none;
  }
/* END_SECTION:hello-world */

/* START_SECTION:hero (INDEX:18) */
/* Pull the section wrapper up so the hero image bleeds behind the transparent header */
  #shopify-section-{{ section.id }} {
    margin-top: calc(-1 * var(--header-height, 72px));
  }

  .hero {
    position: relative;
    min-height: var(--hero-h, 100vh);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    overflow: hidden;
    background: var(--color-paper-warm);
  }

  .hero--no-image {
    min-height: 70vh;
    border-bottom: 1px solid var(--color-border);
  }

  .hero__bg {
    position: absolute;
    inset: 0;
  }

  .hero__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .hero__overlay {
    position: absolute;
    inset: 0;
    background: rgba(13, 13, 13, 0.32);
  }

  .hero__content {
    position: relative;
    z-index: 1;
    max-width: 720px;
    padding: 0 var(--page-margin, 48px);
    padding-top: var(--header-height, 72px);
  }

  .hero__eyebrow--light { color: rgba(250, 250, 247, 0.7); }

  .hero__heading {
    font-size: clamp(3rem, 6vw, 5.5rem);
    margin-bottom: 24px;
    color: var(--color-paper-warm);
    line-height: 1.0;
  }

  .hero--no-image .hero__heading { color: var(--color-ink); }

  .hero__sub {
    font-size: 15px;
    line-height: 1.65;
    letter-spacing: 0.01em;
    color: rgba(250, 250, 247, 0.82);
    margin-bottom: 40px;
  }

  .hero--no-image .hero__sub { color: var(--color-ink-soft); }

  @media (max-width: 768px) {
    .hero { min-height: min(var(--hero-h, 100vh), 75vh); }
    .hero__heading { font-size: clamp(2rem, 9vw, 3rem); }
    .hero__sub { font-size: 14px; margin-bottom: 28px; }
    .hero__content { padding: 0 20px; padding-top: var(--header-height, 60px); }
  }
/* END_SECTION:hero */

/* START_SECTION:product-faq (INDEX:22) */
.shopify-section > .product-faq { grid-column: 1 / -1; }

  .product-faq {
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    margin-top: 80px;
  }

  .product-faq__inner {
    max-width: 860px;
    margin: 0 auto;
    padding: 72px var(--page-margin, 48px);
  }

  .product-faq__heading {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 3vw, 2.75rem);
    font-weight: 300;
    letter-spacing: -0.01em;
    line-height: 1.12;
    color: var(--color-ink);
    margin-bottom: 48px;
  }

  /* ── Accordion items ── */
  .product-faq__list { width: 100%; }

  .product-faq__item {
    border-top: 1px solid var(--color-border);
  }
  .product-faq__item:last-child {
    border-bottom: 1px solid var(--color-border);
  }

  .product-faq__q {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 22px 0;
    cursor: pointer;
    list-style: none;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.01em;
    color: var(--color-ink);
    line-height: 1.5;
    transition: opacity var(--transition-base);
    user-select: none;
  }
  .product-faq__q::-webkit-details-marker { display: none; }
  .product-faq__q:hover { opacity: 0.6; }

  .product-faq__icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .product-faq__icon::before,
  .product-faq__icon::after {
    content: '';
    position: absolute;
    background: var(--color-ink);
    transition: transform 250ms ease, opacity 250ms ease;
  }
  .product-faq__icon::before { width: 12px; height: 1px; }
  .product-faq__icon::after  { width: 1px; height: 12px; }

  .product-faq__item[open] .product-faq__icon::after {
    transform: rotate(90deg);
    opacity: 0;
  }
  .product-faq__item[open] .product-faq__q { opacity: 1; }

  .product-faq__a {
    padding: 4px 40px 24px 0;
    font-size: 13px;
    line-height: 1.85;
    color: var(--color-ink-soft);
    opacity: 0.75;
  }
  .product-faq__a p + p { margin-top: 0.75em; }
  .product-faq__a a { text-decoration: underline; }
  .product-faq__a ul { padding-left: 1.1em; margin-top: 0.5em; }
  .product-faq__a li { margin-bottom: 0.4em; }

  /* ── Responsive ── */
  @media (max-width: 640px) {
    .product-faq__inner { padding: 48px 20px; }
    .product-faq__a { padding-right: 0; }
  }
/* END_SECTION:product-faq */

/* START_SECTION:product-specs (INDEX:23) */
.shopify-section > .specs-section { grid-column: 1 / -1; }

  .specs-section {
    margin-top: 80px;
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
  }

  .specs-section__inner {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    min-height: 520px;
  }

  /* ── Left ── */
  .specs-section__left {
    padding: 64px var(--page-margin, 48px);
    border-right: 1px solid var(--color-border);
  }

  .specs-section__heading {
    font-family: var(--font-heading);
    font-size: clamp(1rem, 1.2vw, 1.15rem);
    font-weight: 400;
    letter-spacing: 0.01em;
    color: var(--color-ink);
    margin-bottom: 48px;
  }

  .specs-section__row {
    display: grid;
    grid-template-columns: 140px 1fr;
    gap: 24px;
    padding: 28px 0;
    border-top: 1px solid var(--color-border);
  }
  .specs-section__row--top { align-items: start; }

  .specs-section__label {
    font-size: 12px;
    font-weight: 400;
    color: var(--color-ink-soft);
    opacity: 0.5;
    padding-top: 2px;
  }

  .specs-section__desc {
    font-size: 13px;
    line-height: 1.85;
    color: var(--color-ink-soft);
    opacity: 0.8;
  }
  .specs-section__desc ul { padding-left: 1.1em; }
  .specs-section__desc li { margin-bottom: 6px; }
  .specs-section__desc p + p { margin-top: 0.75em; }

  /* ── Spec table ── */
  .specs-table { width: 100%; }

  .specs-table__row {
    display: grid;
    grid-template-columns: 160px 1fr;
    gap: 16px;
    padding: 12px 0;
    border-bottom: 1px solid var(--color-border);
  }
  .specs-table__row:last-child { border-bottom: none; }

  .specs-table__key {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.45;
    padding-top: 1px;
  }

  .specs-table__val {
    font-size: 13px;
    color: var(--color-ink);
    line-height: 1.5;
  }

  /* ── Right: diagram ── */
  .specs-section__right {
    background: var(--color-stone);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 56px 48px;
  }

  .specs-section__diagram {
    width: 100%;
    height: 100%;
    object-fit: contain;
    max-height: 520px;
  }

  /* ── Responsive ── */
  @media (max-width: 960px) {
    .specs-section__inner {
      grid-template-columns: 1fr;
    }
    .specs-section__left {
      border-right: none;
      border-bottom: 1px solid var(--color-border);
    }
    .specs-section__right {
      min-height: 360px;
      padding: 40px 24px;
    }
  }

  @media (max-width: 640px) {
    .specs-section__left { padding: 40px 20px; }
    .specs-section__row { grid-template-columns: 1fr; gap: 12px; }
    .specs-table__row { grid-template-columns: 1fr; gap: 4px; }
  }
/* END_SECTION:product-specs */

/* START_SECTION:product-upsell (INDEX:24) */
.upsell {
    background: var(--color-stone);
    padding: 48px 40px 52px;
    border: 1px solid var(--color-border);
    border-radius: 16px;
    margin: 64px 0;
  }

  /* 4-column grid: main product (1.5fr) + 3 upsell cards (1fr each) */
  .upsell__layout {
    display: grid;
    grid-template-columns: 1.5fr repeat(3, 1fr);
    gap: 24px;
    align-items: start;
    margin-bottom: 32px;
  }

  /* ── Main product card ── */
  .upsell-main {
    background: var(--color-paper);
    border: 1px solid var(--color-border);
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
    border-radius: 10px;
    overflow: hidden;
  }

  .upsell-main__media {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--color-stone);
  }

  .upsell-main__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  .upsell-main__body { padding: 20px 22px 22px; }

  .upsell-main__vendor {
    font-size: 10px;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.6;
    margin-bottom: 6px;
  }

  .upsell-main__meta {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
  }

  .upsell-main__title {
    font-size: 14px;
    font-weight: 400;
    color: var(--color-ink);
    line-height: 1.4;
    flex: 1;
  }

  .upsell-main__price {
    font-size: 14px;
    color: var(--color-ink);
    white-space: nowrap;
    flex-shrink: 0;
  }

  /* ── Upsell cards ── */
  .upsell-card {
    position: relative;
    background: var(--color-paper);
    border: 1px solid var(--color-border);
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
    border-radius: 10px;
    overflow: hidden;
    transition: opacity 0.2s;
  }

  .upsell-card:not(.upsell-card--checked) { opacity: 0.4; }

  .upsell-card__toggle {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 2;
    width: 24px;
    height: 24px;
    border: 1.5px solid var(--color-border);
    background: var(--color-paper);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: transparent;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
    padding: 0;
  }
  .upsell-card--checked .upsell-card__toggle {
    background: var(--color-ink);
    border-color: var(--color-ink);
    color: var(--color-paper);
  }

  .upsell-card__media {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--color-stone);
  }
  .upsell-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .upsell-card__placeholder {
    width: 100%;
    height: 100%;
    background: var(--color-stone);
  }

  .upsell-card__body { padding: 16px 18px 18px; }

  .upsell-card__vendor {
    font-size: 10px;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.6;
    margin-bottom: 5px;
  }

  .upsell-card__meta {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 10px;
  }

  .upsell-card__title {
    font-size: 12px;
    font-weight: 400;
    color: var(--color-ink);
    line-height: 1.4;
    flex: 1;
  }

  .upsell-card__price {
    font-size: 12px;
    color: var(--color-ink);
    white-space: nowrap;
    flex-shrink: 0;
  }

  /* Variant pill buttons */
  .upsell-card__options { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 2px; }

  .upsell-opt-btn {
    font-size: 11px;
    font-family: var(--font-body);
    padding: 4px 10px;
    border: 1px solid var(--color-border);
    background: transparent;
    cursor: pointer;
    color: var(--color-ink-soft);
    letter-spacing: 0.03em;
    transition: border-color 0.15s, color 0.15s;
    white-space: nowrap;
  }
  .upsell-opt-btn:hover { border-color: var(--color-ink-soft); color: var(--color-ink); }
  .upsell-opt-btn--active { border-color: var(--color-ink); color: var(--color-ink); font-weight: 500; }

  /* Footer */
  .upsell__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding-top: 24px;
    border-top: 1px solid var(--color-border);
    margin-top: 8px;
  }

  .upsell__footer-heading {
    font-size: 20px;
    font-family: var(--font-heading);
    font-weight: 300;
    letter-spacing: -0.01em;
    color: var(--color-ink);
    margin-bottom: 4px;
  }

  .upsell__footer-sub { font-size: 13px; color: var(--color-ink-soft); opacity: 0.65; }

  .upsell__footer-right { display: flex; align-items: center; gap: 24px; flex-shrink: 0; }

  .upsell__total-line { font-size: 14px; color: var(--color-ink); white-space: nowrap; }
  .upsell__total-label { opacity: 0.5; margin-right: 6px; }
  .upsell__total-price { font-weight: 500; }

  .upsell__atc { white-space: nowrap; padding: 14px 32px; font-size: 12px; }
  .upsell__atc:disabled { opacity: 0.35; cursor: not-allowed; }

  /* Responsive */
  @media (max-width: 900px) {
    .upsell__layout { grid-template-columns: 1.5fr repeat(2, 1fr); }
  }
  @media (max-width: 768px) {
    .upsell__layout { grid-template-columns: repeat(2, 1fr); }
    .upsell-main { grid-column: 1 / -1; display: grid; grid-template-columns: 1fr 1fr; }
    .upsell-main__media { aspect-ratio: 1 / 1; }
  }
  @media (max-width: 640px) {
    .upsell { padding: 0; background: none; border: none; border-radius: 0; margin: 32px 0; }

    /* Single column stacked list */
    .upsell__layout { grid-template-columns: 1fr; gap: 10px; margin-bottom: 0; }

    /* Main product — same horizontal card style */
    .upsell-main { display: grid; grid-template-columns: 120px 1fr; border: 1px solid var(--color-border); background: var(--color-paper); border-radius: 10px; overflow: hidden; box-shadow: 0 2px 8px rgba(0,0,0,0.05); }
    .upsell-main__media { aspect-ratio: 1 / 1; }
    .upsell-main__body { padding: 14px 16px; display: flex; flex-direction: column; justify-content: center; gap: 4px; }
    .upsell-main__vendor { display: none; }
    .upsell-main__meta { flex-direction: column; align-items: flex-start; gap: 2px; }
    .upsell-main__title { font-size: 13px; line-height: 1.4; }
    .upsell-main__price { font-size: 13px; font-weight: 500; }

    /* Upsell cards — image | text | checkbox */
    .upsell-card { display: grid; grid-template-columns: 110px 1fr 52px; align-items: center; border-radius: 10px; box-shadow: 0 2px 8px rgba(0,0,0,0.05); overflow: hidden; }
    .upsell-card__media { order: 1; aspect-ratio: 1 / 1; }
    .upsell-card__body { order: 2; padding: 14px 12px; display: flex; flex-direction: column; justify-content: center; gap: 4px; }
    .upsell-card__vendor { display: none; }
    .upsell-card__meta { flex-direction: column; align-items: flex-start; gap: 2px; margin-bottom: 0; }
    .upsell-card__title { font-size: 13px; line-height: 1.4; }
    .upsell-card__price { font-size: 13px; font-weight: 500; }

    /* Checkbox moves to right column */
    .upsell-card__toggle {
      order: 3;
      position: static;
      width: 26px;
      height: 26px;
      margin: 0 auto;
      flex-shrink: 0;
      border-radius: 4px;
    }

    /* Variant swatches — smaller and inline */
    .upsell-card__options { flex-wrap: wrap; gap: 6px; margin-top: 6px; }
    .upsell-opt-btn { font-size: 10px; padding: 3px 8px; }

    /* Footer */
    .upsell__footer {
      flex-direction: row;
      align-items: center;
      justify-content: space-between;
      padding-top: 20px;
      gap: 12px;
    }
    .upsell__footer-left { display: none; }
    .upsell__footer-right { width: 100%; justify-content: space-between; gap: 12px; }
    .upsell__atc { flex: 1; text-align: center; }
    .upsell__total-line { white-space: nowrap; }
  }
/* END_SECTION:product-upsell */

/* START_SECTION:product (INDEX:25) */
.pd-breadcrumb-wrap {
    padding: 20px var(--page-margin, 48px) 0;
    grid-column: 1 / -1;
  }
  .shopify-section > .pd { grid-column: 1 / -1; }
  .pd { padding-top: 0; }

  .pd__layout {
    display: grid;
    grid-template-columns: 1.25fr 0.75fr;
    align-items: start;
    gap: 48px;
    max-width: 1400px;
    margin: 0 auto;
    padding: 48px var(--page-margin);
  }

  /* ── Gallery ── */
  .pd__gallery {
    position: sticky;
    top: 48px;
  }

  .pd__main-wrap {
    position: relative;
    background: var(--color-paper-warm);
    height: 660px;
    overflow: hidden;
  }

  .pd__img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: none;
    background: var(--color-paper-warm);
  }
  .pd__img--active { display: block; }

  .pd__img-placeholder {
    height: 660px;
    background: var(--color-stone);
  }

  .pd__arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    width: 44px;
    height: 44px;
    background: transparent;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--color-ink);
    transition: background var(--transition-base), color var(--transition-base);
  }
  .pd__arrow:hover {
    background: rgba(255, 255, 255, 0.85);
    border-radius: 50%;
  }
  .pd__arrow--prev { left: 16px; }
  .pd__arrow--next { right: 16px; }

  .pd__thumbs {
    display: flex;
    flex-direction: row;
    gap: 6px;
    padding: 12px 0;
    overflow-x: auto;
    scrollbar-width: none;
  }
  .pd__thumbs::-webkit-scrollbar { display: none; }

  .pd__thumb {
    flex: 1 1 0;
    min-width: 0;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border: 1px solid var(--color-border);
    padding: 0;
    cursor: pointer;
    background: var(--color-paper-warm);
    position: relative;
    opacity: 0.55;
    transition: opacity var(--transition-base), border-color var(--transition-base);
  }
  .pd__thumb:hover { opacity: 0.85; }
  .pd__thumb--active {
    opacity: 1;
    border-color: var(--color-ink);
  }
  .pd__thumb img { width: 100%; height: 100%; object-fit: contain; }

  .pd__thumb--extra { display: none; }

  .pd__thumb-more {
    flex: 1 1 0;
    min-width: 0;
    aspect-ratio: 1 / 1;
    border: 1px solid var(--color-border);
    background: var(--color-stone);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.06em;
    font-family: var(--font-body);
    color: var(--color-ink-soft);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 4px;
    line-height: 1.4;
    transition: background var(--transition-base), color var(--transition-base);
  }
  .pd__thumb-more:hover { background: var(--color-border); color: var(--color-ink); }

  /* ── Info panel ── */
  .pd__info {
    position: sticky;
    top: 48px;
    padding: 40px 44px;
    background: var(--color-paper);
    border: 1px solid var(--color-border);
  }

  .pd__vendor { margin-bottom: 10px; }

  .pd__title {
    font-size: clamp(1.6rem, 2.5vw, 2.25rem);
    font-weight: 300;
    line-height: 1.15;
    margin-bottom: 16px;
  }

  .pd__price {
    font-size: 16px;
    font-weight: 400;
    letter-spacing: 0.04em;
    color: var(--color-ink-soft);
  }
  .pd__price-compare {
    text-decoration: line-through;
    opacity: 0.4;
    margin-right: 10px;
  }

  .pd__divider {
    height: 1px;
    background: var(--color-border);
    margin: 28px 0;
  }

  /* ── Options ── */
  .pd__option { margin-bottom: 24px; }

  .pd__option-label {
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    margin-bottom: 12px;
  }
  .pd__option-value { font-weight: 400; text-transform: none; letter-spacing: 0; }

  .pd__option-btns { display: flex; flex-wrap: wrap; gap: 8px; }

  .pd__option-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    border: 1px solid var(--color-border);
    padding: 9px 18px;
    font-size: 13px;
    font-family: var(--font-body);
    cursor: pointer;
    transition: border-color var(--transition-base), background var(--transition-base), color var(--transition-base);
    user-select: none;
    color: var(--color-ink-soft);
  }
  .pd__option-btn:hover { border-color: var(--color-ink-soft); }
  .pd__option-btn--active {
    border-color: var(--color-ink);
    color: var(--color-ink);
    font-weight: 500;
  }
  .pd__option-btn input { position: absolute; opacity: 0; pointer-events: none; width: 0; height: 0; }

  .pd__option-btn--swatch { padding: 8px 14px; gap: 10px; }
  .pd__swatch-dot {
    display: block;
    width: 14px;
    height: 14px;
    border: 1px solid rgba(0,0,0,0.12);
    flex-shrink: 0;
  }

  /* ── Buy row ── */
  .pd__buy {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 10px;
    align-items: stretch;
  }

  .pd__qty-wrap {
    display: grid;
    grid-template-columns: 36px 1fr 36px;
    border: 1px solid var(--color-border);
    overflow: hidden;
  }

  .pd__qty-btn {
    background: none;
    border: none;
    padding: 0;
    font-size: 18px;
    font-weight: 300;
    cursor: pointer;
    color: var(--color-ink);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--transition-base);
    line-height: 1;
  }
  .pd__qty-btn:hover { background: var(--color-stone); }

  .pd__qty-input {
    border: none;
    border-left: 1px solid var(--color-border);
    border-right: 1px solid var(--color-border);
    border-radius: 0;
    text-align: center;
    font-size: 14px;
    padding: 0;
    width: 100%;
    background: transparent;
    -moz-appearance: textfield;
  }
  .pd__qty-input::-webkit-inner-spin-button,
  .pd__qty-input::-webkit-outer-spin-button { -webkit-appearance: none; }

  .pd__atc {
    width: 100%;
    padding: 14px 20px;
    font-size: 12px;
  }
  .pd__atc[disabled] { opacity: 0.35; cursor: not-allowed; }

  .pd__dynamic-checkout { margin-top: 10px; }
  .shopify-payment-button__button {
    border-radius: 0 !important;
    font-family: var(--font-body) !important;
    font-size: 12px !important;
    letter-spacing: 0.1em !important;
  }

  /* ── Description / text blocks ── */
  .pd__block-desc,
  .pd__block-text {
    font-size: 14px;
    line-height: 1.8;
    color: var(--color-ink-soft);
    opacity: 0.8;
  }
  .pd__block-desc p + p,
  .pd__block-text p + p { margin-top: 1em; }

  /* ── Inline accordions (inside info panel) ── */
  .pd__accordion--inline { border-top: 1px solid var(--color-border); }
  .pd__accordion--inline + .pd__accordion--inline { border-top: none; }

  .pd__accordion-head--inline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 0;
    cursor: pointer;
    list-style: none;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-ink);
    user-select: none;
    transition: opacity var(--transition-base);
  }
  .pd__accordion-head--inline::-webkit-details-marker { display: none; }
  .pd__accordion-head--inline:hover { opacity: 0.65; }

  .pd__accordion--inline[open] .pd__accordion-icon::before { content: '−'; }

  .pd__accordion-icon {
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    font-weight: 300;
    flex-shrink: 0;
  }
  .pd__accordion-icon::before { content: '+'; }

  .pd__accordion-body--inline {
    padding-bottom: 18px;
    font-size: 14px;
    line-height: 1.8;
    color: var(--color-ink-soft);
    opacity: 0.8;
  }
  .pd__accordion-body--inline p + p { margin-top: 0.85em; }
  .pd__accordion-body--inline ul,
  .pd__accordion-body--inline ol { padding-left: 1.2em; margin-top: 0.5em; }
  .pd__accordion-body--inline li { margin-bottom: 0.4em; }

  /* ── Shipping note ── */
  .pd__shipping-note {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    letter-spacing: 0.04em;
    color: var(--color-ink-soft);
    opacity: 0.5;
  }

  /* ── Inline trust icons ── */
  .pd__trust-icons {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    border-top: 1px solid var(--color-border);
    margin-top: 4px;
  }

  .pd__trust-icon-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 16px 0;
    border-bottom: 1px solid var(--color-border);
  }
  .pd__trust-icon-item:nth-child(odd) { padding-right: 20px; }
  .pd__trust-icon-item:nth-child(even) {
    padding-left: 20px;
    border-left: 1px solid var(--color-border);
  }

  .pd__trust-icon-svg {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--color-ink);
    opacity: 0.6;
    margin-top: 1px;
  }

  .pd__trust-icon-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
  }

  .pd__trust-icon-heading {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-ink);
    line-height: 1.3;
  }

  .pd__trust-icon-sub {
    font-size: 12px;
    color: var(--color-ink-soft);
    opacity: 0.6;
    line-height: 1.4;
  }

  /* ── Trust badges ── */
  .pd__trust {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    padding-top: 24px;
    padding-bottom: 36px;
  }

  .pd__trust-label {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    opacity: 0.45;
    text-align: center;
  }

  .pd__trust-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    justify-content: center;
  }

  .pd__payment-icon {
    height: 28px;
    width: auto;
    display: block;
    flex-shrink: 0;
  }

  /* ── Utilities ── */
  .visually-hidden {
    position: absolute; width: 1px; height: 1px;
    overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap;
  }
  .rte a { text-decoration: underline; }
  .rte strong { font-weight: 500; }

  /* ── Responsive ── */
  @media (max-width: 960px) {
    .pd__layout { grid-template-columns: 1fr; gap: 0; padding: 0; }
    .pd__gallery { position: static; top: auto; }
    .pd__main-wrap { height: 420px; }
    .pd__img-placeholder { height: 420px; }
    .pd__info {
      position: static;
      padding: 40px 32px;
    }
  }

  @media (max-width: 640px) {
    .pd__thumb-more { font-size: 10px; }
    .pd__info { padding: 32px 20px 48px; border-left: none; border-right: none; }
    .pd__buy { grid-template-columns: 108px 1fr; }
  }
/* END_SECTION:product */

/* START_SECTION:rich-text (INDEX:26) */
.richtext {
    padding: var(--section-spacing) var(--page-margin, 48px);
    display: flex;
    flex-direction: column;
    align-items: var(--align, flex-start);
    text-align: var(--align, left);
    gap: 20px;
    border-top: 1px solid var(--color-border);
  }

  .richtext__heading {
    font-size: clamp(1.75rem, 3.5vw, 3rem);
    font-weight: 300;
    max-width: 760px;
    line-height: 1.15;
  }

  .richtext__body {
    font-size: 15px;
    line-height: 1.8;
    color: var(--color-ink-soft);
    opacity: 0.75;
    max-width: 600px;
  }
  .richtext__body p + p { margin-top: 1em; }

  .richtext__cta { margin-top: 8px; }

  @media (max-width: 640px) {
    .richtext { padding-left: 20px; padding-right: 20px; }
  }
/* END_SECTION:rich-text */

/* START_SECTION:search (INDEX:27) */
.search-page {
    padding-bottom: var(--section-spacing);
  }

  .search-page__header {
    padding: 56px 0 48px;
    border-bottom: 1px solid var(--color-border);
    margin-bottom: 56px;
  }

  .search-page__header .eyebrow { margin-bottom: 20px; }

  .search-page__form { width: 100%; }

  .search-page__input-wrap {
    display: flex;
    align-items: center;
    border-bottom: 1px solid var(--color-ink);
    padding-bottom: 4px;
    gap: 12px;
  }

  .search-page__input {
    flex: 1;
    border: none;
    background: transparent;
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 3vw, 2.5rem);
    font-weight: 300;
    color: var(--color-ink);
    padding: 0;
    outline: none;
    width: 100%;
    letter-spacing: -0.01em;
  }
  .search-page__input::placeholder { color: var(--color-border); }
  .search-page__input::-webkit-search-cancel-button { -webkit-appearance: none; }

  .search-page__submit {
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    color: var(--color-ink);
    display: flex;
    flex-shrink: 0;
    transition: opacity var(--transition-base);
  }
  .search-page__submit:hover { opacity: 0.45; }

  .search-page__meta { margin-bottom: 40px; }

  .search-page__empty {
    padding: 80px 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
  .search-page__empty-msg {
    font-family: var(--font-heading);
    font-size: clamp(1.25rem, 2vw, 1.75rem);
    font-weight: 300;
    color: var(--color-ink);
  }
  .search-page__empty-hint {
    font-size: 14px;
    color: var(--color-ink-soft);
    opacity: 0.6;
    margin-bottom: 8px;
  }

  .search-result-item {
    display: block;
    color: inherit;
  }
  .search-result-item__img-wrap {
    aspect-ratio: 4 / 5;
    overflow: hidden;
    background: var(--color-stone);
    margin-bottom: 14px;
  }
  .search-result-item__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: opacity var(--transition-slow);
  }
  .search-result-item:hover .search-result-item__img { opacity: 0.85; }
  .search-result-item__info { padding: 0 2px; }
  .search-result-item__title {
    font-family: var(--font-heading);
    font-size: 1.05rem;
    font-weight: 300;
    color: var(--color-ink);
    margin-top: 6px;
  }
/* END_SECTION:search */

/* START_SECTION:sticky-atc (INDEX:28) */
.sticky-atc {
    position: fixed;
    bottom: 20px;
    left: 24px;
    right: 24px;
    z-index: 190;
    background: var(--color-paper);
    border: 1px solid var(--color-border);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.10), 0 2px 8px rgba(0, 0, 0, 0.06);
    transform: translateY(calc(100% + 28px));
    transition: transform 300ms cubic-bezier(0.4, 0, 0.2, 1);
    pointer-events: none;
  }
  .sticky-atc--visible {
    transform: translateY(0);
    pointer-events: auto;
  }

  .sticky-atc__inner {
    display: flex;
    align-items: center;
    gap: 28px;
    padding: 0 28px;
    height: 64px;
  }

  .sticky-atc__info {
    flex-shrink: 0;
    min-width: 0;
    max-width: 260px;
    overflow: hidden;
  }
  .sticky-atc__vendor {
    font-size: 10px;
    letter-spacing: 0.16em;
    color: var(--color-ink-soft);
    opacity: 0.5;
    margin-bottom: 2px;
  }
  .sticky-atc__title {
    font-size: 13px;
    font-weight: 400;
    color: var(--color-ink);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  @media (min-width: 768px) {
    .sticky-atc__info {
      max-width: none;
    }
    .sticky-atc__title {
      white-space: normal;
      overflow: visible;
      text-overflow: unset;
    }
  }

  .sticky-atc__variants {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 12px;
    overflow: hidden;
    justify-content: center;
  }
  .sticky-atc__option-btns {
    display: flex;
    gap: 6px;
    flex-wrap: nowrap;
  }
  .sticky-atc__opt-btn {
    border: 1px solid var(--color-border);
    background: transparent;
    padding: 7px 16px;
    font-size: 12px;
    font-family: var(--font-body);
    letter-spacing: 0.04em;
    cursor: pointer;
    color: var(--color-ink-soft);
    transition: border-color var(--transition-base), color var(--transition-base);
    white-space: nowrap;
  }
  .sticky-atc__opt-btn:hover { border-color: var(--color-ink-soft); color: var(--color-ink); }
  .sticky-atc__opt-btn--active {
    border-color: var(--color-ink);
    color: var(--color-ink);
    font-weight: 500;
  }

  .sticky-atc__buy {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-shrink: 0;
    margin-left: auto;
  }
  .sticky-atc__price {
    font-size: 15px;
    font-weight: 400;
    color: var(--color-ink);
    letter-spacing: 0.02em;
    white-space: nowrap;
  }
  .sticky-atc__btn {
    padding: 14px 36px;
    font-size: 12px;
    white-space: nowrap;
  }
  .sticky-atc__btn[disabled] { opacity: 0.35; cursor: not-allowed; }

  @media (max-width: 768px) {
    .sticky-atc { left: 12px; right: 12px; bottom: 12px; }
    .sticky-atc__inner { padding: 0 18px; gap: 12px; }
    .sticky-atc__info { display: none; }
  }
  @media (max-width: 480px) {
    .sticky-atc__variants { display: none; }
    .sticky-atc__buy { margin-left: 0; width: 100%; justify-content: space-between; }
  }
/* END_SECTION:sticky-atc */

/* START_SECTION:trust-bar (INDEX:29) */
.trust-bar {
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
  }

  .trust-bar__inner {
    display: grid;
    grid-template-columns: repeat({{ section.blocks.size }}, 1fr);
    max-width: var(--page-width, 1440px);
    margin: 0 auto;
  }

  .trust-bar__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 40px 32px;
    gap: 12px;
    border-right: 1px solid var(--color-border);
  }
  .trust-bar__item:last-child { border-right: none; }

  .trust-bar__icon {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-ink);
    opacity: 0.75;
    margin-bottom: 4px;
  }
  .trust-bar__icon svg { width: 26px; height: 26px; }

  .trust-bar__heading {
    font-family: var(--font-body);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--color-ink);
  }

  .trust-bar__subtext {
    font-size: 13px;
    line-height: 1.6;
    color: var(--color-ink-soft);
    opacity: 0.65;
    max-width: 180px;
  }

  @media (max-width: 768px) {
    .trust-bar__inner { grid-template-columns: repeat(2, 1fr); }
    .trust-bar__item { padding: 32px 20px; }
    .trust-bar__item:nth-child(2) { border-right: none; }
    .trust-bar__item:nth-child(odd):not(:nth-last-child(-n+2)):not(:only-child) {
      border-bottom: 1px solid var(--color-border);
    }
    .trust-bar__item:nth-child(even):not(:last-child) {
      border-bottom: 1px solid var(--color-border);
    }
  }

  @media (max-width: 480px) {
    .trust-bar__inner { grid-template-columns: 1fr; }
    .trust-bar__item { border-right: none; border-bottom: 1px solid var(--color-border); }
    .trust-bar__item:last-child { border-bottom: none; }
  }
/* END_SECTION:trust-bar */

/* START_SECTION:volume-discount (INDEX:30) */
.vd {
    margin: 24px 0;
    border: 1px solid var(--color-border);
    padding: 20px;
    background: var(--color-paper);
  }

  .vd__heading {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    margin-bottom: 14px;
  }

  .vd__tiers {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }

  .vd__tier {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border: 1.5px solid var(--color-border);
    background: transparent;
    cursor: pointer;
    text-align: left;
    transition: border-color 180ms ease, background 180ms ease;
    font-family: var(--font-body);
  }

  .vd__tier:hover { border-color: var(--color-ink-soft); }

  .vd__tier--active {
    border-color: var(--color-ink);
    background: var(--color-paper-warm);
  }

  .vd__tier--best { border-color: var(--color-ink); }

  .vd__badge {
    position: absolute;
    top: -1px;
    right: 12px;
    font-size: 9px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    background: var(--color-ink);
    color: var(--color-paper-warm);
    padding: 3px 8px;
    transform: translateY(-50%);
  }

  .vd__tier-qty {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-ink);
    white-space: nowrap;
    min-width: 60px;
  }

  .vd__tier-pricing {
    display: flex;
    flex-direction: column;
    gap: 2px;
  }

  .vd__tier-per {
    font-size: 13px;
    color: var(--color-ink);
  }

  .vd__tier-save {
    font-size: 11px;
    color: #5a7a4a;
    font-weight: 500;
  }

  .vd__tier-save--none {
    color: var(--color-ink-soft);
    opacity: 0.5;
    font-weight: 400;
  }

  .vd__tier-total {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-ink);
    white-space: nowrap;
    text-align: right;
  }

  .vd__note {
    font-size: 11px;
    color: var(--color-ink-soft);
    opacity: 0.55;
    margin-top: 12px;
    letter-spacing: 0.03em;
  }

  @media (max-width: 480px) {
    .vd { padding: 16px; }
    .vd__tier { padding: 12px 14px; gap: 10px; }
    .vd__tier-qty { min-width: 50px; font-size: 12px; }
    .vd__tier-per { font-size: 12px; }
    .vd__tier-total { font-size: 12px; }
  }
/* END_SECTION:volume-discount */

/* START_SECTION:why-nourgate (INDEX:31) */
.why-ng {
    background: var(--color-ink);
    color: var(--color-paper-warm);
    padding: 80px var(--page-margin, 48px);
  }

  .why-ng__head {
    text-align: center;
    margin-bottom: 64px;
  }

  .why-ng__head .eyebrow {
    color: var(--color-paper-warm);
    opacity: 0.5;
  }

  .why-ng__heading {
    color: var(--color-paper-warm);
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 300;
    margin-top: 12px;
  }

  .why-ng__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: rgba(250, 250, 247, 0.12);
  }

  .why-ng__item {
    background: var(--color-ink);
    padding: 48px 40px;
    display: flex;
    flex-direction: column;
    gap: 18px;
  }

  .why-ng__icon {
    width: 48px;
    height: 48px;
    border: 1px solid rgba(250, 250, 247, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-paper-warm);
    opacity: 0.75;
    flex-shrink: 0;
  }

  .why-ng__item-heading {
    font-family: var(--font-heading);
    font-size: clamp(1.1rem, 1.5vw, 1.4rem);
    font-weight: 300;
    color: var(--color-paper-warm);
    letter-spacing: -0.01em;
    line-height: 1.2;
  }

  .why-ng__item-text {
    font-size: 13px;
    line-height: 1.75;
    color: var(--color-paper-warm);
    opacity: 0.6;
  }

  @media (max-width: 768px) {
    .why-ng__grid { grid-template-columns: 1fr; }
    .why-ng__item { padding: 36px 24px; }
  }

  @media (max-width: 640px) {
    .why-ng { padding: 56px 20px; }
  }
/* END_SECTION:why-nourgate */

/* CSS from block stylesheet tags */
/* START_BLOCK:group (INDEX:32) */
.group {
    display: flex;
    flex-wrap: nowrap;
    overflow: hidden;
    width: 100%;
  }

  .group--horizontal {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    padding: 0 var(--padding);
  }

  .group--vertical {
    flex-direction: column;
    align-items: var(--alignment);
    padding: var(--padding) 0;
  }
/* END_BLOCK:group */

/* START_BLOCK:text (INDEX:33) */
.text {
    text-align: var(--text-align);
  }
  .text--title {
    font-size: 2rem;
    font-weight: 700;
  }
  .text--subtitle {
    font-size: 1.5rem;
  }
/* END_BLOCK:text */

/* CSS from snippet stylesheet tags */
/* START_SNIPPET:image (INDEX:36) */
.image {
    display: block;
    position: relative;
    overflow: hidden;
    width: 100%;
    height: auto;
  }

  .image > img {
    width: 100%;
    height: auto;
  }
/* END_SNIPPET:image */