/*
 * Majestic Lenses — child theme styles.
 * Pipeline: PostCSS (Tailwind + Autoprefixer).
 *
 * Architecture:
 *   1. @tailwind base/components/utilities — Tailwind layers.
 *   2. @layer base { :root tokens, body baseline, focus ring, reduced-motion }
 *   3. Project component styles ported from the static `dist/main.css`. These
 *      live OUTSIDE @layer wrappers so their cascade order matches the static
 *      site exactly. Tailwind utilities load later in the file and win on
 *      equal specificity, which is what we want.
 *
 * To keep parity with the static site, do NOT modify the project component
 * rules below. Make styling changes by editing the static stylesheet first
 * and re-pasting. Or, for theme-only tweaks, add them at the bottom under
 * the "Theme-only overrides" section.
 */

*, ::before, ::after {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}

::backdrop {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}

/*
 ! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
 */

/*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/

*,
::before,
::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: #e5e7eb; /* 2 */
}

::before,
::after {
  --tw-content: '';
}

/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
7. Disable tap highlights on iOS
*/

html,
:host {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; /* 4 */
  font-feature-settings: normal; /* 5 */
  font-variation-settings: normal; /* 6 */
  -webkit-tap-highlight-color: transparent; /* 7 */
}

/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/

body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}

/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/

hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}

/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/

abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

/*
Remove the default font size and weight for headings.
*/

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}

/*
Reset links to optimize for opt-in styling instead of opt-out.
*/

a {
  color: inherit;
  text-decoration: inherit;
}

/*
Add the correct font weight in Edge and Safari.
*/

b,
strong {
  font-weight: bolder;
}

/*
1. Use the user's configured `mono` font-family by default.
2. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. Correct the odd `em` font sizing in all browsers.
*/

code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* 1 */
  font-feature-settings: normal; /* 2 */
  font-variation-settings: normal; /* 3 */
  font-size: 1em; /* 4 */
}

/*
Add the correct font size in all browsers.
*/

small {
  font-size: 80%;
}

/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/

table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}

/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-feature-settings: inherit; /* 1 */
  font-variation-settings: inherit; /* 1 */
  font-size: 100%; /* 1 */
  font-weight: inherit; /* 1 */
  line-height: inherit; /* 1 */
  letter-spacing: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}

/*
Remove the inheritance of text transform in Edge and Firefox.
*/

button,
select {
  text-transform: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/

button,
input:where([type='button']),
input:where([type='reset']),
input:where([type='submit']) {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}

/*
Use the modern Firefox focus style for all focusable elements.
*/

:-moz-focusring {
  outline: auto;
}

/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/

:-moz-ui-invalid {
  box-shadow: none;
}

/*
Add the correct vertical alignment in Chrome and Firefox.
*/

progress {
  vertical-align: baseline;
}

/*
Correct the cursor style of increment and decrement buttons in Safari.
*/

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/

[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/*
Remove the inner padding in Chrome and Safari on macOS.
*/

::-webkit-search-decoration {
  -webkit-appearance: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/*
Add the correct display in Chrome and Safari.
*/

summary {
  display: list-item;
}

/*
Removes the default spacing and border for appropriate elements.
*/

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}

fieldset {
  margin: 0;
  padding: 0;
}

legend {
  padding: 0;
}

ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

/*
Reset default styling for dialogs.
*/

dialog {
  padding: 0;
}

/*
Prevent resizing textareas horizontally by default.
*/

textarea {
  resize: vertical;
}

/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/

input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

/*
Set the default cursor for buttons.
*/

button,
[role="button"] {
  cursor: pointer;
}

/*
Make sure disabled buttons don't get the pointer cursor.
*/

:disabled {
  cursor: default;
}

/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/

img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}

/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/

img,
video {
  max-width: 100%;
  height: auto;
}

/* Make elements with the HTML hidden attribute stay hidden by default */

[hidden]:where(:not([hidden="until-found"])) {
  display: none;
}

:root {
    --color-ink:        #0F0A12;
    --color-aubergine:  #2A1530;
    --color-gold:       #C9A14A;
    --color-blush:      #F5E6D8;
    --color-ivory:      #FBF7F0;
    --color-iris:       #7C5BC4;

    --font-display: 'Fraunces', serif;
    --font-body:    'Inter', system-ui, sans-serif;
    --font-urdu:    'Gulzar', serif;
  }

body {
    background: var(--color-ivory);
    color: var(--color-ink);
    font-family: var(--font-body);
    font-feature-settings: 'ss01', 'cv11';
  }

:focus-visible {
    outline: 2px solid var(--color-aubergine);
    outline-offset: 2px;
  }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
      animation-duration: 0.01ms !important;
      animation-iteration-count: 1 !important;
      transition-duration: 0.01ms !important;
      scroll-behavior: auto !important;
    }
  }
