@import url('reset.css')  layer(reset);
@import url('tokens.css') layer(tokens);

@layer base, layout, components, utilities;

/* ───────── base ───────── */
@layer base {
  body {
    background: var(--color-wine);
    color: var(--color-on-wine);
    font-family: var(--font-body);
    font-size: var(--fs-200);
  }
  h1, h2, h3 {
    font-family: var(--font-heading);
    font-weight: 500;
    line-height: 1.15;
  }
  h1 { font-size: var(--fs-900); }
  h2 { font-size: var(--fs-700); }
  h3 { font-size: var(--fs-300); }
  ::selection { background: var(--color-gold); color: var(--color-wine); }

  @media (prefers-reduced-motion: no-preference) {
    html { scroll-behavior: smooth; }
  }

  /* Anchor targets get pushed down past the fixed header when jumped to. */
  :target, [id] { scroll-margin-top: calc(var(--header-h) + var(--sp-3)); }
}

/* ───────── layout ───────── */
@layer layout {
  .container {
    width: min(100%, var(--container-max));
    margin-inline: auto;
    padding-inline: var(--container-pad);
  }

  .skip-link {
    position: absolute; left: -9999px; top: 0;
    background: var(--color-ink); color: white;
    padding: var(--sp-2) var(--sp-4);
    z-index: 200;
  }
  .skip-link:focus { left: var(--sp-4); top: var(--sp-4); }

  /* Sticky white header — fixed to viewport, hidden during hero, slides in after.
     Visibility is toggled via the `data-state` attribute by main.js. */
  .site-header {
    position: fixed;
    inset: 0 0 auto 0;
    z-index: 100;
    height: var(--header-h);
    background: var(--color-paper);
    color: var(--color-ink);
    border-bottom: 1px solid var(--color-line);
    transform: translateY(-100%);
    transition: transform 350ms var(--ease);
    will-change: transform;
  }
  .site-header[data-state="visible"] { transform: translateY(0); }
  @media (prefers-reduced-motion: reduce) {
    .site-header { transition: none; }
  }

  .site-header__inner {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: var(--sp-4);
    height: 100%;
    padding-inline: var(--container-pad);
  }

  .site-nav { justify-self: start; }
  .site-nav ul {
    display: flex; gap: var(--sp-5);
    font-size: var(--fs-100);
    letter-spacing: 0.08em; text-transform: uppercase;
  }
  .site-nav a {
    display: inline-flex; align-items: center; gap: 4px;
    padding-block: var(--sp-2);
    border-bottom: 1px solid transparent;
    transition: border-color 200ms var(--ease);
  }
  .site-nav a:hover { border-bottom-color: var(--color-gold); }
  .caret { font-size: 0.75em; opacity: 0.7; }

  /* Shop dropdown — opens on hover (desktop) and click/keyboard (touch + a11y). */
  .has-submenu { position: relative; }
  .site-nav__trigger {
    display: inline-flex; align-items: center; gap: 4px;
    padding-block: var(--sp-2);
    font: inherit;
    font-size: var(--fs-100);
    letter-spacing: 0.08em; text-transform: uppercase;
    color: inherit;
    background: transparent;
    border: 0;
    border-bottom: 1px solid transparent;
    cursor: pointer;
    transition: border-color 200ms var(--ease);
  }
  .site-nav__trigger:hover { border-bottom-color: var(--color-gold); }

  .submenu {
    position: absolute;
    top: calc(100% + var(--sp-1));
    left: 0;
    min-width: 12rem;
    display: flex;
    flex-direction: column;
    background: var(--color-paper);
    border: 1px solid var(--color-line);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
    padding: var(--sp-2) 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-4px);
    transition: opacity 200ms var(--ease), transform 200ms var(--ease), visibility 200ms;
    z-index: 110;
  }
  .has-submenu:hover .submenu,
  .has-submenu:focus-within .submenu,
  .submenu[data-open="true"] {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }
  @media (prefers-reduced-motion: reduce) {
    .submenu { transition: none; }
  }
  .submenu a {
    display: block;
    padding: var(--sp-2) var(--sp-4);
    font-size: var(--fs-100);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--color-ink);
    border-bottom: 1px solid transparent;
    transition: color 150ms var(--ease), background-color 150ms var(--ease);
  }
  .submenu a:hover {
    color: var(--color-gold);
    background: color-mix(in oklab, var(--color-gold) 8%, transparent);
  }

  .brand {
    justify-self: center;
    font-family: var(--font-heading);
    font-size: var(--fs-500);
    color: var(--color-gold);
    letter-spacing: 0.01em;
    line-height: 1;
  }

  .site-header__utility {
    justify-self: end;
    display: flex; align-items: center; gap: var(--sp-3);
    font-size: var(--fs-100);
  }
  .utility-currency {
    display: inline-flex; align-items: center; gap: 4px;
    letter-spacing: 0.08em; text-transform: uppercase;
    padding: var(--sp-2);
    color: var(--color-ink);
  }
  .utility-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px;
    color: var(--color-ink);
    transition: color 150ms var(--ease);
  }
  .utility-icon:hover { color: var(--color-gold); }
  .utility-icon svg {
    width: 18px; height: 18px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.5;
    stroke-linejoin: round;
  }

  /* On narrow screens, hide left nav text — would normally collapse to a hamburger.
     TODO: build mobile menu when we move beyond wireframe stage. */
  @media (max-width: 720px) {
    .site-nav { display: none; }
    .site-header__inner { grid-template-columns: 1fr 1fr; }
    .brand { justify-self: start; }
  }
}

