/** Shopify CDN: Minification failed

Line 839:2 Unexpected "}"

**/

  /*EDITMODE-BEGIN*/
  /*EDITMODE-END*/
  :root{
    --ivory: #F7F3EC;
    --cream: #EFE7D8;
    --sand: #E4D8C4;
    --espresso: #2A2320;
    --ink: #1A1512;
    --mute: #6E655B;
    --gold: oklch(0.72 0.08 80);
    --gold-deep: oklch(0.58 0.09 72);
    --line: rgba(42,35,32,0.14);
    --shadow-soft: 0 30px 80px -40px rgba(42,35,32,0.35);
    --shadow-card: 0 1px 2px rgba(42,35,32,0.04), 0 20px 50px -30px rgba(42,35,32,0.25);
    --serif: "Italiana", "Cormorant Garamond", serif;
    --serif-body: "Cormorant Garamond", Georgia, serif;
    --sans: "Figtree", ui-sans-serif, system-ui, sans-serif;
    --mono: "JetBrains Mono", ui-monospace, monospace;
  }
  *{ box-sizing: border-box; }
  html,body{ margin:0; padding:0; background: var(--ivory); color: var(--espresso); font-family: var(--sans); -webkit-font-smoothing: antialiased;}
  body{ font-size: 15px; line-height: 1.55; letter-spacing: 0.005em; overflow-x: hidden; }
  a{ color: inherit; text-decoration: none; }
  button{ font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
  img{ display:block; max-width:100%; }
  ::selection{ background: var(--gold); color: var(--ink); }

  /* --- Placeholder imagery --- */
  .ph{
    position: relative; overflow: hidden; background: var(--sand);
    background-image:
      repeating-linear-gradient(135deg,
        rgba(42,35,32,0.05) 0 1px,
        transparent 1px 14px),
      linear-gradient(180deg, var(--sand), var(--cream));
    color: var(--mute);
  }
  .ph--dark{
    background-image:
      repeating-linear-gradient(135deg,
        rgba(247,243,236,0.08) 0 1px,
        transparent 1px 18px),
      linear-gradient(180deg, #2A2320, #14100E);
    color: rgba(247,243,236,0.7);
  }
  .ph__tag{
    position: absolute; left: 14px; bottom: 14px;
    font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em;
    text-transform: uppercase; opacity: 0.85;
    padding: 4px 8px; border: 1px solid currentColor; border-radius: 2px;
  }
  .ph__center{
    position: absolute; inset: 0; display: grid; place-items: center;
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em;
    text-transform: uppercase; opacity: 0.5;
  }

  /* --- Header --- */
  .hdr{
    position: fixed; top: 0; left: 0; right: 0; z-index: 50;
    display: grid; grid-template-columns: 1fr auto 1fr;
    align-items: center; padding: 22px 48px;
    color: #fff; transition: background .4s ease, color .4s ease, padding .3s ease, border-color .3s ease;
    border-bottom: 1px solid transparent;
  }
  .hdr.is-stuck{ background: rgba(247,243,236,0.92); color: var(--espresso); padding: 14px 48px; border-bottom-color: var(--line); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);}
  .hdr__logo{ font-family: var(--serif); font-size: 22px; letter-spacing: 0.22em; text-transform: uppercase; font-weight: 400;}
  .hdr__logo small{ display:block; font-family: var(--mono); font-size: 8px; letter-spacing: 0.4em; opacity: 0.7; margin-top: 2px;}
  .hdr__nav{ display: flex; gap: 36px; justify-content: center; }
  .hdr__nav a{ font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 400; position: relative; padding: 6px 0;}
  .hdr__nav a::after{ content:""; position:absolute; left:50%; bottom:0; width: 0; height: 1px; background: currentColor; transition: all .35s ease;}
  .hdr__nav a:hover::after{ width: 100%; left: 0;}
  .hdr__icons{ display:flex; gap: 20px; justify-content: flex-end; align-items: center;}
  .hdr__icon{ width: 36px; height: 36px; display: grid; place-items: center; border-radius: 999px; transition: background .2s; position: relative;}
  .hdr__icon:hover{ background: rgba(255,255,255,0.1);}
  .hdr.is-stuck .hdr__icon:hover{ background: rgba(42,35,32,0.06);}
  .hdr__cart-count{ position: absolute; top: 2px; right: 2px; background: var(--gold); color: var(--ink); font-size: 9px; font-weight: 600; width: 16px; height: 16px; border-radius: 999px; display: grid; place-items: center; font-family: var(--sans);}

  /* --- Hero --- */
  .hero{ position: relative; height: 100vh; min-height: 720px; overflow: hidden; color: #fff;}
  .hero__video{ position: absolute; inset: 0;}
  .hero__video .ph{ width:100%; height:100%;}
  .hero__scrim{ position:absolute; inset:0; background: linear-gradient(180deg, rgba(20,16,14,0.45) 0%, rgba(20,16,14,0.15) 35%, rgba(20,16,14,0.15) 55%, rgba(20,16,14,0.75) 100%);}
  .hero__grain{ position:absolute; inset:0; opacity:.15; mix-blend-mode: overlay; pointer-events:none;
    background-image: radial-gradient(rgba(255,255,255,0.3) 1px, transparent 1px), radial-gradient(rgba(0,0,0,0.3) 1px, transparent 1px);
    background-size: 3px 3px, 4px 4px; background-position: 0 0, 1px 1px;
  }
  .hero__content{ position: relative; z-index:2; height:100%; display: flex; flex-direction: column; justify-content: flex-end; padding: 0 48px 80px; max-width: 1200px;}
  .hero__eyebrow{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; opacity: 0.85; margin-bottom: 28px; display: flex; align-items: center; gap: 14px;}
  .hero__eyebrow::before{ content:""; width: 40px; height: 1px; background: currentColor;}
  .hero__title{ font-family: var(--serif); font-weight: 400; font-size: clamp(72px, 11vw, 168px); line-height: 0.92; letter-spacing: -0.01em; margin: 0 0 32px; text-wrap: balance;}
  .hero__title em{ font-family: var(--serif-body); font-style: italic; font-weight: 300; }
  .hero__sub{ font-family: var(--serif-body); font-weight: 300; font-size: clamp(20px, 1.8vw, 26px); line-height: 1.4; max-width: 520px; margin: 0 0 48px; opacity: 0.92; text-wrap: pretty;}
  .hero__ctas{ display:flex; gap: 16px; flex-wrap: wrap; align-items: center;}
  .hero__marquee{ position: absolute; bottom: 0; left: 0; right: 0; border-top: 1px solid rgba(255,255,255,0.18); padding: 18px 48px; display: flex; justify-content: space-between; font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; opacity: 0.75; z-index: 2;}
  .hero__scroll{ position: absolute; right: 48px; bottom: 120px; z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 12px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase;}
  .hero__scroll-line{ width: 1px; height: 56px; background: linear-gradient(180deg, rgba(255,255,255,0.8), rgba(255,255,255,0)); animation: scroll-pulse 2.4s ease-in-out infinite;}
  @keyframes scroll-pulse{ 0%,100%{ transform: scaleY(1); opacity: 0.8;} 50%{ transform: scaleY(1.3); opacity: 1;} }

  /* --- Buttons --- */
  .btn{ display: inline-flex; align-items: center; gap: 12px; padding: 16px 32px; font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase; font-weight: 500; border-radius: 2px; transition: all .3s ease; border: 1px solid transparent; cursor: pointer;}
  .btn--gold{ background: var(--gold); color: var(--ink); }
  .btn--gold:hover{ background: var(--gold-deep); color: #fff; transform: translateY(-1px);}
  .btn--outline{ border-color: rgba(255,255,255,0.6); color: #fff;}
  .btn--outline:hover{ border-color: #fff; background: rgba(255,255,255,0.08);}
  .btn--dark{ background: var(--ink); color: var(--ivory);}
  .btn--dark:hover{ background: var(--espresso); transform: translateY(-1px);}
  .btn--ghost{ color: var(--espresso); border-color: var(--line);}
  .btn--ghost:hover{ border-color: var(--espresso);}
  .btn__arrow{ transition: transform .3s ease;}
  .btn:hover .btn__arrow{ transform: translateX(4px);}

  /* --- Section frame --- */
  section{ padding: 120px 48px; position: relative;}
  .sec-head{ display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 64px; gap: 48px; flex-wrap: wrap;}
  .sec-eyebrow{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--mute); margin-bottom: 16px; display: flex; align-items: center; gap: 12px;}
  .sec-eyebrow::before{ content: ""; width: 24px; height: 1px; background: var(--mute);}
  .sec-title{ font-family: var(--serif); font-size: clamp(40px, 5.6vw, 76px); font-weight: 400; line-height: 0.98; letter-spacing: -0.01em; margin: 0; text-wrap: balance; max-width: 16ch;}
  .sec-title em{ font-family: var(--serif-body); font-style: italic; font-weight: 300;}
  .sec-link{ font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; font-weight: 500; display: inline-flex; gap: 10px; align-items: center; padding-bottom: 4px; border-bottom: 1px solid var(--espresso); white-space: nowrap;}
  .sec-link:hover .btn__arrow{ transform: translateX(4px);}

  /* --- Categories --- */
  .cats{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px;}
  .cat{ position: relative; aspect-ratio: 3/4; overflow: hidden; cursor: pointer;}
  .cat .ph{ width:100%; height:100%; transition: transform .9s cubic-bezier(.2,.8,.2,1);}
  .cat:hover .ph{ transform: scale(1.05);}
  .cat__label{ position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end; padding: 24px; color: #fff; background: linear-gradient(180deg, transparent 50%, rgba(20,16,14,0.7) 100%);}
  .cat__num{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; opacity: 0.8;}
  .cat__name{ font-family: var(--serif); font-size: 34px; line-height: 1; margin: 8px 0 16px;}
  .cat__cta{ font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; display: flex; align-items: center; gap: 10px; opacity: 0; transform: translateY(10px); transition: all .5s ease;}
  .cat:hover .cat__cta{ opacity: 1; transform: translateY(0);}

  /* --- Best sellers --- */
  .prods{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px;}
  .prod{ position: relative;}
  .prod__media{ aspect-ratio: 4/5; background: var(--cream); position: relative; overflow: hidden; margin-bottom: 20px;}
  .prod__media .ph{ width:100%; height:100%; transition: transform .8s cubic-bezier(.2,.8,.2,1);}
  .prod:hover .prod__media .ph{ transform: scale(1.04);}
  .prod__badge{ position: absolute; top: 16px; left: 16px; font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase; background: var(--ivory); padding: 6px 10px; border-radius: 2px; color: var(--ink);}
  .prod__wish{ position: absolute; top: 14px; right: 14px; width: 36px; height: 36px; background: rgba(247,243,236,0.9); backdrop-filter: blur(6px); border-radius: 999px; display: grid; place-items: center; opacity: 0; transform: translateY(-6px); transition: all .3s ease;}
  .prod:hover .prod__wish{ opacity: 1; transform: translateY(0);}
  .prod__wish.is-on svg{ fill: var(--gold-deep); stroke: var(--gold-deep);}
  .prod__qv{ position: absolute; left: 16px; right: 16px; bottom: 16px; background: rgba(20,16,14,0.9); color: var(--ivory); padding: 12px; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; text-align: center; opacity: 0; transform: translateY(8px); transition: all .3s ease; backdrop-filter: blur(6px); border-radius: 2px; cursor: pointer;}
  .prod:hover .prod__qv{ opacity: 1; transform: translateY(0);}
  .prod__cat{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute); margin-bottom: 6px;}
  .prod__name{ font-family: var(--serif-body); font-size: 22px; line-height: 1.2; margin: 0 0 8px; font-weight: 400;}
  .prod__row{ display: flex; justify-content: space-between; align-items: center; margin-top: 10px;}
  .prod__price{ font-size: 13px; letter-spacing: 0.08em;}
  .prod__stars{ display: inline-flex; gap: 2px; align-items: center; font-size: 11px; color: var(--mute);}
  .prod__add{ margin-top: 14px; width: 100%; padding: 12px; border: 1px solid var(--line); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; display: flex; align-items: center; justify-content: center; gap: 10px; transition: all .3s ease;}
  .prod__add:hover{ background: var(--ink); color: var(--ivory); border-color: var(--ink);}
  .prod__add.is-added{ background: var(--gold); color: var(--ink); border-color: var(--gold);}

  /* --- Why --- */
  .why{ background: var(--cream); }
  .whys{ display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--line); border: 1px solid var(--line);}
  .why-card{ background: var(--cream); padding: 56px 40px; display: flex; flex-direction: column; gap: 20px;}
  .why-card__num{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.24em; color: var(--mute);}
  .why-card__ico{ width: 56px; height: 56px; border-radius: 999px; border: 1px solid var(--espresso); display: grid; place-items: center; margin-bottom: 8px;}
  .why-card__title{ font-family: var(--serif); font-size: 32px; font-weight: 400; line-height: 1.05; margin: 0;}
  .why-card__body{ font-family: var(--serif-body); font-size: 17px; line-height: 1.5; color: var(--espresso); opacity: 0.85; margin: 0;}
  .why-card__more{ margin-top: auto; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; display: inline-flex; gap: 10px; align-items: center; padding-top: 16px;}

  /* --- Brand story --- */
  .story{ display: grid; grid-template-columns: 1.1fr 1fr; gap: 80px; align-items: center; padding: 140px 48px;}
  .story__media{ aspect-ratio: 4/5; position: relative;}
  .story__media .ph{ width: 100%; height: 100%;}
  .story__media::after{ content:""; position: absolute; top: 24px; left: 24px; right: -24px; bottom: -24px; border: 1px solid var(--gold); z-index: -1;}
  .story__copy h2{ font-family: var(--serif); font-size: clamp(44px, 5.4vw, 84px); font-weight: 400; line-height: 0.98; letter-spacing: -0.01em; margin: 0 0 32px; text-wrap: balance;}
  .story__copy h2 em{ font-family: var(--serif-body); font-style: italic; font-weight: 300;}
  .story__copy p{ font-family: var(--serif-body); font-size: 19px; line-height: 1.55; margin: 0 0 20px; color: var(--espresso); opacity: 0.9;}
  .story__slogan{ font-family: var(--serif); font-size: 28px; font-style: italic; margin: 40px 0 32px; padding: 24px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); letter-spacing: 0.01em;}
  .story__sig{ display: flex; align-items: center; gap: 16px; margin-top: 36px;}
  .story__sig-name{ font-family: var(--serif); font-size: 18px;}
  .story__sig-role{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute);}

  /* --- Reviews --- */
  .reviews{ background: var(--ink); color: var(--ivory); padding-top: 140px; padding-bottom: 140px;}
  .reviews .sec-title{ color: var(--ivory);}
  .reviews .sec-eyebrow{ color: rgba(247,243,236,0.6);}
  .reviews .sec-eyebrow::before{ background: rgba(247,243,236,0.6);}
  .review{ max-width: 840px; margin: 0 auto; text-align: center;}
  .review__stars{ display:flex; gap: 4px; justify-content: center; margin-bottom: 28px; color: var(--gold);}
  .review__quote{ font-family: var(--serif); font-weight: 400; font-size: clamp(28px, 3.2vw, 44px); line-height: 1.25; letter-spacing: -0.005em; margin: 0 0 40px; text-wrap: balance;}
  .review__quote em{ font-family: var(--serif-body); font-style: italic; font-weight: 300;}
  .review__author{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; opacity: 0.85;}
  .review__dots{ display: flex; gap: 10px; justify-content: center; margin-top: 56px;}
  .review__dots button{ width: 28px; height: 1px; background: rgba(247,243,236,0.25); transition: all .3s ease; padding: 0;}
  .review__dots button.is-on{ background: var(--gold); height: 2px;}
  .ig{ display: grid; grid-template-columns: repeat(6, 1fr); gap: 4px; margin-top: 100px;}
  .ig__tile{ aspect-ratio: 1; position: relative; overflow: hidden; cursor: pointer;}
  .ig__tile .ph{ width:100%; height:100%; transition: transform .6s ease;}
  .ig__tile:hover .ph{ transform: scale(1.08);}
  .ig__tile .ph::after{ content:""; position:absolute; inset:0; background: rgba(20,16,14,0); transition: background .3s ease;}
  .ig__tile:hover .ph::after{ background: rgba(20,16,14,0.3);}

  /* --- Email --- */
  .prive{ background: var(--cream); text-align: center; padding: 140px 48px;}
  .prive__eyebrow{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.34em; text-transform: uppercase; color: var(--gold-deep); margin-bottom: 28px;}
  .prive h2{ font-family: var(--serif); font-size: clamp(56px, 8vw, 120px); font-weight: 400; line-height: 0.95; margin: 0 0 24px; letter-spacing: -0.01em;}
  .prive h2 em{ font-family: var(--serif-body); font-style: italic; font-weight: 300;}
  .prive p{ font-family: var(--serif-body); font-size: 20px; line-height: 1.5; max-width: 540px; margin: 0 auto 48px; color: var(--espresso); opacity: 0.9;}
  .prive__form{ max-width: 520px; margin: 0 auto; display: flex; border-bottom: 1px solid var(--espresso); padding-bottom: 8px; transition: border-color .3s;}
  .prive__form:focus-within{ border-color: var(--gold-deep);}
  .prive__form input{ flex: 1; border: none; background: transparent; font-family: var(--sans); font-size: 15px; padding: 14px 4px; outline: none; color: var(--espresso);}
  .prive__form input::placeholder{ color: var(--mute); letter-spacing: 0.02em;}
  .prive__form button{ font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; padding: 0 8px; display: flex; align-items: center; gap: 10px; font-weight: 500;}
  .prive__form.is-sent{ border-color: var(--gold-deep);}
  .prive__sent{ color: var(--gold-deep); font-family: var(--mono); font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase; margin-top: 20px; opacity: 0; transition: opacity .3s ease;}
  .prive__sent.is-on{ opacity: 1;}
  .prive__perks{ display: flex; justify-content: center; gap: 40px; margin-top: 64px; flex-wrap: wrap;}
  .prive__perk{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute); display: flex; align-items: center; gap: 10px;}
  .prive__perk-dot{ width: 4px; height: 4px; border-radius: 999px; background: var(--gold);}

  /* --- Footer --- */
  .ftr{ background: var(--ivory); padding: 100px 48px 40px; border-top: 1px solid var(--line);}
  .ftr__top{ display: grid; grid-template-columns: 1.3fr repeat(4, 1fr); gap: 48px; padding-bottom: 72px; border-bottom: 1px solid var(--line);}
  .ftr__logo{ font-family: var(--serif); font-size: 32px; letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 20px;}
  .ftr__tag{ font-family: var(--serif-body); font-size: 17px; line-height: 1.4; color: var(--mute); max-width: 280px; margin-bottom: 32px;}
  .ftr__socials{ display: flex; gap: 12px;}
  .ftr__social{ width: 38px; height: 38px; border: 1px solid var(--line); border-radius: 999px; display: grid; place-items: center; transition: all .3s;}
  .ftr__social:hover{ background: var(--ink); color: var(--ivory); border-color: var(--ink);}
  .ftr__col h4{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; font-weight: 400; margin: 0 0 20px; color: var(--mute);}
  .ftr__col ul{ list-style: none; padding: 0; margin: 0; display: grid; gap: 12px;}
  .ftr__col a{ font-size: 14px; transition: opacity .2s;}
  .ftr__col a:hover{ opacity: 0.6;}
  .ftr__btm{ display: flex; justify-content: space-between; align-items: center; padding-top: 32px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; color: var(--mute); text-transform: uppercase;}
  .ftr__btm-links{ display: flex; gap: 28px;}

  /* --- Cart drawer --- */
  .drawer-scrim{ position: fixed; inset: 0; background: rgba(20,16,14,0.4); z-index: 90; opacity: 0; pointer-events: none; transition: opacity .3s ease; backdrop-filter: blur(4px);}
  .drawer-scrim.is-on{ opacity: 1; pointer-events: auto;}
  .drawer{ position: fixed; top: 0; right: 0; bottom: 0; width: 440px; max-width: 100vw; background: var(--ivory); z-index: 91; transform: translateX(100%); transition: transform .45s cubic-bezier(.2,.8,.2,1); display: flex; flex-direction: column;}
  .drawer.is-on{ transform: translateX(0);}
  .drawer__head{ display: flex; justify-content: space-between; align-items: center; padding: 24px 28px; border-bottom: 1px solid var(--line);}
  .drawer__title{ font-family: var(--serif); font-size: 26px;}
  .drawer__close{ width: 36px; height: 36px; display: grid; place-items: center; border-radius: 999px;}
  .drawer__close:hover{ background: var(--cream);}
  .drawer__items{ flex: 1; overflow-y: auto; padding: 20px 28px;}
  .drawer__empty{ padding: 80px 0; text-align: center; color: var(--mute); font-family: var(--serif-body); font-size: 18px;}
  .ci{ display: grid; grid-template-columns: 80px 1fr auto; gap: 16px; padding: 20px 0; border-bottom: 1px solid var(--line); align-items: start;}
  .ci__media{ aspect-ratio: 1; overflow: hidden;}
  .ci__name{ font-family: var(--serif-body); font-size: 17px; margin: 0 0 4px;}
  .ci__meta{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--mute); margin-bottom: 10px;}
  .ci__qty{ display: inline-flex; border: 1px solid var(--line); border-radius: 2px; align-items: center;}
  .ci__qty button{ width: 28px; height: 28px; font-size: 14px;}
  .ci__qty span{ min-width: 24px; text-align: center; font-size: 13px;}
  .ci__price{ font-size: 14px; text-align: right;}
  .ci__remove{ font-family: var(--mono); font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--mute); margin-top: 8px; display: block;}
  .ci__remove:hover{ color: var(--espresso);}
  .drawer__foot{ padding: 24px 28px; border-top: 1px solid var(--line); background: var(--cream);}
  .drawer__total{ display: flex; justify-content: space-between; font-family: var(--serif-body); font-size: 18px; margin-bottom: 16px;}
  .drawer__note{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--mute); text-align: center; margin-top: 14px;}

  /* --- Quick view modal --- */
  .qv-scrim{ position: fixed; inset: 0; background: rgba(20,16,14,0.5); z-index: 92; opacity: 0; pointer-events: none; transition: opacity .3s ease; backdrop-filter: blur(6px); display: grid; place-items: center; padding: 32px;}
  .qv-scrim.is-on{ opacity: 1; pointer-events: auto;}
  .qv{ background: var(--ivory); max-width: 1040px; width: 100%; display: grid; grid-template-columns: 1fr 1fr; transform: translateY(20px); transition: transform .4s ease; max-height: 86vh; overflow: hidden;}
  .qv-scrim.is-on .qv{ transform: translateY(0);}
  .qv__media{ aspect-ratio: 1; background: var(--cream); }
  .qv__body{ padding: 48px; overflow-y: auto;}
  .qv__cat{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute); margin-bottom: 12px;}
  .qv__name{ font-family: var(--serif); font-size: 42px; font-weight: 400; line-height: 1; margin: 0 0 16px;}
  .qv__price{ font-size: 16px; margin-bottom: 24px;}
  .qv__desc{ font-family: var(--serif-body); font-size: 17px; line-height: 1.5; margin-bottom: 28px; color: var(--espresso); opacity: 0.9;}
  .qv__sizes{ display: flex; gap: 8px; margin-bottom: 28px;}
  .qv__size{ padding: 10px 16px; border: 1px solid var(--line); font-size: 12px; letter-spacing: 0.12em; transition: all .2s;}
  .qv__size.is-on{ border-color: var(--ink); background: var(--ink); color: var(--ivory);}
  .qv__close{ position: absolute; top: 20px; right: 20px; width: 40px; height: 40px; display: grid; place-items: center; background: var(--ivory); border-radius: 999px; z-index: 2;}

  /* --- Toast --- */
  .toast{ position: fixed; bottom: 32px; left: 50%; transform: translateX(-50%) translateY(20px); background: var(--ink); color: var(--ivory); padding: 14px 24px; border-radius: 2px; z-index: 100; font-family: var(--mono); font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; opacity: 0; pointer-events: none; transition: all .3s ease; display: flex; align-items: center; gap: 12px;}
  .toast.is-on{ opacity: 1; transform: translateX(-50%) translateY(0);}
  .toast__dot{ width: 6px; height: 6px; background: var(--gold); border-radius: 999px;}

  /* --- Tweaks panel --- */
  .tweaks{ position: fixed; bottom: 20px; right: 20px; width: 280px; background: rgba(247,243,236,0.96); backdrop-filter: blur(14px); border: 1px solid var(--line); border-radius: 4px; padding: 20px; z-index: 200; box-shadow: var(--shadow-soft); display: none;}
  .tweaks.is-on{ display: block;}
  .tweaks h4{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; margin: 0 0 16px; color: var(--mute);}
  .tweaks__row{ margin-bottom: 14px;}
  .tweaks__label{ font-size: 12px; margin-bottom: 6px; display: flex; justify-content: space-between;}
  .tweaks__swatches{ display: flex; gap: 6px;}
  .tweaks__swatch{ width: 24px; height: 24px; border-radius: 999px; border: 1px solid var(--line); cursor: pointer; transition: transform .2s;}
  .tweaks__swatch.is-on{ transform: scale(1.15); box-shadow: 0 0 0 2px var(--ivory), 0 0 0 3px var(--espresso);}
  .tweaks__seg{ display: flex; gap: 4px;}
  .tweaks__seg button{ flex: 1; padding: 8px; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; border: 1px solid var(--line); transition: all .2s;}
  .tweaks__seg button.is-on{ background: var(--ink); color: var(--ivory); border-color: var(--ink);}

  /* ====================================================
     COLLECTIONS PAGE
  ==================================================== */
  .col-hero{ position: relative; height: 62vh; min-height: 520px; overflow: hidden; color: #fff; margin-top: 0;}
  .col-hero__bg{ position: absolute; inset: 0;}
  .col-hero__bg .ph{ width:100%; height:100%;}
  .col-hero__scrim{ position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,16,14,0.35) 0%, rgba(20,16,14,0.15) 40%, rgba(20,16,14,0.7) 100%);}
  .col-hero__content{ position: relative; z-index: 2; height: 100%; display: flex; flex-direction: column; justify-content: flex-end; padding: 0 48px 72px; max-width: 1400px;}
  .col-hero__crumbs{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.26em; text-transform: uppercase; opacity: 0.85; margin-bottom: 24px; display: flex; gap: 10px;}
  .col-hero__crumbs a{ opacity: 0.7; }
  .col-hero__crumbs a:hover{ opacity: 1;}
  .col-hero__title{ font-family: var(--serif); font-weight: 400; font-size: clamp(56px, 9vw, 132px); line-height: 0.95; letter-spacing: -0.01em; margin: 0 0 24px;}
  .col-hero__title em{ font-family: var(--serif-body); font-style: italic; font-weight: 300;}
  .col-hero__sub{ font-family: var(--serif-body); font-size: clamp(18px, 1.5vw, 22px); line-height: 1.4; max-width: 560px; margin: 0 0 28px; opacity: 0.92;}

  /* Collections shell */
  .col-shell{ padding: 56px 48px 120px; display: grid; grid-template-columns: 260px 1fr; gap: 56px; align-items: start;}
  .col-sidebar{ position: sticky; top: 100px;}
  .col-sidebar__title{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--mute); padding-bottom: 16px; border-bottom: 1px solid var(--line); margin-bottom: 20px; display: flex; justify-content: space-between; align-items: center;}
  .col-sidebar__clear{ font-size: 10px; letter-spacing: 0.18em; color: var(--gold-deep); cursor: pointer;}
  .col-filter{ border-bottom: 1px solid var(--line); padding: 16px 0;}
  .col-filter__head{ display: flex; justify-content: space-between; align-items: center; width: 100%; padding: 0; font-family: var(--sans); font-size: 13px; font-weight: 500; letter-spacing: 0.04em; cursor: pointer;}
  .col-filter__head svg{ transition: transform .3s ease;}
  .col-filter.is-open .col-filter__head svg{ transform: rotate(180deg);}
  .col-filter__body{ max-height: 0; overflow: hidden; transition: max-height .4s ease;}
  .col-filter.is-open .col-filter__body{ max-height: 480px; padding-top: 14px;}
  .col-opt{ display: flex; align-items: center; gap: 10px; padding: 6px 0; font-size: 13px; cursor: pointer; color: var(--espresso);}
  .col-opt input{ appearance: none; width: 14px; height: 14px; border: 1px solid var(--mute); border-radius: 2px; cursor: pointer; position: relative;}
  .col-opt input:checked{ background: var(--ink); border-color: var(--ink);}
  .col-opt input:checked::after{ content:""; position: absolute; left: 3px; top: 0px; width: 5px; height: 9px; border: solid var(--ivory); border-width: 0 1.5px 1.5px 0; transform: rotate(45deg);}
  .col-opt__count{ margin-left: auto; font-family: var(--mono); font-size: 10px; color: var(--mute);}
  .col-range{ display: flex; justify-content: space-between; font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; color: var(--mute); margin-top: 10px;}
  .col-range input[type="range"]{ width: 100%; accent-color: var(--gold-deep); margin: 14px 0 6px;}

  /* Collections main */
  .col-bar{ display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--line); padding-bottom: 20px; margin-bottom: 32px;}
  .col-bar__count{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em; color: var(--mute); text-transform: uppercase;}
  .col-bar__right{ display: flex; gap: 24px; align-items: center;}
  .col-bar__view{ display: inline-flex; border: 1px solid var(--line); border-radius: 2px;}
  .col-bar__view button{ padding: 8px 10px; display: grid; place-items: center;}
  .col-bar__view button.is-on{ background: var(--ink); color: var(--ivory);}
  .col-sort{ position: relative;}
  .col-sort__trigger{ display: inline-flex; gap: 10px; align-items: center; padding: 10px 14px; border: 1px solid var(--line); font-size: 12px; letter-spacing: 0.1em; cursor: pointer;}
  .col-sort__menu{ position: absolute; top: 100%; right: 0; margin-top: 4px; background: var(--ivory); border: 1px solid var(--line); min-width: 220px; z-index: 10; box-shadow: var(--shadow-soft); display: none;}
  .col-sort.is-open .col-sort__menu{ display: block;}
  .col-sort__menu button{ display: block; width: 100%; text-align: left; padding: 12px 16px; font-size: 12px; letter-spacing: 0.08em;}
  .col-sort__menu button:hover{ background: var(--cream);}
  .col-sort__menu button.is-on{ color: var(--gold-deep); font-weight: 500;}

  .col-chips{ display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 20px;}
  .col-chip{ display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px; background: var(--cream); border-radius: 999px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; cursor: pointer;}
  .col-chip:hover{ background: var(--sand);}

  /* Product cards on collection */
  .prods--3{ grid-template-columns: repeat(3, 1fr);}
  .prod__benefit{ font-family: var(--serif-body); font-size: 15px; color: var(--mute); font-style: italic; margin: 2px 0 4px;}
  .prod__compare{ font-size: 13px; color: var(--mute); text-decoration: line-through; margin-right: 8px;}
  .prod__price--sale{ color: var(--gold-deep);}
  .prod__hover{ position: absolute; inset: 0; opacity: 0; transition: opacity .6s ease;}
  .prod__media:hover .prod__hover{ opacity: 1;}

  /* SEO block */
  .seo{ background: var(--cream); padding: 100px 48px; display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: start;}
  .seo h3{ font-family: var(--serif); font-size: clamp(36px, 4vw, 52px); font-weight: 400; line-height: 1.02; margin: 0; text-wrap: balance;}
  .seo h3 em{ font-family: var(--serif-body); font-style: italic; font-weight: 300;}
  .seo__body p{ font-family: var(--serif-body); font-size: 18px; line-height: 1.6; margin: 0 0 18px; color: var(--espresso); opacity: 0.9;}
  .seo__meta{ display: flex; gap: 32px; margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--line);}
  .seo__meta-item{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute);}
  .seo__meta-val{ display: block; font-family: var(--serif); font-size: 26px; color: var(--espresso); letter-spacing: 0; margin-top: 6px;}

  /* ====================================================
     PRODUCT PAGE
  ==================================================== */
  .pdp-crumbs{ padding: 104px 48px 0; font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute);}
  .pdp-crumbs a{ margin-right: 10px;}
  .pdp-crumbs span{ margin-right: 10px;}
  .pdp-crumbs .is-current{ color: var(--espresso);}

  .pdp{ padding: 40px 48px 80px; display: grid; grid-template-columns: 1fr 1fr; gap: 80px;}
  .pdp__gallery{ position: sticky; top: 100px; align-self: start;}
  .pdp__gallery-main{ aspect-ratio: 4/5; position: relative; overflow: hidden; background: var(--cream); margin-bottom: 12px; cursor: zoom-in;}
  .pdp__gallery-main .ph{ width:100%; height:100%; transition: transform .6s ease;}
  .pdp__gallery-main.is-zoom .ph{ transform: scale(1.6);}
  .pdp__gallery-main .pdp__zoom-badge{ position: absolute; top: 16px; right: 16px; background: rgba(247,243,236,0.9); backdrop-filter: blur(6px); padding: 8px 10px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; border-radius: 2px;}
  .pdp__thumbs{ display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px;}
  .pdp__thumb{ aspect-ratio: 1; overflow: hidden; cursor: pointer; border: 1px solid transparent; transition: border-color .2s;}
  .pdp__thumb.is-on{ border-color: var(--ink);}
  .pdp__thumb .ph{ width:100%; height:100%;}
  .pdp__thumb .pdp__thumb-play{ position:absolute; inset: 0; display:grid; place-items: center; background: rgba(20,16,14,0.4); color: #fff;}

  /* PDP info column */
  .pdp__cat{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--gold-deep); margin-bottom: 14px;}
  .pdp__name{ font-family: var(--serif); font-size: clamp(40px, 4.8vw, 64px); font-weight: 400; line-height: 0.98; letter-spacing: -0.005em; margin: 0 0 12px;}
  .pdp__name em{ font-family: var(--serif-body); font-style: italic; font-weight: 300;}
  .pdp__tagline{ font-family: var(--serif-body); font-size: 22px; line-height: 1.4; color: var(--mute); margin: 0 0 24px; font-style: italic;}
  .pdp__ratings{ display: flex; gap: 16px; align-items: center; padding: 16px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin-bottom: 28px;}
  .pdp__ratings-link{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute); border-bottom: 1px solid var(--mute); padding-bottom: 2px;}
  .pdp__avail{ margin-left: auto; font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold-deep); display: flex; gap: 8px; align-items: center;}
  .pdp__avail-dot{ width: 6px; height: 6px; border-radius: 999px; background: var(--gold-deep); box-shadow: 0 0 0 3px oklch(0.72 0.08 80 / .25);}
  .pdp__price-row{ display: flex; gap: 12px; align-items: baseline; margin-bottom: 28px;}
  .pdp__price{ font-family: var(--serif); font-size: 38px; letter-spacing: 0;}
  .pdp__price-compare{ font-size: 20px; color: var(--mute); text-decoration: line-through;}
  .pdp__price-per{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; color: var(--mute); text-transform: uppercase; margin-left: auto;}

  .pdp__desc{ font-family: var(--serif-body); font-size: 18px; line-height: 1.55; margin: 0 0 28px; color: var(--espresso);}

  /* Sensitivity scale */
  .pdp-sens{ background: var(--cream); padding: 22px 24px; margin-bottom: 32px; border-left: 2px solid var(--gold);}
  .pdp-sens__head{ display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px;}
  .pdp-sens__label{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute);}
  .pdp-sens__val{ font-family: var(--serif); font-size: 20px; font-style: italic;}
  .pdp-sens__scale{ display: flex; gap: 6px; margin-bottom: 10px;}
  .pdp-sens__dot{ flex: 1; height: 6px; background: rgba(42,35,32,0.12); border-radius: 999px; transition: background .3s;}
  .pdp-sens__dot.is-on{ background: var(--gold-deep);}
  .pdp-sens__ticks{ display: flex; justify-content: space-between; font-family: var(--mono); font-size: 9px; letter-spacing: 0.2em; color: var(--mute); text-transform: uppercase;}

  /* Size / variant picker */
  .pdp-variant{ margin-bottom: 24px;}
  .pdp-variant__head{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute); margin-bottom: 12px; display: flex; justify-content: space-between;}
  .pdp-variant__list{ display: flex; gap: 10px; flex-wrap: wrap;}
  .pdp-variant__opt{ padding: 12px 20px; border: 1px solid var(--line); font-size: 12px; letter-spacing: 0.14em; transition: all .2s; background: transparent;}
  .pdp-variant__opt.is-on{ border-color: var(--ink); background: var(--ink); color: var(--ivory);}
  .pdp-variant__opt:hover{ border-color: var(--espresso);}

  /* Qty + CTAs */
  .pdp-cta{ display: grid; grid-template-columns: auto 1fr; gap: 12px; margin-bottom: 14px;}
  .pdp-qty{ display: inline-flex; border: 1px solid var(--line); border-radius: 2px; align-items: center; background: var(--ivory);}
  .pdp-qty button{ width: 44px; height: 52px; font-size: 16px;}
  .pdp-qty span{ min-width: 34px; text-align: center; font-size: 14px;}
  .pdp-cta__add{ background: var(--ink); color: var(--ivory); padding: 16px; font-size: 12px; letter-spacing: 0.24em; text-transform: uppercase; font-weight: 500; display: flex; align-items: center; justify-content: center; gap: 14px; transition: all .3s; border-radius: 2px; cursor: pointer;}
  .pdp-cta__add:hover{ background: var(--espresso); transform: translateY(-1px);}
  .pdp-cta__buy{ width: 100%; background: var(--gold); color: var(--ink); padding: 16px; font-size: 12px; letter-spacing: 0.24em; text-transform: uppercase; font-weight: 600; display: flex; align-items: center; justify-content: center; gap: 12px; margin-bottom: 20px; border-radius: 2px; transition: all .3s; cursor: pointer;}
  .pdp-cta__buy:hover{ background: var(--gold-deep); color: #fff;}

  /* Trust badges */
  .pdp-trust{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; padding: 18px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin-bottom: 28px;}
  .pdp-trust__item{ text-align: center; font-family: var(--mono); font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--mute); line-height: 1.4;}
  .pdp-trust__item svg{ display: block; margin: 0 auto 6px; color: var(--espresso);}

  /* Benefits list */
  .pdp-benefits{ margin-bottom: 32px;}
  .pdp-benefits__title{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute); margin-bottom: 18px;}
  .pdp-benefits__list{ display: grid; grid-template-columns: 1fr 1fr; gap: 14px;}
  .pdp-benefit{ display: flex; gap: 14px; align-items: flex-start; font-family: var(--serif-body); font-size: 16px; line-height: 1.35;}
  .pdp-benefit svg{ color: var(--gold-deep); flex-shrink: 0; margin-top: 2px;}

  /* Accordion */
  .pdp-acc{ border-top: 1px solid var(--line); margin-top: 8px;}
  .pdp-acc__item{ border-bottom: 1px solid var(--line);}
  .pdp-acc__head{ width: 100%; padding: 22px 0; display: flex; justify-content: space-between; align-items: center; font-family: var(--serif); font-size: 20px; cursor: pointer; text-align: left;}
  .pdp-acc__head svg{ transition: transform .3s ease;}
  .pdp-acc.is-open-0 .pdp-acc__item:nth-child(1) .pdp-acc__head svg,
  .pdp-acc__item.is-open .pdp-acc__head svg{ transform: rotate(45deg);}
  .pdp-acc__body{ max-height: 0; overflow: hidden; transition: max-height .5s ease; font-family: var(--serif-body); font-size: 16px; line-height: 1.55;}
  .pdp-acc__item.is-open .pdp-acc__body{ max-height: 800px; padding-bottom: 22px;}
  .pdp-ing{ display: grid; gap: 16px;}
  .pdp-ing__item{ display: grid; grid-template-columns: 56px 1fr; gap: 16px; align-items: start;}
  .pdp-ing__dot{ width: 56px; height: 56px; border-radius: 999px; background: var(--cream); display: grid; place-items: center; font-family: var(--serif); font-size: 18px; font-style: italic; color: var(--gold-deep);}
  .pdp-ing__name{ font-family: var(--serif); font-size: 18px; margin: 0 0 4px;}

  /* How to use */
  .pdp-use{ background: var(--cream); padding: 100px 48px;}
  .pdp-use__grid{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; margin-top: 48px;}
  .pdp-use__step{ display: flex; flex-direction: column; gap: 20px;}
  .pdp-use__media{ aspect-ratio: 4/3; background: var(--sand);}
  .pdp-use__num{ font-family: var(--serif); font-size: 64px; font-style: italic; color: var(--gold-deep); line-height: 0.9;}
  .pdp-use__title{ font-family: var(--serif); font-size: 26px; margin: 0;}
  .pdp-use__body{ font-family: var(--serif-body); font-size: 16px; line-height: 1.5; color: var(--espresso); opacity: 0.9; margin: 0;}

  /* PDP reviews */
  .pdp-rev{ padding: 120px 48px;}
  .pdp-rev__top{ display: grid; grid-template-columns: 1fr 2fr; gap: 64px; padding-bottom: 48px; border-bottom: 1px solid var(--line); margin-bottom: 48px;}
  .pdp-rev__score{ display: flex; flex-direction: column; gap: 10px;}
  .pdp-rev__big{ font-family: var(--serif); font-size: 96px; line-height: 0.9; letter-spacing: -0.02em;}
  .pdp-rev__count{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute);}
  .pdp-rev__bars{ display: grid; gap: 10px; align-content: center;}
  .pdp-rev__bar{ display: grid; grid-template-columns: 30px 1fr 40px; gap: 12px; align-items: center; font-family: var(--mono); font-size: 11px; color: var(--mute);}
  .pdp-rev__bar-track{ height: 3px; background: var(--line); border-radius: 999px; overflow: hidden;}
  .pdp-rev__bar-fill{ height: 100%; background: var(--gold); border-radius: 999px;}
  .pdp-rev__list{ display: grid; gap: 0;}
  .pdp-rev__card{ padding: 28px 0; border-bottom: 1px solid var(--line); display: grid; grid-template-columns: 200px 1fr; gap: 40px;}
  .pdp-rev__who{ }
  .pdp-rev__name{ font-family: var(--serif); font-size: 20px; margin: 0 0 4px;}
  .pdp-rev__meta{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--mute); margin-bottom: 8px;}
  .pdp-rev__verified{ display: inline-flex; gap: 6px; align-items: center; font-family: var(--mono); font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold-deep); margin-top: 8px;}
  .pdp-rev__rating{ display: flex; gap: 3px; color: var(--gold); margin-bottom: 10px;}
  .pdp-rev__title{ font-family: var(--serif); font-size: 22px; margin: 0 0 10px;}
  .pdp-rev__body{ font-family: var(--serif-body); font-size: 17px; line-height: 1.55; margin: 0 0 14px; color: var(--espresso);}
  .pdp-rev__photo{ width: 100px; aspect-ratio: 1; margin-top: 8px;}
  .pdp-rev__helpful{ margin-top: 14px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--mute);}

  /* Complete the ritual */
  .ritual{ padding: 120px 48px; background: var(--ivory);}

  /* Brand strip */
  .strip{ background: var(--ink); color: var(--ivory); padding: 80px 48px; text-align: center;}
  .strip__slogan{ font-family: var(--serif); font-size: clamp(40px, 5vw, 72px); font-style: italic; margin: 0; letter-spacing: 0.005em; text-wrap: balance;}
  .strip__sub{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; opacity: 0.7; margin-top: 20px;}

  /* Sticky mobile add-to-cart */
  .sticky-buy{ position: fixed; bottom: 0; left: 0; right: 0; background: rgba(247,243,236,0.96); backdrop-filter: blur(14px); border-top: 1px solid var(--line); padding: 12px 20px; display: none; z-index: 40; grid-template-columns: auto 1fr; gap: 12px; align-items: center;}
  .sticky-buy__info{ min-width: 0;}
  .sticky-buy__name{ font-family: var(--serif-body); font-size: 15px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin: 0;}
  .sticky-buy__price{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; color: var(--mute);}

  /* ====================================================
     CONTENT PAGES (legal, support, loyalty, blog, etc.)
  ==================================================== */
  .page-hero{ position: relative; padding: 160px 48px 80px; background: var(--cream); border-bottom: 1px solid var(--line);}
  .page-hero--dark{ background: var(--ink); color: var(--ivory); border-bottom: none;}
  .page-hero__inner{ max-width: 1200px; margin: 0 auto;}
  .page-hero__crumbs{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.26em; text-transform: uppercase; opacity: 0.75; margin-bottom: 24px;}
  .page-hero__crumbs a{ opacity: 0.7;}
  .page-hero__crumbs span{ margin: 0 8px;}
  .page-hero__title{ font-family: var(--serif); font-weight: 400; font-size: clamp(56px, 8vw, 120px); line-height: 0.95; letter-spacing: -0.01em; margin: 0 0 24px; text-wrap: balance;}
  .page-hero__title em{ font-family: var(--serif-body); font-style: italic; font-weight: 300;}
  .page-hero__sub{ font-family: var(--serif-body); font-size: clamp(18px, 1.4vw, 22px); line-height: 1.5; max-width: 640px; margin: 0; opacity: 0.92;}
  .page-hero__meta{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute); margin-top: 40px;}

  .page-shell{ padding: 80px 48px 120px; max-width: 1200px; margin: 0 auto;}
  .page-shell--legal{ display: grid; grid-template-columns: 260px 1fr; gap: 80px; align-items: start;}

  .page-toc{ position: sticky; top: 100px;}
  .page-toc__title{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--mute); margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--line);}
  .page-toc ol{ list-style: none; padding: 0; margin: 0; counter-reset: toc; display: grid; gap: 10px;}
  .page-toc li{ counter-increment: toc;}
  .page-toc a{ display: flex; gap: 14px; font-size: 13px; line-height: 1.4; color: var(--mute); padding: 4px 0; transition: color .2s;}
  .page-toc a::before{ content: counter(toc, decimal-leading-zero); font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; color: var(--mute); flex-shrink: 0;}
  .page-toc a:hover, .page-toc a.is-on{ color: var(--espresso);}

  .page-body{ max-width: 760px;}
  .page-body h2{ font-family: var(--serif); font-weight: 400; font-size: clamp(30px, 3vw, 42px); line-height: 1.1; margin: 56px 0 20px; letter-spacing: -0.005em; scroll-margin-top: 100px;}
  .page-body h2:first-child{ margin-top: 0;}
  .page-body h3{ font-family: var(--serif); font-weight: 400; font-size: 22px; line-height: 1.2; margin: 32px 0 12px;}
  .page-body p, .page-body li{ font-family: var(--serif-body); font-size: 18px; line-height: 1.65; color: var(--espresso); margin: 0 0 16px;}
  .page-body ul{ padding-left: 20px; margin: 0 0 20px;}
  .page-body li{ margin-bottom: 8px;}
  .page-body a{ color: var(--gold-deep); border-bottom: 1px solid currentColor;}
  .page-body strong{ font-weight: 500;}
  .page-body .lede{ font-family: var(--serif-body); font-size: 22px; line-height: 1.55; color: var(--espresso); padding: 24px 28px; background: var(--cream); border-left: 2px solid var(--gold); margin: 0 0 40px; font-style: italic;}
  .page-body .callout{ padding: 24px 28px; background: var(--cream); border: 1px solid var(--line); margin: 28px 0; font-family: var(--serif-body); font-size: 17px; line-height: 1.55;}

  /* Contact */
  .contact-grid{ display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: start;}
  .contact-form{ display: grid; gap: 20px;}
  .contact-field{ display: grid; gap: 8px;}
  .contact-field label{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute);}
  .contact-field input, .contact-field textarea, .contact-field select{ border: none; border-bottom: 1px solid var(--line); background: transparent; padding: 12px 0; font-family: var(--sans); font-size: 15px; color: var(--espresso); outline: none; transition: border-color .2s; border-radius: 0;}
  .contact-field textarea{ min-height: 140px; resize: vertical;}
  .contact-field input:focus, .contact-field textarea:focus, .contact-field select:focus{ border-color: var(--espresso);}
  .contact-field--row{ display: grid; grid-template-columns: 1fr 1fr; gap: 24px;}
  .contact-aside{ background: var(--cream); padding: 40px; border: 1px solid var(--line);}
  .contact-aside h3{ font-family: var(--serif); font-size: 28px; margin: 0 0 20px; font-weight: 400;}
  .contact-channel{ display: grid; grid-template-columns: 40px 1fr; gap: 16px; padding: 20px 0; border-top: 1px solid var(--line);}
  .contact-channel:first-of-type{ border-top: none;}
  .contact-channel__ico{ width: 40px; height: 40px; border-radius: 999px; border: 1px solid var(--espresso); display: grid; place-items: center;}
  .contact-channel__label{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute); margin-bottom: 4px;}
  .contact-channel__val{ font-family: var(--serif-body); font-size: 17px;}
  .contact-channel__meta{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; color: var(--mute); margin-top: 4px;}

  /* Support FAQ */
  .support-cats{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 80px;}
  .support-cat{ padding: 32px; border: 1px solid var(--line); cursor: pointer; transition: all .3s;}
  .support-cat:hover, .support-cat.is-on{ background: var(--ink); color: var(--ivory); border-color: var(--ink);}
  .support-cat__num{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; color: var(--mute); margin-bottom: 20px;}
  .support-cat.is-on .support-cat__num{ color: rgba(247,243,236,0.6);}
  .support-cat__title{ font-family: var(--serif); font-size: 22px; line-height: 1.2; margin: 0 0 8px; font-weight: 400;}
  .support-cat__count{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--mute);}
  .support-cat.is-on .support-cat__count{ color: var(--gold);}

  .faq-list{ border-top: 1px solid var(--line);}
  .faq-item{ border-bottom: 1px solid var(--line);}
  .faq-item__head{ width: 100%; padding: 28px 0; display: flex; justify-content: space-between; align-items: center; font-family: var(--serif); font-size: 22px; font-weight: 400; cursor: pointer; text-align: left;}
  .faq-item__body{ max-height: 0; overflow: hidden; transition: max-height .5s ease; font-family: var(--serif-body); font-size: 17px; line-height: 1.6; color: var(--espresso);}
  .faq-item.is-open .faq-item__body{ max-height: 500px; padding-bottom: 28px;}
  .faq-item__head svg{ transition: transform .3s;}
  .faq-item.is-open .faq-item__head svg{ transform: rotate(45deg);}

  /* Blog */
  .blog-feature{ display: grid; grid-template-columns: 1.2fr 1fr; gap: 64px; align-items: center; margin-bottom: 100px; padding-bottom: 100px; border-bottom: 1px solid var(--line);}
  .blog-feature__media{ aspect-ratio: 5/4;}
  .blog-feature__media .ph{ width: 100%; height: 100%;}
  .blog-feature__meta{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute); margin-bottom: 20px;}
  .blog-feature__title{ font-family: var(--serif); font-size: clamp(40px, 4.6vw, 64px); font-weight: 400; line-height: 1.02; letter-spacing: -0.01em; margin: 0 0 20px; text-wrap: balance;}
  .blog-feature__title em{ font-family: var(--serif-body); font-style: italic; font-weight: 300;}
  .blog-feature__excerpt{ font-family: var(--serif-body); font-size: 19px; line-height: 1.55; margin: 0 0 28px; color: var(--espresso); opacity: 0.9;}

  .blog-filters{ display: flex; gap: 24px; padding-bottom: 24px; border-bottom: 1px solid var(--line); margin-bottom: 40px; flex-wrap: wrap;}
  .blog-filter{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute); padding-bottom: 4px; border-bottom: 1px solid transparent;}
  .blog-filter.is-on{ color: var(--espresso); border-color: var(--espresso);}

  .blog-grid{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px;}
  .blog-card{ cursor: pointer;}
  .blog-card__media{ aspect-ratio: 4/3; margin-bottom: 20px; overflow: hidden;}
  .blog-card__media .ph{ width: 100%; height: 100%; transition: transform .6s ease;}
  .blog-card:hover .blog-card__media .ph{ transform: scale(1.04);}
  .blog-card__meta{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute); margin-bottom: 10px;}
  .blog-card__title{ font-family: var(--serif); font-size: 26px; font-weight: 400; line-height: 1.15; margin: 0 0 10px; text-wrap: balance;}
  .blog-card__excerpt{ font-family: var(--serif-body); font-size: 16px; line-height: 1.5; color: var(--mute); margin: 0;}

  /* Shipping & Returns */
  .ship-grid{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); margin-bottom: 80px;}
  .ship-card{ background: var(--ivory); padding: 48px 36px;}
  .ship-card__label{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute); margin-bottom: 16px;}
  .ship-card__big{ font-family: var(--serif); font-size: 44px; line-height: 1; margin: 0 0 16px;}
  .ship-card__body{ font-family: var(--serif-body); font-size: 16px; line-height: 1.5; color: var(--espresso); opacity: 0.85; margin: 0;}

  .ship-table{ border-top: 1px solid var(--line); margin-bottom: 48px;}
  .ship-row{ display: grid; grid-template-columns: 220px 1fr 120px 100px; gap: 24px; padding: 22px 0; border-bottom: 1px solid var(--line); align-items: center; font-family: var(--serif-body); font-size: 16px;}
  .ship-row--head{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute);}

  /* Loyalty */
  .loyalty-hero{ background: var(--ink); color: var(--ivory);}
  .loyalty-hero .page-hero__crumbs a, .loyalty-hero .page-hero__meta{ color: rgba(247,243,236,0.7);}

  .tier-grid{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 100px;}
  .tier{ background: var(--cream); padding: 48px 40px; position: relative; border: 1px solid var(--line);}
  .tier--gold{ background: var(--ink); color: var(--ivory); border-color: var(--ink);}
  .tier__ribbon{ position: absolute; top: 20px; right: 20px; font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase; background: var(--gold); color: var(--ink); padding: 5px 10px; border-radius: 2px;}
  .tier__label{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--mute); margin-bottom: 16px;}
  .tier--gold .tier__label{ color: var(--gold);}
  .tier__name{ font-family: var(--serif); font-size: 48px; font-weight: 400; line-height: 1; margin: 0 0 8px; letter-spacing: -0.005em;}
  .tier__name em{ font-family: var(--serif-body); font-style: italic; font-weight: 300;}
  .tier__req{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; color: var(--mute); text-transform: uppercase; margin-bottom: 32px; padding-bottom: 24px; border-bottom: 1px solid var(--line);}
  .tier--gold .tier__req{ color: rgba(247,243,236,0.6); border-color: rgba(247,243,236,0.15);}
  .tier__perks{ list-style: none; padding: 0; margin: 0; display: grid; gap: 12px;}
  .tier__perks li{ font-family: var(--serif-body); font-size: 17px; line-height: 1.4; padding-left: 24px; position: relative;}
  .tier__perks li::before{ content: "◦"; position: absolute; left: 0; color: var(--gold-deep); font-weight: 600;}
  .tier--gold .tier__perks li::before{ color: var(--gold);}

  .earn-grid{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 80px;}
  .earn-card{ padding: 32px 28px; border: 1px solid var(--line);}
  .earn-card__points{ font-family: var(--serif); font-size: 52px; line-height: 1; color: var(--gold-deep); margin-bottom: 12px;}
  .earn-card__points em{ font-family: var(--serif-body); font-style: italic; font-weight: 300;}
  .earn-card__label{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute); margin-bottom: 10px;}
  .earn-card__body{ font-family: var(--serif-body); font-size: 15px; line-height: 1.45; color: var(--espresso); opacity: 0.85; margin: 0;}

  /* ====================================================
     SHARED PAGE SHELL (About, Journal, FAQ, Contact, etc.)
  ==================================================== */
  .page-hero{ padding: 160px 48px 80px; background: var(--cream); border-bottom: 1px solid var(--line);}
  .page-hero--dark{ background: var(--ink); color: var(--ivory); border-bottom-color: transparent;}
  .page-hero__inner{ max-width: 1200px; margin: 0 auto;}
  .page-hero__crumbs{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--mute); margin-bottom: 28px; display: flex; gap: 10px;}
  .page-hero--dark .page-hero__crumbs{ color: rgba(247,243,236,0.7);}
  .page-hero__title{ font-family: var(--serif); font-weight: 400; font-size: clamp(56px, 8vw, 124px); line-height: 0.95; margin: 0 0 24px; letter-spacing: -0.01em;}
  .page-hero__title em{ font-family: var(--serif-body); font-style: italic; font-weight: 300;}
  .page-hero__sub{ font-family: var(--serif-body); font-size: clamp(20px, 1.8vw, 26px); line-height: 1.4; max-width: 720px; margin: 0 0 28px; opacity: 0.9;}
  .page-hero__meta{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute); display: flex; gap: 28px; flex-wrap: wrap; padding-top: 24px; border-top: 1px solid var(--line);}
  .page-hero--dark .page-hero__meta{ color: rgba(247,243,236,0.7); border-top-color: rgba(247,243,236,0.2);}

  .page-body{ padding: 100px 48px; max-width: 1200px; margin: 0 auto;}
  .page-body--wide{ max-width: 1400px;}
  .page-body--toc{ display: grid; grid-template-columns: 220px 1fr; gap: 80px; align-items: start;}
  .page-toc{ position: sticky; top: 100px; font-family: var(--sans);}
  .page-toc__title{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--mute); margin-bottom: 18px;}
  .page-toc ol{ list-style: none; padding: 0; margin: 0; display: grid; gap: 14px;}
  .page-toc a{ font-size: 13px; color: var(--mute); padding-left: 14px; border-left: 1px solid var(--line); display: block; padding: 4px 0 4px 14px; transition: all .2s;}
  .page-toc a.is-on, .page-toc a:hover{ color: var(--espresso); border-left-color: var(--gold-deep);}

  .prose h2{ font-family: var(--serif); font-size: clamp(36px, 4.5vw, 60px); font-weight: 400; line-height: 1; margin: 64px 0 24px; letter-spacing: -0.01em; scroll-margin-top: 100px;}
  .prose h2 em{ font-family: var(--serif-body); font-style: italic; font-weight: 300;}
  .prose h3{ font-family: var(--serif); font-size: 28px; font-weight: 400; margin: 36px 0 14px;}
  .prose p{ font-family: var(--serif-body); font-size: 19px; line-height: 1.6; margin: 0 0 18px; color: var(--espresso);}
  .prose p.lead{ font-size: 24px; color: var(--espresso); opacity: 0.9;}
  .prose blockquote{ font-family: var(--serif); font-size: 34px; font-style: italic; line-height: 1.3; margin: 48px 0; padding: 0 0 0 32px; border-left: 2px solid var(--gold); color: var(--espresso);}
  .prose ul{ font-family: var(--serif-body); font-size: 18px; line-height: 1.6; padding-left: 0; list-style: none;}
  .prose ul li{ padding: 10px 0 10px 28px; border-bottom: 1px solid var(--line); position: relative;}
  .prose ul li::before{ content: "◦"; position: absolute; left: 0; color: var(--gold-deep); font-size: 20px;}
  .prose figure{ margin: 48px 0;}
  .prose figure .ph{ aspect-ratio: 16/9;}
  .prose figcaption{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute); margin-top: 14px; text-align: center;}

  /* Stats bar */
  .stats{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); margin: 64px 0;}
  .stat{ background: var(--ivory); padding: 40px 28px;}
  .stat__num{ font-family: var(--serif); font-size: 64px; font-style: italic; line-height: 0.9; color: var(--gold-deep); margin-bottom: 12px;}
  .stat__label{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute); line-height: 1.5;}

  /* Timeline */
  .timeline{ margin: 48px 0; position: relative;}
  .timeline::before{ content:""; position: absolute; left: 120px; top: 0; bottom: 0; width: 1px; background: var(--line);}
  .timeline__item{ display: grid; grid-template-columns: 120px 1fr; gap: 40px; padding: 32px 0; position: relative;}
  .timeline__year{ font-family: var(--serif); font-size: 32px; font-style: italic; color: var(--gold-deep);}
  .timeline__item::before{ content:""; position: absolute; left: 116px; top: 44px; width: 9px; height: 9px; border-radius: 999px; background: var(--gold); border: 2px solid var(--ivory);}
  .timeline__title{ font-family: var(--serif); font-size: 28px; margin: 0 0 10px; font-weight: 400;}
  .timeline__body{ font-family: var(--serif-body); font-size: 17px; line-height: 1.55; color: var(--espresso); margin: 0;}

  /* Team grid */
  .team{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; margin: 48px 0;}
  .team__card .ph{ aspect-ratio: 3/4; margin-bottom: 16px;}
  .team__name{ font-family: var(--serif); font-size: 22px; margin: 0 0 4px;}
  .team__role{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute);}
  .team__bio{ font-family: var(--serif-body); font-size: 15px; line-height: 1.5; color: var(--mute); margin: 8px 0 0;}

  /* FAQ */
  .faq-list{ max-width: 860px; margin: 0 auto;}
  .faq-item{ border-bottom: 1px solid var(--line);}
  .faq-item__head{ width: 100%; padding: 28px 0; display: flex; justify-content: space-between; align-items: center; text-align: left; font-family: var(--serif); font-size: 24px; cursor: pointer; gap: 32px; font-weight: 400;}
  .faq-item__head svg{ transition: transform .3s ease; flex-shrink: 0;}
  .faq-item.is-open .faq-item__head svg{ transform: rotate(45deg);}
  .faq-item__body{ max-height: 0; overflow: hidden; transition: max-height .5s ease; font-family: var(--serif-body); font-size: 18px; line-height: 1.6; color: var(--espresso); opacity: 0.9;}
  .faq-item.is-open .faq-item__body{ max-height: 500px; padding-bottom: 28px;}
  .faq-cats{ display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; margin-bottom: 48px;}
  .faq-cat{ padding: 10px 20px; border: 1px solid var(--line); font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; border-radius: 999px; transition: all .2s;}
  .faq-cat.is-on{ background: var(--ink); color: var(--ivory); border-color: var(--ink);}

  /* Journal grid */
  .jnl{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px 32px; margin: 48px 0;}
  .jnl__item .ph{ aspect-ratio: 4/3; margin-bottom: 20px; transition: transform .6s ease;}
  .jnl__item:hover .ph{ transform: scale(1.02);}
  .jnl__cat{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold-deep); margin-bottom: 10px;}
  .jnl__title{ font-family: var(--serif); font-size: 28px; line-height: 1.1; margin: 0 0 10px; font-weight: 400;}
  .jnl__meta{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--mute);}
  .jnl__excerpt{ font-family: var(--serif-body); font-size: 17px; line-height: 1.5; color: var(--espresso); opacity: 0.85; margin: 10px 0;}
  .jnl-feat{ display: grid; grid-template-columns: 1.3fr 1fr; gap: 48px; margin-bottom: 64px; padding-bottom: 64px; border-bottom: 1px solid var(--line); align-items: center;}
  .jnl-feat .ph{ aspect-ratio: 4/3;}
  .jnl-feat__title{ font-family: var(--serif); font-size: clamp(40px, 5vw, 64px); font-weight: 400; line-height: 1; margin: 16px 0;}

  /* Article body */
  .article{ max-width: 760px; margin: 0 auto; padding: 0 48px;}
  .article__hero{ aspect-ratio: 16/10; margin-bottom: 40px;}
  .article p:first-of-type::first-letter{ font-family: var(--serif); font-size: 72px; float: left; line-height: 0.9; padding: 6px 14px 0 0; color: var(--gold-deep);}

  /* Contact form */
  .contact{ display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start;}
  .contact__form{ display: grid; gap: 20px;}
  .contact__field{ display: grid; gap: 6px;}
  .contact__field label{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute);}
  .contact__field input, .contact__field textarea, .contact__field select{ font-family: var(--sans); font-size: 15px; padding: 14px 0; border: none; border-bottom: 1px solid var(--line); background: transparent; outline: none; color: var(--espresso); transition: border-color .2s;}
  .contact__field input:focus, .contact__field textarea:focus, .contact__field select:focus{ border-bottom-color: var(--gold-deep);}
  .contact__field textarea{ min-height: 120px; resize: vertical;}
  .contact__field-row{ display: grid; grid-template-columns: 1fr 1fr; gap: 20px;}
  .contact__chips{ display: flex; gap: 8px; flex-wrap: wrap;}
  .contact__chip{ padding: 10px 16px; border: 1px solid var(--line); font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; border-radius: 999px; cursor: pointer;}
  .contact__chip.is-on{ background: var(--ink); color: var(--ivory); border-color: var(--ink);}
  .contact__info-card{ padding: 32px; background: var(--cream); margin-bottom: 16px;}
  .contact__info-head{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute); margin-bottom: 14px;}
  .contact__info-val{ font-family: var(--serif); font-size: 24px; margin: 0 0 6px;}
  .contact__info-sub{ font-family: var(--serif-body); font-size: 16px; color: var(--mute); margin: 0;}

  /* Auth forms */
  .auth{ max-width: 440px; margin: 0 auto; padding: 100px 20px;}
  .auth__tabs{ display: flex; gap: 32px; border-bottom: 1px solid var(--line); margin-bottom: 40px;}
  .auth__tab{ padding: 16px 0; font-family: var(--mono); font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute); border-bottom: 2px solid transparent; margin-bottom: -1px; cursor: pointer;}
  .auth__tab.is-on{ color: var(--espresso); border-bottom-color: var(--espresso);}
  .auth__title{ font-family: var(--serif); font-size: 48px; margin: 0 0 12px; font-weight: 400; line-height: 1;}
  .auth__sub{ font-family: var(--serif-body); font-size: 18px; color: var(--mute); margin: 0 0 32px;}
  .auth__divider{ display: flex; align-items: center; gap: 14px; margin: 24px 0; font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute);}
  .auth__divider::before, .auth__divider::after{ content:""; flex: 1; height: 1px; background: var(--line);}
  .auth__social{ display: grid; gap: 10px;}
  .auth__social button{ padding: 14px; border: 1px solid var(--line); font-family: var(--sans); font-size: 14px; display: flex; align-items: center; justify-content: center; gap: 12px; transition: all .2s;}
  .auth__social button:hover{ background: var(--cream);}

  /* Cart page */
  .cart-page{ display: grid; grid-template-columns: 1.6fr 1fr; gap: 64px; align-items: start;}
  .cart-page__items{ border-top: 1px solid var(--line);}
  .cart-row{ display: grid; grid-template-columns: 140px 1fr auto; gap: 28px; padding: 28px 0; border-bottom: 1px solid var(--line);}
  .cart-row__media{ aspect-ratio: 1;}
  .cart-row__name{ font-family: var(--serif); font-size: 26px; font-weight: 400; margin: 0 0 6px;}
  .cart-row__meta{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--mute); margin-bottom: 14px;}
  .cart-row__price{ font-family: var(--serif); font-size: 22px;}
  .cart-summary{ position: sticky; top: 120px; background: var(--cream); padding: 32px;}
  .cart-summary h3{ font-family: var(--serif); font-size: 28px; margin: 0 0 20px; font-weight: 400;}
  .cart-summary__row{ display: flex; justify-content: space-between; padding: 12px 0; font-family: var(--serif-body); font-size: 16px; border-bottom: 1px solid var(--line);}
  .cart-summary__row:last-of-type{ border: none; padding-top: 20px; font-size: 22px;}
  .cart-summary__promo{ display: flex; gap: 8px; margin: 20px 0;}
  .cart-summary__promo input{ flex: 1; padding: 12px; border: 1px solid var(--line); font-family: var(--sans); font-size: 13px; background: var(--ivory);}

  /* Checkout */
  .checkout{ display: grid; grid-template-columns: 1.4fr 1fr; gap: 0; min-height: 100vh;}
  .checkout__main{ padding: 60px 48px;}
  .checkout__side{ background: var(--cream); padding: 60px 48px;}
  .checkout__steps{ display: flex; gap: 32px; margin-bottom: 48px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute);}
  .checkout__step.is-on{ color: var(--espresso);}
  .checkout__step::before{ content: attr(data-n); display: inline-block; width: 20px; height: 20px; border-radius: 999px; border: 1px solid currentColor; text-align: center; line-height: 18px; margin-right: 8px; font-size: 9px;}

  /* Sustainability */
  .pillars{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); margin: 48px 0;}
  .pillar{ background: var(--ivory); padding: 48px 36px;}
  .pillar__num{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.24em; color: var(--mute); margin-bottom: 16px;}
  .pillar__title{ font-family: var(--serif); font-size: 32px; font-weight: 400; line-height: 1.05; margin: 0 0 14px;}
  .pillar__body{ font-family: var(--serif-body); font-size: 17px; line-height: 1.5; color: var(--espresso); opacity: 0.85; margin: 0 0 20px;}
  .pillar__stat{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold-deep); padding-top: 16px; border-top: 1px solid var(--line);}

  /* Quiz / Skin Consult */
  .quiz{ max-width: 720px; margin: 0 auto; padding: 100px 48px;}
  .quiz__progress{ display: flex; gap: 6px; margin-bottom: 48px;}
  .quiz__progress span{ flex: 1; height: 2px; background: var(--line); border-radius: 999px;}
  .quiz__progress span.is-on{ background: var(--gold-deep);}
  .quiz__q{ font-family: var(--serif); font-size: clamp(36px, 4vw, 56px); font-weight: 400; line-height: 1.05; margin: 0 0 16px;}
  .quiz__sub{ font-family: var(--serif-body); font-size: 18px; color: var(--mute); margin: 0 0 48px;}
  .quiz__opts{ display: grid; gap: 12px;}
  .quiz__opt{ padding: 24px 28px; border: 1px solid var(--line); text-align: left; cursor: pointer; transition: all .2s; display: grid; grid-template-columns: auto 1fr auto; gap: 20px; align-items: center;}
  .quiz__opt:hover{ border-color: var(--espresso);}
  .quiz__opt.is-on{ border-color: var(--ink); background: var(--cream);}
  .quiz__opt-letter{ width: 36px; height: 36px; border: 1px solid var(--line); border-radius: 999px; display: grid; place-items: center; font-family: var(--mono); font-size: 12px;}
  .quiz__opt.is-on .quiz__opt-letter{ background: var(--ink); color: var(--ivory); border-color: var(--ink);}
  .quiz__opt-label{ font-family: var(--serif); font-size: 22px;}
  .quiz__opt-desc{ font-family: var(--serif-body); font-size: 14px; color: var(--mute); display: block; margin-top: 4px;}

  /* Gift cards */
  .gift-grid{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin: 48px 0;}
  .gift-card{ aspect-ratio: 5/3; border: 1px solid var(--line); padding: 24px; cursor: pointer; display: flex; flex-direction: column; justify-content: space-between; transition: all .3s; position: relative; overflow: hidden;}
  .gift-card.is-on{ border-color: var(--ink); box-shadow: var(--shadow-card);}
  .gift-card__amt{ font-family: var(--serif); font-size: 56px; font-style: italic; color: var(--gold-deep);}
  .gift-card__lbl{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase;}

  /* Stockists */
  .stockist{ display: grid; grid-template-columns: 1fr auto auto; gap: 40px; padding: 24px 0; border-bottom: 1px solid var(--line); align-items: center;}
  .stockist__name{ font-family: var(--serif); font-size: 22px; margin: 0;}
  .stockist__addr{ font-family: var(--serif-body); font-size: 15px; color: var(--mute); margin: 4px 0 0;}

  @media (max-width: 960px){
    .page-hero{ padding: 120px 20px 60px;}
    .page-body{ padding: 60px 20px;}
    .page-body--toc{ grid-template-columns: 1fr; gap: 32px;}
    .page-toc{ position: static;}
    .stats{ grid-template-columns: repeat(2, 1fr);}
    .team{ grid-template-columns: repeat(2, 1fr);}
    .jnl{ grid-template-columns: 1fr;}
    .jnl-feat{ grid-template-columns: 1fr;}
    .contact{ grid-template-columns: 1fr; gap: 48px;}
    .cart-page{ grid-template-columns: 1fr; gap: 32px;}
    .checkout{ grid-template-columns: 1fr;}
    .checkout__main, .checkout__side{ padding: 40px 20px;}
    .pillars{ grid-template-columns: 1fr;}
    .gift-grid{ grid-template-columns: 1fr 1fr;}
    .timeline::before{ left: 8px;}
    .timeline__item{ grid-template-columns: 1fr; gap: 8px; padding-left: 32px;}
    .timeline__item::before{ left: 4px; top: 16px;}
  }

    .page-shell--legal{ grid-template-columns: 1fr; gap: 40px;}
    .page-toc{ position: static;}
    .contact-grid{ grid-template-columns: 1fr; gap: 48px;}
    .blog-grid{ grid-template-columns: repeat(2, 1fr);}
    .blog-feature{ grid-template-columns: 1fr; gap: 32px;}
    .support-cats{ grid-template-columns: repeat(2, 1fr);}
    .ship-grid{ grid-template-columns: 1fr;}
    .ship-row{ grid-template-columns: 1fr 1fr; gap: 12px;}
    .tier-grid{ grid-template-columns: 1fr;}
    .earn-grid{ grid-template-columns: repeat(2, 1fr);}
  }
  @media (max-width: 640px){
    .page-hero{ padding: 120px 20px 60px;}
    .page-shell{ padding: 56px 20px 80px;}
    .blog-grid{ grid-template-columns: 1fr;}
  }

  @media (max-width: 960px){
    .col-shell{ grid-template-columns: 1fr; padding: 32px 20px 80px;}
    .col-sidebar{ position: static;}
    .col-hero__content{ padding: 0 20px 48px;}
    .pdp-crumbs{ padding: 104px 20px 0;}
    .pdp{ grid-template-columns: 1fr; padding: 24px 20px 120px; gap: 32px;}
    .pdp__gallery{ position: static;}
    .pdp-use{ padding: 80px 20px;}
    .pdp-use__grid{ grid-template-columns: 1fr;}
    .pdp-rev{ padding: 80px 20px;}
    .pdp-rev__top{ grid-template-columns: 1fr; gap: 32px;}
    .pdp-rev__card{ grid-template-columns: 1fr; gap: 12px;}
    .seo{ grid-template-columns: 1fr; padding: 80px 20px;}
    .strip{ padding: 60px 20px;}
    .sticky-buy{ display: grid;}
  }
  @media (max-width: 960px){
  /* inherit original mobile rules */
    .hdr{ padding: 16px 20px; grid-template-columns: 1fr auto;}
    .hdr__nav{ display: none;}
    section{ padding: 80px 20px;}
    .hero__content{ padding: 0 20px 80px;}
    .hero__marquee, .hero__scroll{ display: none;}
    .cats{ grid-template-columns: repeat(2, 1fr);}
    .prods{ grid-template-columns: repeat(2, 1fr);}
    .whys{ grid-template-columns: 1fr;}
    .story{ grid-template-columns: 1fr; gap: 48px; padding: 80px 20px;}
    .ig{ grid-template-columns: repeat(3,1fr);}
    .ftr__top{ grid-template-columns: 1fr 1fr;}
    .qv{ grid-template-columns: 1fr; max-height: 92vh; overflow-y: auto;}
    .drawer{ width: 100%;}
  }


  /* ═══════════════════════════════════════════════════════════
     CLIENT ACCOUNT DASHBOARD
  ═══════════════════════════════════════════════════════════ */
  .client{ background: var(--ivory); min-height: 100vh;}
  .client__mode-bar{
    max-width: 1440px; margin: 0 auto; padding: 32px 48px;
    display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 24px;
    border-bottom: 1px solid var(--line);
  }
  .client__mode-switch{ display: inline-flex; background: var(--cream); padding: 4px; border-radius: 999px;}
  .client__mode-switch button{
    padding: 12px 24px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
    text-transform: uppercase; color: var(--mute); border-radius: 999px; transition: all .2s;
  }
  .client__mode-switch button.is-on{ background: var(--ink); color: var(--ivory); box-shadow: 0 2px 12px rgba(0,0,0,0.12);}

  .client__grid{
    max-width: 1440px; margin: 0 auto; padding: 48px 48px 120px;
    display: grid; grid-template-columns: 300px 1fr; gap: 64px; align-items: flex-start;
  }
  .client__side{ position: sticky; top: 120px; background: #fff; padding: 32px 28px; box-shadow: var(--shadow-card);}
  .client__avatar{ display: flex; gap: 16px; align-items: center; padding-bottom: 24px; border-bottom: 1px solid var(--line); margin-bottom: 24px;}
  .client__avatar-circle{
    width: 56px; height: 56px; border-radius: 999px;
    background: linear-gradient(135deg, var(--gold), var(--gold-deep));
    color: var(--ivory); display: grid; place-items: center;
    font-family: var(--serif); font-size: 26px; font-style: italic;
    flex-shrink: 0; box-shadow: 0 4px 16px rgba(184,134,74,0.3);
  }
  .client__greet{ font-family: var(--serif); font-size: 22px; font-weight: 400;}
  .client__greet em{ font-family: var(--serif-body); font-style: italic; color: var(--gold-deep);}

  .client__nav{ display: flex; flex-direction: column; gap: 2px;}
  .client__nav button{
    display: flex; justify-content: space-between; align-items: center;
    padding: 14px 14px; width: 100%; text-align: left;
    font-family: var(--serif-body); font-size: 16px; color: var(--espresso);
    transition: all .2s; border: 1px solid transparent;
  }
  .client__nav button svg{ opacity: 0; transform: translateX(-4px); transition: all .2s;}
  .client__nav button:hover{ background: var(--ivory);}
  .client__nav button.is-on{ background: var(--ink); color: var(--ivory); }
  .client__nav button.is-on svg{ opacity: 1; transform: translateX(0); color: var(--gold);}
  .client__side-foot{ margin-top: 32px;}

  .client__main{ min-width: 0;}
  .client__hello h1{ font-family: var(--serif); font-size: 64px; font-weight: 400; line-height: 1; margin: 0 0 24px;}
  .client__hello h1 em{ font-family: var(--serif-body); font-style: italic; color: var(--gold-deep);}
  .client__lead{ font-family: var(--serif-body); font-size: 22px; line-height: 1.5; color: var(--espresso); opacity: 0.85; max-width: 720px; margin: 0 0 48px;}
  .client__lead strong{ font-weight: 500; color: var(--ink);}

  .client__stats{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin: 0 0 72px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);}
  .client__stats .stat{ padding: 32px 24px; border-right: 1px solid var(--line);}
  .client__stats .stat:last-child{ border-right: 0;}
  .client__stats .stat__num{ font-family: var(--serif); font-size: 44px; font-weight: 400; color: var(--ink); line-height: 1; margin-bottom: 10px;}
  .client__stats .stat__label{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute); line-height: 1.5;}

  .client__h3{ font-family: var(--serif); font-size: 28px; font-weight: 400; margin: 56px 0 24px; padding-top: 32px; border-top: 1px solid var(--line);}
  .client__h3:first-child{ border-top: 0; padding-top: 0; margin-top: 0;}

  .client__profile{
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px;
    background: #fff; padding: 40px; box-shadow: var(--shadow-card);
  }

  /* Order / invoice table */
  .client__table{ background: #fff; box-shadow: var(--shadow-card); margin: 16px 0 40px;}
  .client__tr{
    display: grid; grid-template-columns: 140px 120px 1fr 2fr 110px 80px;
    gap: 20px; align-items: center; padding: 18px 24px; border-bottom: 1px solid var(--line);
  }
  .client__tr:last-child{ border-bottom: 0;}
  .client__tr--head{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute); background: var(--ivory);}
  .client__table--wide .client__tr{ grid-template-columns: 140px 120px 140px 2fr 120px 80px;}
  .client__pill{
    display: inline-block; padding: 4px 12px; border-radius: 999px;
    font-family: var(--mono); font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase;
    border: 1px solid currentColor;
  }
  .client__pill--ok{ color: #4A7C5A; background: rgba(74,124,90,0.08);}
  .client__pill--info{ color: var(--gold-deep); background: rgba(184,134,74,0.1);}
  .client__pill--warn{ color: #B25540; background: rgba(178,85,64,0.08);}

  /* Subs / refills */
  .client__subs{ display: flex; flex-direction: column; gap: 16px;}
  .client__sub-row{
    display: grid; grid-template-columns: 100px 1fr auto; gap: 24px; align-items: center;
    background: #fff; padding: 20px; box-shadow: var(--shadow-card);
  }
  .client__sub-media{ aspect-ratio: 1; position: relative;}
  .client__sub-actions{ display: flex; gap: 8px;}

  /* Addresses */
  .client__addrs{ display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px;}
  .client__addr{ background: #fff; padding: 28px; box-shadow: var(--shadow-card); min-height: 200px;}
  .client__addr--add{
    border: 1px dashed var(--line); background: transparent; box-shadow: none;
    display: flex; align-items: center; justify-content: center; gap: 12px;
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute);
    cursor: pointer; transition: all .2s;
  }
  .client__addr--add:hover{ border-color: var(--ink); color: var(--ink);}

  /* Privé bar */
  .client__prive-bar{ height: 6px; background: var(--cream); border-radius: 999px; overflow: hidden; margin-top: 24px;}
  .client__prive-fill{ height: 100%; background: linear-gradient(90deg, var(--gold), var(--gold-deep));}
  .client__rewards{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 20px;}
  .client__reward{ background: #fff; padding: 24px; box-shadow: var(--shadow-card);}

  /* Wholesale catalogue */
  .client__cat-table{ background: #fff; box-shadow: var(--shadow-card); margin: 16px 0 32px;}
  .client__cat-head, .client__cat-row{
    display: grid; grid-template-columns: 140px 2fr 100px 110px 70px 110px 80px;
    gap: 20px; align-items: center; padding: 16px 24px; border-bottom: 1px solid var(--line);
  }
  .client__cat-head{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mute); background: var(--ivory);}
  .client__cat-row:last-child{ border-bottom: 0;}
  .client__cat-row:hover{ background: var(--ivory);}

  /* Rep card */
  .client__rep{ background: #fff; padding: 32px; display: grid; grid-template-columns: 120px 1fr; gap: 32px; align-items: flex-start; box-shadow: var(--shadow-card); margin: 16px 0;}
  .client__rep-avatar{ aspect-ratio: 1; position: relative; border-radius: 999px; overflow: hidden;}
  .client__rep-avatar .ph{ border-radius: 999px;}

  /* Team grid in wholesale */
  .client__team{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-bottom: 16px;}
  .client__team-card{ background: #fff; padding: 24px; box-shadow: var(--shadow-card); text-align: left;}
  .client__team-avatar{ aspect-ratio: 1; position: relative; border-radius: 999px; overflow: hidden;}
  .client__team-avatar .ph{ border-radius: 999px;}
  .client__team-card--add{
    border: 1px dashed var(--line); background: transparent; box-shadow: none;
    display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px;
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute);
    cursor: pointer; transition: all .2s; text-align: center;
  }
  .client__team-card--add:hover{ border-color: var(--ink); color: var(--ink);}

  /* Settings */
  .client__sett{ display: flex; flex-direction: column; gap: 1px; background: var(--line); box-shadow: var(--shadow-card);}
  .client__sett-row{ background: #fff; padding: 24px 28px; display: flex; justify-content: space-between; align-items: center; gap: 24px;}

  @media (max-width: 1100px){
    .client__grid{ grid-template-columns: 1fr; padding: 32px 24px 80px;}
    .client__side{ position: static;}
    .client__stats{ grid-template-columns: repeat(2,1fr);}
    .client__stats .stat:nth-child(2){ border-right: 0;}
    .client__profile{ grid-template-columns: 1fr;}
    .client__tr, .client__table--wide .client__tr{ grid-template-columns: 1fr 1fr; gap: 8px;}
    .client__cat-head{ display: none;}
    .client__cat-row{ grid-template-columns: 1fr 1fr; gap: 8px;}
    .client__addrs, .client__rewards, .client__team{ grid-template-columns: 1fr;}
    .client__rep{ grid-template-columns: 1fr;}
    .client__sub-row{ grid-template-columns: 1fr; gap: 12px;}
    .client__sub-actions{ justify-content: flex-start;}
    .client__hello h1{ font-size: 44px;}
  }


  /* ═══════════════════════════════════════════════════════════
     FLOUREA HOMME — dark editorial
  ═══════════════════════════════════════════════════════════ */
  body.homme-body{ background: #0E0B09; color: #E8E1D2;}
  body.homme-body .hdr{ color: #E8E1D2; border-bottom-color: rgba(232,225,210,0.1);}
  body.homme-body .hdr.is-stuck{ background: rgba(14,11,9,0.9); color: #E8E1D2; border-bottom-color: rgba(232,225,210,0.1);}
  body.homme-body .hdr__nav a::after{ background: #E8E1D2;}

  .homme{ background: #0E0B09; color: #E8E1D2;}
  .homme .ftr{ background: #060404; border-top-color: rgba(232,225,210,0.08);}

  /* Hero */
  .homme-hero{ position: relative; min-height: 100vh; padding: 140px 48px 96px; display: flex; align-items: flex-end; overflow: hidden;}
  .homme-hero__bg{ position: absolute; inset: 0; }
  .homme-hero__scrim{ position: absolute; inset: 0; background: linear-gradient(180deg, rgba(14,11,9,0.6) 0%, rgba(14,11,9,0.35) 40%, rgba(14,11,9,0.92) 100%);}
  .homme-hero__grid{ position: relative; max-width: 1440px; margin: 0 auto; width: 100%; display: grid; grid-template-columns: 1.1fr 1fr; grid-template-rows: auto auto auto auto; gap: 8px 64px; align-items: end;}
  .homme-hero__crumbs{ grid-column: 1/2; font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: rgba(232,225,210,0.65); display: flex; align-items: center; gap: 12px;}
  .homme-hero__crumbs a{ color: inherit;}
  .homme-hero__crumbs span:first-of-type{ opacity: 0.4;}
  .homme-hero__meta{ grid-column: 2/3; font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: rgba(232,225,210,0.65); display: flex; align-items: center; gap: 16px; justify-self: end;}
  .homme-hero__meta .dot{ width: 4px; height: 4px; border-radius: 999px; background: currentColor;}
  .homme-hero__title{ grid-column: 1/2; grid-row: 2/4; font-family: var(--serif); font-size: clamp(68px, 9vw, 148px); line-height: 0.92; font-weight: 300; letter-spacing: -0.02em; margin: 24px 0 0; color: #F5EFE2;}
  .homme-hero__title em{ font-family: var(--serif-body); font-style: italic; font-weight: 300; color: var(--gold);}
  .homme-hero__sub{ grid-column: 2/3; grid-row: 2/3; font-family: var(--serif-body); font-size: 20px; line-height: 1.6; color: rgba(232,225,210,0.85); max-width: 460px; justify-self: end; margin: 0;}
  .homme-hero__cta{ grid-column: 2/3; grid-row: 3/4; display: flex; gap: 12px; justify-self: end; margin-top: 24px;}
  .homme-hero__sig{ grid-column: 1/3; grid-row: 4/5; display: flex; gap: 20px; align-items: center; margin-top: 80px; padding-top: 32px; border-top: 1px solid rgba(232,225,210,0.15); max-width: 420px;}
  .homme-hero__sig-num{ font-family: var(--serif); font-size: 48px; line-height: 1; color: var(--gold);}
  .homme-hero__sig-txt{ display: flex; flex-direction: column; gap: 4px;}
  .homme-hero__sig-txt strong{ font-family: var(--serif-body); font-size: 15px; font-weight: 500; color: #F5EFE2;}
  .homme-hero__sig-txt span{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(232,225,210,0.55);}

  /* Buttons in dark mode */
  body.homme-body .btn--gold{ background: var(--gold); color: #0E0B09; border-color: var(--gold);}
  body.homme-body .btn--gold:hover{ background: var(--gold-deep); border-color: var(--gold-deep);}
  body.homme-body .btn--ghost{ background: transparent; color: #F5EFE2; border: 1px solid rgba(232,225,210,0.4);}
  body.homme-body .btn--ghost:hover{ border-color: #F5EFE2; background: rgba(232,225,210,0.05);}

  /* Pillars */
  .homme-pillars{ padding: 96px 48px; border-top: 1px solid rgba(232,225,210,0.1); border-bottom: 1px solid rgba(232,225,210,0.1);}
  .homme-pillars__inner{ max-width: 1440px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;}
  .homme-pillar{ padding: 0 32px; border-right: 1px solid rgba(232,225,210,0.1);}
  .homme-pillar:last-child{ border-right: 0;}
  .homme-pillar:first-child{ padding-left: 0;}
  .homme-pillar__n{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.28em; color: var(--gold); margin-bottom: 32px;}
  .homme-pillar__k{ font-family: var(--serif); font-size: 32px; font-weight: 300; color: #F5EFE2; line-height: 1.1; margin-bottom: 20px; letter-spacing: -0.01em;}
  .homme-pillar__v{ font-family: var(--serif-body); font-size: 15px; line-height: 1.65; color: rgba(232,225,210,0.75);}

  /* Ritual */
  .homme-ritual{ padding: 120px 48px 96px; max-width: 1600px; margin: 0 auto;}
  .homme-ritual__head{ max-width: 720px; margin-bottom: 64px;}
  .homme-ritual__label, .homme-line__label{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold); margin-bottom: 24px;}
  .homme-ritual h2, .homme-line h2, .homme-sets h2, .homme-journal h2, .homme-frag h2, .homme-list h2{ font-family: var(--serif); font-size: clamp(44px, 5vw, 72px); line-height: 1; font-weight: 300; color: #F5EFE2; margin: 0 0 24px; letter-spacing: -0.015em;}
  .homme-ritual h2 em, .homme-line h2 em, .homme-sets h2 em, .homme-journal h2 em, .homme-frag h2 em, .homme-list h2 em{ font-family: var(--serif-body); font-style: italic; color: var(--gold);}
  .homme-ritual__head p{ font-family: var(--serif-body); font-size: 18px; line-height: 1.6; color: rgba(232,225,210,0.75); max-width: 560px;}
  .homme-ritual__grid{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px 32px;}

  .homme-step{ }
  .homme-step__media{ position: relative; aspect-ratio: 4/5; margin-bottom: 20px; overflow: hidden;}
  .homme-step__time{ position: absolute; top: 20px; left: 20px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.24em; color: #F5EFE2; background: rgba(14,11,9,0.7); padding: 6px 10px; backdrop-filter: blur(8px);}
  .homme-step__n{ position: absolute; bottom: 20px; right: 20px; font-family: var(--serif); font-size: 64px; line-height: 1; color: #F5EFE2; text-shadow: 0 2px 20px rgba(0,0,0,0.4);}
  .homme-step__body h4{ font-family: var(--serif); font-size: 26px; font-weight: 300; color: #F5EFE2; margin: 0 0 8px; letter-spacing: -0.01em;}
  .homme-step__body p{ font-family: var(--serif-body); font-size: 15px; line-height: 1.6; color: rgba(232,225,210,0.7); margin: 0;}

  /* Lineup */
  .homme-line{ padding: 96px 48px; max-width: 1600px; margin: 0 auto; border-top: 1px solid rgba(232,225,210,0.1);}
  .homme-line__head{ display: grid; grid-template-columns: 1fr auto; align-items: end; gap: 32px; margin-bottom: 64px;}
  .homme-line__right{ padding-bottom: 12px;}
  body.homme-body .link-arrow{ color: #F5EFE2; display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;}
  body.homme-body .link-arrow:hover{ color: var(--gold);}
  .homme-line__grid{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px 32px;}

  .homme-card{ cursor: pointer; transition: all .3s;}
  .homme-card:hover{ transform: translateY(-6px);}
  .homme-card__media{ position: relative; aspect-ratio: 3/4; margin-bottom: 20px; background: #1A1512; overflow: hidden;}
  .homme-card__n{ position: absolute; top: 20px; left: 20px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; color: rgba(245,239,226,0.7);}
  .homme-card__cat{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold); margin-bottom: 10px;}
  .homme-card h3{ font-family: var(--serif); font-size: 26px; font-weight: 300; color: #F5EFE2; margin: 0 0 10px; letter-spacing: -0.005em;}
  .homme-card p{ font-family: var(--serif-body); font-size: 14px; line-height: 1.5; color: rgba(232,225,210,0.65); margin: 0 0 20px;}
  .homme-card__foot{ display: flex; justify-content: space-between; align-items: center; padding-top: 16px; border-top: 1px solid rgba(232,225,210,0.12);}
  .homme-card__price{ font-family: var(--serif); font-size: 22px; color: #F5EFE2;}
  .homme-card__add{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold); display: inline-flex; align-items: center; gap: 6px; padding: 8px 0; transition: all .2s;}
  .homme-card__add:hover{ color: #F5EFE2;}

  /* Fragrance hero */
  .homme-frag{ display: grid; grid-template-columns: 1fr 1fr; gap: 0; border-top: 1px solid rgba(232,225,210,0.1); border-bottom: 1px solid rgba(232,225,210,0.1);}
  .homme-frag__media{ position: relative; min-height: 800px;}
  .homme-frag__body{ padding: 120px 80px; display: flex; flex-direction: column; justify-content: center; background: #060404;}
  .homme-frag__label{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold); margin-bottom: 24px;}
  .homme-frag__notes{ display: flex; flex-direction: column; gap: 18px; padding: 32px 0; border-top: 1px solid rgba(232,225,210,0.12); border-bottom: 1px solid rgba(232,225,210,0.12); margin: 40px 0;}
  .homme-frag__notes > div{ display: grid; grid-template-columns: 70px 1fr; gap: 20px; align-items: baseline;}
  .homme-frag__notes span{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold);}
  .homme-frag__notes strong{ font-family: var(--serif-body); font-size: 16px; font-weight: 400; color: #F5EFE2;}
  .homme-frag__quote{ font-family: var(--serif-body); font-size: 17px; font-style: italic; line-height: 1.7; color: rgba(232,225,210,0.85); max-width: 520px;}
  .homme-frag__quote em{ font-style: normal; color: var(--gold); font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;}

  /* Review */
  .homme-review{ padding: 120px 48px; background: #0A0806;}
  .homme-review__inner{ max-width: 980px; margin: 0 auto; text-align: center;}
  .homme-review__mark{ font-family: var(--serif); font-size: 180px; line-height: 0.4; color: var(--gold); opacity: 0.5; margin-bottom: 32px;}
  .homme-review__quote{ font-family: var(--serif); font-size: clamp(32px, 3.6vw, 48px); font-weight: 300; line-height: 1.25; color: #F5EFE2; margin: 0 0 40px; letter-spacing: -0.01em;}
  .homme-review__attr{ display: flex; justify-content: center; align-items: center; gap: 32px; padding: 24px 0; border-top: 1px solid rgba(232,225,210,0.12); border-bottom: 1px solid rgba(232,225,210,0.12);}
  .homme-review__attr strong{ display: block; font-family: var(--serif-body); font-size: 15px; font-weight: 500; color: #F5EFE2;}
  .homme-review__attr span{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: rgba(232,225,210,0.55); display: block; margin-top: 4px;}
  .homme-review__stars{ display: inline-flex; gap: 2px; color: var(--gold);}
  .homme-review__meta{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 40px;}
  .homme-review__meta > div{ text-align: center;}
  .homme-review__meta strong{ display: block; font-family: var(--serif); font-size: 32px; font-weight: 300; color: #F5EFE2; margin-bottom: 6px;}
  .homme-review__meta span{ font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase; color: rgba(232,225,210,0.55);}

  /* Sets */
  .homme-sets{ padding: 120px 48px; max-width: 1600px; margin: 0 auto;}
  .homme-sets__head{ max-width: 720px; margin-bottom: 64px;}
  .homme-sets__grid{ display: grid; grid-template-columns: 1fr 1fr; gap: 32px;}
  .homme-set{ background: #1A1512; border: 1px solid rgba(232,225,210,0.08); display: grid; grid-template-columns: 1fr 1fr; gap: 0;}
  .homme-set__media{ position: relative; min-height: 480px;}
  .homme-set__body{ padding: 48px 40px; display: flex; flex-direction: column;}
  .homme-set__n{ font-family: var(--serif); font-size: 32px; color: var(--gold); margin-bottom: 8px;}
  .homme-set h3{ font-family: var(--serif); font-size: 38px; font-weight: 300; color: #F5EFE2; margin: 0 0 8px; letter-spacing: -0.01em;}
  .homme-set__sub{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: rgba(232,225,210,0.6); margin-bottom: 24px;}
  .homme-set p{ font-family: var(--serif-body); font-size: 15px; line-height: 1.6; color: rgba(232,225,210,0.75); flex: 1; margin: 0 0 32px;}
  .homme-set__foot{ display: flex; justify-content: space-between; align-items: flex-end; padding-top: 24px; border-top: 1px solid rgba(232,225,210,0.12); gap: 16px;}
  .homme-set__price strong{ display: block; font-family: var(--serif); font-size: 28px; color: #F5EFE2; font-weight: 300;}
  .homme-set__price span{ font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold);}

  /* Journal */
  .homme-journal{ padding: 96px 48px; max-width: 1600px; margin: 0 auto; border-top: 1px solid rgba(232,225,210,0.1);}
  .homme-journal__head{ display: grid; grid-template-columns: 1fr 1fr auto; align-items: end; gap: 24px; margin-bottom: 64px;}
  .homme-journal__head h2{ margin: 0;}
  .homme-journal__grid{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px;}
  .homme-jpost{ display: block; cursor: pointer;}
  .homme-jpost__media{ position: relative; aspect-ratio: 4/3; margin-bottom: 24px; overflow: hidden;}
  .homme-jpost__meta{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold); margin-bottom: 12px;}
  .homme-jpost h4{ font-family: var(--serif); font-size: 24px; font-weight: 300; color: #F5EFE2; line-height: 1.2; margin: 0 0 12px; letter-spacing: -0.005em;}
  .homme-jpost p{ font-family: var(--serif-body); font-size: 14px; line-height: 1.55; color: rgba(232,225,210,0.7); margin: 0 0 16px;}

  /* List */
  .homme-list{ padding: 120px 48px; background: #060404; border-top: 1px solid rgba(232,225,210,0.08);}
  .homme-list__inner{ max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: center;}
  .homme-list__inner h2{ margin: 0 0 20px;}
  .homme-list__inner p{ font-family: var(--serif-body); font-size: 17px; line-height: 1.6; color: rgba(232,225,210,0.75); max-width: 480px; margin: 0;}
  .homme-list__form{ display: flex; gap: 12px; align-items: stretch;}
  .homme-list__form input{ flex: 1; background: transparent; border: 1px solid rgba(232,225,210,0.25); color: #F5EFE2; padding: 18px 20px; font-family: var(--serif-body); font-size: 16px;}
  .homme-list__form input::placeholder{ color: rgba(232,225,210,0.4);}
  .homme-list__form input:focus{ outline: none; border-color: var(--gold);}
  .homme-list__ok{ font-family: var(--serif-body); font-style: italic; font-size: 16px; color: var(--gold); padding: 18px 0;}

  @media (max-width: 1000px){
    .homme-hero{ padding: 120px 24px 60px;}
    .homme-hero__grid{ grid-template-columns: 1fr; gap: 24px;}
    .homme-hero__meta, .homme-hero__cta, .homme-hero__sub{ grid-column: 1/2; justify-self: start;}
    .homme-hero__sig{ grid-column: 1/2;}
    .homme-pillars__inner{ grid-template-columns: 1fr 1fr;}
    .homme-pillar{ padding: 0 20px; border-right: 0; border-bottom: 1px solid rgba(232,225,210,0.1); padding-bottom: 32px; margin-bottom: 32px;}
    .homme-pillar:nth-child(2n){ border-right: 0;}
    .homme-pillars{ padding: 64px 24px;}
    .homme-ritual, .homme-line, .homme-sets, .homme-journal, .homme-list{ padding: 64px 24px;}
    .homme-ritual__grid, .homme-line__grid, .homme-journal__grid{ grid-template-columns: 1fr; gap: 32px;}
    .homme-sets__grid{ grid-template-columns: 1fr;}
    .homme-set{ grid-template-columns: 1fr;}
    .homme-set__media{ min-height: 280px;}
    .homme-frag{ grid-template-columns: 1fr;}
    .homme-frag__media{ min-height: 400px;}
    .homme-frag__body{ padding: 64px 24px;}
    .homme-line__head, .homme-journal__head{ grid-template-columns: 1fr;}
    .homme-review__meta{ grid-template-columns: 1fr 1fr;}
    .homme-list__inner{ grid-template-columns: 1fr; gap: 40px;}
    .homme-list__form{ flex-direction: column;}
  }
/* Shopify Liquid conversion helpers */
.hero__image,.hero__video video,.cat__img,.prod__media img,.story__media img,.collection-hero img,.pdp__gallery-main img{width:100%;height:100%;object-fit:cover;display:block}.hero__title p{margin:0}.ph span{position:relative;z-index:2;font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(42,35,32,.5);text-align:center;padding:20px}.ph--dark span,.ph--mono span{color:rgba(255,255,255,.62)}.foot{padding:80px 48px;background:var(--ink);color:var(--ivory);display:grid;grid-template-columns:1fr 2fr;gap:60px}.foot a{display:block;color:inherit;margin:10px 0;opacity:.82}.foot__brand{font-family:var(--serif);font-size:42px;opacity:1!important}.foot__copy{font-family:var(--serif-body);font-size:18px;line-height:1.55;max-width:420px;opacity:.78}.foot__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}.foot h4{font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;margin:0 0 18px;color:var(--gold)}.prive{background:var(--cream);text-align:center}.prive__inner{max-width:760px;margin:0 auto}.prive h2{font-family:var(--serif);font-size:clamp(44px,6vw,88px);font-weight:400;line-height:.95;margin:0 0 20px}.prive p{font-family:var(--serif-body);font-size:20px;color:var(--mute)}.prive form{display:flex;gap:12px;justify-content:center;margin-top:32px}.prive input{min-width:320px;background:var(--ivory);border:1px solid var(--line);padding:16px 18px;font:inherit}.shopify-section{display:block}.pdp{display:grid;grid-template-columns:1fr 1fr;gap:70px;padding:140px 48px 80px}.pdp__gallery-main{aspect-ratio:4/5;background:var(--cream)}.pdp__info{padding-top:40px}.pdp__kicker,.collection-kicker{font-family:var(--mono);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--mute);margin-bottom:18px}.pdp h1,.collection-hero h1,.page-lux h1{font-family:var(--serif);font-size:clamp(48px,6vw,92px);line-height:.96;font-weight:400;margin:0 0 24px}.pdp__price{font-size:18px;letter-spacing:.08em;margin-bottom:28px}.pdp__desc{font-family:var(--serif-body);font-size:20px;line-height:1.55;color:var(--espresso);margin-bottom:30px}.pdp select,.pdp button{width:100%;margin-top:12px}.collection-hero{min-height:52vh;display:flex;align-items:flex-end;padding:120px 48px 60px;background:var(--ink);color:var(--ivory);position:relative;overflow:hidden}.collection-grid{padding:80px 48px;display:grid;grid-template-columns:repeat(4,1fr);gap:32px}.page-lux{padding:140px 48px;max-width:980px;margin:0 auto}.page-lux .rte{font-family:var(--serif-body);font-size:20px;line-height:1.65}.cart-lux{padding:140px 48px}.cart-lux h1{font-family:var(--serif);font-size:72px;font-weight:400}.cart-lux table{width:100%;border-collapse:collapse}.cart-lux td,.cart-lux th{border-bottom:1px solid var(--line);padding:20px;text-align:left}.search-lux{padding:140px 48px}.search-lux input{width:min(640px,100%);padding:18px;border:1px solid var(--line);background:var(--cream)}@media(max-width:900px){.foot,.pdp{grid-template-columns:1fr}.foot__cols,.collection-grid{grid-template-columns:1fr 1fr}.prive form{flex-direction:column}.prive input{min-width:0}.collection-grid{padding:48px 20px}.pdp{padding:100px 20px 60px}}@media(max-width:640px){.foot__cols,.collection-grid{grid-template-columns:1fr}.foot{padding:60px 24px}section{padding-left:20px!important;padding-right:20px!important}}