.container {
  width: 100%;
}
@media (min-width: 640px) {

  .container {
    max-width: 640px;
  }
}
@media (min-width: 768px) {

  .container {
    max-width: 768px;
  }
}
@media (min-width: 1024px) {

  .container {
    max-width: 1024px;
  }
}
@media (min-width: 1280px) {

  .container {
    max-width: 1280px;
  }
}
@media (min-width: 1536px) {

  .container {
    max-width: 1536px;
  }
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}
.visible {
  visibility: visible;
}
.static {
  position: static;
}
.fixed {
  position: fixed;
}
.absolute {
  position: absolute;
}
.relative {
  position: relative;
}
.sticky {
  position: sticky;
}
.bottom-0 {
  bottom: 0px;
}
.left-0 {
  left: 0px;
}
.right-0 {
  right: 0px;
}
.top-\[var\(--header-height\2c 64px\)\] {
  top: var(--header-height,64px);
}
.z-30 {
  z-index: 30;
}
.mx-auto {
  margin-left: auto;
  margin-right: auto;
}
.mb-2 {
  margin-bottom: 0.5rem;
}
.mb-4 {
  margin-bottom: 1rem;
}
.mb-6 {
  margin-bottom: 1.5rem;
}
.mt-2 {
  margin-top: 0.5rem;
}
.block {
  display: block;
}
.inline {
  display: inline;
}
.flex {
  display: flex;
}
.table {
  display: table;
}
.grid {
  display: grid;
}
.contents {
  display: contents;
}
.hidden {
  display: none;
}
.h-10 {
  height: 2.5rem;
}
.h-5 {
  height: 1.25rem;
}
.w-10 {
  width: 2.5rem;
}
.w-20 {
  width: 5rem;
}
.w-5 {
  width: 1.25rem;
}
.min-w-0 {
  min-width: 0px;
}
.max-w-3xl {
  max-width: 48rem;
}
.flex-1 {
  flex: 1 1 0%;
}
.transform {
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.resize {
  resize: both;
}
.flex-wrap {
  flex-wrap: wrap;
}
.items-end {
  align-items: flex-end;
}
.items-center {
  align-items: center;
}
.justify-between {
  justify-content: space-between;
}
.gap-1 {
  gap: 0.25rem;
}
.gap-10 {
  gap: 2.5rem;
}
.gap-12 {
  gap: 3rem;
}
.gap-2 {
  gap: 0.5rem;
}
.gap-3 {
  gap: 0.75rem;
}
.gap-4 {
  gap: 1rem;
}
.gap-8 {
  gap: 2rem;
}
.space-y-1 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.25rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.25rem * var(--tw-space-y-reverse));
}
.space-y-6 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.5rem * var(--tw-space-y-reverse));
}
.self-start {
  align-self: flex-start;
}
.truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.rounded {
  border-radius: 0.25rem;
}
.rounded-2xl {
  border-radius: 1rem;
}
.rounded-full {
  border-radius: 9999px;
}
.border {
  border-width: 1px;
}
.border-b {
  border-bottom-width: 1px;
}
.border-t {
  border-top-width: 1px;
}
.border-ink\/10 {
  border-color: rgb(15 10 18 / 0.1);
}
.border-ink\/20 {
  border-color: rgb(15 10 18 / 0.2);
}
.bg-blush {
  --tw-bg-opacity: 1;
  background-color: rgb(245 230 216 / var(--tw-bg-opacity, 1));
}
.bg-ivory {
  --tw-bg-opacity: 1;
  background-color: rgb(251 247 240 / var(--tw-bg-opacity, 1));
}
.bg-ivory\/95 {
  background-color: rgb(251 247 240 / 0.95);
}
.p-4 {
  padding: 1rem;
}
.p-6 {
  padding: 1.5rem;
}
.px-2 {
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}
.px-4 {
  padding-left: 1rem;
  padding-right: 1rem;
}
.px-5 {
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}
.py-1 {
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
}
.py-12 {
  padding-top: 3rem;
  padding-bottom: 3rem;
}
.py-2 {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}
.py-3 {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}
.py-8 {
  padding-top: 2rem;
  padding-bottom: 2rem;
}
.pt-2 {
  padding-top: 0.5rem;
}
.font-body {
  font-family: Inter, system-ui, sans-serif;
}
.font-display {
  font-family: Fraunces, serif;
}
.text-2xl {
  font-size: 1.5rem;
  line-height: 2rem;
}
.text-4xl {
  font-size: 2.25rem;
  line-height: 2.5rem;
}
.text-base {
  font-size: 1rem;
  line-height: 1.5rem;
}
.text-lg {
  font-size: 1.125rem;
  line-height: 1.75rem;
}
.text-sm {
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.text-xl {
  font-size: 1.25rem;
  line-height: 1.75rem;
}
.text-xs {
  font-size: 0.75rem;
  line-height: 1rem;
}
.text-ink {
  --tw-text-opacity: 1;
  color: rgb(15 10 18 / var(--tw-text-opacity, 1));
}
.text-ink\/50 {
  color: rgb(15 10 18 / 0.5);
}
.text-ink\/60 {
  color: rgb(15 10 18 / 0.6);
}
.text-ink\/70 {
  color: rgb(15 10 18 / 0.7);
}
.text-ink\/80 {
  color: rgb(15 10 18 / 0.8);
}
.underline {
  text-decoration-line: underline;
}
.outline {
  outline-style: solid;
}
.ring {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.ring-1 {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.ring-ink\/10 {
  --tw-ring-color: rgb(15 10 18 / 0.1);
}
.blur {
  --tw-blur: blur(8px);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}
.filter {
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}
.backdrop-blur {
  --tw-backdrop-blur: blur(8px);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}
.transition {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}
.ease-in-out {
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

/* =========================================================================
 * Project components — verbatim from dist/main.css (static-site stylesheet)
 * ========================================================================= */
/* =========================================================
   Majestic Lenses — pre-built stylesheet (no build step needed)
   ========================================================= */

:root{
  --ml-ink:#0F0A12;
  --ml-aubergine:#2A1530;
  --ml-plum:#3D1E45;
  --ml-gold:#C9A14A;
  --ml-gold-lite:#E5C97A;
  --ml-blush:#F5E6D8;
  --ml-ivory:#FBF7F0;
  --ml-iris:#7C5BC4;
  --ml-mist:#EFE7DD;
  --ml-ease:cubic-bezier(.2,.8,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--ml-ivory);
  color:var(--ml-ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%;height:auto}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit;padding:0}
a{color:inherit;text-decoration:none}
ul{margin:0;padding:0;list-style:none}
input,select,textarea{font:inherit;color:inherit}
::-moz-selection{background:var(--ml-gold);color:var(--ml-ink)}
::selection{background:var(--ml-gold);color:var(--ml-ink)}

:where(a,button,input,select,textarea,details,summary,[tabindex]):focus-visible{
  outline:2px solid var(--ml-ink);
  outline-offset:3px;
  border-radius:8px;
}

h1,h2,h3,h4{
  font-family:"Fraunces",ui-serif,Georgia,serif;
  letter-spacing:-0.04em;
  font-weight:500;
  margin:0;
  font-optical-sizing:auto;
}
h1{font-variation-settings:"opsz" 144,"SOFT" 30,"WONK" 1;line-height:.92}
p{margin:0}

.container-x{max-width:1400px;margin-inline:auto;padding-inline:1.5rem}
@media(min-width:1024px){.container-x{padding-inline:2.5rem}}

.eyebrow{
  font-size:11px;text-transform:uppercase;letter-spacing:.22em;
  font-weight:500;color:rgba(201,161,74,.95);
}
.aubergine-gradient{background:radial-gradient(120% 80% at 20% 0%,#3D1E45 0%,#2A1530 45%,#160B1B 100%)}
.grain{position:relative;isolation:isolate}
.grain::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.4' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .25 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.35;mix-blend-mode:overlay;
}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.875rem 1.5rem;border-radius:9999px;
  font-size:.875rem;font-weight:500;
  min-height:44px;
  transition:all .25s var(--ml-ease);
  border:1px solid transparent;
  text-align:center;
}
.btn-primary{background:var(--ml-ink);color:var(--ml-ivory)}
.btn-primary:hover{background:var(--ml-aubergine);box-shadow:0 20px 40px -24px rgba(15,10,18,.45)}
.btn-gold{background:var(--ml-gold);color:var(--ml-ink);
  box-shadow:0 1px 0 rgba(201,161,74,.45) inset,0 30px 60px -30px rgba(15,10,18,.55)}
.btn-gold:hover{background:var(--ml-gold-lite);transform:translateY(-2px)}
.btn-ghost{border-color:rgba(15,10,18,.2);color:var(--ml-ink);background:transparent}
.btn-ghost:hover{background:var(--ml-ink);color:var(--ml-ivory);border-color:var(--ml-ink)}
.btn-whatsapp{background:#25D366;color:#fff}
.btn-whatsapp:hover{background:#1ebe5b}
.btn-on-dark{border-color:rgba(251,247,240,.3);color:var(--ml-ivory);background:transparent}
.btn-on-dark:hover{background:var(--ml-ivory);color:var(--ml-ink)}

.iris-card{
  position:relative;display:block;overflow:hidden;border-radius:24px;
  background:var(--ml-ivory);
  transition:transform .5s var(--ml-ease),box-shadow .5s var(--ml-ease);
}
.iris-card:hover{box-shadow:0 30px 60px -30px rgba(15,10,18,.4)}
.iris-card .iris-img{
  width:100%;aspect-ratio:1/1;-o-object-fit:cover;object-fit:cover;
  transition:transform .7s var(--ml-ease);
}
.iris-card:hover .iris-img{transform:scale(1.06)}

.iris-swatch{
  display:inline-block;border-radius:9999px;
  width:36px;height:36px;
  background:radial-gradient(circle at 50% 50%,
    var(--c-pupil,#0F0A12) 0 18%,
    var(--c-inner,#888) 18% 38%,
    var(--c-mid,#444) 38% 70%,
    var(--c-outer,#0F0A12) 70% 78%,
    transparent 78% 100%);
  border:0;cursor:pointer;
}
.iris-swatch:hover{transform:scale(1.08)}

.chip{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.5rem 1rem;border-radius:9999px;
  border:1px solid rgba(15,10,18,.15);
  font-size:.875rem;min-height:36px;
  transition:border-color .2s,background .2s,color .2s;
  background:transparent;color:var(--ml-ink);
}
.chip:hover{border-color:var(--ml-ink)}
.chip[aria-pressed="true"]{background:var(--ml-ink);color:var(--ml-ivory);border-color:var(--ml-ink)}
.chip-on-dark{border-color:rgba(251,247,240,.3);color:var(--ml-ivory)}
.chip-on-dark:hover{border-color:var(--ml-gold);color:var(--ml-gold)}
.chip-on-dark.solid{background:var(--ml-ivory);color:var(--ml-ink);border-color:var(--ml-ivory)}

.field-label{
  display:block;font-size:.75rem;font-weight:500;
  text-transform:uppercase;letter-spacing:.22em;
  color:rgba(15,10,18,.7);margin-bottom:.5rem;
}
.input,select,textarea,input[type=email],input[type=number],input[type=text]{
  width:100%;padding:.75rem 1rem;border-radius:14px;
  border:1px solid rgba(15,10,18,.15);background:#fff;color:var(--ml-ink);
  transition:border-color .2s,box-shadow .2s;
}
.input:focus,select:focus,textarea:focus,input:focus{outline:none;border-color:var(--ml-ink)}
input[type=file]{font-size:.875rem;color:rgba(15,10,18,.7)}
input[type=checkbox]{accent-color:var(--ml-ink);width:1rem;height:1rem}

.marquee{overflow:hidden;white-space:nowrap}
.marquee-track{display:inline-flex;gap:3rem;align-items:center;animation:marquee 40s linear infinite;will-change:transform}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

@keyframes iris-bloom{
  0%{transform:scale(.94);filter:blur(6px);opacity:0}
  100%{transform:scale(1);filter:blur(0);opacity:1}
}
@keyframes fade-up{
  0%{transform:translateY(14px);opacity:0}
  100%{transform:translateY(0);opacity:1}
}
.animate-iris-bloom{animation:iris-bloom .6s var(--ml-ease) both}
.animate-fade-up{animation:fade-up .6s var(--ml-ease) both}
.animate-fade-up.d1{animation-delay:.08s}
.animate-fade-up.d2{animation-delay:.16s}
.animate-fade-up.d3{animation-delay:.24s}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
}

/* Header */
.announce{
  background:var(--ml-ink);color:var(--ml-ivory);
  font-size:12px;text-transform:uppercase;letter-spacing:.22em;
}
.announce .marquee{padding:.5rem 0}
.site-header{
  position:sticky;top:0;z-index:40;
  background:rgba(251,247,240,.88);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid rgba(201,161,74,.35);
}
.site-header-inner{
  max-width:1400px;margin-inline:auto;
  padding-inline:1.5rem;height:80px;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
@media(min-width:1024px){.site-header-inner{padding-inline:2.5rem}}
.nav-primary{display:none;gap:1.75rem;font-size:.875rem;align-items:center}
@media(min-width:1024px){.nav-primary{display:flex}}
.nav-primary a:hover{color:var(--ml-aubergine)}
.brand{display:flex;flex-direction:column;align-items:center;line-height:1;text-align:center}
.brand-name{font-family:"Fraunces",serif;font-size:1.5rem;letter-spacing:-.04em;font-weight:500}
.brand-sub{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(201,161,74,.95);margin-top:.25rem}
.actions{display:flex;align-items:center;gap:1rem;font-size:.875rem}
.actions a,.actions button{display:inline-flex;align-items:center;gap:.4rem;min-height:44px;padding:0 .25rem}
.actions a:hover,.actions button:hover{color:var(--ml-aubergine)}
.actions svg{width:18px;height:18px}
.cart{position:relative}
.cart .badge{
  position:absolute;top:-6px;right:-12px;
  width:18px;height:18px;border-radius:9999px;
  background:var(--ml-gold);color:var(--ml-ink);
  font-size:10px;font-weight:600;
  display:flex;align-items:center;justify-content:center;
}
.menu-btn{display:inline-flex}
@media(min-width:1024px){.menu-btn{display:none}}
.hide-mobile{display:none}
@media(min-width:768px){.hide-mobile{display:inline-flex}}

/* Footer */
.site-footer{
  position:relative;isolation:isolate;margin-top:6rem;
  background:radial-gradient(120% 80% at 20% 0%,#3D1E45,#2A1530 45%,#160B1B);
  color:var(--ml-ivory);overflow:hidden;
}
.site-footer .container-x{padding-block:5rem;position:relative;z-index:1}
.footer-grid{display:grid;gap:3rem}
@media(min-width:1024px){.footer-grid{grid-template-columns:5fr 7fr}}
.footer-cols{display:grid;gap:2rem;grid-template-columns:repeat(2,1fr)}
@media(min-width:768px){.footer-cols{grid-template-columns:repeat(4,1fr)}}
.footer-cols a{color:rgba(251,247,240,.85)}
.footer-cols a:hover{color:var(--ml-gold-lite)}
.footer-newsletter{display:flex;max-width:28rem;margin-top:2rem;position:relative}
.footer-newsletter input{
  flex:1;background:transparent;border:0;border-bottom:1px solid rgba(251,247,240,.3);
  border-radius:0;color:var(--ml-ivory);padding:.75rem 0;
}
.footer-newsletter input::-moz-placeholder{color:rgba(251,247,240,.5)}
.footer-newsletter input::placeholder{color:rgba(251,247,240,.5)}
.footer-newsletter input:focus{border-bottom-color:var(--ml-gold)}
.footer-newsletter .btn-gold{border-radius:0;padding:0 1.25rem}
.footer-bottom{
  margin-top:4rem;padding-top:2rem;border-top:1px solid rgba(251,247,240,.15);
  display:flex;flex-direction:column;gap:1rem;
  font-size:12px;color:rgba(251,247,240,.55);
}
@media(min-width:768px){
  .footer-bottom{flex-direction:row;justify-content:space-between;align-items:center}
}
.footer-iris{
  position:absolute;right:-160px;bottom:-160px;width:680px;opacity:.22;
  pointer-events:none;z-index:0;
}
.nasta{font-family:"Gulzar","Noto Nastaliq Urdu",serif;color:var(--ml-gold-lite);font-size:1rem}

/* Hero */
.hero{
  position:relative;isolation:isolate;overflow:hidden;color:var(--ml-ivory);
  background:radial-gradient(120% 80% at 20% 0%,#3D1E45,#2A1530 45%,#160B1B);
}
.hero .container-x{padding-block:4rem 6rem;position:relative;z-index:1}
@media(min-width:1024px){.hero .container-x{padding-block:6rem 8rem}}
.hero-grid{display:grid;gap:2.5rem;align-items:end}
@media(min-width:1024px){.hero-grid{grid-template-columns:7fr 5fr}}
.hero h1{font-size:clamp(3rem,12vw,7.5rem);margin-top:1.5rem}
.hero h1 em{color:var(--ml-gold-lite);font-style:normal}
.hero p.lede{margin-top:2rem;max-width:34rem;color:rgba(251,247,240,.8);font-size:1.05rem}
.hero-cta{margin-top:2.5rem;display:flex;flex-wrap:wrap;gap:1rem}
.hero-stats{
  margin-top:3.5rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
  max-width:36rem;border-top:1px solid rgba(251,247,240,.15);padding-top:1.5rem;font-size:.875rem;
}
.hero-stats dt{color:rgba(251,247,240,.55)}
.hero-stats dd{font-family:"Fraunces",serif;font-size:1.5rem;margin:.25rem 0 0}
.hero-collage{position:relative;height:460px;margin-top:2rem}
@media(min-width:768px){.hero-collage{height:560px}}
@media(min-width:1024px){.hero-collage{height:620px;margin-top:0}}
.hero-img-a{position:absolute;right:0;top:0;width:78%;aspect-ratio:4/5;
  border-radius:28px;overflow:hidden;
  box-shadow:0 30px 60px -30px rgba(15,10,18,.55);
  animation:iris-bloom .6s var(--ml-ease) both;margin:0;}
.hero-img-a img,.hero-img-b img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}
.hero-img-b{position:absolute;left:0;bottom:0;width:58%;aspect-ratio:1/1;
  border-radius:24px;overflow:hidden;
  box-shadow:0 1px 0 rgba(201,161,74,.45) inset,0 30px 60px -30px rgba(15,10,18,.55);
  outline:1px solid rgba(201,161,74,.4);
  animation:iris-bloom .6s var(--ml-ease) both;animation-delay:.18s;margin:0}
.price-bubble{
  position:absolute;right:2rem;bottom:3rem;
  width:7rem;height:7rem;border-radius:9999px;
  background:var(--ml-ivory);color:var(--ml-ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:"Fraunces",serif;
  transform:rotate(6deg);
  box-shadow:0 20px 40px -24px rgba(15,10,18,.4);
}
.price-bubble .lbl{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ml-gold)}
.price-bubble .amt{font-size:1.5rem;margin-top:.25rem}

.section{padding-block:5rem}
@media(min-width:1024px){.section{padding-block:7rem}}
.section-head{display:grid;gap:2rem;margin-bottom:3rem;align-items:end}
@media(min-width:768px){.section-head{grid-template-columns:7fr 5fr}}
.h-display{font-family:"Fraunces",serif;letter-spacing:-.04em;line-height:.95;
  font-size:clamp(2.5rem,6vw,4.5rem);margin-top:.75rem;font-weight:500}
.h-display em{font-style:normal;color:var(--ml-iris)}

.mosaic{display:grid;gap:1.5rem;grid-template-columns:repeat(12,1fr)}
.mosaic-card{position:relative;overflow:hidden;border-radius:24px;
  height:380px;color:var(--ml-ivory);grid-column:span 12;
  isolation:isolate;display:block;
  transition:transform .5s var(--ml-ease);
}
.mosaic-card:hover{transform:translateY(-4px)}
@media(min-width:768px){
  .mosaic-card{height:520px}
  .mosaic-card.span-7{grid-column:span 7}
  .mosaic-card.span-5{grid-column:span 5}
}
.mosaic-card img{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;
  transition:transform .7s var(--ml-ease);z-index:0}
.mosaic-card:hover img{transform:scale(1.05)}
.mosaic-card::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,10,18,0) 30%,rgba(15,10,18,.85) 100%);
  z-index:1;
}
.mosaic-card .meta{position:absolute;left:2rem;right:2rem;bottom:2rem;z-index:2}
.mosaic-card .arrow{position:absolute;top:1.5rem;right:1.5rem;z-index:2;color:rgba(251,247,240,.85)}
.mosaic-card:hover .arrow{color:var(--ml-gold-lite)}
.mosaic-card h3{font-size:clamp(2.25rem,4vw,3.5rem);margin-top:.5rem;color:var(--ml-ivory)}

.shade-marquee{
  background:rgba(245,230,216,.4);
  border-block:1px solid rgba(201,161,74,.35);
  overflow:hidden;
}
.shade-marquee .marquee-track{
  font-family:"Fraunces",serif;letter-spacing:-.04em;
  font-size:clamp(2.5rem,6vw,4.5rem);
  padding-block:2rem;
}
.shade-marquee .dot{color:var(--ml-gold)}

.grid-cards{display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}
@media(min-width:1024px){.grid-cards{grid-template-columns:repeat(4,1fr)}}
.card-body{padding:1.25rem}
.card-body h3{font-family:"Fraunces",serif;font-size:1.15rem;margin-top:.5rem;line-height:1.2;letter-spacing:-.02em}
.card-body .price{margin-top:.75rem;font-size:.875rem}
.price .was{text-decoration:line-through;color:rgba(15,10,18,.4);margin-right:.5rem}
.price .now{font-weight:500}
.tag{
  position:absolute;top:.75rem;left:.75rem;z-index:2;
  background:var(--ml-ink);color:var(--ml-ivory);
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  padding:.25rem .5rem;border-radius:9999px;
}
.tag.gold{background:var(--ml-gold);color:var(--ml-ink)}
.tag.iris{background:var(--ml-iris);color:var(--ml-ivory)}

.why{background:var(--ml-ink);color:var(--ml-ivory);position:relative;isolation:isolate;overflow:hidden}
.why .container-x{padding-block:5rem;position:relative;z-index:1}
@media(min-width:1024px){.why .container-x{padding-block:7rem}}
.why-grid{display:grid;gap:3rem;align-items:center}
@media(min-width:1024px){.why-grid{grid-template-columns:1fr 1fr}}
.why-points{display:grid;gap:1.5rem 2.5rem;margin-top:2.5rem}
@media(min-width:640px){.why-points{grid-template-columns:1fr 1fr}}
.why-points h4{font-family:"Fraunces",serif;font-size:1.25rem;letter-spacing:-.02em;color:var(--ml-ivory)}
.why-points p{font-size:.875rem;color:rgba(251,247,240,.75);margin-top:.25rem}
.why-img{position:relative;height:480px;border-radius:32px;overflow:hidden;outline:1px solid rgba(201,161,74,.3)}
.why-img img{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}
.quote-card{
  position:absolute;left:-1.5rem;bottom:2rem;
  background:var(--ml-ivory);color:var(--ml-ink);
  border-radius:18px;padding:1.5rem;max-width:18rem;
  box-shadow:0 30px 60px -30px rgba(15,10,18,.4);
}
.quote-card .q{font-family:"Fraunces",serif;font-size:1.5rem;line-height:1.15;letter-spacing:-.02em}
.quote-card .who{margin-top:.75rem;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(15,10,18,.6)}

.steps{display:grid;gap:2rem}
@media(min-width:768px){.steps{grid-template-columns:repeat(3,1fr)}}
.steps h3{font-family:"Fraunces",serif;font-size:1.5rem;margin-top:.5rem;letter-spacing:-.02em}
.steps p{margin-top:.75rem;color:rgba(15,10,18,.7)}

/* Shop */
.shop-head{position:relative;color:var(--ml-ivory)}
.shop-head .container-x{padding-block:5rem;position:relative;z-index:1}
@media(min-width:1024px){.shop-head .container-x{padding-block:7rem}}
.crumbs{font-size:12px;color:rgba(251,247,240,.6);margin-bottom:1.5rem}
.crumbs a:hover{color:var(--ml-gold)}
.shop-head h1{font-size:clamp(3rem,9vw,6rem);margin-top:1rem;line-height:.92;color:var(--ml-ivory)}
.shop-head h1 em{font-style:normal;color:var(--ml-gold-lite)}
.shop-tabs{margin-top:3rem;display:flex;flex-wrap:wrap;gap:.75rem}
.toolbar{
  position:sticky;top:80px;z-index:30;
  background:rgba(251,247,240,.95);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(201,161,74,.35);
}
.toolbar-inner{
  max-width:1400px;margin-inline:auto;padding-inline:1.5rem;
  height:56px;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  font-size:.875rem;
}
@media(min-width:1024px){.toolbar-inner{padding-inline:2.5rem}}
.toolbar-chips{display:flex;align-items:center;gap:.5rem;overflow-x:auto;flex:1;scrollbar-width:none}
.toolbar-chips::-webkit-scrollbar{display:none}
.shop-layout{display:grid;gap:2.5rem;padding-block:4rem;max-width:1400px;margin-inline:auto;padding-inline:1.5rem}
@media(min-width:1024px){.shop-layout{grid-template-columns:3fr 9fr;padding-inline:2.5rem}}
.filters{display:flex;flex-direction:column;gap:2.5rem}
@media(min-width:1024px){.filters{position:sticky;top:152px;align-self:start}}
.filters .group p.eyebrow{margin-bottom:1rem}
.filters ul{display:flex;flex-direction:column;gap:.5rem;font-size:.875rem}
.filters label{display:flex;align-items:center;gap:.75rem;min-height:36px;cursor:pointer}
.filters .count{margin-left:auto;color:rgba(15,10,18,.4)}
.swatches{display:flex;flex-wrap:wrap;gap:.5rem}
.price-range{display:flex;align-items:center;gap:.75rem;font-size:.875rem}
.price-range .input{padding:.5rem .75rem}
.editorial-banner{
  display:grid;border-radius:24px;overflow:hidden;
  height:288px;margin-bottom:2.5rem;
}
@media(min-width:768px){.editorial-banner{grid-template-columns:1fr 1fr;height:384px}}
.editorial-banner .text{
  padding:2.5rem;color:var(--ml-ivory);
  background:var(--ml-aubergine);position:relative;isolation:isolate;
  display:flex;flex-direction:column;justify-content:space-between;
}
.editorial-banner .text h2{font-size:clamp(2.25rem,4vw,3.5rem);line-height:.95;margin-top:.5rem;color:var(--ml-ivory)}
.editorial-banner .img{position:relative;overflow:hidden;min-height:240px}
.editorial-banner .img img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .7s var(--ml-ease)}
.editorial-banner:hover .img img{transform:scale(1.04)}
.shop-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}
@media(min-width:1024px){.shop-grid{grid-template-columns:repeat(3,1fr)}}
.results-meta{display:flex;justify-content:space-between;font-size:.875rem;color:rgba(15,10,18,.6);margin-bottom:1.5rem}
.load-more{margin-top:3rem;display:flex;justify-content:center}

/* PDP */
.bread{max-width:1400px;margin-inline:auto;padding:2rem 1.5rem 0;font-size:12px;color:rgba(15,10,18,.6)}
@media(min-width:1024px){.bread{padding-inline:2.5rem}}
.bread a:hover{color:var(--ml-ink)}
.pdp{max-width:1400px;margin-inline:auto;padding:2.5rem 1.5rem;display:grid;gap:2.5rem}
@media(min-width:1024px){.pdp{padding-inline:2.5rem;grid-template-columns:7fr 5fr;gap:3.5rem}}
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}
@media(min-width:1024px){.gallery{position:sticky;top:104px;align-self:start}}
.thumbs{display:none;flex-direction:column;gap:.75rem;grid-column:span 2}
@media(min-width:768px){.thumbs{display:flex}}
.thumb{
  aspect-ratio:1/1;border-radius:14px;overflow:hidden;
  border:1px solid rgba(15,10,18,.15);background:none;padding:0;width:100%;
}
.thumb.active{outline:2px solid var(--ml-ink);border-color:var(--ml-ink)}
.thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}
.thumb.more{background:var(--ml-aubergine);color:var(--ml-ivory);font-size:12px;
  display:flex;align-items:center;justify-content:center}
.gallery-main{grid-column:span 12}
@media(min-width:768px){.gallery-main{grid-column:span 10}}
.gallery-main figure{
  position:relative;aspect-ratio:4/5;border-radius:24px;overflow:hidden;
  background:rgba(245,230,216,.4);
  animation:iris-bloom .6s var(--ml-ease) both;margin:0;
}
.gallery-main img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}
.save-btn{
  position:absolute;top:1rem;right:1rem;width:44px;height:44px;border-radius:9999px;
  background:rgba(251,247,240,.85);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
}
.save-btn:hover{background:var(--ml-ivory)}

.pdp-title{font-size:clamp(2rem,4vw,3rem);line-height:1;margin-top:.75rem}
.pdp-title em{font-style:normal;color:var(--ml-iris)}
.rating{margin-top:1rem;display:flex;align-items:center;gap:.75rem;font-size:.875rem}
.rating .stars{color:var(--ml-gold)}
.price-row{margin-top:1.5rem;display:flex;align-items:baseline;gap:.75rem;flex-wrap:wrap}
.price-row .now{font-family:"Fraunces",serif;font-size:1.875rem}
.price-row .was{text-decoration:line-through;color:rgba(15,10,18,.4)}
.price-row .save{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ml-iris)}
.tax-line{font-size:11px;color:rgba(15,10,18,.6);margin-top:.25rem}
.lede{margin-top:1.5rem;color:rgba(15,10,18,.75);line-height:1.6}

.buybox{
  margin-top:2rem;padding:1.5rem;border-radius:24px;
  background:rgba(245,230,216,.4);
  border:1px solid rgba(201,161,74,.35);
  display:flex;flex-direction:column;gap:1.5rem;
}
.buybox .row2{display:grid;gap:1rem;grid-template-columns:1fr 1fr}
.qty{
  display:inline-flex;align-items:center;
  border:1px solid rgba(15,10,18,.2);border-radius:9999px;padding:0 .5rem;height:48px;
}
.qty button{width:36px;height:36px;font-size:1.125rem}
.qty input{width:40px;text-align:center;background:none;border:0;font-weight:500;padding:0}
.qty input:focus{outline:none}
.actions-row{display:flex;align-items:stretch;gap:.75rem}
.actions-row .btn{flex:1}
.trust{
  margin-top:2rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;
  font-size:12px;color:rgba(15,10,18,.7);
}
.trust li{display:flex;gap:.5rem}
.trust .star{color:var(--ml-gold)}

details.spec{border-top:1px solid rgba(201,161,74,.35);padding-top:1.25rem;margin-top:2rem}
details.spec[open]{padding-bottom:.5rem}
details.spec summary{
  display:flex;align-items:center;justify-content:space-between;
  cursor:pointer;list-style:none;
}
details.spec summary::-webkit-details-marker{display:none}
details.spec summary .label{font-family:"Fraunces",serif;font-size:1.25rem;letter-spacing:-.02em}
details.spec summary .plus{color:var(--ml-gold);transition:transform .25s var(--ml-ease);font-size:1.25rem;line-height:1}
details.spec[open] summary .plus{transform:rotate(45deg)}
details.spec dl{margin-top:1.25rem;display:grid;grid-template-columns:1fr 1fr;gap:.5rem 1.5rem;font-size:.875rem}
details.spec dt{color:rgba(15,10,18,.55);margin:0}
details.spec dd{margin:0}
details.spec p{margin-top:1rem;font-size:.875rem;color:rgba(15,10,18,.75);line-height:1.6}

.pdp-strip{color:var(--ml-ivory);position:relative;isolation:isolate;overflow:hidden;
  background:radial-gradient(120% 80% at 20% 0%,#3D1E45,#2A1530 45%,#160B1B);
}
.pdp-strip .container-x{padding-block:5rem;position:relative;z-index:1}
.pdp-strip-grid{display:grid;gap:2.5rem;align-items:center}
@media(min-width:768px){.pdp-strip-grid{grid-template-columns:5fr 7fr}}
.pdp-strip h2{font-size:clamp(2.25rem,5vw,4rem);margin-top:1rem;line-height:.95;color:var(--ml-ivory)}
.pdp-strip h2 em{font-style:normal;color:var(--ml-gold-lite)}
.pdp-strip .specs{margin-top:2.5rem;display:flex;flex-wrap:wrap;gap:2rem;font-size:.875rem}
.pdp-strip .specs strong{display:block;font-family:"Fraunces",serif;font-size:1.875rem;font-weight:500}
.pdp-strip .specs span{color:rgba(251,247,240,.6)}
.pdp-strip figure{aspect-ratio:4/5;border-radius:24px;overflow:hidden;outline:1px solid rgba(201,161,74,.3);margin:0}
.pdp-strip figure img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}

.reviews-grid{display:grid;gap:2.5rem}
@media(min-width:768px){.reviews-grid{grid-template-columns:1fr 2fr}}
.reviews-meta .big{font-family:"Fraunces",serif;font-size:3.5rem;line-height:1}
.reviews-list{display:flex;flex-direction:column;gap:1.5rem}
.review{border-top:1px solid rgba(201,161,74,.35);padding-top:1.5rem}
.review header{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}
.review h3{font-family:"Fraunces",serif;font-size:1.15rem;margin-top:.25rem;letter-spacing:-.02em}
.review p{margin-top:.5rem;color:rgba(15,10,18,.75)}

.pdp-sticky{
  position:fixed;inset:auto 0 0 0;z-index:40;
  background:rgba(251,247,240,.95);backdrop-filter:blur(10px);
  border-top:1px solid rgba(201,161,74,.35);
  padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;
}
@media(min-width:1024px){.pdp-sticky{display:none}}
.pdp-sticky .info{flex:1;min-width:0}
.pdp-sticky .info p:first-child{font-size:11px;color:rgba(15,10,18,.6)}
.pdp-sticky .info p:last-child{font-family:"Fraunces",serif;font-size:1.125rem;line-height:1}

.skip-link{
  position:absolute;left:-9999px;top:0;background:var(--ml-ink);color:var(--ml-ivory);
  padding:.75rem 1rem;border-radius:0 0 8px 0;z-index:100;
}
.skip-link:focus{left:0}

.flex{display:flex}.items-end{align-items:flex-end}.items-center{align-items:center}
.justify-between{justify-content:space-between}

/* =========================================================
   RETAIL E-COMMERCE HOMEPAGE
   ========================================================= */

/* ---------- Promo hero ---------- */
.promo-hero{
  position:relative;isolation:isolate;overflow:hidden;color:var(--ml-ivory);
  background:radial-gradient(120% 80% at 70% 10%,#3D1E45,#2A1530 45%,#160B1B);
}
.promo-hero .container-x{padding-block:3rem 4rem;position:relative;z-index:1}
@media(min-width:1024px){.promo-hero .container-x{padding-block:4.5rem 5.5rem}}
.promo-grid{display:grid;gap:2rem;align-items:center}
@media(min-width:1024px){.promo-grid{grid-template-columns:1.1fr 1fr;gap:3rem}}
.promo-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.5rem 1rem;border-radius:9999px;
  background:rgba(201,161,74,.15);border:1px solid rgba(201,161,74,.4);
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ml-gold-lite);
  font-weight:500;
}
.promo-badge .pulse{width:6px;height:6px;border-radius:9999px;background:var(--ml-gold);
  animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}
.promo-hero h1{
  font-size:clamp(2.5rem,8vw,5.5rem);line-height:.95;margin-top:1.25rem;
}
.promo-hero h1 em{color:var(--ml-gold-lite);font-style:normal}
.promo-hero .strike{
  display:inline-flex;align-items:baseline;gap:1rem;margin-top:1.25rem;
  font-family:"Fraunces",serif;font-size:1.5rem;color:rgba(251,247,240,.85);
}
.promo-hero .strike .from{font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(251,247,240,.55);font-family:"Inter",sans-serif}
.promo-hero .strike .was-px{text-decoration:line-through;color:rgba(251,247,240,.4);font-size:1.125rem}
.promo-hero .strike .now-px{color:var(--ml-gold-lite);font-size:2rem}
.promo-cta{margin-top:1.75rem;display:flex;flex-wrap:wrap;gap:.75rem}
.promo-trust{
  display:flex;flex-wrap:wrap;gap:1.25rem 2rem;margin-top:2rem;font-size:.8rem;color:rgba(251,247,240,.7);
}
.promo-trust li{display:flex;align-items:center;gap:.5rem}
.promo-trust .star{color:var(--ml-gold);font-size:.7rem}

.promo-visual{position:relative;height:380px}
@media(min-width:768px){.promo-visual{height:480px}}
@media(min-width:1024px){.promo-visual{height:540px}}
.promo-visual .v-main{
  position:absolute;inset:0;border-radius:28px;overflow:hidden;
  box-shadow:0 30px 60px -30px rgba(15,10,18,.55);
  animation:iris-bloom .6s var(--ml-ease) both;
}
.promo-visual .v-main img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}
.promo-visual .v-tag{
  position:absolute;top:1.25rem;left:1.25rem;z-index:2;
  background:var(--ml-gold);color:var(--ml-ink);
  padding:.5rem 1rem;border-radius:9999px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  font-weight:600;
}
.promo-visual .v-thumb{
  position:absolute;width:128px;height:128px;border-radius:18px;overflow:hidden;
  background:var(--ml-ivory);
  box-shadow:0 20px 40px -20px rgba(15,10,18,.5);
  outline:3px solid var(--ml-ivory);
  animation:iris-bloom .6s var(--ml-ease) both;
}
.promo-visual .v-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}
.promo-visual .v-thumb.t1{right:-1rem;bottom:8rem;animation-delay:.15s}
.promo-visual .v-thumb.t2{right:7rem;bottom:-1rem;animation-delay:.25s}
@media(max-width:767px){
  .promo-visual .v-thumb.t1{width:96px;height:96px;right:-.5rem;bottom:5rem}
  .promo-visual .v-thumb.t2{width:96px;height:96px;right:5rem;bottom:-.5rem}
}