/* ───────── components ───────── */
@layer components {
  /* Full-bleed cinema hero — image (and later video) fills the viewport edge-to-edge. */
  .hero {
    background: #000;
    overflow: hidden;
  }
  .hero__media {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 2256 / 1504;
    max-height: 100svh;
    object-fit: cover;
    object-position: center;
  }

  /* Section 2 — promo split: two product photos side-by-side with overlay copy on the left. */
  .promo-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: #000;
    min-height: 60vh;
  }
  .promo-split__column {
    position: relative;
    overflow: hidden;
  }
  .promo-split__column img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .promo-split__overlay {
    position: absolute;
    bottom: clamp(2rem, 5vw, 4rem);
    left: clamp(2rem, 5vw, 4rem);
    color: #fff;
    max-width: 24rem;
    z-index: 2;
  }
  .promo-split__title {
    font-family: var(--font-heading);
    font-size: clamp(2.25rem, 1.5rem + 2.5vw, 3.5rem);
    font-weight: 400;
    line-height: 1.05;
    margin-bottom: var(--sp-1);
  }
  .promo-split__subtitle {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 1.2rem + 1.8vw, 2.75rem);
    font-weight: 400;
    font-style: italic;
    line-height: 1.05;
    color: #fff;
    margin-bottom: var(--sp-6);
  }
  @media (max-width: 720px) {
    .promo-split { grid-template-columns: 1fr; min-height: 0; }
    .promo-split__column img { height: auto; }
    .promo-split__overlay { max-width: 80%; }
  }

  /* Section 3 (and reused for Section 6) — copy block on wine background. */
  .story-block {
    background: var(--color-wine);
    color: var(--color-on-wine);
    padding-block: clamp(3rem, 6vw, 6rem);
    padding-inline: clamp(1.5rem, 5vw, 5rem);
  }
  .story-block__inner {
    max-width: 60rem;
  }
  .story-block__eyebrow {
    font-family: var(--font-heading);
    font-size: clamp(0.95rem, 0.9rem + 0.2vw, 1.125rem);
    color: var(--color-gold);
    margin-bottom: var(--sp-4);
  }
  .story-block .btn--outline-light {
    color: var(--color-gold);
    border-color: var(--color-gold);
  }
  .story-block .btn--outline-light:hover {
    background: var(--color-gold);
    color: var(--color-wine);
  }
  .story-block__body {
    font-family: var(--font-heading);
    font-size: clamp(1.4rem, 1.05rem + 1.4vw, 2.1rem);
    line-height: 1.3;
    font-weight: 400;
    color: var(--color-gold);
    margin-bottom: var(--sp-6);
    max-width: 56rem;
  }

  /* Section 4 — 4-up category grid (Earrings / Rings / Necklaces / Bracelets). */
  .category-grid { background: var(--color-wine); }
  .category-grid__list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
  }
  .category-card { position: relative; overflow: hidden; }
  .category-card a { display: block; position: relative; line-height: 0; }
  .category-card img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 476 / 420;
    object-fit: cover;
    transition: transform 600ms var(--ease);
  }
  .category-card a:hover img { transform: scale(1.04); }
  .category-card__label {
    position: absolute;
    top: var(--sp-5);
    left: var(--sp-5);
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 1.1rem + 1.5vw, 2.5rem);
    font-weight: 400;
    color: #fff;
    line-height: 1;
    z-index: 2;
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
  }
  .category-card__cta {
    position: absolute;
    left: 50%;
    bottom: var(--sp-6);
    transform: translate(-50%, 8px);
    padding: 0.85rem 2rem;
    color: #fff;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.85);
    font-family: var(--font-body);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    white-space: nowrap;
    line-height: 1;
    opacity: 0;
    pointer-events: none;
    transition: opacity 250ms var(--ease), transform 250ms var(--ease), background-color 200ms var(--ease), color 200ms var(--ease);
    z-index: 2;
  }
  .category-card a:hover .category-card__cta,
  .category-card a:focus-visible .category-card__cta {
    opacity: 1;
    transform: translate(-50%, 0);
  }
  .category-card__cta:hover {
    background: rgba(255, 255, 255, 0.95);
    color: var(--color-ink);
  }
  @media (hover: none) {
    .category-card__cta { opacity: 1; transform: translate(-50%, 0); }
  }
  @media (max-width: 960px) {
    .category-grid__list { grid-template-columns: repeat(2, 1fr); }
  }
  @media (max-width: 540px) {
    .category-grid__list { grid-template-columns: 1fr; }
  }

  /* Section 5 — featured product on cream background. */
  .featured-product {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: var(--color-cream);
    color: var(--color-ink);
    min-height: 60vh;
  }
  .featured-product__copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: clamp(2rem, 6vw, 6rem);
    gap: var(--sp-3);
  }
  .featured-product__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 1.2rem + 1.8vw, 2.75rem);
    font-weight: 400;
    line-height: 1.1;
    color: var(--color-gold);
  }
  .featured-product__sub {
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-ink-muted);
    margin-bottom: var(--sp-5);
  }
  .featured-product__image { overflow: hidden; }
  .featured-product__image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  @media (max-width: 720px) {
    .featured-product { grid-template-columns: 1fr; }
    .featured-product__image img { height: auto; }
  }

  /* Outline button — dark border on cream/light background. */
  .btn--outline-dark {
    display: inline-block;
    padding: 0.85rem 2rem;
    color: var(--color-ink);
    background: transparent;
    border: 1px solid var(--color-ink);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    border-radius: 0;
    transition: background-color 200ms var(--ease), color 200ms var(--ease);
  }
  .btn--outline-dark:hover {
    background: var(--color-ink);
    color: var(--color-cream);
  }

  /* Section 7 — Collection highlights carousel. */
  .highlights {
    background: var(--color-wine);
    color: var(--color-on-wine);
    padding-block: clamp(2rem, 4vw, 4rem);
    padding-inline: clamp(1.5rem, 5vw, 5rem);
  }
  .highlights__header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: var(--sp-6);
    gap: var(--sp-4);
  }
  .highlights__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 1.2rem + 1.8vw, 2.75rem);
    font-weight: 400;
    color: var(--color-on-wine);
  }
  .highlights__nav { display: flex; gap: var(--sp-2); }
  .carousel-arrow {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px;
    font-size: 1.25rem; line-height: 1;
    color: var(--color-on-wine);
    background: transparent;
    border: 1px solid var(--color-line-on-wine);
    border-radius: 50%;
    transition: background-color 200ms var(--ease), color 200ms var(--ease), opacity 200ms var(--ease);
  }
  .carousel-arrow:hover { background: var(--color-on-wine); color: var(--color-wine); }
  .carousel-arrow:disabled { opacity: 0.3; cursor: not-allowed; }
  .highlights__track {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: calc((100% - var(--sp-4) * 3) / 4);
    gap: var(--sp-4);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    padding-bottom: var(--sp-4);
    scrollbar-width: none;
  }
  .highlights__track::-webkit-scrollbar { display: none; }
  .product-card { scroll-snap-align: start; }
  .product-card a { display: block; color: inherit; }
  .product-card img {
    display: block;
    width: 100%;
    aspect-ratio: 473 / 440;
    object-fit: cover;
    margin-bottom: var(--sp-3);
    transition: transform 400ms var(--ease);
  }
  .product-card a:hover img { transform: scale(1.03); }
  .product-card__name {
    font-family: var(--font-heading);
    font-size: var(--fs-300);
    font-weight: 400;
    line-height: 1.3;
    margin-bottom: var(--sp-1);
  }
  .product-card__sub {
    font-size: 0.65rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-on-wine-muted);
    margin-bottom: var(--sp-2);
  }
  .product-card__price {
    font-size: var(--fs-200);
    color: var(--color-on-wine);
  }
  .highlights__dots {
    display: flex; justify-content: center; gap: var(--sp-2);
    margin-top: var(--sp-5);
  }
  .highlights__dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: color-mix(in oklab, var(--color-gold) 35%, transparent);
    border: 0;
    cursor: pointer;
    transition: background-color 200ms var(--ease);
    padding: 0;
  }
  .highlights__dot[aria-current="true"] { background: var(--color-gold); }
  @media (max-width: 960px) {
    .highlights__track { grid-auto-columns: calc((100% - var(--sp-4)) / 2); }
  }
  @media (max-width: 540px) {
    .highlights__track { grid-auto-columns: 85%; }
  }

  /* Section 8 — twin promo (New in / Natural Treasures) on wine background. */
  .twin-promo {
    background: var(--color-wine);
    padding-block: var(--sp-5);
  }
  .twin-promo__bullets {
    display: flex; justify-content: center; gap: var(--sp-3);
    margin-bottom: var(--sp-5);
  }
  .twin-promo__bullets span {
    display: block;
    width: 8px; height: 8px;
    background: var(--color-gold);
    transform: rotate(45deg);
  }
  .twin-promo__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
  }
  .twin-promo__cell {
    position: relative;
    display: block;
    overflow: hidden;
  }
  .twin-promo__cell img {
    display: block;
    width: 100%;
    height: auto;
    transition: transform 600ms var(--ease);
  }
  .twin-promo__cell:hover img { transform: scale(1.03); }
  .twin-promo__label {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 1.2rem + 1.8vw, 2.5rem);
    color: #fff;
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
  }
  @media (max-width: 720px) {
    .twin-promo__grid { grid-template-columns: 1fr; }
  }

  /* ───────── Footer ───────── */
  .site-footer {
    background: var(--color-wine);
    color: var(--color-on-wine);
    padding-block: var(--sp-7);
    padding-inline: clamp(1.5rem, 5vw, 5rem);
  }

  /* Brand promises strip */
  .promises__list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--sp-5);
    padding-block: var(--sp-5);
    border-bottom: 1px solid var(--color-line-on-wine);
  }
  .promise {
    display: flex; flex-direction: column; align-items: center; text-align: center;
    gap: var(--sp-2);
  }
  .promise__icon {
    width: 32px; height: 32px;
    fill: none;
    stroke: var(--color-gold);
    stroke-width: 1.2;
    stroke-linecap: round;
    stroke-linejoin: round;
  }
  .promise__title {
    font-family: var(--font-heading);
    font-size: var(--fs-200);
    font-weight: 400;
    color: var(--color-gold);
    margin: 0;
  }
  .promise__link {
    font-size: 0.65rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-gold);
    border-bottom: 1px solid var(--color-gold);
    padding-bottom: 2px;
    margin-top: var(--sp-1);
    transition: opacity 200ms var(--ease);
  }
  .promise__link:hover { opacity: 0.75; }

  /* Email signup */
  .signup {
    padding-block: var(--sp-6);
    border-bottom: 1px solid var(--color-line-on-wine);
  }
  .signup__lead {
    text-align: center;
    font-family: var(--font-heading);
    font-size: clamp(1.125rem, 1rem + 0.5vw, 1.5rem);
    color: var(--color-on-wine);
    margin-bottom: var(--sp-4);
  }
  .signup__form {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    border-bottom: 1px solid var(--color-line-on-wine);
    padding-bottom: var(--sp-2);
    max-width: 50rem;
    margin-inline: auto;
  }
  .signup__form input {
    flex: 1;
    background: transparent;
    border: 0;
    color: var(--color-on-wine);
    padding: var(--sp-2);
    font-size: var(--fs-200);
  }
  .signup__form input::placeholder { color: var(--color-on-wine-muted); }
  .signup__form input:focus { outline: none; }
  .signup__form button {
    background: transparent;
    color: var(--color-on-wine);
    font-size: 0.65rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    padding: var(--sp-2) var(--sp-4);
    cursor: pointer;
    transition: color 200ms var(--ease);
  }
  .signup__form button:hover { color: var(--color-gold); }

  /* Footer links — diamond-drop logo + 3 column nav */
  .footer-links {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: clamp(2rem, 5vw, 5rem);
    padding-block: var(--sp-7);
  }
  .footer-links__mark svg {
    width: 40px; height: 50px;
    color: var(--color-gold);
    fill: none;
    stroke: currentColor;
    stroke-width: 1.2;
  }
  .footer-links__nav {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(1.5rem, 3vw, 3rem);
  }
  .footer-links__nav h4 {
    font-family: var(--font-body);
    font-size: 0.65rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-gold);
    margin-bottom: var(--sp-4);
    font-weight: 500;
  }
  .footer-links__nav ul { display: flex; flex-direction: column; gap: var(--sp-2); }
  .footer-links__nav a {
    font-family: var(--font-heading);
    font-size: var(--fs-200);
    color: var(--color-gold);
    transition: opacity 200ms var(--ease);
  }
  .footer-links__nav a:hover { opacity: 0.75; }

  /* Bottom legal row */
  .footer-legal {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: end;
    gap: var(--sp-5);
    padding-top: var(--sp-5);
    border-top: 1px solid var(--color-line-on-wine);
  }
  .footer-legal__wordmark {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 2vw + 1.5rem, 4rem);
    color: var(--color-gold);
    line-height: 1;
  }
  .footer-legal__copy {
    font-size: 0.65rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-on-wine-muted);
    text-align: center;
  }
  .footer-legal__links { display: flex; gap: var(--sp-4); }
  .footer-legal__links a {
    font-size: 0.65rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-on-wine-muted);
    transition: color 200ms var(--ease);
  }
  .footer-legal__links a:hover { color: var(--color-gold); }

  @media (max-width: 720px) {
    .promises__list { grid-template-columns: repeat(2, 1fr); }
    .footer-links { grid-template-columns: 1fr; gap: var(--sp-5); }
    .footer-links__nav { grid-template-columns: 1fr; gap: var(--sp-5); }
    .footer-legal { grid-template-columns: 1fr; text-align: center; justify-items: center; }
  }

  /* ───────── Our Story page ───────── */
  .os-page { padding-top: var(--header-h); }

  /* Eyebrow / section labels */
  .os-eyebrow {
    font-family: var(--font-heading);
    font-size: clamp(0.95rem, 0.9rem + 0.2vw, 1.125rem);
    color: var(--color-gold);
    text-align: center;
    margin-bottom: var(--sp-5);
  }
  .os-eyebrow--ink { color: var(--color-ink-muted); text-transform: uppercase; font-style: normal; letter-spacing: 0.18em; font-size: 0.7rem; font-family: var(--font-body); }
  .os-section-label {
    font-family: var(--font-heading);
    font-style: italic;
    font-size: 0.9rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-gold);
    text-align: center;
  }
  .os-section-label--ink { color: var(--color-gold); text-transform: none; letter-spacing: 0.02em; font-size: clamp(1.25rem, 1rem + 0.8vw, 1.75rem); }
  .os-section-label__star { display: inline-block; color: var(--color-gold); margin-right: var(--sp-2); transform: translateY(-1px); }

  /* Vertical divider line connecting paragraphs */
  .os-divider {
    width: 1px;
    height: clamp(40px, 6vw, 80px);
    background: color-mix(in oklab, var(--color-gold) 35%, transparent);
    margin: var(--sp-4) auto;
  }

  /* Decorative diamond mark below founders story */
  .os-mark {
    display: block;
    width: 32px; height: 40px;
    margin: var(--sp-7) auto 0;
    color: var(--color-gold);
    fill: none;
    stroke: currentColor;
    stroke-width: 1.2;
  }

  .os-emphasis {
    font-style: italic;
    color: var(--color-gold) !important;
    font-size: clamp(1.1rem, 0.95rem + 0.6vw, 1.4rem);
  }

  /* Intro section — centered serif copy on wine */
  .os-intro {
    background: var(--color-wine);
    color: var(--color-on-wine);
    text-align: center;
    padding: clamp(3rem, 8vw, 7rem) clamp(1.5rem, 5vw, 5rem) var(--sp-6);
  }
  .os-intro__body {
    font-family: var(--font-heading);
    font-size: clamp(1.4rem, 1.05rem + 1.4vw, 2.1rem);
    line-height: 1.35;
    color: var(--color-gold);
    max-width: 56rem;
    margin-inline: auto;
  }

  /* Founders story — multi-paragraph centered with vertical dividers */
  .os-founders-story {
    background: var(--color-wine);
    color: var(--color-on-wine);
    text-align: center;
    padding: var(--sp-5) clamp(1.5rem, 5vw, 5rem) clamp(3rem, 6vw, 6rem);
  }
  .os-founders-story p {
    font-family: var(--font-heading);
    font-size: clamp(1.05rem, 0.95rem + 0.5vw, 1.35rem);
    line-height: 1.5;
    color: var(--color-on-wine);
    max-width: 38rem;
    margin-inline: auto;
  }

  /* Founders quote — silhouette photo (left) + quote on cream (right) */
  .founders-quote {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: var(--color-cream);
  }
  .founders-quote__image { overflow: hidden; background: #000; }
  .founders-quote__image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .founders-quote__copy {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(2rem, 5vw, 5rem);
  }
  .founders-quote blockquote {
    max-width: 30rem;
    font-family: var(--font-heading);
    font-style: italic;
    font-size: clamp(1rem, 0.9rem + 0.5vw, 1.25rem);
    line-height: 1.5;
    color: var(--color-ink);
    text-align: center;
  }
  .founders-quote blockquote p { color: var(--color-ink); margin-bottom: var(--sp-5); }
  .founders-quote blockquote footer {
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-style: normal;
    font-family: var(--font-body);
    color: var(--color-gold);
  }
  .founders-quote cite {
    font-style: normal;
    color: var(--color-gold);
  }
  .founders-quote__role { color: var(--color-ink-muted); margin-top: var(--sp-1); font-size: 0.65rem; }

  @media (max-width: 720px) {
    .founders-quote { grid-template-columns: 1fr; }
    .founders-quote__image img { height: auto; }
  }

  /* Sustainable Luxury intro — light cream, centered */
  .luxury-intro {
    background: var(--color-cream);
    color: var(--color-ink);
    text-align: center;
    padding: clamp(3rem, 6vw, 6rem) clamp(1.5rem, 5vw, 5rem);
  }
  .luxury-intro__body {
    font-family: var(--font-heading);
    font-size: clamp(1.1rem, 0.95rem + 0.6vw, 1.4rem);
    line-height: 1.5;
    color: var(--color-ink);
    max-width: 50rem;
    margin-inline: auto;
  }

  /* Naturally inspired — 2-column on cream */
  .inspired-block {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: var(--color-cream-2);
  }
  .inspired-block__copy {
    display: flex; flex-direction: column; justify-content: center;
    padding: clamp(2rem, 5vw, 5rem);
    color: var(--color-ink);
    text-align: center;
  }
  .inspired-block__copy .os-section-label--ink { margin-bottom: var(--sp-5); }
  .inspired-block__copy p {
    font-family: var(--font-heading);
    font-size: clamp(0.95rem, 0.9rem + 0.3vw, 1.1rem);
    line-height: 1.6;
    color: var(--color-gold);
    max-width: 28rem;
    margin: 0 auto var(--sp-4);
  }
  .inspired-block__dots {
    display: flex; justify-content: center; gap: var(--sp-2);
    margin-top: var(--sp-5);
  }
  .inspired-block__dots li {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: color-mix(in oklab, var(--color-gold) 30%, transparent);
  }
  .inspired-block__dots li.active { background: var(--color-gold); }
  .inspired-block__image { overflow: hidden; background: #000; }
  .inspired-block__image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  @media (max-width: 720px) {
    .inspired-block { grid-template-columns: 1fr; }
    .inspired-block__image img { height: auto; }
  }

  /* Three panels — Sustainability / Craftsmanship / Inspiration */
  .three-panels {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    background: var(--color-wine);
  }
  .panel {
    position: relative;
    display: block;
    overflow: hidden;
    background: #000;
  }
  .panel img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 633 / 370;
    transition: transform 600ms var(--ease);
  }
  .panel:hover img { transform: scale(1.04); }
  .panel__label {
    position: absolute;
    top: var(--sp-5);
    left: var(--sp-5);
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 1.1rem + 1.5vw, 2.5rem);
    font-weight: 400;
    color: #fff;
    line-height: 1;
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
  }
  @media (max-width: 720px) {
    .three-panels { grid-template-columns: 1fr; }
  }

  /* ───────── Inspiration page ───────── */
  .insp-page { padding-top: var(--header-h); }

  .insp-intro {
    background: var(--color-wine);
    color: var(--color-on-wine);
    padding: clamp(2rem, 5vw, 5rem) clamp(1.5rem, 5vw, 5rem) clamp(2rem, 4vw, 4rem);
  }
  .insp-intro__bullets {
    display: flex; justify-content: center; gap: var(--sp-5);
    margin-bottom: var(--sp-5);
  }
  .insp-intro__bullets span {
    display: block;
    width: 6px; height: 6px;
    background: var(--color-gold);
    transform: rotate(45deg);
    opacity: 0.6;
  }
  .insp-intro__title {
    font-family: var(--font-heading);
    font-weight: 400;
    font-size: clamp(2.25rem, 1.5rem + 2.5vw, 3.5rem);
    color: var(--color-gold);
    line-height: 1.1;
    text-align: left;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: clamp(0rem, 2vw, 2rem);
  }
  .insp-intro__title em { font-style: italic; }

  .article-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(1.5rem, 3vw, 3rem);
    background: var(--color-cream);
    padding: clamp(2rem, 4vw, 4rem) clamp(1.5rem, 5vw, 5rem);
  }
  @media (max-width: 960px) {
    .article-grid { grid-template-columns: repeat(2, 1fr); }
  }
  @media (max-width: 540px) {
    .article-grid { grid-template-columns: 1fr; }
  }

  .article-card a {
    display: block;
    color: inherit;
  }
  .article-card img {
    display: block;
    width: 100%;
    aspect-ratio: 633 / 460;
    object-fit: cover;
    margin-bottom: var(--sp-4);
    transition: transform 600ms var(--ease);
  }
  .article-card a:hover img { transform: scale(1.03); }
  .article-card__label {
    font-size: 0.65rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-gold);
    margin-bottom: var(--sp-2);
  }
  .article-card__title {
    font-family: var(--font-heading);
    font-size: clamp(1.1rem, 0.95rem + 0.6vw, 1.4rem);
    font-weight: 400;
    line-height: 1.3;
    color: var(--color-ink);
    transition: color 200ms var(--ease);
  }
  .article-card a:hover .article-card__title { color: var(--color-gold); }

  .view-more {
    background: var(--color-cream);
    text-align: center;
    padding-block: clamp(1.5rem, 3vw, 3rem) clamp(2rem, 5vw, 5rem);
  }

  /* ───────── Craftsmanship page ───────── */
  .cs-page { padding-top: var(--header-h); }

  /* Hero — two photos with title overlaid centered across both columns */
  .cs-hero {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: #000;
  }
  .cs-hero__col { overflow: hidden; }
  .cs-hero__col img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .cs-hero__title {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 1.2rem + 2vw, 3rem);
    font-weight: 400;
    color: #fff;
    text-align: center;
    text-shadow: 0 2px 16px rgba(0, 0, 0, 0.4);
    margin: 0;
    width: max-content;
    max-width: 90%;
    z-index: 2;
  }
  @media (max-width: 720px) {
    .cs-hero { grid-template-columns: 1fr; }
    .cs-hero__col img { height: auto; }
  }

  /* Intro — wine background centered, reuses tokens from .story-block */
  .cs-intro {
    background: var(--color-wine);
    color: var(--color-on-wine);
    text-align: center;
    padding: clamp(3rem, 6vw, 6rem) clamp(1.5rem, 5vw, 5rem);
  }
  .cs-intro__body {
    font-family: var(--font-heading);
    font-size: clamp(1.25rem, 1rem + 1vw, 1.85rem);
    line-height: 1.4;
    color: var(--color-gold);
    max-width: 56rem;
    margin: var(--sp-3) auto 0;
  }

  /* 5-step process — 2-column alternating, cream background */
  .cs-step {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: var(--color-cream);
  }
  .cs-step__copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: clamp(2rem, 5vw, 5rem);
    text-align: center;
    color: var(--color-ink);
  }
  .cs-step__num {
    font-family: var(--font-heading);
    font-style: italic;
    font-size: 0.85rem;
    letter-spacing: 0.18em;
    color: var(--color-gold);
    margin-bottom: var(--sp-3);
  }
  .cs-step__title {
    font-family: var(--font-heading);
    font-size: clamp(1.25rem, 1rem + 0.8vw, 1.75rem);
    font-weight: 400;
    color: var(--color-gold);
    margin-bottom: var(--sp-4);
  }
  .cs-step__copy p:not(.cs-step__num) {
    font-family: var(--font-heading);
    font-size: clamp(0.95rem, 0.9rem + 0.3vw, 1.1rem);
    line-height: 1.6;
    color: var(--color-ink-muted);
    max-width: 28rem;
  }
  .cs-step__image { overflow: hidden; background: #000; }
  .cs-step__image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  /* Reverse modifier flips columns so the image stays on the SAME side as in the design */
  .cs-step--reverse .cs-step__copy { order: 2; }
  .cs-step--reverse .cs-step__image { order: 1; }
  @media (max-width: 720px) {
    .cs-step { grid-template-columns: 1fr; }
    .cs-step__image img { height: auto; }
    /* On mobile, restore natural source order so image always comes first */
    .cs-step--reverse .cs-step__copy { order: 0; }
    .cs-step--reverse .cs-step__image { order: 0; }
  }

  /* ───────── Contact page ───────── */
  .contact-page {
    padding-top: var(--header-h);
    background: var(--color-wine);
    color: var(--color-on-wine);
  }

  .contact-intro {
    text-align: center;
    padding: clamp(3rem, 6vw, 6rem) clamp(1.5rem, 5vw, 5rem) clamp(2rem, 4vw, 4rem);
  }
  .contact-intro__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 1.2rem + 2.2vw, 3.25rem);
    font-weight: 400;
    line-height: 1.25;
    color: var(--color-gold);
    max-width: 56rem;
    margin: var(--sp-3) auto 0;
  }
  .contact-intro__title em { font-style: italic; }
  .contact-intro__sub {
    font-family: var(--font-heading);
    font-size: clamp(1rem, 0.9rem + 0.5vw, 1.25rem);
    color: var(--color-on-wine);
    margin-top: clamp(2rem, 4vw, 4rem);
  }

  /* Form */
  .contact-form-wrap {
    padding: 0 clamp(1.5rem, 5vw, 5rem) clamp(2rem, 4vw, 4rem);
  }
  .contact-form {
    display: flex;
    flex-direction: column;
    gap: var(--sp-4);
    max-width: 56rem;
    margin-inline: auto;
  }
  .contact-field input,
  .contact-field select,
  .contact-field textarea {
    width: 100%;
    background: transparent;
    border: 1px solid var(--color-line-on-wine);
    color: var(--color-gold);
    font-family: inherit;
    font-size: 0.75rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    padding: var(--sp-4) var(--sp-5);
    transition: border-color 200ms var(--ease);
  }
  .contact-field textarea {
    text-transform: none;
    letter-spacing: 0.06em;
    font-size: var(--fs-200);
    min-height: 12rem;
    resize: vertical;
    font-family: var(--font-body);
  }
  .contact-field input::placeholder,
  .contact-field textarea::placeholder {
    color: var(--color-gold);
    opacity: 0.85;
  }
  .contact-field input:focus,
  .contact-field select:focus,
  .contact-field textarea:focus {
    outline: none;
    border-color: var(--color-gold);
  }

  /* Custom select chevron — native arrow hidden, gold caret rendered via background */
  .contact-field--select { position: relative; }
  .contact-field--select select {
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    padding-right: var(--sp-7);
  }
  .contact-field--select::after {
    content: "▾";
    position: absolute;
    right: var(--sp-5);
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-gold);
    pointer-events: none;
  }
  .contact-field select option {
    background: var(--color-wine);
    color: var(--color-on-wine);
  }

  .contact-submit {
    align-self: flex-start;
    background: transparent;
    color: var(--color-gold);
    border: 1px solid var(--color-line-on-wine);
    font-family: inherit;
    font-size: 0.75rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    padding: var(--sp-4) clamp(2rem, 4vw, 4rem);
    cursor: pointer;
    transition: background-color 200ms var(--ease), color 200ms var(--ease);
  }
  .contact-submit:hover {
    background: var(--color-gold);
    color: var(--color-wine);
  }

  /* Alternative contact details */
  .contact-alt {
    text-align: center;
    padding: clamp(3rem, 5vw, 5rem) clamp(1.5rem, 5vw, 5rem) clamp(3rem, 5vw, 5rem);
    border-top: 1px solid var(--color-line-on-wine);
  }
  .contact-alt__lead {
    font-family: var(--font-heading);
    font-size: clamp(1rem, 0.9rem + 0.5vw, 1.25rem);
    color: var(--color-on-wine);
    margin-bottom: clamp(1.5rem, 3vw, 3rem);
  }
  .contact-alt__details {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: clamp(2rem, 5vw, 5rem);
  }
  .contact-alt__label {
    font-size: 0.65rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-on-wine-muted);
    margin-bottom: var(--sp-2);
  }
  .contact-alt__value {
    font-family: var(--font-heading);
    font-size: clamp(1.125rem, 1rem + 0.6vw, 1.5rem);
    color: var(--color-gold);
  }
  .contact-alt__value a {
    color: inherit;
    border-bottom: 1px solid transparent;
    transition: border-color 200ms var(--ease);
  }
  .contact-alt__value a:hover { border-bottom-color: var(--color-gold); }

  /* Outline button — white border on dark image. */
  .btn--outline-light {
    display: inline-block;
    padding: 0.85rem 2rem;
    color: #fff;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.85);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    border-radius: 0;
    transition: background-color 200ms var(--ease), color 200ms var(--ease);
  }
  .btn--outline-light:hover {
    background: #fff;
    color: var(--color-ink);
  }

  /* 404 page — kept minimal */
  .btn {
    display: inline-block;
    padding: var(--sp-3) var(--sp-5);
    font-size: var(--fs-100);
    letter-spacing: 0.08em; text-transform: uppercase;
    border-radius: var(--radius-md);
    transition: transform 150ms var(--ease), border-color 150ms var(--ease), color 150ms var(--ease);
  }
  .btn:hover { transform: translateY(-1px); }
  .btn--ghost {
    background: transparent; color: var(--color-on-wine);
    border: 1px solid var(--color-line-on-wine);
  }
  .btn--ghost:hover { border-color: var(--color-gold); color: var(--color-gold); }

  .error-page main {
    display: grid; place-content: center; min-height: 80vh; text-align: center;
    gap: var(--sp-4);
  }
  .error-page h1 { font-size: var(--fs-900); color: var(--color-gold); }

  /* ───────── Shop All page ───────── */
  .sa-page { padding-top: var(--header-h); }

  .sa-heading {
    background: var(--color-wine);
    padding: clamp(1.5rem, 3vw, 2.5rem) clamp(1.5rem, 5vw, 5rem);
  }
  .sa-heading__title {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 1.4rem + 2vw, 3rem);
    font-weight: 400;
    color: var(--color-on-wine);
    line-height: 1;
    margin: 0;
  }
  .sa-heading__title em { font-style: italic; color: var(--color-gold); }

  .sa-filterbar {
    background: var(--color-paper);
    color: var(--color-ink);
    border-bottom: 1px solid var(--color-line);
  }
  .sa-filterbar__inner {
    display: flex; align-items: center; gap: var(--sp-5);
    padding: var(--sp-4) clamp(1.5rem, 5vw, 5rem);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-ink-muted);
  }
  .sa-filterbar__filters {
    background: transparent; border: 0; padding: 0;
    color: inherit;
    font: inherit; letter-spacing: inherit; text-transform: inherit;
    cursor: pointer;
  }
  .sa-filterbar__filters:hover { color: var(--color-gold); }
  .sa-filterbar__sort { margin-left: auto; }
  .sa-filterbar__sort strong { font-weight: 500; color: var(--color-ink); }
  .sa-filterbar__count { color: var(--color-ink-muted); }
  .sa-filterbar__count strong { font-weight: 500; color: var(--color-ink); }
  @media (max-width: 720px) {
    .sa-filterbar__inner { flex-wrap: wrap; gap: var(--sp-3); }
    .sa-filterbar__sort { margin-left: 0; }
  }

  .sa-products {
    background: var(--color-paper);
    color: var(--color-ink);
    padding: var(--sp-6) clamp(1rem, 3vw, 3rem) var(--sp-8);
  }
  .sa-products__list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: clamp(1rem, 2vw, 2rem) clamp(0.75rem, 1.5vw, 1.5rem);
  }
  .sa-products .product-card a { color: var(--color-ink); }
  .sa-products .product-card__name { color: var(--color-ink); }
  .sa-products .product-card__price { color: var(--color-ink); }
  .sa-products .product-card__sub { color: var(--color-ink-muted); }
  .product-card__media {
    position: relative;
    overflow: hidden;
    margin-bottom: var(--sp-3);
  }
  .product-card__media img { margin-bottom: 0; }
  .product-card__cta {
    position: absolute;
    left: 50%;
    bottom: var(--sp-5);
    transform: translate(-50%, 8px);
    padding: 0.85rem 2rem;
    color: #fff;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.85);
    font-family: var(--font-body);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    white-space: nowrap;
    line-height: 1;
    opacity: 0;
    pointer-events: none;
    transition: opacity 250ms var(--ease), transform 250ms var(--ease), background-color 200ms var(--ease), color 200ms var(--ease);
    z-index: 2;
  }
  .product-card a:hover .product-card__cta,
  .product-card a:focus-visible .product-card__cta {
    opacity: 1;
    transform: translate(-50%, 0);
  }
  .product-card__cta:hover {
    background: rgba(255, 255, 255, 0.95);
    color: var(--color-ink);
  }
  @media (hover: none) {
    .product-card__cta { display: none; }
  }
  @media (max-width: 960px) {
    .sa-products__list { grid-template-columns: repeat(3, 1fr); }
  }
  @media (max-width: 720px) {
    .sa-products__list { grid-template-columns: repeat(2, 1fr); }
  }
  @media (max-width: 420px) {
    .sa-products__list { grid-template-columns: 1fr; }
  }
}

/* ───────── utilities ───────── */
@layer utilities {
  .reveal {
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 600ms var(--ease), transform 600ms var(--ease);
  }
  .reveal[data-revealed="true"] {
    opacity: 1;
    transform: none;
  }
  @media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
  }

  .visually-hidden {
    position: absolute; width: 1px; height: 1px;
    padding: 0; margin: -1px; overflow: hidden;
    clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
  }
}