/* ---------- USP strip ---------- */
.usp-strip{background:#fff;border-block:1px solid rgba(15,10,18,.07)}
.usp-strip .container-x{padding-block:1.25rem}
.usp-grid{
  display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);
}
@media(min-width:768px){.usp-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem}}
.usp-grid li{
  display:flex;align-items:center;gap:.75rem;font-size:.85rem;color:var(--ml-ink);
}
.usp-grid svg{width:24px;height:24px;color:var(--ml-iris);flex-shrink:0}
.usp-grid strong{display:block;font-weight:500}
.usp-grid span{color:rgba(15,10,18,.55);font-size:.75rem}

/* ---------- Category tiles ---------- */
.cat-tiles{display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}
@media(min-width:768px){.cat-tiles{grid-template-columns:repeat(4,1fr);gap:1.25rem}}
.cat-tile{
  position:relative;display:block;text-align:center;
  transition:transform .3s var(--ml-ease);
}
.cat-tile:hover{transform:translateY(-4px)}
.cat-tile .disc{
  width:100%;aspect-ratio:1/1;border-radius:9999px;overflow:hidden;
  background:var(--ml-blush);
  box-shadow:0 30px 60px -40px rgba(15,10,18,.4);
  position:relative;
}
.cat-tile .disc::after{
  content:"";position:absolute;inset:0;border-radius:9999px;
  outline:1px solid rgba(201,161,74,.4);outline-offset:-8px;
  pointer-events:none;
}
.cat-tile img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .7s var(--ml-ease)}
.cat-tile:hover img{transform:scale(1.06)}
.cat-tile h3{
  font-family:"Fraunces",serif;font-size:1.5rem;margin-top:1rem;letter-spacing:-.02em;
}
.cat-tile p{font-size:.8rem;color:rgba(15,10,18,.6);margin-top:.25rem}
.cat-tile .count{
  display:inline-block;font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ml-gold);margin-top:.25rem;
}

/* ---------- Hue rail ---------- */
.hue-rail{
  display:flex;gap:1.5rem;overflow-x:auto;padding-block:1rem 1.25rem;
  scroll-snap-type:x mandatory;scrollbar-width:thin;
  padding-inline:.25rem;
}
.hue-rail::-webkit-scrollbar{height:6px}
.hue-rail::-webkit-scrollbar-thumb{background:rgba(15,10,18,.15);border-radius:9999px}
.hue-card{
  flex:0 0 130px;scroll-snap-align:start;text-align:center;
  transition:transform .3s var(--ml-ease);
}
@media(min-width:768px){.hue-card{flex-basis:148px}}
.hue-card:hover{transform:translateY(-4px)}

/* Realistic lens — sclera + iris with striations + limbal ring + pupil + highlight */
.hue-card .lens{
  position:relative;width:100%;aspect-ratio:1/1;border-radius:9999px;
  background:radial-gradient(circle at 50% 45%,
    #FBF7F0 0 100%);            /* sclera/ivory base */
  box-shadow:
    inset 0 -6px 14px rgba(15,10,18,.18),
    inset 0 6px 14px rgba(255,255,255,.6),
    0 22px 36px -22px rgba(15,10,18,.45);
  overflow:hidden;
  isolation:isolate;
}
/* the iris itself — ringed colour using conic + radial layers */
.hue-card .lens::before{
  content:"";position:absolute;left:50%;top:50%;
  width:78%;height:78%;transform:translate(-50%,-50%);
  border-radius:9999px;
  background:
    /* striations */
    repeating-conic-gradient(
      from 0deg at 50% 50%,
      var(--c-fleck,rgba(255,255,255,.15)) 0deg 3deg,
      transparent 3deg 9deg
    ),
    /* limbal dark ring + iris fill */
    radial-gradient(circle at 50% 50%,
      var(--c-pupil,#0F0A12) 0 15%,        /* pupil */
      #0F0A12 15% 17%,                       /* pupil edge */
      var(--c-inner,#888) 17% 36%,           /* inner iris */
      var(--c-mid,#666)   36% 64%,           /* mid iris */
      var(--c-outer,#222) 64% 88%,           /* outer iris */
      rgba(15,10,18,.85)  88% 96%,           /* limbal ring */
      transparent 96% 100%);
  box-shadow:0 0 0 1px rgba(15,10,18,.12);
}
/* the catchlight */
.hue-card .lens::after{
  content:"";position:absolute;left:32%;top:24%;
  width:18%;height:18%;border-radius:9999px;
  background:radial-gradient(circle at 35% 35%,rgba(255,255,255,.95),rgba(255,255,255,0) 70%);
  filter:blur(.5px);
  z-index:2;pointer-events:none;
}
.hue-card .name{
  margin-top:1rem;font-family:"Fraunces",serif;font-size:1.05rem;letter-spacing:-.02em;
}
.hue-card .qty{font-size:.7rem;color:rgba(15,10,18,.5);text-transform:uppercase;letter-spacing:.22em;margin-top:.15rem}

/* ---------- Retail product card ---------- */
.r-card{
  position:relative;display:block;background:#fff;border-radius:18px;overflow:hidden;
  border:1px solid rgba(15,10,18,.06);
  transition:transform .3s var(--ml-ease),box-shadow .3s var(--ml-ease),border-color .3s;
}
.r-card:hover{transform:translateY(-4px);box-shadow:0 30px 60px -30px rgba(15,10,18,.25);border-color:rgba(201,161,74,.3)}
.r-card .img-wrap{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--ml-blush)}
.r-card .img-wrap img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .6s var(--ml-ease)}
.r-card:hover .img-wrap img{transform:scale(1.05)}
.r-card .quick-add{
  position:absolute;left:1rem;right:1rem;bottom:1rem;z-index:2;
  background:var(--ml-ink);color:var(--ml-ivory);
  padding:.625rem 1rem;border-radius:9999px;
  font-size:.8rem;font-weight:500;
  display:flex;align-items:center;justify-content:center;gap:.5rem;
  opacity:0;transform:translateY(10px);
  transition:opacity .3s var(--ml-ease),transform .3s var(--ml-ease);
  min-height:40px;
}
.r-card:hover .quick-add{opacity:1;transform:translateY(0)}
@media(hover:none){.r-card .quick-add{opacity:1;transform:none;background:rgba(15,10,18,.85)}}
.r-card .badges{position:absolute;top:.75rem;left:.75rem;z-index:2;display:flex;flex-direction:column;gap:.35rem;align-items:flex-start}
.r-card .badge-px{
  background:var(--ml-ink);color:var(--ml-ivory);
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  padding:.25rem .5rem;border-radius:9999px;
}
.r-card .badge-px.gold{background:var(--ml-gold);color:var(--ml-ink)}
.r-card .badge-px.iris{background:var(--ml-iris);color:#fff}
.r-card .wishlist{
  position:absolute;top:.75rem;right:.75rem;z-index:2;
  width:36px;height:36px;border-radius:9999px;
  background:rgba(251,247,240,.9);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,color .2s;
}
.r-card .wishlist:hover{background:#fff;color:var(--ml-iris)}
.r-card .wishlist svg{width:16px;height:16px}
.r-card .body{padding:1rem 1rem 1.25rem}
.r-card .col{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ml-gold);font-weight:500}
.r-card h3{font-family:"Fraunces",serif;font-size:1.05rem;margin-top:.4rem;letter-spacing:-.02em;line-height:1.2}
.r-card .meta-row{display:flex;align-items:center;justify-content:space-between;margin-top:.6rem}
.r-card .stars{color:var(--ml-gold);font-size:.75rem;letter-spacing:.05em}
.r-card .review-n{font-size:.7rem;color:rgba(15,10,18,.5);margin-left:.25rem}
.r-card .price-r{font-size:.9rem;display:flex;gap:.5rem;align-items:baseline;margin-top:.6rem}
.r-card .price-r .now{font-weight:600;color:var(--ml-ink)}
.r-card .price-r .was{text-decoration:line-through;color:rgba(15,10,18,.4)}
.r-card .price-r .save-px{margin-left:auto;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ml-iris);font-weight:600}
.r-card .swatch-row{display:flex;gap:.4rem;margin-top:.75rem}
.r-card .swatch-row span{
  width:14px;height:14px;border-radius:9999px;outline:1px solid rgba(15,10,18,.1);outline-offset:1px;
}

/* ---------- Section header w/ link ---------- */
.sec-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;
  margin-bottom:1.5rem;
}
.sec-head h2{font-family:"Fraunces",serif;letter-spacing:-.03em;font-size:clamp(1.75rem,4vw,2.5rem);line-height:1}
.sec-head .sub{font-size:.85rem;color:rgba(15,10,18,.6);margin-top:.4rem}
.sec-head .more{font-size:.85rem;display:inline-flex;align-items:center;gap:.4rem;flex-shrink:0}
.sec-head .more:hover{color:var(--ml-iris)}

/* ---------- Carousel ---------- */
.h-scroll{
  display:grid;grid-auto-flow:column;grid-auto-columns:75%;gap:1rem;
  overflow-x:auto;scroll-snap-type:x mandatory;
  padding-bottom:1rem;
  scrollbar-width:thin;
}
@media(min-width:640px){.h-scroll{grid-auto-columns:42%}}
@media(min-width:1024px){.h-scroll{grid-auto-columns:25%}}
.h-scroll > *{scroll-snap-align:start}
.h-scroll::-webkit-scrollbar{height:6px}
.h-scroll::-webkit-scrollbar-thumb{background:rgba(15,10,18,.15);border-radius:9999px}

/* ---------- Split promo banner ---------- */
.split-promo{
  display:grid;gap:1rem;border-radius:24px;overflow:hidden;
}
@media(min-width:768px){.split-promo{grid-template-columns:1fr 1fr;gap:1.25rem}}
.split-card{
  position:relative;border-radius:24px;overflow:hidden;
  min-height:280px;display:flex;flex-direction:column;justify-content:flex-end;
  padding:2rem;color:var(--ml-ivory);isolation:isolate;
  transition:transform .3s var(--ml-ease);
}
.split-card:hover{transform:translateY(-4px)}
@media(min-width:768px){.split-card{min-height:380px;padding:2.5rem}}
.split-card img{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;z-index:0;
  transition:transform .7s var(--ml-ease)}
.split-card:hover img{transform:scale(1.04)}
.split-card::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,10,18,0) 30%,rgba(15,10,18,.85) 100%);z-index:1}
.split-card > *{position:relative;z-index:2}
.split-card .lbl{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ml-gold-lite);font-weight:500}
.split-card h3{font-family:"Fraunces",serif;font-size:clamp(1.5rem,3vw,2.25rem);margin-top:.5rem;line-height:1.05;color:var(--ml-ivory)}
.split-card p{margin-top:.5rem;color:rgba(251,247,240,.8);max-width:24rem;font-size:.9rem}
.split-card .cta{
  margin-top:1.25rem;display:inline-flex;align-items:center;gap:.5rem;
  padding:.625rem 1.25rem;border-radius:9999px;
  background:var(--ml-ivory);color:var(--ml-ink);font-size:.85rem;font-weight:500;
  align-self:flex-start;min-height:40px;
  transition:background .2s;
}
.split-card .cta:hover{background:var(--ml-gold-lite)}

/* ---------- Reviews snapshot ---------- */
.reviews-snapshot{
  display:grid;gap:2rem;
}
@media(min-width:1024px){.reviews-snapshot{grid-template-columns:1fr 2.5fr;align-items:start}}
.review-summary{
  background:var(--ml-blush);border-radius:24px;padding:2rem;text-align:center;
  border:1px solid rgba(201,161,74,.3);
}
.review-summary .big{font-family:"Fraunces",serif;font-size:4rem;line-height:1;color:var(--ml-ink)}
.review-summary .stars-big{color:var(--ml-gold);font-size:1.25rem;margin-top:.5rem;letter-spacing:.1em}
.review-summary .count{font-size:.8rem;color:rgba(15,10,18,.6);margin-top:.25rem}
.review-summary .bars{margin-top:1.5rem;display:flex;flex-direction:column;gap:.4rem;text-align:left}
.review-summary .bar-row{display:grid;grid-template-columns:auto 1fr auto;gap:.5rem;align-items:center;font-size:.75rem}
.review-summary .bar{height:6px;background:rgba(15,10,18,.08);border-radius:9999px;overflow:hidden}
.review-summary .bar i{display:block;height:100%;background:var(--ml-gold)}
.review-cards{display:grid;gap:1rem;grid-template-columns:1fr}
@media(min-width:768px){.review-cards{grid-template-columns:repeat(3,1fr)}}
.review-card{
  background:#fff;border:1px solid rgba(15,10,18,.07);
  border-radius:18px;padding:1.5rem;
}
.review-card .rstars{color:var(--ml-gold);letter-spacing:.05em;font-size:.8rem}
.review-card h4{font-family:"Fraunces",serif;font-size:1.05rem;margin-top:.5rem;letter-spacing:-.02em}
.review-card p{font-size:.85rem;color:rgba(15,10,18,.7);margin-top:.5rem;line-height:1.5}
.review-card footer{margin-top:1rem;display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:rgba(15,10,18,.5)}
.review-card .verified{color:var(--ml-iris);font-weight:500}

/* ---------- Instagram strip ---------- */
.ig-strip{
  display:grid;gap:.5rem;grid-template-columns:repeat(2,1fr);
}
@media(min-width:640px){.ig-strip{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.ig-strip{grid-template-columns:repeat(6,1fr)}}
.ig-strip a{
  position:relative;aspect-ratio:1/1;overflow:hidden;border-radius:14px;
}
.ig-strip img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .5s var(--ml-ease)}
.ig-strip a:hover img{transform:scale(1.06)}
.ig-strip a::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(15,10,18,.4) 100%);
  opacity:0;transition:opacity .3s}
.ig-strip a:hover::after{opacity:1}

/* ---------- Why us — icon row ---------- */
.why-row{
  display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr);
}
@media(min-width:768px){.why-row{grid-template-columns:repeat(4,1fr)}}
.why-row li{
  text-align:center;padding:1.5rem 1rem;
  background:var(--ml-blush);border-radius:18px;
  border:1px solid rgba(201,161,74,.25);
}
.why-row .ic{
  width:48px;height:48px;margin:0 auto 1rem;
  border-radius:9999px;background:var(--ml-ivory);
  display:flex;align-items:center;justify-content:center;
  color:var(--ml-iris);
  border:1px solid rgba(201,161,74,.3);
}
.why-row .ic svg{width:22px;height:22px}
.why-row h4{font-family:"Fraunces",serif;font-size:1rem;letter-spacing:-.02em}
.why-row p{font-size:.8rem;color:rgba(15,10,18,.65);margin-top:.4rem;line-height:1.45}

/* ---------- Power split CTA ---------- */
.power-split{
  display:grid;gap:1rem;
}
@media(min-width:768px){.power-split{grid-template-columns:1fr 1fr}}
.power-card{
  position:relative;border-radius:24px;overflow:hidden;padding:2rem;
  background:#fff;border:1px solid rgba(15,10,18,.08);
  display:flex;flex-direction:column;gap:.75rem;
  transition:border-color .3s,transform .3s var(--ml-ease);
}
.power-card:hover{border-color:var(--ml-iris);transform:translateY(-3px)}
.power-card.dark{background:var(--ml-ink);color:var(--ml-ivory);border-color:transparent}
.power-card.dark h3{color:var(--ml-ivory)}
.power-card.dark p{color:rgba(251,247,240,.7)}
.power-card .num{
  font-family:"Fraunces",serif;font-size:2rem;color:var(--ml-gold);
}
.power-card h3{font-family:"Fraunces",serif;font-size:1.5rem;letter-spacing:-.02em}
.power-card p{font-size:.9rem;color:rgba(15,10,18,.65)}
.power-card .arrow-link{
  margin-top:auto;display:inline-flex;align-items:center;gap:.5rem;
  font-size:.85rem;font-weight:500;color:var(--ml-iris);
}
.power-card.dark .arrow-link{color:var(--ml-gold-lite)}

/* ---------- FAQ ---------- */
.faq-list{
  border-top:1px solid rgba(15,10,18,.1);
}
.faq-list details{
  border-bottom:1px solid rgba(15,10,18,.1);padding:1.25rem 0;
}
.faq-list summary{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  cursor:pointer;list-style:none;font-family:"Fraunces",serif;font-size:1.1rem;letter-spacing:-.01em;
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary .pl{
  color:var(--ml-gold);transition:transform .25s var(--ml-ease);font-size:1.5rem;line-height:1;flex-shrink:0;
}
.faq-list details[open] summary .pl{transform:rotate(45deg)}
.faq-list details p{margin-top:.75rem;color:rgba(15,10,18,.7);font-size:.95rem;line-height:1.6;max-width:46rem}

/* ---------- Tighter section paddings for retail rhythm ---------- */
.s-pad{padding-block:3.5rem}
@media(min-width:1024px){.s-pad{padding-block:5rem}}

/* =========================================================
   v2 — Real logo, drawers, try-on, dimension, sticky buy
   ========================================================= */

html.lock-scroll,html.lock-scroll body{overflow:hidden}

/* Real logo */
.brand-img{display:flex;align-items:center;gap:.5rem;line-height:1}
.brand-img img{height:42px;width:auto;display:block}
@media(min-width:768px){.brand-img img{height:48px}}

/* ---------- Drawers (mobile menu + cart) ---------- */
.drawer{position:fixed;inset:0;z-index:80;pointer-events:none}
.drawer__scrim{
  position:absolute;inset:0;background:rgba(15,10,18,.55);
  opacity:0;transition:opacity .28s var(--ml-ease);
  backdrop-filter:blur(2px);
}
.drawer__panel{
  position:absolute;top:0;bottom:0;width:min(420px,90vw);
  background:var(--ml-ivory);color:var(--ml-ink);
  display:flex;flex-direction:column;
  box-shadow:0 30px 80px -20px rgba(15,10,18,.5);
  transition:transform .3s var(--ml-ease);
  pointer-events:auto;
}
.drawer.left .drawer__panel{left:0;transform:translateX(-100%)}
.drawer.right .drawer__panel{right:0;transform:translateX(100%)}
.drawer.is-open{pointer-events:auto}
.drawer.is-open .drawer__scrim{opacity:1}
.drawer.is-open .drawer__panel{transform:translateX(0)}

.drawer__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.25rem 1.5rem;border-bottom:1px solid rgba(15,10,18,.08);
}
.drawer__head h2{font-family:"Fraunces",serif;font-size:1.25rem;letter-spacing:-.02em}
.drawer__close{
  width:40px;height:40px;border-radius:9999px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(15,10,18,.15);
}
.drawer__close:hover{background:var(--ml-ink);color:var(--ml-ivory);border-color:var(--ml-ink)}
.drawer__body{flex:1;overflow-y:auto;padding:1.5rem}
.drawer__foot{padding:1.25rem 1.5rem;border-top:1px solid rgba(15,10,18,.08);background:rgba(245,230,216,.4)}

/* Mobile menu */
.menu-list{display:flex;flex-direction:column;gap:.25rem}
.menu-list a{
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem .25rem;font-family:"Fraunces",serif;font-size:1.5rem;letter-spacing:-.02em;
  border-bottom:1px solid rgba(15,10,18,.06);
}
.menu-list a:hover{color:var(--ml-iris)}
.menu-list a span{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ml-gold);font-family:"Inter",sans-serif}
.menu-meta{margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(15,10,18,.08);display:flex;flex-direction:column;gap:.75rem;font-size:.875rem}
.menu-meta a{display:inline-flex;align-items:center;gap:.5rem;min-height:44px}

/* Cart line items */
.cart-empty{text-align:center;padding:3rem 1rem}
.cart-empty p{color:rgba(15,10,18,.6);margin-top:.5rem}
.cart-line{
  display:grid;grid-template-columns:72px 1fr auto;gap:1rem;align-items:center;
  padding:1rem 0;border-bottom:1px solid rgba(15,10,18,.07);
}
.cart-line img{width:72px;height:72px;border-radius:12px;-o-object-fit:cover;object-fit:cover;background:var(--ml-blush)}
.cart-line .info p{margin:0}
.cart-line .info .nm{font-family:"Fraunces",serif;font-size:1rem;letter-spacing:-.02em}
.cart-line .info .opt{font-size:.75rem;color:rgba(15,10,18,.55);margin-top:.15rem}
.cart-line .info .px{font-size:.875rem;font-weight:500;margin-top:.25rem}
.cart-line .qty-mini{
  display:inline-flex;align-items:center;border:1px solid rgba(15,10,18,.15);
  border-radius:9999px;padding:.15rem;
}
.cart-line .qty-mini button{width:28px;height:28px;font-size:.875rem}
.cart-line .qty-mini span{padding:0 .5rem;font-weight:500;font-size:.875rem}
.cart-totals{display:flex;flex-direction:column;gap:.5rem;font-size:.875rem;margin-bottom:1rem}
.cart-totals .row{display:flex;justify-content:space-between}
.cart-totals .total{font-family:"Fraunces",serif;font-size:1.25rem;border-top:1px solid rgba(15,10,18,.08);padding-top:.5rem;margin-top:.25rem}
.cart-foot-actions{display:grid;gap:.5rem}

/* ---------- Wishlist active state ---------- */
.wishlist[aria-pressed="true"]{background:#fff;color:var(--ml-iris)}
.wishlist[aria-pressed="true"] svg{fill:currentColor}

/* ---------- Try-on (PDP) ---------- */
.tryon{
  border-radius:24px;overflow:hidden;border:1px solid rgba(201,161,74,.3);
  background:var(--ml-blush);
}
.tryon__head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;padding:1.25rem 1.5rem 0}
.tryon__head h3{font-family:"Fraunces",serif;font-size:1.25rem;letter-spacing:-.02em}
.tryon__tabs{display:flex;flex-wrap:wrap;gap:.5rem;padding:1rem 1.5rem}
.tryon__tabs button{
  padding:.5rem 1rem;border-radius:9999px;border:1px solid rgba(15,10,18,.15);
  font-size:.85rem;font-weight:500;background:#fff;min-height:40px;
  display:inline-flex;align-items:center;gap:.5rem;
  transition:all .2s var(--ml-ease);
}
.tryon__tabs button[aria-pressed="true"]{background:var(--ml-ink);color:var(--ml-ivory);border-color:var(--ml-ink)}
.tryon__tabs .iris-swatch{width:18px;height:18px}
.tryon__stage{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--ml-ink)}
.tryon__stage img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:opacity .3s var(--ml-ease)}
.tryon__caption{padding:1rem 1.5rem;font-size:.85rem;color:rgba(15,10,18,.7)}
.tryon__caption strong{color:var(--ml-ink)}

/* ---------- Lens dimension diagram (PDP) ---------- */
.dim-explain{
  display:grid;gap:1.5rem;border:1px solid rgba(15,10,18,.08);
  border-radius:24px;padding:1.5rem;background:#fff;
}
@media(min-width:768px){.dim-explain{grid-template-columns:1fr 1fr;gap:2rem;padding:2rem}}
.dim-svg{aspect-ratio:1/1;max-width:280px;margin:0 auto;width:100%;display:block}
.dim-list{display:flex;flex-direction:column;gap:1rem}
.dim-list dt{font-family:"Fraunces",serif;font-size:1.05rem;letter-spacing:-.02em;display:flex;align-items:center;gap:.5rem;margin:0}
.dim-list dt .ic{
  width:24px;height:24px;border-radius:9999px;background:var(--ml-blush);
  display:inline-flex;align-items:center;justify-content:center;color:var(--ml-iris);font-size:.7rem;font-weight:600;
  border:1px solid rgba(201,161,74,.4);font-family:"Inter",sans-serif;
}
.dim-list dd{margin:.25rem 0 0 32px;font-size:.875rem;color:rgba(15,10,18,.7);line-height:1.5}

/* ---------- Sticky buy bar (desktop) ---------- */
.sticky-buy{
  position:fixed;left:0;right:0;bottom:0;z-index:50;
  background:rgba(251,247,240,.96);backdrop-filter:blur(12px);
  border-top:1px solid rgba(201,161,74,.35);
  transform:translateY(110%);transition:transform .35s var(--ml-ease);
  display:none;
}
@media(min-width:1024px){.sticky-buy{display:block}}
.sticky-buy.is-visible{transform:translateY(0)}
.sticky-buy__inner{
  max-width:1400px;margin-inline:auto;padding:1rem 2.5rem;
  display:flex;align-items:center;gap:1.5rem;
}
.sticky-buy img{width:56px;height:56px;border-radius:12px;-o-object-fit:cover;object-fit:cover}
.sticky-buy .sb-info p:first-child{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ml-gold)}
.sticky-buy .sb-info p:nth-child(2){font-family:"Fraunces",serif;font-size:1.15rem;letter-spacing:-.02em;line-height:1.1}
.sticky-buy .sb-price{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;font-size:.875rem}
.sticky-buy .sb-price .now{font-family:"Fraunces",serif;font-size:1.25rem}
.sticky-buy .sb-price .was{text-decoration:line-through;color:rgba(15,10,18,.4);font-size:.8rem}
.sticky-buy .sb-actions{display:flex;gap:.5rem}

/* ---------- "Worn on" PDP eye preview overlay swatches ---------- */
.eye-preview{
  display:flex;align-items:center;gap:.75rem;font-size:.8rem;color:rgba(15,10,18,.65);
  margin-top:1rem;
}
.eye-preview .dot{
  width:18px;height:18px;border-radius:9999px;outline:1px solid rgba(15,10,18,.1);outline-offset:1px;
}

/* =========================================================
   CRO v3 — Quick wins
   ========================================================= */

/* W2: above-fold rating ribbon */
.rating-ribbon{
  display:inline-flex;align-items:center;flex-wrap:wrap;gap:.5rem .75rem;
  margin-top:.75rem;padding:.5rem .85rem;border-radius:9999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(251,247,240,.2);
  font-size:.8rem;color:rgba(251,247,240,.9);
}
.rating-ribbon .stars{color:var(--ml-gold);letter-spacing:.05em}
.rating-ribbon b{font-weight:600;color:var(--ml-gold-lite)}
.rating-ribbon .sep{color:rgba(251,247,240,.35)}
@media(max-width:640px){
  .rating-ribbon{font-size:.7rem;padding:.4rem .65rem;gap:.35rem .5rem}
}

/* W3: WhatsApp inline link under CTAs */
.whatsapp-inline{
  display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;
  font-size:.85rem;color:rgba(251,247,240,.75);
  text-decoration:underline;text-decoration-color:rgba(251,247,240,.3);
  text-underline-offset:3px;
}
.whatsapp-inline:hover{color:var(--ml-gold-lite);text-decoration-color:var(--ml-gold)}
.whatsapp-inline svg{width:16px;height:16px;color:#25D366;flex-shrink:0}

/* W4: free-delivery progress line */
.delivery-progress{
  margin-top:1rem;padding:.75rem 1rem;border-radius:14px;
  background:rgba(201,161,74,.1);border:1px dashed rgba(201,161,74,.4);
  font-size:.8rem;color:rgba(251,247,240,.85);
  display:flex;align-items:center;gap:.6rem;max-width:30rem;
}
.delivery-progress .ic{color:var(--ml-gold-lite);flex-shrink:0}
.delivery-progress strong{color:var(--ml-gold-lite)}

/* W5: replace decorative price bubble with working trust sticker */
.trust-sticker{
  position:absolute;right:1.5rem;bottom:2.5rem;
  width:8.5rem;padding:.85rem;border-radius:18px;
  background:var(--ml-ivory);color:var(--ml-ink);
  display:flex;flex-direction:column;gap:.25rem;
  font-size:.7rem;
  transform:rotate(4deg);
  box-shadow:0 24px 48px -20px rgba(15,10,18,.55);
  border:1px solid rgba(201,161,74,.3);
  z-index:3;
}
.trust-sticker .head{
  display:flex;align-items:baseline;justify-content:space-between;gap:.4rem;
}
.trust-sticker .px{font-family:"Fraunces",serif;font-size:1.5rem;line-height:1;letter-spacing:-.02em}
.trust-sticker .off{
  background:var(--ml-iris);color:#fff;border-radius:9999px;
  padding:.15rem .5rem;font-size:9px;font-weight:600;letter-spacing:.1em;
}
.trust-sticker ul{display:flex;flex-direction:column;gap:.2rem;margin-top:.25rem}
.trust-sticker li{display:flex;align-items:center;gap:.35rem;color:rgba(15,10,18,.7);font-size:11px}
.trust-sticker li svg{width:11px;height:11px;color:var(--ml-iris);flex-shrink:0}
@media(max-width:640px){.trust-sticker{right:.5rem;bottom:1.5rem;width:7.5rem}}

/* W6: "as worn by" influencer strip */
.influencers{
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;justify-content:center;
  padding-block:1.25rem;
  border-bottom:1px solid rgba(15,10,18,.06);
  background:#fff;
}
.influencers .lbl{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(15,10,18,.55);
  display:inline-flex;align-items:center;gap:.5rem;
}
.influencers .lbl::after{content:"";width:24px;height:1px;background:rgba(15,10,18,.2)}
.influencers .row{display:flex;align-items:center;gap:.85rem;flex-wrap:wrap;justify-content:center}
.influencers a{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.85rem;color:var(--ml-ink);
  padding:.4rem .85rem;border-radius:9999px;
  border:1px solid rgba(15,10,18,.08);background:var(--ml-ivory);
  transition:transform .2s var(--ml-ease),border-color .2s;
}
.influencers a:hover{transform:translateY(-2px);border-color:var(--ml-iris);color:var(--ml-iris)}
.influencers .av{
  width:28px;height:28px;border-radius:9999px;overflow:hidden;flex-shrink:0;
  background:var(--ml-blush);
}
.influencers .av img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}
.influencers .handle{font-weight:500;letter-spacing:-.01em}
.influencers .bio{color:rgba(15,10,18,.55);font-size:11px}

/* =========================================================
   CRO v4 — High-impact homepage additions
   ========================================================= */

/* H2: hero "worn on eye" composite */
.eye-composite{
  position:relative;width:100%;aspect-ratio:1/1;border-radius:28px;overflow:hidden;
  background:radial-gradient(circle at 50% 45%,#FBF7F0 0 100%);
  box-shadow:
    inset 0 -10px 28px rgba(15,10,18,.22),
    inset 0 8px 20px rgba(255,255,255,.55),
    0 30px 60px -30px rgba(15,10,18,.55);
  isolation:isolate;
  animation:iris-bloom .6s var(--ml-ease) both;
}
.eye-composite::before{
  /* skin/eyelid soft frame top + bottom */
  content:"";position:absolute;left:0;right:0;
  top:-22%;height:55%;
  background:radial-gradient(ellipse at 50% 100%,rgba(186,138,108,.55),rgba(186,138,108,0) 60%);
  z-index:1;pointer-events:none;
}
.eye-composite::after{
  content:"";position:absolute;left:0;right:0;
  bottom:-22%;height:55%;
  background:radial-gradient(ellipse at 50% 0%,rgba(186,138,108,.45),rgba(186,138,108,0) 60%);
  z-index:1;pointer-events:none;
}
.eye-composite .iris{
  position:absolute;left:50%;top:50%;
  width:62%;height:62%;transform:translate(-50%,-50%);
  border-radius:9999px;
  background:
    repeating-conic-gradient(from 0deg at 50% 50%,
      rgba(220,235,255,.32) 0deg 2.5deg,
      transparent 2.5deg 8deg),
    radial-gradient(circle at 50% 50%,
      #0A1828 0 14%,
      #0F0A12 14% 16%,
      #9CC3E8 16% 32%,
      #4677B0 32% 56%,
      #16335A 56% 86%,
      rgba(15,10,18,.92) 86% 95%,
      transparent 95% 100%);
  box-shadow:0 0 0 1px rgba(15,10,18,.18);
  z-index:2;
}
.eye-composite .glint{
  position:absolute;left:34%;top:30%;width:14%;height:14%;border-radius:9999px;
  background:radial-gradient(circle at 35% 35%,rgba(255,255,255,.95),rgba(255,255,255,0) 70%);
  filter:blur(.4px);z-index:3;
}
.eye-composite .lashes{position:absolute;inset:0;z-index:4;pointer-events:none;opacity:.85}
.eye-composite .swatch-pop{
  position:absolute;left:1rem;top:1rem;z-index:5;
  background:rgba(15,10,18,.7);color:var(--ml-ivory);
  padding:.4rem .8rem;border-radius:9999px;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  backdrop-filter:blur(6px);
  display:inline-flex;align-items:center;gap:.5rem;
}
.eye-composite .swatch-pop .iris-swatch{width:14px;height:14px}

/* H1: "Match my eye colour" band */
.match-band{
  background:linear-gradient(180deg,rgba(245,230,216,.55),rgba(245,230,216,.2));
  border-block:1px solid rgba(201,161,74,.25);
}
.match-band .container-x{padding-block:2.25rem 2rem}
.match-band .head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;
  margin-bottom:1rem;flex-wrap:wrap;
}
.match-band h2{font-family:"Fraunces",serif;font-size:clamp(1.5rem,3vw,2rem);letter-spacing:-.02em}
.match-band .help{font-size:.8rem;color:rgba(15,10,18,.6)}
.match-options{
  display:flex;flex-wrap:wrap;gap:.6rem;
}
.match-options button{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.55rem 1rem .55rem .6rem;border-radius:9999px;
  background:#fff;border:1px solid rgba(15,10,18,.1);
  font-size:.85rem;font-weight:500;min-height:42px;
  transition:all .2s var(--ml-ease);
}
.match-options button:hover{border-color:var(--ml-ink);transform:translateY(-2px)}
.match-options button[aria-pressed="true"]{
  background:var(--ml-ink);color:var(--ml-ivory);border-color:var(--ml-ink);
}
.match-options .dot{
  width:22px;height:22px;border-radius:9999px;flex-shrink:0;
  outline:1px solid rgba(15,10,18,.1);outline-offset:1px;
}
.match-result{
  margin-top:1rem;font-size:.875rem;color:rgba(15,10,18,.7);
}
.match-result strong{color:var(--ml-ink)}

/* Visual fade on filtered cards */
.r-card.dim{opacity:.32;filter:saturate(.4);transition:opacity .35s var(--ml-ease),filter .35s var(--ml-ease)}
.r-card.match-glow{
  outline:2px solid var(--ml-iris);outline-offset:-2px;
  transition:outline-color .25s var(--ml-ease);
}

/* H5: Guarantee strip */
.guarantee{
  background:#fff;border-block:1px solid rgba(15,10,18,.07);
}
.guarantee .container-x{
  padding-block:1.5rem;
  display:grid;gap:1rem;align-items:center;
  grid-template-columns:auto 1fr auto;
}
@media(max-width:640px){
  .guarantee .container-x{grid-template-columns:1fr;text-align:center;gap:.75rem}
}
.guarantee .seal{
  width:56px;height:56px;border-radius:9999px;
  background:linear-gradient(140deg,var(--ml-gold),var(--ml-gold-lite));
  color:var(--ml-ink);
  display:flex;align-items:center;justify-content:center;
  font-family:"Fraunces",serif;font-size:1.25rem;
  box-shadow:0 14px 24px -10px rgba(201,161,74,.55);
  flex-shrink:0;
  position:relative;
}
.guarantee .seal::after{
  content:"";position:absolute;inset:-6px;border-radius:9999px;
  border:1px dashed rgba(201,161,74,.55);
}
@media(max-width:640px){.guarantee .seal{margin:0 auto}}
.guarantee .copy h3{font-family:"Fraunces",serif;font-size:1.15rem;letter-spacing:-.02em;line-height:1.2}
.guarantee .copy p{font-size:.85rem;color:rgba(15,10,18,.65);margin-top:.25rem;line-height:1.5}
.guarantee .copy strong{color:var(--ml-ink)}
.guarantee .more{
  font-size:.8rem;color:var(--ml-iris);font-weight:500;white-space:nowrap;
}

/* H3: First-time wearer 60-sec band */
.firsttime{
  background:rgba(245,230,216,.45);border-block:1px solid rgba(201,161,74,.2);
}
.firsttime .container-x{padding-block:3rem}
.firsttime .head{margin-bottom:1.75rem}
.firsttime h2{font-family:"Fraunces",serif;font-size:clamp(1.75rem,3.5vw,2.25rem);letter-spacing:-.02em;line-height:1.05}
.firsttime .sub{font-size:.875rem;color:rgba(15,10,18,.65);margin-top:.5rem}
.ft-grid{
  display:grid;gap:1rem;grid-template-columns:1fr;
}
@media(min-width:768px){.ft-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem}}
.ft-card{
  background:#fff;border:1px solid rgba(15,10,18,.06);border-radius:18px;
  padding:1.5rem;display:flex;flex-direction:column;gap:.5rem;
  transition:transform .25s var(--ml-ease),border-color .25s;
}
.ft-card:hover{transform:translateY(-3px);border-color:rgba(201,161,74,.4)}
.ft-card .q{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:"Fraunces",serif;font-size:1.1rem;letter-spacing:-.02em;
}
.ft-card .q::before{
  content:"?";display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:9999px;
  background:var(--ml-iris);color:var(--ml-ivory);
  font-family:"Fraunces",serif;font-weight:600;font-size:.95rem;
  flex-shrink:0;
}
.ft-card .a{font-size:.9rem;color:rgba(15,10,18,.7);line-height:1.55}
.ft-card .a strong{color:var(--ml-ink)}
.ft-card .lnk{
  margin-top:auto;font-size:.8rem;font-weight:500;color:var(--ml-iris);
  display:inline-flex;align-items:center;gap:.4rem;
}
.ft-card .lnk:hover{color:var(--ml-ink)}

/* H7: Avatar bubble for reviews */
.review-card .who{
  display:flex;align-items:center;gap:.6rem;margin-top:1rem;
}
.review-card .av{
  width:36px;height:36px;border-radius:9999px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:"Fraunces",serif;font-weight:600;font-size:.85rem;
  color:var(--ml-ivory);letter-spacing:.02em;
  outline:2px solid var(--ml-ivory);
}
.review-card .who .name{font-size:.85rem;color:var(--ml-ink);font-weight:500;line-height:1.1}
.review-card .who .city{font-size:.7rem;color:rgba(15,10,18,.55);margin-top:.15rem;letter-spacing:.05em}
.review-card .who .verified{font-size:.7rem;color:var(--ml-iris);font-weight:500;margin-left:auto}

/* =========================================================
   v5 — Filters empty state, Checkout, Wishlist filled
   ========================================================= */

/* Wishlist filled state — heart fills when toggled */
.wishlist[aria-pressed="true"] svg path{fill:var(--ml-iris);stroke:var(--ml-iris)}
.wishlist[aria-pressed="true"]{color:var(--ml-iris)}

/* Empty filter state on shop */
.empty-state{
  text-align:center;padding:4rem 1rem;
  border:1px dashed rgba(15,10,18,.15);border-radius:24px;
  background:#fff;
}
.empty-state p.eyebrow{color:var(--ml-iris)}
.empty-state h3{font-family:"Fraunces",serif;font-size:1.75rem;letter-spacing:-.02em;margin-top:.5rem}
.empty-state p.lead{color:rgba(15,10,18,.6);margin-top:.75rem;max-width:24rem;margin-inline:auto}
.empty-state .btn{margin-top:1.5rem}

/* Active sidebar swatch ring */
.filters .swatches .iris-swatch{transition:transform .15s,outline .15s}
.filters .swatches .iris-swatch:focus-visible{outline:2px solid var(--ml-ink);outline-offset:2px}

/* =========================================================
   Checkout page
   ========================================================= */
.checkout-head{
  background:radial-gradient(120% 80% at 30% 10%,#3D1E45,#2A1530 45%,#160B1B);
  color:var(--ml-ivory);
}
.checkout-head .container-x{padding-block:3rem}
.checkout-head h1{font-family:"Fraunces",serif;font-size:clamp(2rem,5vw,3rem);letter-spacing:-.03em;margin-top:.5rem;line-height:1}
.checkout-head .crumbs{color:rgba(251,247,240,.6);font-size:12px;margin-bottom:1rem}
.checkout-head .crumbs a:hover{color:var(--ml-gold)}

.checkout-grid{
  max-width:1400px;margin-inline:auto;
  padding:3rem 1.5rem;display:grid;gap:2.5rem;
}
@media(min-width:1024px){.checkout-grid{padding-inline:2.5rem;grid-template-columns:1.4fr 1fr;gap:4rem}}

.checkout-form{display:flex;flex-direction:column;gap:2.5rem}
.checkout-block{
  background:#fff;border:1px solid rgba(15,10,18,.06);border-radius:24px;padding:1.75rem;
}
.checkout-block h2{
  display:flex;align-items:center;gap:.6rem;
  font-family:"Fraunces",serif;font-size:1.25rem;letter-spacing:-.02em;margin-bottom:1.25rem;
}
.checkout-block h2 .num{
  width:28px;height:28px;border-radius:9999px;background:var(--ml-ink);color:var(--ml-ivory);
  font-family:"Inter",sans-serif;font-size:.8rem;font-weight:600;
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
}
.checkout-row{display:grid;gap:1rem;grid-template-columns:1fr}
@media(min-width:640px){.checkout-row.cols-2{grid-template-columns:1fr 1fr}.checkout-row.cols-3{grid-template-columns:2fr 1fr 1fr}}

.pay-options{display:flex;flex-direction:column;gap:.75rem}
.pay-option{
  display:flex;align-items:flex-start;gap:.75rem;
  padding:1rem;border:1px solid rgba(15,10,18,.1);border-radius:14px;
  cursor:pointer;transition:border-color .2s,background .2s;
}
.pay-option:hover{border-color:var(--ml-ink)}
.pay-option input{margin-top:.2rem;accent-color:var(--ml-ink)}
.pay-option:has(input:checked){border-color:var(--ml-iris);background:rgba(124,91,196,.05)}
.pay-option .pay-name{font-weight:500;display:flex;align-items:center;gap:.5rem}
.pay-option .pay-meta{font-size:.8rem;color:rgba(15,10,18,.6);margin-top:.25rem}
.pay-option .pay-tag{
  background:var(--ml-iris);color:#fff;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  padding:.15rem .5rem;border-radius:9999px;font-weight:600;
}

.checkout-summary{align-self:start;position:sticky;top:96px}
.summary-card{
  background:var(--ml-blush);border:1px solid rgba(201,161,74,.3);border-radius:24px;
  padding:1.75rem;
}
.summary-card h2{
  font-family:"Fraunces",serif;font-size:1.25rem;letter-spacing:-.02em;
  display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;
}
.summary-card h2 .edit{font-size:.75rem;color:var(--ml-iris);font-weight:500;font-family:"Inter",sans-serif}
.summary-card .lines{display:flex;flex-direction:column;gap:0;margin-bottom:1rem}
.summary-card .cart-line{padding:.75rem 0;border-color:rgba(201,161,74,.2)}
.summary-card .cart-line:last-child{border-bottom:0}
.summary-totals{display:flex;flex-direction:column;gap:.5rem;font-size:.875rem;border-top:1px solid rgba(15,10,18,.08);padding-top:1rem}
.summary-totals .row{display:flex;justify-content:space-between}
.summary-totals .row.total{font-family:"Fraunces",serif;font-size:1.5rem;border-top:1px solid rgba(15,10,18,.08);padding-top:.75rem;margin-top:.25rem}
.summary-actions{margin-top:1.5rem;display:grid;gap:.5rem}
.summary-promo{
  margin-top:1rem;padding:.75rem;border-radius:12px;border:1px dashed rgba(201,161,74,.4);
  background:rgba(255,255,255,.5);font-size:.8rem;color:rgba(15,10,18,.7);text-align:center;
}

/* =========================================================
   v6 — MOBILE PASS  (80% of traffic — first-class)
   ========================================================= */

/* ---- Global safety ---- */
html,body{overflow-x:hidden}
*{min-width:0}                       /* prevents flex children from blowing layout */
img,video,svg{max-width:100%;height:auto}

/* The viewport pile (announce + sticky header + sticky toolbar) is too tall
   on phones. Slim everything under 640px. */
@media (max-width: 640px) {
  .announce .marquee{padding:.35rem 0}
  .announce .marquee-track{font-size:10px;letter-spacing:.18em;gap:1.5rem}
  .site-header-inner{height:64px;padding-inline:1rem}
  .brand-img img{height:34px}
  .actions{gap:.5rem}
  .actions svg{width:20px;height:20px}      /* slightly bigger tap target */
  .actions a span,.actions button span{display:none}  /* icon-only on mobile */
  .actions .cart .badge{top:-4px;right:-4px}
  .toolbar{top:64px}                         /* match slim header */
  .toolbar-inner{height:52px;padding-inline:1rem;gap:.75rem}
  .toolbar .btn-ghost{padding:.45rem .8rem !important;font-size:.8rem}
  /* anything sticky deeper down updates accordingly */
  .filters{position:static !important}       /* sidebar should never be sticky on mobile */
  .gallery{position:static !important}       /* full-bleed gallery flows naturally */
  .checkout-summary{position:static !important}
}

/* Modern viewport units fix mobile chrome address-bar jumps for any 100vh */
.drawer__panel{min-height:100dvh}

/* ---- Hero ---- */
@media (max-width: 768px) {
  .promo-hero .container-x{padding-block:2rem 3rem}
  .promo-hero h1{font-size:clamp(2.25rem,10vw,3.5rem);margin-top:1rem}
  .promo-hero p.lede,.promo-hero .strike{font-size:.95rem}
  .promo-hero .strike .now-px{font-size:1.5rem}
  .rating-ribbon{flex-wrap:wrap}
  .promo-cta{flex-direction:column;align-items:stretch;gap:.6rem}
  .promo-cta .btn{width:100%}                /* full-width primary on mobile */
  .promo-cta .btn-on-dark{background:transparent;border:1px solid rgba(251,247,240,.4)}
  .delivery-progress{margin-top:.75rem;padding:.6rem .75rem;font-size:.78rem}
  .promo-trust{font-size:.75rem;gap:.6rem 1rem;margin-top:1.5rem}
  /* Hero composite — smaller, no overlap with sticker */
  .promo-visual{height:auto;margin-top:1.5rem}
  .eye-composite{aspect-ratio:5/4;border-radius:20px}
  .trust-sticker{
    position:static;width:auto;transform:none;margin:1rem auto 0;
    flex-direction:row;align-items:center;gap:1rem;justify-content:space-between;
    max-width:24rem;
  }
  .trust-sticker ul{flex-direction:row;gap:.6rem;flex-wrap:wrap;margin-top:0;flex:1;justify-content:flex-end}
  .trust-sticker li{font-size:10px}
  .trust-sticker .head{flex-shrink:0}
}

/* ---- Influencer strip becomes a swipe rail on mobile ---- */
@media (max-width: 640px) {
  .influencers{flex-direction:column;align-items:stretch;gap:.5rem;padding:1rem 1rem .75rem}
  .influencers .lbl{justify-content:center;font-size:10px}
  .influencers .lbl::after{display:none}
  .influencers .row{
    flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;
    scroll-snap-type:x mandatory;padding:.25rem .25rem .5rem;
    scrollbar-width:none;
  }
  .influencers .row::-webkit-scrollbar{display:none}
  .influencers a{flex-shrink:0;scroll-snap-align:start}
}

/* ---- USP strip stacks 2-up properly + denser ---- */
@media (max-width: 640px) {
  .usp-strip .container-x{padding-block:1rem}
  .usp-grid{gap:.75rem}
  .usp-grid li{font-size:.78rem;gap:.5rem}
  .usp-grid svg{width:20px;height:20px}
  .usp-grid span{display:none}              /* drop the secondary line on mobile */
}

/* ---- Section headers tighter on mobile ---- */
@media (max-width: 768px) {
  .s-pad{padding-block:2.75rem}
  .sec-head{flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:1.5rem}
  .sec-head .more{font-size:.8rem}
  .h-display,.section-head .h-display{font-size:clamp(1.75rem,7vw,2.5rem) !important}
}

/* ---- Hue rail: bigger swatches that fit two-up ---- */
@media (max-width: 640px) {
  .hue-rail{gap:1rem;padding-inline:0}
  .hue-card{flex-basis:108px}
  .hue-card .lens{width:108px;height:108px;margin:0 auto}
  .hue-card .name{margin-top:.6rem;font-size:.95rem}
}

/* ---- Match band fits one-handed ---- */
@media (max-width: 640px) {
  .match-band .container-x{padding-block:1.5rem}
  .match-options{gap:.4rem}
  .match-options button{padding:.45rem .75rem .45rem .5rem;font-size:.78rem;min-height:40px}
  .match-options .dot{width:18px;height:18px}
}

/* ---- Retail product cards: hover-only stuff visible on touch ---- */
@media (hover: none), (max-width: 768px) {
  .r-card .quick-add{opacity:1;transform:none;background:rgba(15,10,18,.85)}
  .r-card .wishlist{background:#fff}
  .iris-card .iris-img{transform:none !important}
  .iris-card:hover{transform:none !important;box-shadow:0 16px 32px -22px rgba(15,10,18,.25)}
}
@media (max-width: 640px) {
  .grid-cards{gap:.85rem}
  .r-card .body{padding:.85rem}
  .r-card h3{font-size:1rem}
  .r-card .quick-add{font-size:.75rem;padding:.5rem .75rem;left:.6rem;right:.6rem;bottom:.6rem}
  .r-card .badges .badge-px{font-size:9px;padding:.2rem .4rem}
  .r-card .wishlist{width:34px;height:34px}
}

/* ---- Power split stacks + slimmer ---- */
@media (max-width: 768px) {
  .power-card{padding:1.5rem}
  .power-card h3{font-size:1.25rem}
}

/* ---- Reviews snapshot + first-time stack better ---- */
@media (max-width: 768px) {
  .review-summary{padding:1.5rem}
  .review-summary .big{font-size:3rem}
  .ft-grid{gap:.75rem}
  .ft-card{padding:1.25rem}
  .ft-card .q{font-size:1rem}
  .ft-card .a{font-size:.85rem}
}

/* ---- Footer ---- */
@media (max-width: 640px) {
  .site-footer{margin-top:3rem}
  .site-footer .container-x{padding-block:3rem}
  .footer-newsletter{flex-direction:column;gap:.75rem;max-width:100%}
  .footer-newsletter input{border-bottom:1px solid rgba(251,247,240,.3);padding:.75rem 0}
  .footer-newsletter .btn-gold{border-radius:9999px;padding:.75rem 1.5rem;align-self:flex-start}
  .footer-iris{width:380px;right:-120px;bottom:-120px}
  .footer-bottom{font-size:11px;text-align:center}
  .footer-bottom .nasta{font-size:.85rem}
}

/* =========================================================
   PDP — mobile-specific overhaul
   ========================================================= */

/* The vertical thumbs hide under 768. Replace with a horizontal scroll rail
   under the main image on mobile so users can actually browse all photos. */
@media (max-width: 767px) {
  .pdp{padding-block:1.25rem;gap:1.5rem}
  .gallery{gap:.5rem}
  .gallery-main{grid-column:span 12 !important}
  .gallery-main figure{aspect-ratio:1/1;border-radius:18px}
  .pdp-title{font-size:clamp(1.75rem,7vw,2.5rem)}
  .price-row .now{font-size:1.5rem}
  .price-row .save{font-size:10px}
  /* Build a horizontal rail from .thumbs */
  .thumbs{
    display:flex !important;flex-direction:row !important;
    grid-column:span 12;gap:.5rem;
    overflow-x:auto;scroll-snap-type:x mandatory;
    padding:.25rem .25rem .5rem;scrollbar-width:none;
  }
  .thumbs::-webkit-scrollbar{display:none}
  .thumb{
    flex:0 0 64px !important;width:64px !important;height:64px !important;aspect-ratio:1/1;
    scroll-snap-align:start;
  }
  .buybox{padding:1.25rem;border-radius:18px}
  .buybox .row2{grid-template-columns:1fr}    /* stack power dropdowns */
  .actions-row{flex-direction:column;align-items:stretch}
  .actions-row .qty{width:-moz-fit-content;width:fit-content;align-self:center}
  .trust{grid-template-columns:1fr;gap:.5rem;font-size:.8rem}
  .trust li{justify-content:flex-start}
  details.spec dl{grid-template-columns:1fr}
  details.spec dt{margin-top:.5rem}
}

/* Try-on tabs scroll horizontally on tiny screens */
@media (max-width: 640px) {
  .tryon__tabs{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;padding:.75rem 1rem}
  .tryon__tabs::-webkit-scrollbar{display:none}
  .tryon__tabs button{flex-shrink:0}
  .tryon__head{padding:1rem 1rem 0}
  .tryon__head h3{font-size:1.1rem}
  .tryon__caption{padding:.75rem 1rem;font-size:.8rem}
}

/* Lens-dimension diagram scales right */
@media (max-width: 640px) {
  .dim-svg{max-width:220px}
  .dim-explain{padding:1.25rem;gap:1rem}
  .dim-list dt{font-size:1rem}
}

/* PDP-strip text */
@media (max-width: 640px) {
  .pdp-strip .container-x{padding-block:3rem}
  .pdp-strip h2{font-size:clamp(1.75rem,7vw,2.25rem)}
  .pdp-strip .specs{gap:1rem 1.5rem;margin-top:1.5rem}
  .pdp-strip .specs strong{font-size:1.5rem}
}

/* ---- Cart drawer: bigger qty buttons on touch ---- */
@media (hover: none), (max-width: 640px) {
  .cart-line .qty-mini button{width:36px;height:36px;font-size:1rem}
  .cart-line .qty-mini span{padding:0 .65rem}
  .cart-line{gap:.75rem}
  .drawer__panel{width:100%}
}

/* ---- Mobile sticky bar refinements ---- */
@media (max-width: 1023px) {
  .pdp-sticky{padding:.65rem .75rem;gap:.5rem}
  .pdp-sticky .info p:last-child{font-size:1rem}
  .pdp-sticky .btn{font-size:.85rem;padding:.65rem 1rem !important;min-height:42px}
  /* Reserve space so sticky bar doesn't cover last reviewed shade card */
  body{padding-bottom:64px}
}
@media (min-width: 1024px) { body{padding-bottom:0} }

/* ---- Shop layout ---- */
@media (max-width: 1023px) {
  .shop-head .container-x{padding-block:3rem}
  .shop-head h1{font-size:clamp(2rem,8vw,4rem)}
  .shop-tabs{margin-top:1.5rem;gap:.4rem}
  .shop-tabs .chip{padding:.4rem .75rem;font-size:.78rem;min-height:36px}
  .shop-layout{padding-block:2rem;gap:1.5rem}
  .filters{gap:1.5rem}
  .filters .group p.eyebrow{margin-bottom:.6rem}
  .editorial-banner{height:auto;min-height:240px}
  .editorial-banner .text{padding:1.5rem}
  .editorial-banner .text h2{font-size:clamp(1.5rem,5vw,2.25rem)}
  .shop-grid{gap:.85rem}
}

/* ---- Checkout ---- */
@media (max-width: 1023px) {
  .checkout-grid{padding:1.5rem;gap:1.5rem}
  .checkout-block{padding:1.25rem}
  .checkout-block h2{font-size:1.1rem;margin-bottom:1rem}
  .summary-card{padding:1.25rem}
  .summary-card h2{font-size:1.1rem}
}

/* ---- FAQ breathing room ---- */
@media (max-width: 640px) {
  .faq-list details{padding:1rem 0}
  .faq-list summary{font-size:1rem;gap:.75rem}
  .faq-list details p{font-size:.9rem}
}

/* ---- Editorial banner inside shop becomes single column ---- */
@media (max-width: 767px) {
  .editorial-banner{grid-template-columns:1fr}
  .editorial-banner .img{display:none}
}

/* ---- Drawer head minimum touch target on close ---- */
.drawer__close{min-width:44px;min-height:44px}

/* ---- Bottom sticky bar on PDP doesn't overlap content if there's an iOS home indicator ---- */
.pdp-sticky{padding-bottom:calc(.75rem + env(safe-area-inset-bottom))}
.sticky-buy{padding-bottom:env(safe-area-inset-bottom)}

/* =========================================================
   v7 — Mobile bug-fix pass
   ========================================================= */

/* (1) Hero image flowing off-right — promo-visual children were absolutely
       positioned (.v-thumb t1/t2 use right:-1rem etc). On mobile the eye
       composite replaces them, but the leftover .v-* rules still bleed.
       Constrain the column to its grid track and clip overflow. */
@media (max-width: 1023px) {
  .promo-grid{overflow:hidden}
  .promo-visual{
    position:relative;width:100%;max-width:100%;
    overflow:hidden;border-radius:24px;
  }
  .promo-visual .v-main,
  .promo-visual .v-thumb,
  .promo-visual .v-tag{display:none !important}  /* old collage hidden on mobile, eye composite is the only hero asset */
  .eye-composite{max-width:min(420px,90vw);margin:0 auto}
}

/* (2) "Find your hue" — on mobile it should be a scannable GRID, not a swipe
       carousel. Hue picking is option selection, not browsing. */
.hue-rail{max-width:100%}
@media (max-width: 767px) {
  .hue-rail{
    display:grid;grid-template-columns:repeat(3,1fr);
    gap:1.25rem .75rem;
    overflow:visible;padding:1rem 0 .5rem;
    -webkit-mask-image:none;mask-image:none;
  }
  .hue-card{flex:initial;width:100%;scroll-snap-align:none}
  .hue-card .lens{width:100%;max-width:96px;aspect-ratio:1/1;height:auto;margin:0 auto}
  .hue-card .name{font-size:.9rem;margin-top:.5rem}
  .hue-card .qty{font-size:.65rem}
}
/* On really small screens (≤360px) drop to 2 columns so swatches stay readable */
@media (max-width: 360px) {
  .hue-rail{grid-template-columns:repeat(2,1fr)}
  .hue-card .lens{max-width:120px}
}

/* (3) Eye-colour buttons wrapping to two rows.
       Make them a single horizontal scroll-snap rail. */
@media (max-width: 640px) {
  .match-options{
    flex-wrap:nowrap;overflow-x:auto;
    scroll-snap-type:x mandatory;
    padding-bottom:.5rem;scrollbar-width:none;
    -webkit-mask-image:linear-gradient(90deg,#000 0,#000 92%,transparent 100%);
            mask-image:linear-gradient(90deg,#000 0,#000 92%,transparent 100%);
  }
  .match-options::-webkit-scrollbar{display:none}
  .match-options button{flex-shrink:0;scroll-snap-align:start;white-space:nowrap}
  .match-band .head{margin-bottom:.75rem}
  .match-result{font-size:.8rem}
}

/* (4) "Just landed" / New Arrivals — needs visible breathing room above. */
@media (max-width: 768px) {
  .container-x.section,
  .container-x.s-pad{padding-top:3rem}
  /* the carousel section had inline `padding-top:0`; override on mobile */
  .container-x.s-pad[style*="padding-top:0"]{padding-top:2.5rem !important}
}

/* (5) "New arrivals" carousel — Slick-slider feel on mobile.
       Cards become wider (peek-style), snap firmly, dots indicate position. */
@media (max-width: 768px) {
  .h-scroll{
    grid-auto-columns:78%;
    gap:.85rem;
    padding-inline:1.5rem;
    padding-bottom:1.5rem;
    scroll-padding-inline:1.5rem;
    scrollbar-width:none;
  }
  .h-scroll::-webkit-scrollbar{display:none}
  /* Counter the container-x padding so the rail edge-aligns */
  .h-scroll{margin-inline:-1.5rem}
  .h-scroll > *{scroll-snap-align:center}
  /* subtle peek into next card */
  .h-scroll .r-card{box-shadow:0 14px 28px -18px rgba(15,10,18,.25)}
}
@media (min-width: 640px) and (max-width: 1023px) {
  .h-scroll{grid-auto-columns:48%}
}

/* (6) Footer — white area beneath because gradient bg only paints inside the
       footer and the body has implicit margin from sticky-bar padding +
       margin-top:6rem on .site-footer. Give the page a dark backstop and
       make the footer extend through any safe-area. */
html,body{background:var(--ml-ivory)}
.site-footer{
  margin-bottom:0;
  padding-bottom:env(safe-area-inset-bottom);
}
/* Paint the area below the page in aubergine so any overscroll / sticky-bar
   reservation never reveals white. */
html{background:#160B1B}                        /* matches footer gradient end */
body{background:var(--ml-ivory)}                /* page itself stays ivory */
@media (max-width: 1023px) {
  /* Sticky CTA reserved 64px on body (added in v6). That gap was rendering
     ivory under the footer because body bg = ivory. Move the reservation
     to a wrapper so the footer can sit flush. */
  body{padding-bottom:0}
  main{padding-bottom:64px}
}
@media (min-width: 1024px) {
  main{padding-bottom:0}
}

/* =========================================================
   v8 — Carousel arrows (Slick-style)
   ========================================================= */
.h-scroll-wrap{position:relative}
.h-scroll-arrow{
  position:absolute;top:38%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:9999px;
  background:rgba(251,247,240,.95);color:var(--ml-ink);
  border:1px solid rgba(15,10,18,.1);
  display:none;align-items:center;justify-content:center;
  box-shadow:0 14px 28px -16px rgba(15,10,18,.45);
  z-index:5;cursor:pointer;
  transition:transform .2s var(--ml-ease),background .2s,opacity .25s;
}
.h-scroll-arrow:hover{background:#fff;transform:translateY(-50%) scale(1.06)}
.h-scroll-arrow svg{width:18px;height:18px}
.h-scroll-arrow.prev{left:-18px}
.h-scroll-arrow.next{right:-18px}
.h-scroll-arrow[disabled]{opacity:.3;pointer-events:none}

/* show on mobile + tablet — desktop already shows 4-up so no need */
@media (max-width: 1023px) {
  .h-scroll-arrow{display:inline-flex}
  .h-scroll-arrow.prev{left:.5rem}
  .h-scroll-arrow.next{right:.5rem}
}

/* Dots indicator */
.h-scroll-dots{
  display:none;justify-content:center;gap:.4rem;
  margin-top:.5rem;
}
@media (max-width: 1023px) {.h-scroll-dots{display:flex}}
.h-scroll-dots button{
  width:8px;height:8px;border-radius:9999px;
  background:rgba(15,10,18,.18);border:0;padding:0;
  transition:background .2s,width .2s;
}
.h-scroll-dots button[aria-current="true"]{background:var(--ml-ink);width:24px;border-radius:4px}

/* =========================================================
   v9 — Shop page mobile overhaul
   ========================================================= */

/* Toolbar gains a count, sort, and the Filter button morphs into a
   bottom-sheet trigger on mobile. */
.toolbar-inner{flex-wrap:wrap;gap:.5rem .75rem}
.toolbar-meta{
  display:none;align-items:center;gap:.75rem;font-size:.8rem;color:rgba(15,10,18,.6);
  margin-left:auto;
}
@media (max-width: 1023px){
  .toolbar-meta{display:flex;flex:1;justify-content:flex-end}
  .toolbar-meta strong{color:var(--ml-ink)}
  /* Hide the desktop hue chip rail on mobile — bottom sheet hosts everything */
  .toolbar-chips{display:none !important}
}
.toolbar-meta select{
  background:transparent;border:0;border-bottom:1px solid rgba(15,10,18,.2);
  padding:.25rem 1rem .25rem 0;border-radius:0;font-size:.8rem;
  -moz-appearance:none;
       appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'><path d='M2 4l3 3 3-3' fill='none' stroke='%230F0A12' stroke-width='1.4'/></svg>");
  background-repeat:no-repeat;background-position:right center;
}

/* Filter button gets badge + count when filters active */
.btn-filter{position:relative;display:inline-flex;align-items:center;gap:.4rem}
.btn-filter[data-count]:not([data-count="0"])::after{
  content:attr(data-count);
  display:inline-flex;align-items:center;justify-content:center;
  min-width:18px;height:18px;padding:0 5px;border-radius:9999px;
  background:var(--ml-iris);color:#fff;font-size:10px;font-weight:600;letter-spacing:0;
}

/* Active-filter chips row */
.applied-row{
  display:none;flex-wrap:wrap;gap:.4rem;
  padding:.75rem 0 1rem;
  border-bottom:1px solid rgba(15,10,18,.06);margin-bottom:1rem;
}
.applied-row.has-filters{display:flex}
.applied-chip{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.3rem .65rem;border-radius:9999px;
  background:rgba(124,91,196,.1);color:var(--ml-iris);
  border:1px solid rgba(124,91,196,.3);
  font-size:.78rem;font-weight:500;
}
.applied-chip button{
  width:16px;height:16px;border-radius:9999px;
  background:rgba(124,91,196,.25);color:var(--ml-iris);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:11px;line-height:1;
}
.applied-chip button:hover{background:var(--ml-iris);color:#fff}
.applied-row .reset{
  margin-left:auto;font-size:.78rem;color:rgba(15,10,18,.55);
  text-decoration:underline;text-underline-offset:3px;align-self:center;
}
.applied-row .reset:hover{color:var(--ml-iris)}

/* Sticky collection sub-header */
.collection-sub{
  position:sticky;top:calc(64px + 52px);     /* mobile: header + toolbar */
  z-index:25;
  background:rgba(251,247,240,.96);backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(201,161,74,.2);
  padding:.5rem 1rem;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ml-gold);
  display:none;
  font-weight:500;
  transform:translateY(-4px);opacity:0;
  transition:transform .25s var(--ml-ease),opacity .25s var(--ml-ease);
}
.collection-sub.is-visible{display:block;transform:translateY(0);opacity:1}
.collection-sub strong{color:var(--ml-ink);font-weight:500}
@media (min-width: 1024px){
  .collection-sub{display:none !important}    /* not needed on desktop with sidebar */
}

/* ========== Bottom sheet for filters (mobile) ========== */
.filter-sheet{
  position:fixed;inset:auto 0 0 0;z-index:80;
  background:transparent;pointer-events:none;
}
.filter-sheet[hidden]{display:none}
.filter-sheet .sheet-scrim{
  position:fixed;inset:0;background:rgba(15,10,18,.55);
  opacity:0;transition:opacity .28s var(--ml-ease);backdrop-filter:blur(2px);
}
.filter-sheet .sheet-panel{
  position:relative;background:var(--ml-ivory);
  border-radius:24px 24px 0 0;
  max-height:85dvh;display:flex;flex-direction:column;
  transform:translateY(100%);transition:transform .32s var(--ml-ease);
  pointer-events:auto;
  box-shadow:0 -20px 40px -10px rgba(15,10,18,.3);
}
.filter-sheet.is-open{pointer-events:auto}
.filter-sheet.is-open .sheet-scrim{opacity:1}
.filter-sheet.is-open .sheet-panel{transform:translateY(0)}
.filter-sheet .grabber{
  width:40px;height:4px;border-radius:9999px;background:rgba(15,10,18,.18);
  margin:.65rem auto .25rem;
}
.filter-sheet .sheet-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:.75rem 1.25rem;border-bottom:1px solid rgba(15,10,18,.07);
}
.filter-sheet .sheet-head h2{font-family:"Fraunces",serif;font-size:1.15rem;letter-spacing:-.02em}
.filter-sheet .sheet-head .clear{font-size:.8rem;color:var(--ml-iris);font-weight:500;padding:.5rem;min-height:44px}
.filter-sheet .sheet-body{flex:1;overflow-y:auto;padding:1.25rem 1.25rem 1.5rem;display:flex;flex-direction:column;gap:1.75rem}
.filter-sheet .sheet-foot{
  padding:1rem 1.25rem calc(1rem + env(safe-area-inset-bottom));
  border-top:1px solid rgba(15,10,18,.07);background:#fff;
  display:grid;grid-template-columns:1fr 1.4fr;gap:.5rem;
}

/* Sidebar relocates *into* the sheet on mobile via class swap.
   Keep the same .filters look but reset the sticky positioning. */
@media (max-width: 1023px){
  .shop-layout{grid-template-columns:1fr;gap:0}
  /* Hide the desktop sidebar entirely on mobile — sheet replaces it. */
  .shop-layout > aside.filters{display:none}
}

/* Inside the sheet, .filters block looks the same but stacks the heading
   bigger and gives each group a thicker divider for thumb-friendly scanning. */
.filter-sheet .filters{display:flex;flex-direction:column;gap:1.5rem}
.filter-sheet .filters .group p.eyebrow{font-size:11px;color:var(--ml-iris);margin-bottom:.6rem}
.filter-sheet .filters label{min-height:44px;font-size:.95rem}
.filter-sheet .filters ul{gap:.25rem}
.filter-sheet .swatches{gap:.65rem}
.filter-sheet .swatches .iris-swatch{width:42px;height:42px}

/* Hide editorial banner on mobile */
@media (max-width: 767px){
  .editorial-banner{display:none !important}
}

/* Ensure shop-grid hugs viewport on mobile (full-bleed-ish padding) */
@media (max-width: 640px){
  .shop-layout{padding-inline:1rem}
  .shop-grid{gap:.75rem;grid-template-columns:repeat(2,1fr)}
  .results-meta{display:none}                   /* moved to toolbar */
}

/* The "tabs" in shop-head should not wrap chaotically on mobile.
   Make them a single horizontal scroll-snap rail with a fade. */
@media (max-width: 767px){
  .shop-tabs{
    flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x mandatory;
    margin-inline:-1.5rem;padding-inline:1.5rem;
    -webkit-mask-image:linear-gradient(90deg,#000 0,#000 92%,transparent 100%);
            mask-image:linear-gradient(90deg,#000 0,#000 92%,transparent 100%);
    scrollbar-width:none;
  }
  .shop-tabs::-webkit-scrollbar{display:none}
  .shop-tabs .chip{flex-shrink:0;scroll-snap-align:start}
}

/* =========================================================
   v10 — PDP CRO additions
   ========================================================= */

/* Q1: "Don't wear glasses?" callout above power selectors */
.plain-hint{
  display:flex;align-items:flex-start;gap:.6rem;
  padding:.75rem .9rem;border-radius:14px;
  background:rgba(124,91,196,.08);border:1px solid rgba(124,91,196,.25);
  font-size:.85rem;color:var(--ml-ink);line-height:1.45;
}
.plain-hint .ic{
  width:24px;height:24px;border-radius:9999px;
  background:var(--ml-iris);color:#fff;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:.85rem;
}
.plain-hint strong{color:var(--ml-iris);font-weight:600}

/* H5: Hero review above the buy box */
.hero-review{
  margin-top:1.5rem;padding:1rem 1.1rem;border-radius:14px;
  background:rgba(245,230,216,.55);border:1px solid rgba(201,161,74,.25);
  display:flex;flex-direction:column;gap:.4rem;
}
.hero-review .stars{color:var(--ml-gold);font-size:.85rem;letter-spacing:.05em}
.hero-review .quote{
  font-family:"Fraunces",serif;font-size:1.05rem;letter-spacing:-.02em;
  line-height:1.35;color:var(--ml-ink);
}
.hero-review .who{
  font-size:.75rem;color:rgba(15,10,18,.6);
  display:flex;align-items:center;gap:.5rem;
}
.hero-review .who .v{color:var(--ml-iris);font-weight:500}

/* H1: Frequently bought together bundle */
.bundle{
  margin-top:1.5rem;padding:1.25rem;border-radius:18px;
  background:#fff;border:1px solid rgba(201,161,74,.3);
  box-shadow:0 14px 28px -22px rgba(15,10,18,.25);
}
.bundle .b-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:.85rem;
}
.bundle .b-head h3{
  font-family:"Fraunces",serif;font-size:1.05rem;letter-spacing:-.02em;
  display:flex;align-items:center;gap:.4rem;
}
.bundle .b-head .save{
  background:var(--ml-iris);color:#fff;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  padding:.2rem .5rem;border-radius:9999px;
}
.bundle-row{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:.5rem;align-items:center;margin-bottom:1rem}
.bundle-item{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:.5rem;border-radius:12px;background:rgba(245,230,216,.4);
  cursor:pointer;
  position:relative;
}
.bundle-item img{width:56px;height:56px;border-radius:10px;-o-object-fit:cover;object-fit:cover}
.bundle-item .nm{font-size:.7rem;font-weight:500;margin-top:.4rem;line-height:1.15;color:var(--ml-ink)}
.bundle-item .px{font-size:.7rem;color:rgba(15,10,18,.55);margin-top:.15rem}
.bundle-item input{position:absolute;top:.25rem;right:.25rem;accent-color:var(--ml-iris);width:14px;height:14px}
.bundle-plus{color:var(--ml-iris);font-weight:600;font-family:"Fraunces",serif;font-size:1.25rem}
.bundle-totals{
  display:flex;align-items:baseline;justify-content:space-between;
  padding-top:.85rem;border-top:1px solid rgba(15,10,18,.07);
  margin-bottom:.85rem;
}
.bundle-totals .bp-label{font-size:.8rem;color:rgba(15,10,18,.65)}
.bundle-totals .bp-val{font-family:"Fraunces",serif;font-size:1.5rem;letter-spacing:-.02em}
.bundle-totals .bp-was{text-decoration:line-through;color:rgba(15,10,18,.4);font-size:.85rem;margin-left:.5rem}
.bundle .btn{width:100%}

/* Item dim when not selected */
.bundle-item:has(input:not(:checked)){opacity:.45;background:transparent}

/* H6: Inline shade switcher */
.shade-switcher{
  margin-top:1.5rem;padding:1rem;border-radius:18px;
  background:#fff;border:1px solid rgba(15,10,18,.06);
}
.shade-switcher .ss-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:.75rem;font-size:.78rem;
}
.shade-switcher .ss-head .lbl{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ml-gold);font-weight:500;
}
.shade-switcher .ss-head a{color:var(--ml-iris)}
.ss-row{
  display:flex;gap:.6rem;overflow-x:auto;
  scroll-snap-type:x mandatory;padding-bottom:.5rem;scrollbar-width:none;
}
.ss-row::-webkit-scrollbar{display:none}
.ss-card{
  flex:0 0 80px;scroll-snap-align:start;text-align:center;
  border-radius:12px;padding:.4rem;
  border:1.5px solid transparent;
  transition:border-color .15s var(--ml-ease);
}
.ss-card.is-current{border-color:var(--ml-ink);background:rgba(15,10,18,.04)}
.ss-card:hover{border-color:rgba(15,10,18,.2)}
.ss-card img{width:64px;height:64px;border-radius:9999px;-o-object-fit:cover;object-fit:cover}
.ss-card .nm{font-size:.7rem;margin-top:.4rem;line-height:1.1}
.ss-card .px{font-size:.65rem;color:rgba(15,10,18,.5);margin-top:.1rem}

/* Mobile tweaks */
/* "You may also love" — tighter framing on PDP */
.pdp-related{padding-top:1.5rem !important}
.pdp-related .related-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:1.25rem;gap:1rem;
}
.pdp-related .related-head h2{margin-top:.25rem;font-size:clamp(1.5rem,3vw,2rem)}
.pdp-related .related-head p.eyebrow{margin:0}
@media(max-width:640px){
  .pdp-related{padding-top:1rem !important;padding-bottom:1.25rem !important}
  .pdp-related .related-head{margin-bottom:1rem;align-items:center}
  .pdp-related .related-head h2{font-size:1.5rem}
  .pdp-related .grid-cards{grid-template-columns:repeat(2,1fr);gap:.75rem}
  .pdp-related .iris-card .card-body{padding:.85rem}
  .pdp-related .iris-card h3{font-size:.95rem}
  .bundle-row{grid-template-columns:1fr;gap:.5rem}
  .bundle-row .bundle-plus{display:none}
  .bundle-item{flex-direction:row;text-align:left;gap:.75rem;justify-content:flex-start;padding:.65rem .75rem}
  .bundle-item .nm{margin-top:0;font-size:.85rem}
  .bundle-item .px{margin-top:.15rem;font-size:.75rem}
  .bundle-item input{position:static;margin-left:auto}
}

/* W7: UGC tile shade label overlay */
.ig-strip a .shade-tag{
  position:absolute;left:.5rem;bottom:.5rem;z-index:2;
  background:rgba(15,10,18,.7);color:var(--ml-ivory);
  padding:.25rem .5rem;border-radius:9999px;font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  backdrop-filter:blur(4px);
  opacity:0;transform:translateY(4px);
  transition:opacity .25s var(--ml-ease),transform .25s var(--ml-ease);
}
.ig-strip a:hover .shade-tag,
.ig-strip a:focus .shade-tag{opacity:1;transform:translateY(0)}
@media(hover:none){.ig-strip a .shade-tag{opacity:1;transform:none}}


/* =========================================================================
 * Theme-only overrides go below this line.
 * ========================================================================= */

/* WP nav menu compatibility — wp_nav_menu wraps each item in <li class="menu-item">
 * even when items_wrap drops the outer <ul>. Reset list defaults so the items
 * lay out as flex children of .nav-primary like the static template's <a> tags. */
.nav-primary .menu-item{
  list-style:none;
  margin:0;
  padding:0;
}
.nav-primary .menu-item > a{
  display:inline-block;
  text-decoration:none;
  color:inherit;
  font-size:.875rem;
  white-space:nowrap;
}
.nav-primary .menu-item > a:hover{color:var(--ml-aubergine)}
/* Same hygiene if the <ul> ever stays (other menu locations / mobile drawer) */
.nav-primary-list,
ul.nav-primary-list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:1.75rem;
  align-items:center;
}
.hover\:ring-2:hover {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.hover\:ring-gold:hover {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(201 161 74 / var(--tw-ring-opacity, 1));
}
.focus\:ring-2:focus {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.focus\:ring-gold:focus {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(201 161 74 / var(--tw-ring-opacity, 1));
}
@media (min-width: 1024px) {

  .lg\:sticky {
    position: sticky;
  }

  .lg\:top-24 {
    top: 6rem;
  }

  .lg\:block {
    display: block;
  }

  .lg\:hidden {
    display: none;
  }

  .lg\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lg\:grid-cols-\[1fr_400px\] {
    grid-template-columns: 1fr 400px;
  }

  .lg\:grid-cols-\[280px_1fr\] {
    grid-template-columns: 280px 1fr;
  }
}