:root,
html[data-theme="light"] {
  /*
    MoodIntimates Design Tokens - Step 1
    Direction: pure white + cherry blossom pink + rose gold
  */

  /* Typography */
  --mi-font-display: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --mi-font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  /* 8pt spacing system */
  --mi-space-0: 0;
  --mi-space-1: 0.25rem; /* 4px */
  --mi-space-2: 0.5rem;  /* 8px */
  --mi-space-3: 0.75rem; /* 12px */
  --mi-space-4: 1rem;    /* 16px */
  --mi-space-5: 1.5rem;  /* 24px */
  --mi-space-6: 2rem;    /* 32px */
  --mi-space-7: 3rem;    /* 48px */
  --mi-space-8: 4rem;    /* 64px */
  --mi-space-9: 6rem;    /* 96px */
  --mi-space-10: 8rem;   /* 128px */

  /* Fluid layout */
  --mi-page-gutter: clamp(1rem, 4vw, 4rem);
  --mi-container: 74rem;
  --mi-container-wide: 92rem;
  --mi-section-y: clamp(4.5rem, 10vw, 8rem);
  --mi-hero-min-h: min(56rem, 100svh);

  /* Radius */
  --mi-radius-xs: 0.5rem;
  --mi-radius-sm: 0.875rem;
  --mi-radius-md: 1.25rem;
  --mi-radius-lg: 2rem;
  --mi-radius-xl: 3rem;
  --mi-radius-pill: 999px;

  /* Motion */
  --mi-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --mi-ease-soft: cubic-bezier(0.22, 1, 0.36, 1);
  --mi-ease-luxury: cubic-bezier(0.19, 1, 0.22, 1);
  --mi-duration-fast: 180ms;
  --mi-duration-base: 360ms;
  --mi-duration-slow: 720ms;
  --mi-duration-ambient: 9000ms;

  /* Layering */
  --mi-z-base: 1;
  --mi-z-header: 50;
  --mi-z-overlay: 100;
  --mi-z-modal: 1000;

  /* Light mode palette */
  --mi-color-primary-50: #fff7fa;
  --mi-color-primary-100: #ffeef5;
  --mi-color-primary-200: #ffdce9;
  --mi-color-primary-300: #ffc3d7;
  --mi-color-primary-400: #f99fbd;
  --mi-color-primary-500: #ef7fa5;
  --mi-color-primary-600: #d95f88;

  --mi-color-accent-100: #fff3ec;
  --mi-color-accent-300: #f2c6b5;
  --mi-color-accent-500: #d89a82;
  --mi-color-accent-700: #9f604c;

  --mi-color-neutral-0: #ffffff;
  --mi-color-neutral-50: #fffafd;
  --mi-color-neutral-100: #f9f3f6;
  --mi-color-neutral-200: #eee3e8;
  --mi-color-neutral-500: #8f7a84;
  --mi-color-neutral-700: #4b3942;
  --mi-color-neutral-900: #241820;

  --mi-color-bg: var(--mi-color-neutral-0);
  --mi-color-bg-soft: var(--mi-color-primary-50);
  --mi-color-text: var(--mi-color-neutral-900);
  --mi-color-text-muted: var(--mi-color-neutral-500);
  --mi-color-border: rgba(216, 154, 130, 0.22);
  --mi-color-primary: var(--mi-color-primary-500);
  --mi-color-primary-strong: var(--mi-color-primary-600);
  --mi-color-accent: var(--mi-color-accent-500);
  --mi-color-surface: rgba(255, 255, 255, 0.74);
  --mi-color-surface-strong: rgba(255, 255, 255, 0.92);
  --mi-color-surface-soft: rgba(255, 247, 250, 0.72);
  --mi-color-card: rgba(255, 255, 255, 0.78);
  --mi-color-card-strong: rgba(255, 255, 255, 0.94);
  --mi-color-muted: var(--mi-color-text-muted);
  --mi-color-link: #a84767;
  --mi-color-link-hover: #7b344a;
  --mi-color-input-bg: rgba(255, 255, 255, 0.88);
  --mi-color-input-border: rgba(168, 71, 103, 0.28);
  --mi-color-input-border-hover: rgba(168, 71, 103, 0.42);
  --mi-color-overlay: rgba(36, 24, 32, 0.32);
  --mi-color-modal: rgba(255, 255, 255, 0.94);
  --mi-color-notice-bg: rgba(255, 247, 250, 0.9);
  --mi-color-notice-border: rgba(168, 71, 103, 0.24);
  --mi-color-success: #6f7f4d;
  --mi-color-error: #a94457;

  /* Gradients */
  --mi-gradient-page: radial-gradient(circle at 12% 8%, rgba(255, 220, 233, 0.9), transparent 34%),
                      radial-gradient(circle at 88% 16%, rgba(242, 198, 181, 0.48), transparent 32%),
                      linear-gradient(135deg, #ffffff 0%, #fff7fa 46%, #fff0f6 100%);
  --mi-gradient-primary: linear-gradient(135deg, #ffb7cb 0%, #ef7fa5 48%, #d89a82 100%);
  --mi-gradient-glass: linear-gradient(145deg, rgba(255, 255, 255, 0.86), rgba(255, 238, 245, 0.46));

  /* Shadows */
  --mi-shadow-sm: 0 12px 32px rgba(217, 95, 136, 0.1);
  --mi-shadow-md: 0 24px 70px rgba(75, 57, 66, 0.13);
  --mi-shadow-lg: 0 36px 110px rgba(217, 95, 136, 0.2);
  --mi-shadow-glow: 0 0 72px rgba(239, 127, 165, 0.28);

  /* Focus */
  --mi-focus-ring: 0 0 0 4px rgba(239, 127, 165, 0.22);
}

html[data-theme="dark"] {
  /* Dark mode: deep purple-pink night ambience */
  --mi-color-primary-50: #2a1426;
  --mi-color-primary-100: #3a1832;
  --mi-color-primary-200: #542145;
  --mi-color-primary-300: #7e315f;
  --mi-color-primary-400: #b94a7d;
  --mi-color-primary-500: #ff8db7;
  --mi-color-primary-600: #ffabc9;

  --mi-color-accent-100: #3a211f;
  --mi-color-accent-300: #8b5b51;
  --mi-color-accent-500: #e6aa96;
  --mi-color-accent-700: #ffd1c3;

  --mi-color-neutral-0: #130b14;
  --mi-color-neutral-50: #1a0f1b;
  --mi-color-neutral-100: #231425;
  --mi-color-neutral-200: #3a283d;
  --mi-color-neutral-500: #c1aebb;
  --mi-color-neutral-700: #eadde6;
  --mi-color-neutral-900: #fff8fc;

  --mi-color-bg: #130b14;
  --mi-color-bg-soft: #1d101e;
  --mi-color-text: #fff8fc;
  --mi-color-text-muted: #c1aebb;
  --mi-color-border: rgba(255, 171, 201, 0.2);
  --mi-color-primary: var(--mi-color-primary-500);
  --mi-color-primary-strong: var(--mi-color-primary-600);
  --mi-color-accent: var(--mi-color-accent-500);
  --mi-color-surface: rgba(35, 20, 37, 0.72);
  --mi-color-surface-strong: rgba(42, 20, 38, 0.9);
  --mi-color-surface-soft: rgba(35, 20, 37, 0.62);
  --mi-color-card: rgba(35, 20, 37, 0.76);
  --mi-color-card-strong: rgba(42, 20, 38, 0.94);
  --mi-color-muted: var(--mi-color-text-muted);
  --mi-color-link: #ffabc9;
  --mi-color-link-hover: #ffe2ee;
  --mi-color-input-bg: rgba(19, 11, 20, 0.78);
  --mi-color-input-border: rgba(255, 171, 201, 0.28);
  --mi-color-input-border-hover: rgba(255, 171, 201, 0.42);
  --mi-color-overlay: rgba(9, 4, 10, 0.68);
  --mi-color-modal: rgba(35, 20, 37, 0.94);
  --mi-color-notice-bg: rgba(42, 20, 38, 0.9);
  --mi-color-notice-border: rgba(255, 171, 201, 0.22);
  --mi-color-success: #bfd39a;
  --mi-color-error: #ff9fb4;

  --mi-gradient-page: radial-gradient(circle at 18% 10%, rgba(126, 49, 95, 0.42), transparent 34%),
                      radial-gradient(circle at 86% 18%, rgba(230, 170, 150, 0.18), transparent 30%),
                      linear-gradient(135deg, #130b14 0%, #1d101e 48%, #2a1426 100%);
  --mi-gradient-primary: linear-gradient(135deg, #ffabc9 0%, #ff8db7 46%, #e6aa96 100%);
  --mi-gradient-glass: linear-gradient(145deg, rgba(42, 20, 38, 0.82), rgba(84, 33, 69, 0.38));

  --mi-shadow-sm: 0 12px 32px rgba(0, 0, 0, 0.22);
  --mi-shadow-md: 0 24px 70px rgba(0, 0, 0, 0.32);
  --mi-shadow-lg: 0 36px 110px rgba(126, 49, 95, 0.3);
  --mi-shadow-glow: 0 0 84px rgba(255, 141, 183, 0.24);
  --mi-focus-ring: 0 0 0 4px rgba(255, 141, 183, 0.24);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  min-height: 100%;
  background: var(--mi-color-bg);
  color: var(--mi-color-text);
  color-scheme: light;
  font-family: var(--mi-font-body);
  font-size: 100%;
  scroll-behavior: smooth;
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

html[data-theme="dark"] {
  color-scheme: dark;
}

body {
  min-height: 100vh;
  margin: 0;
  overflow-x: clip;
  background: var(--mi-gradient-page);
  color: var(--mi-color-text);
}

body.mi-menu-open {
  overflow: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -3;
  background: var(--mi-gradient-page);
  background-size: 140% 140%;
  animation: mi-page-breathe var(--mi-duration-ambient) var(--mi-ease-soft) infinite alternate;
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background-image: linear-gradient(rgba(255, 255, 255, 0.08) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(255, 255, 255, 0.08) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(circle at 50% 20%, black, transparent 68%);
  opacity: 0.32;
}

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

a:hover,
a:focus-visible {
  color: var(--mi-color-link-hover);
}

button,
input,
textarea,
select {
  font: inherit;
}

button {
  cursor: pointer;
}

:focus-visible {
  outline: none;
  box-shadow: var(--mi-focus-ring);
}

.mi-skip-link {
  position: fixed;
  top: var(--mi-space-3);
  left: var(--mi-space-3);
  z-index: calc(var(--mi-z-modal) + 20);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.75rem;
  padding: 0.75rem 1rem;
  border: 1px solid rgba(176, 83, 113, 0.24);
  border-radius: 999px;
  background: rgba(255, 250, 252, 0.94);
  box-shadow: 0 18px 48px rgba(93, 54, 65, 0.14);
  color: var(--mi-color-plum);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0;
  transform: translateY(-160%);
  transition: opacity 180ms ease, transform 180ms ease;
}

.mi-skip-link:focus,
.mi-skip-link:focus-visible {
  opacity: 1;
  transform: translateY(0);
}

.mi-main:focus {
  outline: none;
}

::selection {
  background: rgba(239, 127, 165, 0.26);
}

img,
picture,
video,
canvas,
svg {
  filter: none;
}

input,
textarea,
select {
  border-color: var(--mi-color-input-border);
  background-color: var(--mi-color-input-bg);
  color: var(--mi-color-text);
}

input:hover,
textarea:hover,
select:hover {
  border-color: var(--mi-color-input-border-hover);
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--mi-color-primary);
}

.mi-ambient {
  position: fixed;
  inset: 0;
  z-index: -1;
  overflow: hidden;
  pointer-events: none;
}

.mi-ambient__orb {
  position: absolute;
  display: block;
  width: clamp(18rem, 34vw, 38rem);
  aspect-ratio: 1;
  border-radius: 50%;
  filter: blur(18px);
  opacity: 0.56;
  transform: translate3d(0, 0, 0);
  animation: mi-orb-float calc(var(--mi-duration-ambient) * 1.8) var(--mi-ease-soft) infinite alternate;
}

.mi-ambient__orb--rose {
  top: -8rem;
  left: -7rem;
  background: radial-gradient(circle, rgba(255, 195, 215, 0.78), transparent 64%);
}

.mi-ambient__orb--gold {
  right: -9rem;
  top: 12vh;
  animation-delay: -2800ms;
  background: radial-gradient(circle, rgba(242, 198, 181, 0.56), transparent 66%);
}

.mi-ambient__orb--pearl {
  left: 42%;
  bottom: -18rem;
  animation-delay: -5200ms;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.84), transparent 68%);
}

.mi-cursor-glow {
  position: absolute;
  left: var(--mi-cursor-x, 50vw);
  top: var(--mi-cursor-y, 28vh);
  width: clamp(12rem, 24vw, 25rem);
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(239, 127, 165, 0.24), transparent 64%);
  filter: blur(16px);
  opacity: var(--mi-cursor-opacity, 0.46);
  translate: -50% -50%;
  transition: left var(--mi-duration-slow) var(--mi-ease-out),
              top var(--mi-duration-slow) var(--mi-ease-out),
              opacity var(--mi-duration-base) var(--mi-ease-out);
}

.mi-shell {
  position: relative;
  z-index: 1;
  min-height: 100vh;
  isolation: isolate;
}

.mi-pink-particle-background {
  position: fixed;
  inset: 0;
  z-index: calc(var(--mi-z-header) - 2);
  display: block;
  width: 100%;
  height: 100%;
  pointer-events: none;
  opacity: 0.82;
  -webkit-mask-image: linear-gradient(90deg, #000 0%, rgba(0, 0, 0, 0.98) 18%, rgba(0, 0, 0, 0.52) 38%, rgba(0, 0, 0, 0.38) 50%, rgba(0, 0, 0, 0.52) 62%, rgba(0, 0, 0, 0.98) 82%, #000 100%);
  mask-image: linear-gradient(90deg, #000 0%, rgba(0, 0, 0, 0.98) 18%, rgba(0, 0, 0, 0.52) 38%, rgba(0, 0, 0, 0.38) 50%, rgba(0, 0, 0, 0.52) 62%, rgba(0, 0, 0, 0.98) 82%, #000 100%);
}

[data-theme="light"] .mi-pink-particle-background {
  opacity: 0.92;
}

[data-theme="dark"] .mi-pink-particle-background {
  opacity: 0.38;
}

.mi-site-frame {
  width: min(100% - (var(--mi-page-gutter) * 2), var(--mi-container-wide));
  margin-inline: auto;
}

.mi-nav-shell {
  position: sticky;
  top: 0;
  z-index: var(--mi-z-header);
  padding-block: clamp(0.75rem, 2vw, 1.25rem);
  transition: padding var(--mi-duration-base) var(--mi-ease-out),
              background var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out),
              backdrop-filter var(--mi-duration-base) var(--mi-ease-out);
}

.mi-nav-shell.is-scrolled,
.mi-nav-shell:focus-within,
.mi-nav-shell:hover {
  background: rgba(255, 255, 255, 0.56);
  box-shadow: 0 18px 60px rgba(75, 57, 66, 0.08);
  backdrop-filter: blur(22px) saturate(1.25);
}

[data-theme="dark"] .mi-nav-shell.is-scrolled,
[data-theme="dark"] .mi-nav-shell:focus-within,
[data-theme="dark"] .mi-nav-shell:hover {
  background: rgba(19, 11, 20, 0.62);
}

.mi-nav {
  min-height: 4rem;
  display: grid;
  grid-template-columns: minmax(12rem, 0.7fr) auto minmax(12rem, 0.7fr);
  align-items: center;
  gap: var(--mi-space-5);
  padding: 0.55rem 0.7rem 0.55rem 1rem;
  border: 1px solid transparent;
  border-radius: var(--mi-radius-pill);
  transition: border-color var(--mi-duration-base) var(--mi-ease-out),
              background var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out);
}

.mi-nav-shell.is-scrolled .mi-nav,
.mi-nav-shell:hover .mi-nav,
.mi-nav-shell:focus-within .mi-nav {
  border-color: var(--mi-color-border);
  background: var(--mi-color-surface);
  box-shadow: var(--mi-shadow-sm);
}

.mi-wordmark {
  display: inline-flex;
  flex-direction: column;
  gap: 0.1rem;
  width: max-content;
}

.mi-wordmark span {
  font-family: var(--mi-font-display);
  font-size: clamp(1.45rem, 2.4vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.035em;
}

.mi-wordmark small {
  color: var(--mi-color-text-muted);
  font-size: 0.58rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.mi-nav__links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(0.55rem, 1.4vw, 1rem);
}

.mi-nav__links a,
.mi-nav__account {
  position: relative;
  min-height: 2.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding-inline: 0.72rem;
  color: var(--mi-color-text-muted);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.035em;
  transition: color var(--mi-duration-base) var(--mi-ease-out),
              transform var(--mi-duration-base) var(--mi-ease-out);
}

.mi-nav__links a::after,
.mi-nav__account::after {
  content: "";
  position: absolute;
  left: 0.72rem;
  right: 0.72rem;
  bottom: 0.45rem;
  height: 2px;
  border-radius: var(--mi-radius-pill);
  background: var(--mi-gradient-primary);
  opacity: 0;
  transform: scaleX(0.5);
  transform-origin: center;
  transition: opacity var(--mi-duration-base) var(--mi-ease-out),
              transform var(--mi-duration-base) var(--mi-ease-out);
}

.mi-nav__links a:hover,
.mi-nav__links a:focus-visible,
.mi-nav__account:hover,
.mi-nav__account:focus-visible {
  color: var(--mi-color-text);
  transform: translateY(-1px);
}

.mi-nav__links a:hover::after,
.mi-nav__links a:focus-visible::after,
.mi-nav__account:hover::after,
.mi-nav__account:focus-visible::after {
  opacity: 1;
  transform: scaleX(1);
}

.mi-nav__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--mi-space-2);
}

.mi-icon-button,
.mi-theme-toggle,
.mi-menu-button {
  position: relative;
  width: 3rem;
  height: 3rem;
  display: inline-grid;
  place-items: center;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-pill);
  background: var(--mi-color-surface);
  box-shadow: var(--mi-shadow-sm);
  color: var(--mi-color-text);
  backdrop-filter: blur(20px) saturate(1.25);
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              border-color var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out),
              background var(--mi-duration-base) var(--mi-ease-out);
}

.mi-icon-button:hover,
.mi-theme-toggle:hover,
.mi-menu-button:hover {
  transform: translateY(-2px);
  border-color: rgba(239, 127, 165, 0.42);
  box-shadow: var(--mi-shadow-md);
}

.mi-search-button span {
  width: 1rem;
  aspect-ratio: 1;
  border: 2px solid currentColor;
  border-radius: 50%;
}

.mi-search-button span::after {
  content: "";
  position: absolute;
  width: 0.48rem;
  height: 2px;
  background: currentColor;
  border-radius: var(--mi-radius-pill);
  transform: translate(0.66rem, 0.66rem) rotate(45deg);
}

.mi-cart-button {
  min-height: 3rem;
  display: inline-flex;
  align-items: center;
  gap: var(--mi-space-2);
  padding-inline: 1rem 0.45rem;
  border: 1px solid rgba(239, 127, 165, 0.28);
  border-radius: var(--mi-radius-pill);
  background: var(--mi-gradient-primary);
  color: #fff;
  box-shadow: var(--mi-shadow-glow);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out);
}

.mi-cart-button:hover {
  transform: translateY(-2px);
  box-shadow: var(--mi-shadow-lg);
}

.mi-cart-button strong {
  min-width: 2.05rem;
  height: 2.05rem;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.24);
  font-size: 0.78rem;
}

.mi-cart-drawer {
  position: fixed;
  inset: 0;
  z-index: var(--mi-z-modal);
}

.mi-cart-drawer[hidden] {
  display: none;
}

.mi-cart-drawer__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(33, 22, 20, 0.52);
  backdrop-filter: blur(18px) saturate(1.1);
}

.mi-cart-drawer__panel {
  position: absolute;
  inset: 0 0 0 auto;
  width: min(100%, 28rem);
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: var(--mi-space-4);
  padding: clamp(var(--mi-space-5), 4vw, var(--mi-space-6));
  border-left: 1px solid var(--mi-color-border);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-xl);
  color: var(--mi-color-text);
  backdrop-filter: blur(26px) saturate(1.18);
}

.mi-cart-drawer__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--mi-space-4);
}

.mi-cart-drawer__eyebrow {
  margin: 0 0 var(--mi-space-2);
  color: var(--mi-color-primary-strong);
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.mi-cart-drawer__header h2 {
  margin: 0;
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  line-height: 0.95;
}

.mi-cart-drawer__close {
  position: relative;
  width: 2.55rem;
  height: 2.55rem;
  flex: 0 0 auto;
  border: 1px solid var(--mi-color-border);
  border-radius: 50%;
  background: var(--mi-color-surface-strong);
  box-shadow: var(--mi-shadow-sm);
}

.mi-cart-drawer__close::before,
.mi-cart-drawer__close::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1rem;
  height: 1px;
  background: var(--mi-color-text);
  transform-origin: center;
}

.mi-cart-drawer__close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.mi-cart-drawer__close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.mi-cart-drawer__summary {
  display: grid;
  gap: var(--mi-space-3);
  padding: var(--mi-space-4);
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  background: rgba(255, 255, 255, 0.54);
  box-shadow: var(--mi-shadow-sm);
}

.mi-cart-drawer__progress {
  display: grid;
  gap: var(--mi-space-2);
}

.mi-cart-drawer__progress div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--mi-space-3);
}

.mi-cart-drawer__progress span,
.mi-cart-drawer__progress strong {
  color: var(--mi-color-text-muted);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-cart-drawer__progress-track {
  display: block;
  height: 0.45rem;
  overflow: hidden;
  border-radius: var(--mi-radius-pill);
  background: rgba(82, 60, 55, 0.08);
}

.mi-cart-drawer__progress-track i {
  display: block;
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: var(--mi-gradient-primary);
  transition: width var(--mi-duration-base) var(--mi-ease-out);
}

.mi-cart-drawer__perks {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mi-space-2);
}

.mi-cart-drawer__perks span {
  padding: 0.45rem 0.75rem;
  border: 1px solid rgba(239, 127, 165, 0.18);
  border-radius: var(--mi-radius-pill);
  background: rgba(255, 255, 255, 0.72);
  color: var(--mi-color-text-muted);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.mi-cart-drawer__items {
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: var(--mi-space-3);
  overflow-y: auto;
  padding-right: 0.2rem;
}

.mi-cart-drawer__empty {
  display: grid;
  gap: var(--mi-space-2);
  margin: auto 0;
  padding: var(--mi-space-6);
  border: 1px dashed var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  color: var(--mi-color-text-muted);
  text-align: center;
}

.mi-cart-drawer__empty strong {
  color: var(--mi-color-text);
  font-size: 1.2rem;
}

.mi-cart-drawer__empty p {
  color: var(--mi-color-text-muted);
  font-size: 0.92rem;
  line-height: 1.7;
}

.mi-cart-drawer__item {
  display: grid;
  grid-template-columns: 4.5rem minmax(0, 1fr) auto;
  gap: var(--mi-space-3);
  align-items: center;
  padding: var(--mi-space-4);
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  background: var(--mi-color-surface-strong);
  box-shadow: var(--mi-shadow-sm);
}

.mi-cart-drawer__thumb {
  width: 4.5rem;
  aspect-ratio: 1;
  border-radius: 1.2rem;
  background: linear-gradient(145deg, rgba(239, 127, 165, 0.2), rgba(201, 169, 110, 0.16));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.mi-cart-drawer__thumb span {
  display: block;
  width: 1.65rem;
  height: 1.65rem;
  margin: 1.45rem auto 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.72);
}

.mi-cart-drawer__item-main {
  min-width: 0;
}

.mi-cart-drawer__item-main span,
.mi-cart-drawer__item-main small {
  display: block;
  color: var(--mi-color-text-muted);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-cart-drawer__item-main strong {
  display: block;
  margin-block: 0.25rem;
  font-family: var(--mi-font-display);
  font-size: 1.45rem;
  line-height: 1.02;
}

.mi-cart-drawer__item-main small {
  margin-top: 0.15rem;
  letter-spacing: 0.06em;
}

.mi-cart-drawer__remove {
  margin-top: 0.6rem;
  color: var(--mi-color-text-muted);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.mi-cart-drawer__item-side {
  display: grid;
  justify-items: end;
  gap: var(--mi-space-2);
}

.mi-cart-drawer__item-side b {
  display: block;
  font-family: var(--mi-font-display);
  font-size: 1.35rem;
}

.mi-cart-drawer__qty {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.3rem;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-pill);
  background: rgba(255, 255, 255, 0.62);
}

.mi-cart-drawer__qty button {
  width: 1.8rem;
  height: 1.8rem;
  border-radius: 50%;
  background: var(--mi-color-surface-strong);
  font-weight: 900;
}

.mi-cart-drawer__qty span {
  min-width: 1.2rem;
  text-align: center;
  color: var(--mi-color-text);
  font-size: 0.8rem;
  font-weight: 800;
}

.mi-cart-drawer__footer {
  display: grid;
  gap: var(--mi-space-3);
  padding-top: var(--mi-space-4);
  border-top: 1px solid var(--mi-color-border);
}

.mi-cart-drawer__totals {
  display: grid;
  gap: var(--mi-space-3);
}

.mi-cart-drawer__totals p {
  color: var(--mi-color-text-muted);
  font-size: 0.9rem;
  line-height: 1.7;
}

.mi-cart-drawer__subtotal {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--mi-color-text-muted);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-cart-drawer__subtotal strong {
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: 2rem;
  letter-spacing: 0;
  text-transform: none;
}

.mi-cart-drawer__checkout,
.mi-cart-drawer__continue {
  width: 100%;
}

.mi-cart-drawer__continue {
  color: var(--mi-color-text-muted);
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body.mi-cart-drawer-open {
  overflow: hidden;
}

.mi-account-drawer {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  justify-items: end;
}

.mi-account-drawer[hidden] {
  display: none;
}

.mi-account-drawer__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(74, 49, 53, 0.18);
  backdrop-filter: blur(12px);
}

.mi-account-drawer__panel {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  gap: var(--mi-space-4);
  width: min(100vw, 27rem);
  height: 100%;
  padding: clamp(var(--mi-space-5), 4vw, var(--mi-space-6));
  border-left: 1px solid rgba(184, 94, 117, 0.18);
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.94), rgba(255, 247, 250, 0.88));
  box-shadow: -24px 0 70px rgba(74, 49, 53, 0.16);
  overflow-y: auto;
}

.mi-account-drawer__header,
.mi-account-drawer__row,
.mi-account-drawer__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--mi-space-3);
}

.mi-account-drawer__eyebrow {
  margin: 0 0 0.45rem;
  color: var(--mi-color-primary-strong);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.mi-account-drawer__header h2 {
  margin: 0;
  font-size: clamp(2.1rem, 5vw, 3.1rem);
  line-height: 1;
  letter-spacing: 0;
}

.mi-account-drawer__close {
  position: relative;
  flex: 0 0 auto;
  width: 2.65rem;
  height: 2.65rem;
  border: 1px solid rgba(184, 94, 117, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--mi-color-text);
  cursor: pointer;
}

.mi-account-drawer__close::before,
.mi-account-drawer__close::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  width: 1rem;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}

.mi-account-drawer__close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.mi-account-drawer__close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.mi-account-drawer__intro {
  margin: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.7;
}

.mi-account-drawer__form {
  display: grid;
  align-content: start;
  gap: var(--mi-space-3);
}

.mi-social-login {
  display: grid;
  gap: var(--mi-space-3);
}

.mi-social-login__divider {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  color: var(--mi-color-text-muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.mi-social-login__divider::before,
.mi-social-login__divider::after {
  content: '';
  flex: 1 1 auto;
  height: 1px;
  background: rgba(184, 94, 117, 0.16);
}

.mi-social-login__buttons {
  display: grid;
  gap: 0.7rem;
}

.mi-social-login__button,
.mi-social-login__button > *,
.mi-social-login__button a,
.mi-social-login__button button {
  width: 100%;
  max-width: none;
}

.mi-social-login__button a,
.mi-social-login__button button {
  min-height: 3rem;
  border-radius: 999px !important;
}

.mi-account-auth__panel .mi-social-login {
  margin-bottom: var(--mi-space-3);
}

.mi-account-drawer__form .form-row {
  display: grid;
  gap: 0.55rem;
  margin: 0;
  padding: 0;
}

.mi-account-drawer__form label,
.mi-account-drawer__row {
  color: var(--mi-color-text);
  font-size: 0.78rem;
  font-weight: 850;
  letter-spacing: 0.04em;
}

.mi-account-drawer__form input.input-text,
.mi-account-drawer__form .woocommerce-Input {
  width: 100%;
  min-height: 3.25rem;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(184, 94, 117, 0.18);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.82);
  color: var(--mi-color-text);
  outline: none;
}

.mi-account-drawer__form input.input-text:focus,
.mi-account-drawer__form .woocommerce-Input:focus {
  border-color: rgba(184, 94, 117, 0.46);
  background: #fff;
  box-shadow: 0 0 0 0.25rem rgba(184, 94, 117, 0.12);
}

.mi-account-drawer__row {
  flex-wrap: wrap;
  color: var(--mi-color-text-muted);
  letter-spacing: 0;
}

.mi-account-drawer__row label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.mi-account-drawer__row a,
.mi-account-drawer__footer a {
  color: var(--mi-color-primary-strong);
  font-weight: 900;
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

.mi-account-drawer__form .mi-button {
  width: 100%;
  margin-top: 0.25rem;
  border-radius: 999px;
}

.mi-account-drawer__footer {
  align-items: flex-start;
  padding-top: var(--mi-space-4);
  border-top: 1px solid rgba(184, 94, 117, 0.14);
  color: var(--mi-color-text-muted);
  font-size: 0.84rem;
  line-height: 1.55;
}

body.mi-account-drawer-open {
  overflow: hidden;
}

.mi-theme-toggle__icon {
  width: 1.1rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--mi-gradient-primary);
  box-shadow: inset -0.28rem -0.2rem 0 rgba(255, 255, 255, 0.52), var(--mi-shadow-glow);
  transition: transform var(--mi-duration-base) var(--mi-ease-luxury),
              box-shadow var(--mi-duration-base) var(--mi-ease-luxury);
}

[data-theme="dark"] .mi-theme-toggle__icon {
  transform: rotate(-28deg);
  box-shadow: inset -0.42rem -0.18rem 0 rgba(19, 11, 20, 0.72), 0 0 40px rgba(255, 141, 183, 0.34);
}

.mi-menu-button {
  display: none;
}

.mi-menu-button span {
  position: absolute;
  width: 1.05rem;
  height: 2px;
  border-radius: var(--mi-radius-pill);
  background: currentColor;
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              translate var(--mi-duration-base) var(--mi-ease-out);
}

.mi-menu-button span:first-child {
  translate: 0 -0.22rem;
}

.mi-menu-button span:last-child {
  translate: 0 0.22rem;
}

.mi-menu-button[aria-expanded="true"] span:first-child {
  translate: 0 0;
  transform: rotate(45deg);
}

.mi-menu-button[aria-expanded="true"] span:last-child {
  translate: 0 0;
  transform: rotate(-45deg);
}

.mi-mega-menu {
  position: relative;
  z-index: calc(var(--mi-z-modal) + 12);
  display: grid;
  grid-template-columns: 1.35fr repeat(4, 1fr);
  gap: var(--mi-space-3);
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-0.5rem) scale(0.98);
  pointer-events: none;
  transition: max-height var(--mi-duration-slow) var(--mi-ease-luxury),
              opacity var(--mi-duration-base) var(--mi-ease-out),
              transform var(--mi-duration-base) var(--mi-ease-out),
              padding var(--mi-duration-base) var(--mi-ease-out);
}

.mi-nav-shell.is-mega-open .mi-mega-menu {
  max-height: 14rem;
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
  padding-top: var(--mi-space-3);
}

.mi-mega-menu > div,
.mi-mega-menu > a {
  min-height: 6.5rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--mi-space-4);
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-sm);
  backdrop-filter: blur(18px) saturate(1.2);
}

.mi-mega-menu p {
  margin: 0 0 var(--mi-space-2);
  color: var(--mi-color-primary-strong);
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.mi-mega-menu strong {
  font-family: var(--mi-font-display);
  font-size: 1.65rem;
  font-weight: 600;
  line-height: 1;
}

.mi-mega-menu a {
  color: var(--mi-color-text);
  font-weight: 800;
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              border-color var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out);
}

.mi-mega-menu a:hover,
.mi-mega-menu a:focus-visible {
  transform: translateY(-4px);
  border-color: rgba(239, 127, 165, 0.42);
  box-shadow: var(--mi-shadow-md);
}

.mi-mobile-menu {
  display: none;
}

.mi-main {
  position: relative;
}

.mi-section {
  padding-block: var(--mi-section-y);
}

.mi-section--intro {
  min-height: calc(var(--mi-hero-min-h) - 5rem);
  display: grid;
  align-items: center;
  padding-block: clamp(4rem, 9vw, 8rem);
}

.mi-container {
  width: min(100% - (var(--mi-page-gutter) * 2), var(--mi-container));
  margin-inline: auto;
}

.mi-container--hero {
  width: min(100% - (var(--mi-page-gutter) * 2), var(--mi-container-wide));
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(19rem, 0.72fr);
  align-items: center;
  gap: clamp(var(--mi-space-6), 6vw, var(--mi-space-9));
}

.mi-stack {
  display: grid;
  gap: var(--mi-space-4);
}

.mi-stack--xl {
  gap: var(--mi-space-5);
}

.mi-eyebrow {
  margin: 0;
  color: var(--mi-color-primary-strong);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

h1,
h2,
h3,
p {
  margin-block-start: 0;
}

h1,
h2,
h3 {
  color: var(--mi-color-text);
  text-wrap: balance;
}

h1 {
  max-width: 11ch;
  margin-block-end: 0;
  font-family: var(--mi-font-display);
  font-size: clamp(4.5rem, 13vw, 11rem);
  font-weight: 600;
  line-height: 0.84;
  letter-spacing: -0.065em;
}

h2 {
  margin-block-end: var(--mi-space-4);
  font-family: var(--mi-font-display);
  font-size: clamp(3rem, 8vw, 6.5rem);
  font-weight: 600;
  line-height: 0.9;
  letter-spacing: -0.05em;
}

h3 {
  margin-block: 0 var(--mi-space-3);
  font-family: var(--mi-font-display);
  font-size: clamp(1.8rem, 4vw, 2.55rem);
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.035em;
}

.mi-lede {
  max-width: 45rem;
  margin: 0;
  color: var(--mi-color-text-muted);
  font-size: clamp(1.05rem, 2vw, 1.35rem);
  line-height: 1.8;
  text-wrap: pretty;
}

.mi-glass-panel,
.mi-feature-card {
  border: 1px solid var(--mi-color-border);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(24px) saturate(1.2);
}

.mi-glass-panel {
  position: relative;
  overflow: hidden;
  padding: clamp(var(--mi-space-5), 4vw, var(--mi-space-7));
  border-radius: var(--mi-radius-xl);
}

.mi-glass-panel::before {
  content: "";
  position: absolute;
  inset: -40% auto auto -20%;
  width: 18rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 195, 215, 0.42), transparent 65%);
}

.mi-panel-kicker {
  margin: 0 0 var(--mi-space-5);
  color: var(--mi-color-accent);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.mi-check-list {
  display: grid;
  gap: var(--mi-space-4);
  margin: 0;
  padding: 0;
  list-style: none;
}

.mi-check-list li {
  display: grid;
  grid-template-columns: 1.35rem 1fr;
  gap: var(--mi-space-3);
  color: var(--mi-color-text-muted);
  line-height: 1.55;
}

.mi-check-list li::before {
  content: "";
  width: 0.7rem;
  height: 0.7rem;
  margin-top: 0.42rem;
  border-radius: 50%;
  background: var(--mi-gradient-primary);
  box-shadow: 0 0 24px rgba(239, 127, 165, 0.36);
}

.mi-section-heading {
  max-width: 52rem;
  margin-bottom: var(--mi-space-7);
}

.mi-section-heading p:not(.mi-eyebrow) {
  max-width: 42rem;
  margin: 0;
  color: var(--mi-color-text-muted);
  font-size: 1.05rem;
  line-height: 1.8;
}

.mi-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--mi-space-4);
}

.mi-feature-card {
  min-height: 19rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(var(--mi-space-5), 3vw, var(--mi-space-6));
  border-radius: var(--mi-radius-lg);
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out),
              border-color var(--mi-duration-base) var(--mi-ease-out);
}

.mi-feature-card:hover {
  transform: translateY(-8px);
  border-color: rgba(239, 127, 165, 0.38);
  box-shadow: var(--mi-shadow-lg);
}

.mi-feature-card span {
  width: 2.6rem;
  height: 2.6rem;
  display: inline-grid;
  place-items: center;
  margin-bottom: auto;
  border-radius: 50%;
  background: var(--mi-color-surface-strong);
  color: var(--mi-color-primary-strong);
  font-size: 0.78rem;
  font-weight: 800;
  box-shadow: var(--mi-shadow-sm);
}

.mi-feature-card p {
  margin: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.7;
}

@keyframes mi-page-breathe {
  from {
    background-position: 0% 30%;
  }
  to {
    background-position: 100% 70%;
  }
}

@keyframes mi-orb-float {
  from {
    transform: translate3d(-2%, -1%, 0) scale(1);
  }
  to {
    transform: translate3d(4%, 3%, 0) scale(1.08);
  }
}

@media (max-width: 1080px) {
  .mi-nav {
    grid-template-columns: 1fr auto;
  }

  .mi-nav__links,
  .mi-nav__account,
  .mi-mega-menu {
    display: none;
  }

  .mi-menu-button {
    display: inline-grid;
  }

  .mi-mobile-menu {
    position: fixed;
    inset: 5.25rem var(--mi-page-gutter) auto;
    z-index: calc(var(--mi-z-header) + 1);
    display: grid;
    gap: var(--mi-space-2);
    padding: var(--mi-space-4);
    border: 1px solid var(--mi-color-border);
    border-radius: var(--mi-radius-lg);
    background: var(--mi-color-surface-strong);
    box-shadow: var(--mi-shadow-lg);
    backdrop-filter: blur(24px) saturate(1.25);
    opacity: 0;
    transform: translateY(-0.75rem) scale(0.98);
    pointer-events: none;
    transition: opacity var(--mi-duration-base) var(--mi-ease-out),
                transform var(--mi-duration-base) var(--mi-ease-out);
  }

  .mi-mobile-menu.is-open {
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
  }

  .mi-mobile-menu a {
    min-height: 3.3rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-inline: var(--mi-space-4);
    border-radius: var(--mi-radius-md);
    color: var(--mi-color-text);
    font-family: var(--mi-font-display);
    font-size: 1.55rem;
    font-weight: 600;
    background: rgba(255, 255, 255, 0.22);
  }

  .mi-mobile-menu a::after {
    content: "?";
    color: var(--mi-color-primary-strong);
    font-family: var(--mi-font-body);
    font-size: 1rem;
  }
}

@media (max-width: 920px) {
  .mi-container--hero,
  .mi-feature-grid {
    grid-template-columns: 1fr;
  }

  .mi-section--intro {
    min-height: auto;
  }

  .mi-glass-panel {
    max-width: none;
  }
}

@media (max-width: 640px) {
  .mi-product-grid {
    grid-template-columns: 1fr;
  }

  .mi-product-media {
    min-height: 20rem;
  }

  .mi-product-footer {
    align-items: stretch;
    flex-direction: column;
  }

  .mi-add-button {
    width: 100%;
  }

  .mi-quick-modal {
    padding: var(--mi-space-4);
  }

  .mi-quick-modal__panel {
    border-radius: var(--mi-radius-lg);
  }

  .mi-cart-drawer__panel {
    width: min(100%, 24rem);
    padding: var(--mi-space-5) var(--mi-space-4);
  }

  .mi-cart-drawer__item {
    grid-template-columns: 3.8rem minmax(0, 1fr);
  }

  .mi-cart-drawer__item-side {
    grid-column: 2;
    justify-items: start;
    margin-top: var(--mi-space-2);
  }
}

@media (max-width: 430px) {
  .mi-theme-toggle {
    display: none;
  }

  .mi-wordmark span {
    font-size: 1.35rem;
  }
}

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

  .mi-cursor-glow {
    display: none;
  }
}

/* Step 4: Immersive Hero Section */
.mi-section--hero {
  position: relative;
  min-height: calc(var(--mi-hero-min-h) - 4rem);
  display: grid;
  align-items: center;
  padding-block: clamp(4.5rem, 9vw, 8.5rem);
}

.mi-section--hero::before {
  content: "";
  position: absolute;
  inset: 6% var(--mi-page-gutter) auto;
  height: min(34rem, 58vw);
  z-index: -1;
  border-radius: 999px;
  background: radial-gradient(circle at 22% 35%, rgba(255, 195, 215, 0.38), transparent 34%),
              radial-gradient(circle at 78% 28%, rgba(216, 154, 130, 0.28), transparent 32%),
              linear-gradient(120deg, rgba(255, 255, 255, 0.72), rgba(255, 238, 245, 0.36));
  filter: blur(10px);
  opacity: 0.86;
}

.mi-hero-copy {
  position: relative;
  z-index: 2;
}

.mi-hero-copy .mi-lede {
  max-width: 42rem;
}

.mi-hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--mi-space-3);
}

.mi-button {
  position: relative;
  min-height: 3.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding-inline: 1.35rem;
  border-radius: var(--mi-radius-pill);
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: 0.055em;
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out),
              border-color var(--mi-duration-base) var(--mi-ease-out);
}

.mi-button::after {
  content: "";
  position: absolute;
  inset: -40% auto -40% -65%;
  width: 55%;
  transform: skewX(-18deg);
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.52), transparent);
  transition: translate var(--mi-duration-slow) var(--mi-ease-luxury);
}

.mi-button:hover {
  transform: translateY(-3px);
}

.mi-button:hover::after {
  translate: 330% 0;
}

.mi-button--primary {
  border: 1px solid rgba(239, 127, 165, 0.22);
  background: var(--mi-gradient-primary);
  color: #fff;
  box-shadow: var(--mi-shadow-glow);
}

.mi-button--primary:hover {
  box-shadow: var(--mi-shadow-lg);
}

.mi-button--secondary {
  border: 1px solid var(--mi-color-border);
  background: var(--mi-color-surface);
  color: var(--mi-color-text);
  box-shadow: var(--mi-shadow-sm);
  backdrop-filter: blur(18px) saturate(1.2);
}

.mi-button--secondary:hover {
  border-color: rgba(239, 127, 165, 0.38);
  box-shadow: var(--mi-shadow-md);
}

.mi-hero-proof {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mi-space-2);
  padding-top: var(--mi-space-2);
}

.mi-hero-proof span {
  min-height: 2.35rem;
  display: inline-flex;
  align-items: center;
  gap: var(--mi-space-2);
  padding-inline: 0.9rem;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-pill);
  background: rgba(255, 255, 255, 0.42);
  color: var(--mi-color-text-muted);
  font-size: 0.76rem;
  font-weight: 800;
  backdrop-filter: blur(14px);
}

.mi-hero-proof span::before {
  content: "";
  width: 0.45rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--mi-gradient-primary);
  box-shadow: 0 0 18px rgba(239, 127, 165, 0.32);
}

.mi-hero-visual {
  position: relative;
  min-height: clamp(31rem, 46vw, 44rem);
  perspective: 1200px;
  transform-style: preserve-3d;
  isolation: isolate;
}

.mi-hero-video-card,
.mi-hero-product-card,
.mi-floating-tag {
  border: 1px solid var(--mi-color-border);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(24px) saturate(1.25);
}

.mi-hero-video-card {
  position: absolute;
  inset: 4% 4% auto auto;
  width: min(82%, 31rem);
  min-height: clamp(18rem, 29vw, 27rem);
  overflow: hidden;
  border-radius: var(--mi-radius-xl);
  transform: rotate(2deg) translateZ(30px);
}

.mi-hero-video-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 22% 20%, rgba(255, 255, 255, 0.9), transparent 24%),
              radial-gradient(circle at 72% 38%, rgba(255, 183, 203, 0.7), transparent 34%),
              linear-gradient(135deg, rgba(255, 255, 255, 0.64), rgba(255, 195, 215, 0.58), rgba(216, 154, 130, 0.3));
  background-size: 160% 160%;
  animation: mi-hero-gradient-drift calc(var(--mi-duration-ambient) * 1.2) var(--mi-ease-soft) infinite alternate;
}

.mi-video-sheen {
  position: absolute;
  inset: -40% auto -40% -55%;
  width: 40%;
  transform: rotate(18deg);
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.46), transparent);
  animation: mi-video-sheen 5200ms var(--mi-ease-luxury) infinite;
}

.mi-video-card__content {
  position: absolute;
  inset: auto var(--mi-space-5) var(--mi-space-5);
  color: #fff;
  text-shadow: 0 12px 32px rgba(75, 57, 66, 0.25);
}

.mi-video-card__content p {
  margin: 0 0 var(--mi-space-2);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.mi-video-card__content strong {
  max-width: 11ch;
  display: block;
  font-family: var(--mi-font-display);
  font-size: clamp(2rem, 5vw, 4.3rem);
  font-weight: 600;
  line-height: 0.9;
  letter-spacing: -0.05em;
}

.mi-product-orbit {
  position: absolute;
  left: 3%;
  top: 14%;
  width: clamp(16rem, 29vw, 26rem);
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  transform: translateZ(70px);
}

.mi-orbit {
  position: absolute;
  border-radius: 50%;
  border: 1px solid rgba(239, 127, 165, 0.24);
  box-shadow: inset 0 0 40px rgba(255, 255, 255, 0.26);
}

.mi-orbit--one {
  inset: 5%;
  animation: mi-orbit-spin 18000ms linear infinite;
}

.mi-orbit--two {
  inset: 18%;
  border-color: rgba(216, 154, 130, 0.26);
  animation: mi-orbit-spin 14000ms linear infinite reverse;
}

.mi-product-silhouette {
  width: 32%;
  height: 72%;
  border-radius: 999px 999px 48% 48%;
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.88), rgba(255, 195, 215, 0.62) 52%, rgba(216, 154, 130, 0.52));
  box-shadow: inset 12px 8px 28px rgba(255, 255, 255, 0.48),
              inset -16px -18px 34px rgba(217, 95, 136, 0.16),
              var(--mi-shadow-lg);
  transform: rotate(12deg);
}

.mi-hero-product-card {
  position: absolute;
  left: 10%;
  right: 10%;
  bottom: 4%;
  z-index: 3;
  padding: clamp(var(--mi-space-5), 3vw, var(--mi-space-6));
  border-radius: var(--mi-radius-xl);
  transform: translateZ(95px);
}

.mi-hero-product-card h2 {
  margin: 0 0 var(--mi-space-3);
  font-size: clamp(2.35rem, 4.5vw, 4rem);
}

.mi-hero-product-card p:not(.mi-panel-kicker) {
  margin: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.7;
}

.mi-product-card__meta {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--mi-space-4);
  margin-top: var(--mi-space-5);
}

.mi-product-card__meta span {
  font-family: var(--mi-font-display);
  font-size: 2.45rem;
  font-weight: 700;
  line-height: 1;
}

.mi-product-card__meta small {
  color: var(--mi-color-primary-strong);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: right;
}

.mi-floating-tag {
  position: absolute;
  z-index: 4;
  min-height: 2.6rem;
  display: inline-flex;
  align-items: center;
  padding-inline: 1rem;
  border-radius: var(--mi-radius-pill);
  color: var(--mi-color-text);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  animation: mi-float-tag 4600ms var(--mi-ease-soft) infinite alternate;
}

.mi-floating-tag::before {
  content: "";
  width: 0.5rem;
  aspect-ratio: 1;
  margin-right: var(--mi-space-2);
  border-radius: 50%;
  background: var(--mi-gradient-primary);
}

.mi-floating-tag--top {
  top: 8%;
  left: 0;
}

.mi-floating-tag--mid {
  right: -2%;
  top: 48%;
  animation-delay: -1500ms;
}

.mi-floating-tag--bottom {
  left: 4%;
  bottom: 15%;
  animation-delay: -2800ms;
}

@keyframes mi-hero-gradient-drift {
  from {
    background-position: 0% 40%;
  }
  to {
    background-position: 100% 60%;
  }
}

@keyframes mi-video-sheen {
  0%, 28% {
    translate: 0 0;
    opacity: 0;
  }
  48% {
    opacity: 1;
  }
  76%, 100% {
    translate: 360% 0;
    opacity: 0;
  }
}

@keyframes mi-orbit-spin {
  to {
    rotate: 360deg;
  }
}

@keyframes mi-float-tag {
  from {
    transform: translate3d(0, -5px, 0);
  }
  to {
    transform: translate3d(0, 7px, 0);
  }
}

@media (max-width: 920px) {
  .mi-section--hero {
    padding-top: clamp(3.5rem, 10vw, 6rem);
  }

  .mi-hero-visual {
    min-height: 36rem;
    max-width: 42rem;
    width: 100%;
    margin-inline: auto;
  }

  .mi-floating-tag--mid {
    right: 0;
  }
}

@media (max-width: 640px) {
  .mi-hero-actions,
  .mi-button {
    width: 100%;
  }

  .mi-hero-proof {
    display: grid;
    grid-template-columns: 1fr;
  }

  .mi-hero-visual {
    min-height: 34rem;
  }

  .mi-hero-video-card {
    inset: 4% 0 auto auto;
    width: 92%;
  }

  .mi-product-orbit {
    left: -8%;
    top: 17%;
  }

  .mi-hero-product-card {
    left: 0;
    right: 0;
  }

  .mi-floating-tag {
    font-size: 0.7rem;
  }
}
/* Step 5: Category Entry System */
.mi-section--categories {
  position: relative;
  overflow: clip;
}

.mi-section--categories::before {
  content: "";
  position: absolute;
  inset: 10% -10% auto auto;
  width: 32rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 195, 215, 0.34), transparent 66%);
  filter: blur(12px);
  pointer-events: none;
}

.mi-section-heading--split {
  max-width: none;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.42fr);
  align-items: end;
  gap: clamp(var(--mi-space-5), 6vw, var(--mi-space-8));
}

.mi-section-heading--split h2 {
  max-width: 11ch;
}

.mi-section-heading--split > p {
  margin-bottom: var(--mi-space-3) !important;
}

.mi-category-grid {
  display: grid;
  grid-template-columns: 1.12fr 0.88fr 0.88fr;
  grid-auto-rows: minmax(18rem, auto);
  gap: var(--mi-space-4);
}

.mi-category-card {
  position: relative;
  min-height: 18rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
  padding: clamp(var(--mi-space-5), 3vw, var(--mi-space-6));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(24px) saturate(1.25);
  transform: translateY(0);
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              border-color var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out);
}

.mi-category-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background: radial-gradient(circle at 24% 20%, rgba(255, 255, 255, 0.86), transparent 28%),
              radial-gradient(circle at 80% 18%, rgba(255, 183, 203, 0.48), transparent 30%),
              linear-gradient(145deg, rgba(255, 255, 255, 0.5), rgba(255, 238, 245, 0.44));
  transition: scale var(--mi-duration-slow) var(--mi-ease-luxury),
              filter var(--mi-duration-slow) var(--mi-ease-luxury);
}

.mi-category-card::after {
  content: "";
  position: absolute;
  right: -14%;
  top: -18%;
  width: 15rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(216, 154, 130, 0.3), transparent 66%);
  transition: transform var(--mi-duration-slow) var(--mi-ease-luxury),
              opacity var(--mi-duration-base) var(--mi-ease-out);
}

.mi-category-card:hover,
.mi-category-card:focus-visible {
  transform: translateY(-10px);
  border-color: rgba(239, 127, 165, 0.42);
  box-shadow: var(--mi-shadow-lg);
}

.mi-category-card:hover::before,
.mi-category-card:focus-visible::before {
  scale: 1.06;
  filter: saturate(1.08);
}

.mi-category-card:hover::after,
.mi-category-card:focus-visible::after {
  transform: translate3d(-10%, 8%, 0) scale(1.12);
  opacity: 0.86;
}

.mi-category-card--large {
  grid-row: span 2;
  min-height: 37rem;
}

.mi-category-card--large::before {
  background: radial-gradient(circle at 18% 16%, rgba(255, 255, 255, 0.92), transparent 26%),
              radial-gradient(circle at 76% 24%, rgba(239, 127, 165, 0.44), transparent 34%),
              radial-gradient(circle at 54% 86%, rgba(216, 154, 130, 0.28), transparent 38%),
              linear-gradient(145deg, rgba(255, 255, 255, 0.62), rgba(255, 220, 233, 0.58));
}

.mi-category-card__index {
  width: 2.75rem;
  height: 2.75rem;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.52);
  color: var(--mi-color-primary-strong);
  font-size: 0.76rem;
  font-weight: 900;
  box-shadow: var(--mi-shadow-sm);
  backdrop-filter: blur(14px);
}

.mi-category-card small {
  display: block;
  margin-bottom: var(--mi-space-3);
  color: var(--mi-color-primary-strong);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.mi-category-card h3 {
  max-width: 8ch;
  font-size: clamp(2.65rem, 6vw, 5.8rem);
}

.mi-category-card:not(.mi-category-card--large) h3 {
  font-size: clamp(2.1rem, 4vw, 3.7rem);
}

.mi-category-card p {
  max-width: 23rem;
  margin: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.7;
}

[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
}

[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 760ms var(--mi-ease-out),
              transform 760ms var(--mi-ease-out);
  transition-delay: calc(var(--mi-reveal-index, 0) * 90ms);
}

@media (max-width: 1020px) {
  .mi-section-heading--split,
  .mi-category-grid {
    grid-template-columns: 1fr;
  }

  .mi-category-card--large {
    grid-row: auto;
    min-height: 24rem;
  }
}

@media (max-width: 640px) {
  .mi-section-heading--split h2 {
    max-width: 8.5ch;
  }

  .mi-category-card,
  .mi-category-card--large {
    min-height: 20rem;
  }

  .mi-category-card h3,
  .mi-category-card:not(.mi-category-card--large) h3 {
    font-size: clamp(2.4rem, 14vw, 4.2rem);
  }
}
/* Step 6: Product Recommendation Cards */
.mi-section--products {
  position: relative;
}

.mi-section--products::before {
  content: "";
  position: absolute;
  left: -12%;
  top: 18%;
  width: 34rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(216, 154, 130, 0.2), transparent 68%);
  filter: blur(14px);
  pointer-events: none;
}

.mi-product-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--mi-space-4);
}

.mi-product-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(24px) saturate(1.2);
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              border-color var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out);
}

.mi-product-card:hover,
.mi-product-card:focus-within {
  transform: translateY(-10px);
  border-color: rgba(239, 127, 165, 0.42);
  box-shadow: var(--mi-shadow-lg);
}

.mi-product-media {
  position: relative;
  min-height: clamp(18rem, 28vw, 25rem);
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: calc(var(--mi-radius-xl) - 0.45rem);
  margin: var(--mi-space-2);
  background: radial-gradient(circle at 30% 18%, rgba(255,255,255,0.86), transparent 26%),
              linear-gradient(145deg, rgba(255, 238, 245, 0.72), rgba(255, 255, 255, 0.52));
}

.mi-product-media::before {
  content: "";
  position: absolute;
  inset: 12%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.62), transparent 62%);
  transform: scale(0.92);
  transition: transform var(--mi-duration-slow) var(--mi-ease-luxury),
              opacity var(--mi-duration-base) var(--mi-ease-out);
}

.mi-product-card:hover .mi-product-media::before,
.mi-product-card:focus-within .mi-product-media::before {
  transform: scale(1.12);
  opacity: 0.86;
}

.mi-product-media--blush {
  background: radial-gradient(circle at 30% 18%, rgba(255,255,255,0.9), transparent 26%), linear-gradient(145deg, #ffeef5, #ffd4e4);
}

.mi-product-media--pearl {
  background: radial-gradient(circle at 28% 18%, rgba(255,255,255,0.9), transparent 25%), linear-gradient(145deg, #fffafd, #f4e9ee);
}

.mi-product-media--rose {
  background: radial-gradient(circle at 30% 20%, rgba(255,255,255,0.86), transparent 26%), linear-gradient(145deg, #fff1ec, #ffc8d8);
}

.mi-product-media--champagne {
  background: radial-gradient(circle at 30% 18%, rgba(255,255,255,0.88), transparent 26%), linear-gradient(145deg, #fff7ed, #f2c6b5);
}

.mi-product-media--violet {
  background: radial-gradient(circle at 30% 18%, rgba(255,255,255,0.78), transparent 26%), linear-gradient(145deg, #fff0f7, #d7c2ef);
}

.mi-product-media--cream {
  background: radial-gradient(circle at 30% 18%, rgba(255,255,255,0.92), transparent 26%), linear-gradient(145deg, #fffdf7, #ffe8d8);
}

.mi-product-badge {
  position: absolute;
  left: var(--mi-space-4);
  top: var(--mi-space-4);
  z-index: 3;
  min-height: 2.15rem;
  display: inline-flex;
  align-items: center;
  padding-inline: 0.8rem;
  border: 1px solid rgba(255, 255, 255, 0.56);
  border-radius: var(--mi-radius-pill);
  background: rgba(255, 255, 255, 0.54);
  color: var(--mi-color-primary-strong);
  box-shadow: var(--mi-shadow-sm);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  backdrop-filter: blur(14px);
}

.mi-product-shape {
  position: relative;
  z-index: 2;
  background: linear-gradient(155deg, rgba(255,255,255,0.94), rgba(255,195,215,0.58) 52%, rgba(216,154,130,0.5));
  box-shadow: inset 12px 10px 24px rgba(255,255,255,0.5),
              inset -16px -18px 34px rgba(217,95,136,0.14),
              0 30px 80px rgba(75,57,66,0.16);
  transition: transform var(--mi-duration-slow) var(--mi-ease-luxury),
              filter var(--mi-duration-slow) var(--mi-ease-luxury);
}

.mi-product-card:hover .mi-product-shape,
.mi-product-card:focus-within .mi-product-shape {
  transform: translateY(-8px) scale(1.06) rotate(var(--mi-product-rotate, 0deg));
  filter: saturate(1.08);
}

.mi-product-shape--wand {
  --mi-product-rotate: 10deg;
  width: 22%;
  height: 68%;
  border-radius: 999px;
  rotate: 10deg;
}

.mi-product-shape--drop {
  --mi-product-rotate: -8deg;
  width: 34%;
  height: 58%;
  border-radius: 60% 60% 48% 48%;
  rotate: -8deg;
}

.mi-product-shape--curve {
  --mi-product-rotate: 18deg;
  width: 42%;
  height: 50%;
  border-radius: 999px 999px 42% 42%;
  rotate: 18deg;
}

.mi-product-shape--bottle {
  --mi-product-rotate: -4deg;
  width: 30%;
  height: 62%;
  border-radius: 32% 32% 22% 22%;
  rotate: -4deg;
}

.mi-product-shape--loop {
  --mi-product-rotate: 12deg;
  width: 48%;
  height: 48%;
  border: 1.8rem solid rgba(255, 255, 255, 0.62);
  border-radius: 48% 52% 50% 50%;
  background: linear-gradient(155deg, rgba(255,195,215,0.42), rgba(216,154,130,0.38));
  rotate: 12deg;
}

.mi-product-shape--jar {
  --mi-product-rotate: 0deg;
  width: 42%;
  height: 46%;
  border-radius: 34% 34% 42% 42%;
}

.mi-quick-view {
  position: absolute;
  left: 50%;
  bottom: var(--mi-space-4);
  z-index: 4;
  min-height: 2.8rem;
  padding-inline: 1rem;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-pill);
  background: var(--mi-color-surface-strong);
  color: var(--mi-color-text);
  box-shadow: var(--mi-shadow-md);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0;
  transform: translate(-50%, 14px);
  backdrop-filter: blur(18px) saturate(1.2);
  transition: opacity var(--mi-duration-base) var(--mi-ease-out),
              transform var(--mi-duration-base) var(--mi-ease-out),
              border-color var(--mi-duration-base) var(--mi-ease-out);
}

.mi-product-card:hover .mi-quick-view,
.mi-product-card:focus-within .mi-quick-view {
  opacity: 1;
  transform: translate(-50%, 0);
}

.mi-quick-view:hover,
.mi-quick-view:focus-visible {
  border-color: rgba(239, 127, 165, 0.42);
}

.mi-product-info {
  padding: var(--mi-space-4) var(--mi-space-5) var(--mi-space-5);
}

.mi-product-info > p {
  margin: 0 0 var(--mi-space-2);
  color: var(--mi-color-primary-strong);
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.mi-product-info h3 {
  max-width: 11ch;
  margin-bottom: var(--mi-space-3);
  font-size: clamp(1.85rem, 3vw, 2.7rem);
}

.mi-product-rating {
  display: flex;
  align-items: center;
  gap: var(--mi-space-2);
  margin-bottom: var(--mi-space-4);
  color: var(--mi-color-text-muted);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
}


.mi-product-rating span {
  color: var(--mi-color-text-muted);
  font-weight: 800;
  letter-spacing: 0;
}

.mi-product-rating span[aria-hidden="true"] {
  color: var(--mi-color-text-muted);
}

.mi-product-rating span {
  color: var(--mi-color-text-muted);
  font-weight: 800;
  letter-spacing: 0;
}

.mi-product-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--mi-space-3);
}

.mi-product-footer strong {
  font-family: var(--mi-font-display);
  font-size: 2rem;
  line-height: 1;
}

.mi-add-button {
  position: relative;
  min-height: 2.85rem;
  overflow: hidden;
  padding-inline: 1rem;
  border: 1px solid rgba(239, 127, 165, 0.24);
  border-radius: var(--mi-radius-pill);
  background: var(--mi-gradient-primary);
  color: #fff;
  box-shadow: var(--mi-shadow-sm);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out),
              min-width var(--mi-duration-base) var(--mi-ease-out);
}

.mi-add-button::after {
  content: "";
  position: absolute;
  inset: -50% auto -50% -65%;
  width: 55%;
  transform: skewX(-18deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.48), transparent);
  transition: translate var(--mi-duration-slow) var(--mi-ease-luxury);
}

.mi-add-button:hover,
.mi-add-button:focus-visible {
  transform: translateY(-2px);
  box-shadow: var(--mi-shadow-glow);
}

.mi-add-button:hover::after,
.mi-add-button:focus-visible::after {
  translate: 330% 0;
}

.mi-add-button.is-added {
  min-width: 7.4rem;
  background: linear-gradient(135deg, #d89a82 0%, #ef7fa5 100%);
}

@media (max-width: 1020px) {
  .mi-product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.mi-quick-modal {
  position: fixed;
  inset: 0;
  z-index: var(--mi-z-modal);
  display: grid;
  place-items: center;
  padding: var(--mi-space-6);
}

.mi-quick-modal[hidden] {
  display: none;
}

.mi-quick-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(33, 22, 20, 0.62);
  backdrop-filter: blur(20px) saturate(1.12);
}

.mi-quick-modal__panel {
  position: relative;
  z-index: 1;
  width: min(100%, 34rem);
  padding: clamp(var(--mi-space-5), 4vw, var(--mi-space-7));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-xl);
  color: var(--mi-color-text);
  backdrop-filter: blur(24px) saturate(1.15);
}

.mi-quick-modal__close {
  position: absolute;
  top: var(--mi-space-4);
  right: var(--mi-space-4);
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--mi-color-border);
  border-radius: 50%;
  background: var(--mi-color-surface-strong);
  box-shadow: var(--mi-shadow-sm);
}

.mi-quick-modal__close::before,
.mi-quick-modal__close::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1rem;
  height: 1px;
  background: var(--mi-color-text);
  transform-origin: center;
}

.mi-quick-modal__close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.mi-quick-modal__close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.mi-quick-modal__eyebrow {
  margin: 0 0 var(--mi-space-2);
  color: var(--mi-color-primary-strong);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.mi-quick-modal__panel h2 {
  max-width: 12ch;
  margin-bottom: var(--mi-space-4);
  font-size: clamp(2.1rem, 4vw, 3.4rem);
  line-height: 0.95;
}

.mi-quick-modal__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--mi-space-3);
  margin-bottom: var(--mi-space-4);
}

.mi-quick-modal__meta strong {
  font-family: var(--mi-font-display);
  font-size: clamp(1.6rem, 3vw, 2.1rem);
}

.mi-quick-modal__rating {
  display: flex;
  align-items: center;
  gap: var(--mi-space-2);
  color: var(--mi-color-text-muted);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
}

.mi-quick-modal__rating small {
  color: var(--mi-color-text-muted);
  font-weight: 800;
  letter-spacing: 0;
}


.mi-quick-modal__rating small {
  color: var(--mi-color-text-muted);
  font-weight: 800;
  letter-spacing: 0;
}

.mi-quick-modal__panel p {
  margin-bottom: var(--mi-space-5);
  color: var(--mi-color-text-muted);
  font-size: 0.98rem;
  line-height: 1.8;
}

.mi-quick-modal__cart {
  width: 100%;
}

body.mi-quick-view-open {
  overflow: hidden;
}

@media (max-width: 640px) {
  .mi-product-grid {
    grid-template-columns: 1fr;
  }

  .mi-product-media {
    min-height: 20rem;
  }

  .mi-product-footer {
    align-items: stretch;
    flex-direction: column;
  }

  .mi-add-button {
    width: 100%;
  }

  .mi-quick-modal {
    padding: var(--mi-space-4);
  }

  .mi-quick-modal__panel {
    border-radius: var(--mi-radius-lg);
  }
}

/* Step 7: Discreet Packaging Promise */
.mi-section--privacy {
  position: relative;
  overflow: clip;
}

.mi-section--privacy::before {
  content: "";
  position: absolute;
  inset: 6% 4% auto;
  height: 42rem;
  z-index: -1;
  border-radius: var(--mi-radius-xl);
  background: radial-gradient(circle at 22% 22%, rgba(255, 195, 215, 0.34), transparent 34%),
              radial-gradient(circle at 82% 18%, rgba(216, 154, 130, 0.28), transparent 32%),
              linear-gradient(135deg, rgba(255, 255, 255, 0.58), rgba(255, 238, 245, 0.34));
  filter: blur(8px);
}

.mi-privacy-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(22rem, 1.12fr);
  align-items: center;
  gap: clamp(var(--mi-space-6), 7vw, var(--mi-space-9));
}

.mi-privacy-copy .mi-lede {
  max-width: none;
  margin-bottom: var(--mi-space-5);
}

.mi-privacy-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mi-space-3);
}

.mi-privacy-visual {
  position: relative;
  min-height: clamp(31rem, 48vw, 43rem);
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-lg);
  overflow: hidden;
  backdrop-filter: blur(24px) saturate(1.2);
}

.mi-privacy-visual::before {
  content: "";
  position: absolute;
  inset: -18% -10% auto auto;
  width: 26rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(242, 198, 181, 0.46), transparent 68%);
}

.mi-privacy-visual::after {
  content: "PRIVATE";
  position: absolute;
  left: 6%;
  bottom: -0.08em;
  color: rgba(239, 127, 165, 0.08);
  font-family: var(--mi-font-display);
  font-size: clamp(5rem, 14vw, 13rem);
  font-weight: 700;
  letter-spacing: -0.08em;
  line-height: 0.75;
}

.mi-package-scene {
  position: absolute;
  inset: clamp(2rem, 5vw, 4rem);
  transform-style: preserve-3d;
  perspective: 1200px;
}

.mi-package-box {
  position: absolute;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  border: 1px solid rgba(216, 154, 130, 0.26);
  box-shadow: 0 34px 90px rgba(75, 57, 66, 0.16);
  transform-style: preserve-3d;
}

.mi-package-box span {
  font-family: var(--mi-font-display);
  font-weight: 700;
  letter-spacing: -0.04em;
}

.mi-package-box small {
  color: var(--mi-color-text-muted);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.mi-package-box--outer {
  left: 0;
  bottom: 10%;
  width: min(70%, 29rem);
  height: 44%;
  padding: var(--mi-space-5);
  border-radius: 1.2rem 1.2rem 1.8rem 1.8rem;
  background: linear-gradient(145deg, #f4e5d8, #d7b89e);
  transform: rotateX(58deg) rotateZ(-8deg) translateZ(18px);
}

.mi-package-box--outer::before {
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  top: 20%;
  height: 1px;
  background: rgba(75, 57, 66, 0.12);
  box-shadow: 0 3rem 0 rgba(75, 57, 66, 0.08);
}

.mi-package-box--outer span {
  color: rgba(75, 57, 66, 0.62);
  font-family: var(--mi-font-body);
  font-size: 0.9rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-package-box--inner {
  right: 0;
  top: 4%;
  width: min(62%, 25rem);
  height: 52%;
  padding: var(--mi-space-5);
  border-radius: var(--mi-radius-lg);
  background: linear-gradient(145deg, #fffaf4, #ffeef5 52%, #f2c6b5);
  transform: rotateX(58deg) rotateZ(8deg) translateZ(60px);
}

.mi-package-box--inner::before {
  content: "";
  position: absolute;
  inset: 18% 10% auto;
  height: 0.42rem;
  border-radius: var(--mi-radius-pill);
  background: linear-gradient(90deg, transparent, rgba(216, 154, 130, 0.64), transparent);
}

.mi-package-box--inner span {
  color: var(--mi-color-accent-700);
  font-size: clamp(2rem, 5vw, 4.5rem);
}

.mi-package-card {
  position: absolute;
  right: 8%;
  bottom: 15%;
  width: min(52%, 19rem);
  min-height: 9rem;
  display: flex;
  align-items: end;
  padding: var(--mi-space-5);
  border: 1px solid rgba(216, 154, 130, 0.32);
  border-radius: var(--mi-radius-md);
  background: rgba(255, 255, 255, 0.68);
  box-shadow: var(--mi-shadow-md);
  transform: rotateZ(-4deg) translateZ(100px);
  backdrop-filter: blur(18px) saturate(1.2);
}

.mi-package-card p {
  margin: 0;
  color: var(--mi-color-accent-700);
  font-family: var(--mi-font-display);
  font-size: clamp(1.8rem, 4vw, 3.2rem);
  font-style: italic;
  line-height: 0.98;
  letter-spacing: -0.04em;
}

.mi-privacy-promise-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--mi-space-4);
  margin-top: var(--mi-space-6);
}

.mi-promise-card {
  min-height: 17rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(var(--mi-space-5), 3vw, var(--mi-space-6));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(22px) saturate(1.2);
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              border-color var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out);
}

.mi-promise-card:hover,
.mi-promise-card:focus-within {
  transform: translateY(-8px);
  border-color: rgba(216, 154, 130, 0.42);
  box-shadow: var(--mi-shadow-lg);
}

.mi-promise-card span {
  width: 2.7rem;
  height: 2.7rem;
  display: inline-grid;
  place-items: center;
  margin-bottom: auto;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(255,255,255,0.82), rgba(242,198,181,0.44));
  color: var(--mi-color-accent-700);
  box-shadow: var(--mi-shadow-sm);
  font-size: 0.78rem;
  font-weight: 900;
}

.mi-promise-card h3 {
  max-width: 9ch;
}

.mi-promise-card p {
  margin: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.7;
}

@media (max-width: 1020px) {
  .mi-privacy-layout,
  .mi-privacy-promise-grid {
    grid-template-columns: 1fr;
  }

  .mi-privacy-visual {
    min-height: 35rem;
  }
}

@media (max-width: 640px) {
  .mi-privacy-actions,
  .mi-privacy-actions .mi-button {
    width: 100%;
  }

  .mi-privacy-visual {
    min-height: 31rem;
  }

  .mi-package-scene {
    inset: var(--mi-space-4);
  }

  .mi-package-box--outer {
    width: 78%;
  }

  .mi-package-box--inner {
    width: 74%;
  }

  .mi-package-card {
    right: 0;
    width: 66%;
  }

  .mi-promise-card {
    min-height: 14rem;
  }
}
/* Step 8: Reviews + Social Proof */
.mi-section--reviews {
  position: relative;
  overflow: clip;
}

.mi-section--reviews::before {
  content: "";
  position: absolute;
  inset: 8% auto auto 50%;
  width: min(46rem, 82vw);
  aspect-ratio: 1;
  z-index: -1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(239, 127, 165, 0.2), transparent 68%);
  filter: blur(24px);
  transform: translateX(-50%);
}

.mi-reviews-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.34fr);
  align-items: stretch;
  gap: var(--mi-space-5);
  margin-bottom: var(--mi-space-5);
}

.mi-reviews-hero > div {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: clamp(20rem, 33vw, 30rem);
  padding: clamp(var(--mi-space-6), 5vw, var(--mi-space-8));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: radial-gradient(circle at 18% 12%, rgba(255,255,255,0.86), transparent 28%),
              linear-gradient(145deg, rgba(255, 245, 249, 0.92), rgba(255, 255, 255, 0.66) 48%, rgba(242, 198, 181, 0.38));
  box-shadow: var(--mi-shadow-lg);
  backdrop-filter: blur(24px) saturate(1.18);
}

.mi-reviews-hero h2 {
  max-width: 10ch;
}

.mi-reviews-hero .mi-lede {
  max-width: 50rem;
  margin: var(--mi-space-4) 0 0;
}

.mi-review-proof {
  position: relative;
  overflow: hidden;
  min-height: clamp(20rem, 33vw, 30rem);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(var(--mi-space-5), 4vw, var(--mi-space-7));
  border: 1px solid rgba(216, 154, 130, 0.26);
  border-radius: var(--mi-radius-xl);
  background: linear-gradient(160deg, rgba(255,255,255,0.76), rgba(255,238,245,0.5));
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(22px) saturate(1.18);
}

.mi-review-proof::before {
  content: "";
  position: absolute;
  right: -32%;
  top: -24%;
  width: 17rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(216,154,130,0.28), transparent 68%);
}

.mi-review-proof span,
.mi-review-proof small {
  position: relative;
  z-index: 1;
  color: var(--mi-color-text-muted);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.mi-review-proof strong {
  position: relative;
  z-index: 1;
  margin: var(--mi-space-3) 0 var(--mi-space-2);
  color: var(--mi-color-accent-700);
  font-family: var(--mi-font-display);
  font-size: clamp(4.6rem, 9vw, 8rem);
  line-height: 0.82;
  letter-spacing: -0.08em;
}

.mi-section--brand-promise .mi-reviews-hero {
  align-items: center;
  margin-bottom: 0;
  padding-block: clamp(var(--mi-space-7), 6vw, var(--mi-space-9));
  border-block: 1px solid var(--mi-color-border);
}

.mi-section--brand-promise .mi-reviews-hero > div {
  min-height: auto;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.mi-section--brand-promise .mi-reviews-hero h2 {
  max-width: 14ch;
}

.mi-section--brand-promise .mi-review-proof {
  min-height: 12rem;
  border-radius: var(--mi-radius-lg);
  box-shadow: var(--mi-shadow-sm);
}

.mi-section--brand-promise .mi-review-proof strong {
  font-size: clamp(3.8rem, 7vw, 6rem);
}

.mi-reviews-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(20rem, 1.1fr);
  gap: var(--mi-space-4);
}

.mi-featured-review {
  position: relative;
  min-height: clamp(30rem, 42vw, 40rem);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
  padding: clamp(var(--mi-space-6), 5vw, var(--mi-space-8));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: radial-gradient(circle at 18% 12%, rgba(255,255,255,0.84), transparent 26%),
              linear-gradient(145deg, rgba(255, 245, 249, 0.9), rgba(255, 255, 255, 0.64) 48%, rgba(242, 198, 181, 0.4));
  box-shadow: var(--mi-shadow-lg);
  backdrop-filter: blur(24px) saturate(1.18);
}

.mi-featured-review::before {
  content: "\201C";
  position: absolute;
  right: 6%;
  top: -0.16em;
  color: rgba(239, 127, 165, 0.12);
  font-family: var(--mi-font-display);
  font-size: clamp(12rem, 26vw, 24rem);
  line-height: 1;
}

.mi-review-stars {
  position: relative;
  z-index: 1;
  color: var(--mi-color-text-muted);
  font-size: 0.98rem;
  letter-spacing: 0.08em;
}

.mi-review-stars span {
  color: var(--mi-color-text-muted);
}

.mi-review-stars span[aria-hidden="true"] {
  color: var(--mi-color-text-muted);
}

.mi-featured-review blockquote {
  position: relative;
  z-index: 1;
  max-width: 12ch;
  margin: auto 0;
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: clamp(2.8rem, 6.2vw, 6rem);
  font-weight: 600;
  line-height: 0.94;
  letter-spacing: -0.08em;
}

.mi-featured-review footer {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.mi-featured-review footer span {
  color: var(--mi-color-text);
  font-weight: 900;
}

.mi-featured-review footer small {
  color: var(--mi-color-text-muted);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-quote-wall {
  display: grid;
  gap: var(--mi-space-4);
}

.mi-quote-card {
  min-height: 12.5rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: clamp(var(--mi-space-5), 3vw, var(--mi-space-6));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(20px) saturate(1.18);
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              border-color var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out);
}

.mi-quote-card:nth-child(2) {
  transform: translateX(6%);
}

.mi-quote-card:hover,
.mi-quote-card:focus-within {
  transform: translateY(-7px);
  border-color: rgba(216, 154, 130, 0.38);
  box-shadow: var(--mi-shadow-lg);
}

.mi-quote-card:nth-child(2):hover,
.mi-quote-card:nth-child(2):focus-within {
  transform: translateX(6%) translateY(-7px);
}

.mi-quote-card p {
  margin: 0;
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: clamp(1.65rem, 3vw, 2.65rem);
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.05em;
}

.mi-quote-card span {
  margin-top: var(--mi-space-5);
  color: var(--mi-color-primary-strong);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

@media (max-width: 1020px) {
  .mi-reviews-hero,
  .mi-reviews-layout {
    grid-template-columns: 1fr;
  }

  .mi-reviews-hero > div,
  .mi-review-proof,
  .mi-featured-review {
    min-height: 26rem;
  }

  .mi-quote-card:nth-child(2),
  .mi-quote-card:nth-child(2):hover,
  .mi-quote-card:nth-child(2):focus-within {
    transform: none;
  }
}

@media (max-width: 640px) {
  .mi-reviews-hero > div,
  .mi-review-proof,
  .mi-featured-review {
    min-height: 23rem;
  }

  .mi-featured-review blockquote {
    max-width: 12ch;
  }

  .mi-quote-card {
    min-height: 11rem;
  }
}
/* Step 9: FAQ Accordion */
.mi-section--faq {
  position: relative;
  overflow: clip;
}

.mi-section--faq::before,
.mi-section--faq::after {
  content: "";
  position: absolute;
  z-index: -1;
  border-radius: 50%;
  pointer-events: none;
}

.mi-section--faq::before {
  left: -12%;
  top: 18%;
  width: min(38rem, 72vw);
  aspect-ratio: 1;
  background: radial-gradient(circle, rgba(216, 154, 130, 0.18), transparent 70%);
  filter: blur(18px);
}

.mi-section--faq::after {
  right: -18%;
  bottom: -12%;
  width: min(32rem, 68vw);
  aspect-ratio: 1;
  background: radial-gradient(circle, rgba(239, 127, 165, 0.14), transparent 70%);
  filter: blur(22px);
}

.mi-faq-layout {
  display: grid;
  grid-template-columns: minmax(18rem, 0.72fr) minmax(0, 1.28fr);
  align-items: start;
  gap: clamp(var(--mi-space-5), 7vw, var(--mi-space-9));
}

.mi-faq-intro {
  position: sticky;
  top: calc(var(--mi-nav-height) + var(--mi-space-5));
  padding: clamp(var(--mi-space-5), 4vw, var(--mi-space-7));
  border: 1px solid rgba(216, 154, 130, 0.22);
  border-radius: var(--mi-radius-xl);
  background: linear-gradient(150deg, rgba(255, 255, 255, 0.72), rgba(255, 242, 247, 0.48));
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(22px) saturate(1.18);
}

.mi-faq-intro .mi-lede {
  margin-bottom: 0;
}

.mi-faq-note {
  display: grid;
  gap: 0.36rem;
  margin-top: var(--mi-space-6);
  padding-top: var(--mi-space-5);
  border-top: 1px solid rgba(216, 154, 130, 0.2);
}

.mi-faq-note span {
  color: var(--mi-color-text-muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.mi-faq-note strong {
  color: var(--mi-color-primary-strong);
  font-family: var(--mi-font-display);
  font-size: clamp(1.7rem, 3vw, 2.45rem);
  line-height: 0.98;
  letter-spacing: -0.05em;
}

.mi-faq-grid {
  display: grid;
  gap: var(--mi-space-3);
}

.mi-faq-item {
  position: relative;
  overflow: hidden;
  align-self: start;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  background: rgba(255, 255, 255, 0.62);
  box-shadow: var(--mi-shadow-sm);
  backdrop-filter: blur(20px) saturate(1.16);
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              border-color var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out),
              background var(--mi-duration-base) var(--mi-ease-out);
}

.mi-faq-item::before {
  content: "";
  position: absolute;
  inset: -52% -18% auto auto;
  width: 15rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(239, 127, 165, 0.2), transparent 68%);
  opacity: 0;
  transition: opacity var(--mi-duration-base) var(--mi-ease-out);
}

.mi-faq-item:hover,
.mi-faq-item:focus-within,
.mi-faq-item.is-open {
  transform: translateY(-4px);
  border-color: rgba(239, 127, 165, 0.34);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-lg);
}

.mi-faq-item.is-open::before {
  opacity: 1;
}

.mi-faq-question {
  position: relative;
  z-index: 1;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--mi-space-4);
  min-height: 6.4rem;
  padding: var(--mi-space-5) clamp(var(--mi-space-5), 3vw, var(--mi-space-6));
  border: 0;
  background: transparent;
  color: var(--mi-color-text);
  cursor: pointer;
  text-align: left;
}

.mi-faq-question span {
  max-width: 24ch;
  font-family: var(--mi-font-display);
  font-size: clamp(1.8rem, 3.1vw, 3rem);
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: -0.06em;
}

.mi-faq-question i {
  position: relative;
  flex: 0 0 auto;
  width: 2.75rem;
  height: 2.75rem;
  border: 1px solid rgba(216, 154, 130, 0.28);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.58);
  box-shadow: var(--mi-shadow-sm);
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              background var(--mi-duration-base) var(--mi-ease-out),
              border-color var(--mi-duration-base) var(--mi-ease-out);
}

.mi-faq-question i::before,
.mi-faq-question i::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 0.84rem;
  height: 2px;
  border-radius: var(--mi-radius-pill);
  background: var(--mi-color-primary-strong);
  transform: translate(-50%, -50%);
  transition: transform var(--mi-duration-base) var(--mi-ease-out);
}

.mi-faq-question i::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.mi-faq-item.is-open .mi-faq-question i {
  transform: rotate(90deg);
  border-color: rgba(239, 127, 165, 0.38);
  background: linear-gradient(135deg, rgba(255,255,255,0.78), rgba(255,195,215,0.44));
}

.mi-faq-item.is-open .mi-faq-question i::after {
  transform: translate(-50%, -50%) rotate(0deg);
}

.mi-faq-answer {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--mi-duration-slow) var(--mi-ease-luxury);
}

.mi-faq-answer > p {
  overflow: hidden;
  max-width: 60ch;
  margin: 0;
  padding: 0 clamp(var(--mi-space-5), 3vw, var(--mi-space-6));
  color: var(--mi-color-text-muted);
  line-height: 1.78;
  transition: padding-bottom var(--mi-duration-slow) var(--mi-ease-luxury),
              opacity var(--mi-duration-slow) var(--mi-ease-luxury);
  opacity: 0;
}

.mi-faq-item.is-open .mi-faq-answer {
  grid-template-rows: 1fr;
}

.mi-faq-item.is-open .mi-faq-answer > p {
  padding-bottom: clamp(var(--mi-space-5), 3vw, var(--mi-space-6));
  opacity: 1;
}

@media (max-width: 1020px) {
  .mi-faq-layout {
    grid-template-columns: 1fr;
  }

  .mi-faq-intro {
    position: static;
  }
}

@media (max-width: 640px) {
  .mi-faq-intro {
    padding: var(--mi-space-5);
  }

  .mi-faq-question {
    min-height: 5.6rem;
    padding: var(--mi-space-4);
  }

  .mi-faq-question span {
    max-width: 18ch;
  }

  .mi-faq-question i {
    width: 2.45rem;
    height: 2.45rem;
  }

  .mi-faq-answer > p {
    padding-inline: var(--mi-space-4);
  }

  .mi-faq-item.is-open .mi-faq-answer > p {
    padding-bottom: var(--mi-space-4);
  }
}

/* Step 12: Guides / Blog / Learn */
.mi-section--guides {
  position: relative;
  overflow: clip;
}

.mi-section--guides::before {
  content: "";
  position: absolute;
  inset: 10% auto auto -16%;
  width: min(42rem, 78vw);
  aspect-ratio: 1;
  z-index: -1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(239, 127, 165, 0.16), transparent 70%);
  filter: blur(22px);
}

.mi-guides-header {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(20rem, 0.72fr);
  align-items: end;
  gap: var(--mi-space-5);
  margin-bottom: var(--mi-space-5);
}

.mi-guides-header h2 {
  max-width: 11ch;
}

.mi-guides-header .mi-lede {
  margin: 0;
}

.mi-guides-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(18rem, 0.88fr);
  gap: var(--mi-space-4);
}

.mi-guide-card {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(8rem, 0.45fr) minmax(0, 1fr);
  min-height: 22rem;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(22px) saturate(1.18);
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              border-color var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out);
}

.mi-guide-card--featured {
  grid-row: span 2;
  grid-template-columns: 1fr;
  min-height: clamp(34rem, 48vw, 44rem);
}

.mi-guide-card:hover,
.mi-guide-card:focus-within {
  transform: translateY(-7px);
  border-color: rgba(216, 154, 130, 0.36);
  box-shadow: var(--mi-shadow-lg);
}

.mi-guide-card__media {
  position: relative;
  min-height: 100%;
  background: radial-gradient(circle at 30% 24%, rgba(255,255,255,0.78), transparent 28%),
              linear-gradient(145deg, rgba(255, 218, 231, 0.5), rgba(242, 198, 181, 0.42));
}

.mi-guide-card--featured .mi-guide-card__media {
  min-height: 18rem;
}

.mi-guide-card__media::before,
.mi-guide-card__media::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.58);
  background: rgba(255, 255, 255, 0.24);
  box-shadow: inset 0 0 0 1px rgba(216, 154, 130, 0.12);
}

.mi-guide-card__media::before {
  width: 58%;
  height: 42%;
  left: 18%;
  top: 22%;
  transform: rotate(-18deg);
}

.mi-guide-card__media::after {
  width: 36%;
  height: 28%;
  right: 14%;
  bottom: 18%;
  transform: rotate(16deg);
}

.mi-guide-card__media span {
  position: absolute;
  left: var(--mi-space-4);
  bottom: var(--mi-space-4);
  color: rgba(107, 69, 89, 0.24);
  font-family: var(--mi-font-display);
  font-size: clamp(4rem, 10vw, 7rem);
  font-weight: 700;
  line-height: 0.78;
  letter-spacing: -0.08em;
}

.mi-guide-card__content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: clamp(var(--mi-space-5), 4vw, var(--mi-space-7));
}

.mi-guide-card__content h3 {
  max-width: 11ch;
  margin: 0;
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: clamp(2rem, 4.4vw, 4.4rem);
  font-weight: 700;
  line-height: 0.92;
  letter-spacing: -0.07em;
}

.mi-guide-card:not(.mi-guide-card--featured) .mi-guide-card__content h3 {
  font-size: clamp(1.8rem, 3vw, 2.8rem);
}

.mi-guide-card__content > p:not(.mi-eyebrow) {
  max-width: 34rem;
  margin: var(--mi-space-4) 0 var(--mi-space-5);
  color: var(--mi-color-text-muted);
  line-height: 1.74;
}

.mi-guide-card__content a {
  margin-top: auto;
  color: var(--mi-color-primary-strong);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.13em;
  text-decoration: none;
  text-transform: uppercase;
}

.mi-guide-card__content a::after {
  content: " ->";
  letter-spacing: 0;
}

@media (max-width: 1020px) {
  .mi-guides-header,
  .mi-guides-grid {
    grid-template-columns: 1fr;
  }

  .mi-guide-card--featured {
    min-height: auto;
  }
}

@media (max-width: 640px) {
  .mi-guide-card,
  .mi-guide-card--featured {
    grid-template-columns: 1fr;
  }

  .mi-guide-card,
  .mi-guide-card__media,
  .mi-guide-card--featured .mi-guide-card__media {
    min-height: 13rem;
  }
}

/* Step 13: Contact / Private Support */
.mi-section--contact {
  position: relative;
  overflow: clip;
}

.mi-section--contact::before {
  content: "";
  position: absolute;
  inset: 4% -16% auto auto;
  width: min(42rem, 76vw);
  aspect-ratio: 1;
  z-index: -1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(242, 198, 181, 0.24), transparent 70%);
  filter: blur(24px);
}

.mi-contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(22rem, 0.92fr);
  align-items: start;
  gap: clamp(var(--mi-space-5), 6vw, var(--mi-space-8));
}

.mi-contact-copy {
  min-height: clamp(34rem, 46vw, 42rem);
  display: flex;
  flex-direction: column;
  padding: clamp(var(--mi-space-6), 5vw, var(--mi-space-8));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: radial-gradient(circle at 20% 14%, rgba(255,255,255,0.86), transparent 30%),
              linear-gradient(145deg, rgba(255, 245, 249, 0.9), rgba(255, 255, 255, 0.66) 50%, rgba(242, 198, 181, 0.34));
  box-shadow: var(--mi-shadow-lg);
  backdrop-filter: blur(24px) saturate(1.18);
}

.mi-contact-copy h2 {
  max-width: 10ch;
}

.mi-contact-copy .mi-lede {
  max-width: 48rem;
  margin-bottom: 0;
}

.mi-contact-promises {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--mi-space-3);
  margin-top: auto;
  padding-top: var(--mi-space-6);
}

.mi-contact-promises article {
  padding: var(--mi-space-4);
  border: 1px solid rgba(216, 154, 130, 0.2);
  border-radius: var(--mi-radius-md);
  background: rgba(255, 255, 255, 0.5);
}

.mi-contact-promises span {
  display: block;
  color: rgba(107, 69, 89, 0.28);
  font-family: var(--mi-font-display);
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 0.88;
  letter-spacing: -0.08em;
}

.mi-contact-promises strong {
  display: block;
  margin-top: var(--mi-space-3);
  color: var(--mi-color-text);
  font-weight: 900;
}

.mi-contact-promises p {
  margin: var(--mi-space-2) 0 0;
  color: var(--mi-color-text-muted);
  font-size: 0.88rem;
  line-height: 1.62;
}

.mi-contact-form {
  display: grid;
  gap: var(--mi-space-4);
  padding: clamp(var(--mi-space-5), 4vw, var(--mi-space-6));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-lg);
  backdrop-filter: blur(22px) saturate(1.18);
}

.mi-contact-form__header {
  display: flex;
  justify-content: space-between;
  gap: var(--mi-space-3);
  padding-bottom: var(--mi-space-4);
  border-bottom: 1px solid rgba(216, 154, 130, 0.18);
}

.mi-contact-form__header span,
.mi-contact-form label span,
.mi-contact-form small {
  color: var(--mi-color-text-muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.mi-contact-form__header strong {
  color: var(--mi-color-primary-strong);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-contact-form label {
  display: grid;
  gap: var(--mi-space-2);
}

.mi-contact-form input,
.mi-contact-form select,
.mi-contact-form textarea {
  width: 100%;
  min-height: 3.15rem;
  padding: 0 var(--mi-space-4);
  border: 1px solid rgba(216, 154, 130, 0.26);
  border-radius: var(--mi-radius-md);
  background: rgba(255, 255, 255, 0.68);
  color: var(--mi-color-text);
  font: inherit;
  outline: none;
  transition: border-color var(--mi-duration-fast) var(--mi-ease-out),
              box-shadow var(--mi-duration-fast) var(--mi-ease-out),
              background var(--mi-duration-fast) var(--mi-ease-out);
}

.mi-contact-form textarea {
  min-height: 8.5rem;
  padding-top: var(--mi-space-3);
  resize: vertical;
}

.mi-contact-form input:focus,
.mi-contact-form select:focus,
.mi-contact-form textarea:focus {
  border-color: rgba(239, 127, 165, 0.48);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 0 0 4px rgba(239, 127, 165, 0.1);
}

.mi-contact-form .mi-button {
  width: 100%;
  margin-top: var(--mi-space-2);
}

.mi-contact-form small {
  line-height: 1.6;
  letter-spacing: 0.08em;
}

@media (max-width: 1020px) {
  .mi-contact-layout,
  .mi-contact-promises {
    grid-template-columns: 1fr;
  }

  .mi-contact-copy {
    min-height: auto;
  }
}

@media (max-width: 640px) {
  .mi-contact-copy,
  .mi-contact-form {
    padding: var(--mi-space-5);
  }

  .mi-contact-form__header {
    flex-direction: column;
  }
}

/* Step 14: Cart / Checkout Trust Preview */
.mi-section--checkout {
  position: relative;
  overflow: clip;
}

.mi-section--checkout::before {
  content: "";
  position: absolute;
  inset: 12% auto auto 44%;
  width: min(46rem, 82vw);
  aspect-ratio: 1;
  z-index: -1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(239, 127, 165, 0.14), transparent 70%);
  filter: blur(24px);
  transform: translateX(-50%);
}

.mi-checkout-header {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(20rem, 0.72fr);
  align-items: end;
  gap: var(--mi-space-5);
  margin-bottom: var(--mi-space-5);
}

.mi-checkout-header h2 {
  max-width: 12ch;
}

.mi-checkout-header .mi-lede {
  margin: 0;
}

.mi-checkout-layout {
  display: grid;
  grid-template-columns: minmax(22rem, 0.88fr) minmax(0, 1.12fr);
  gap: var(--mi-space-4);
  align-items: stretch;
}

.mi-checkout-panel {
  display: grid;
  gap: var(--mi-space-4);
  padding: clamp(var(--mi-space-5), 4vw, var(--mi-space-6));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-lg);
  backdrop-filter: blur(22px) saturate(1.18);
}

.mi-checkout-panel__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--mi-space-3);
  padding-bottom: var(--mi-space-4);
  border-bottom: 1px solid rgba(216, 154, 130, 0.18);
}

.mi-checkout-panel__top span,
.mi-checkout-trust article span {
  color: var(--mi-color-primary-strong);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.mi-checkout-panel__top strong {
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: 1.6rem;
  line-height: 1;
  letter-spacing: -0.04em;
}

.mi-checkout-item {
  display: grid;
  grid-template-columns: 4.6rem minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--mi-space-3);
  padding: var(--mi-space-3);
  border: 1px solid rgba(216, 154, 130, 0.18);
  border-radius: var(--mi-radius-lg);
  background: rgba(255, 255, 255, 0.56);
}

.mi-checkout-item__thumb {
  width: 4.6rem;
  aspect-ratio: 1;
  border-radius: 1.35rem;
  background: radial-gradient(circle at 34% 28%, rgba(255,255,255,0.9), transparent 32%),
              linear-gradient(145deg, rgba(239, 127, 165, 0.34), rgba(242, 198, 181, 0.42));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.48);
}

.mi-checkout-item__thumb--soft {
  background: radial-gradient(circle at 34% 28%, rgba(255,255,255,0.9), transparent 32%),
              linear-gradient(145deg, rgba(242, 198, 181, 0.48), rgba(255, 230, 238, 0.72));
}

.mi-checkout-item h3 {
  margin: 0;
  color: var(--mi-color-text);
  font-size: 1rem;
  line-height: 1.2;
}

.mi-checkout-item p {
  margin: 0.28rem 0 0;
  color: var(--mi-color-text-muted);
  font-size: 0.84rem;
  line-height: 1.5;
}

.mi-checkout-item > strong {
  color: var(--mi-color-text);
  font-weight: 900;
}

.mi-checkout-summary {
  display: grid;
  gap: var(--mi-space-2);
  padding: var(--mi-space-4);
  border: 1px solid rgba(216, 154, 130, 0.18);
  border-radius: var(--mi-radius-lg);
  background: rgba(255, 255, 255, 0.46);
}

.mi-checkout-summary div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--mi-space-3);
  color: var(--mi-color-text-muted);
  font-size: 0.9rem;
}

.mi-checkout-summary div:last-child {
  margin-top: var(--mi-space-2);
  padding-top: var(--mi-space-3);
  border-top: 1px solid rgba(216, 154, 130, 0.18);
  color: var(--mi-color-text);
  font-weight: 900;
}

.mi-checkout-summary strong {
  color: inherit;
  text-align: right;
}

.mi-checkout-panel .mi-button {
  width: 100%;
}

.mi-checkout-trust {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--mi-space-4);
}

.mi-checkout-trust article {
  position: relative;
  overflow: hidden;
  min-height: 25rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(var(--mi-space-5), 3vw, var(--mi-space-6));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: radial-gradient(circle at 20% 14%, rgba(255,255,255,0.78), transparent 30%),
              linear-gradient(145deg, rgba(255, 245, 249, 0.84), rgba(255, 255, 255, 0.58) 54%, rgba(242, 198, 181, 0.34));
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(20px) saturate(1.16);
  transition: transform var(--mi-duration-base) var(--mi-ease-out),
              box-shadow var(--mi-duration-base) var(--mi-ease-out);
}

.mi-checkout-trust article:hover,
.mi-checkout-trust article:focus-within {
  transform: translateY(-7px);
  box-shadow: var(--mi-shadow-lg);
}

.mi-checkout-trust article span {
  color: rgba(107, 69, 89, 0.28);
  font-family: var(--mi-font-display);
  font-size: clamp(4rem, 8vw, 6.5rem);
  line-height: 0.8;
  letter-spacing: -0.08em;
}

.mi-checkout-trust h3 {
  max-width: 9ch;
  margin: auto 0 var(--mi-space-3);
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: clamp(2rem, 3vw, 3.2rem);
  font-weight: 700;
  line-height: 0.94;
  letter-spacing: -0.06em;
}

.mi-checkout-trust p {
  margin: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.7;
}

@media (max-width: 1120px) {
  .mi-checkout-layout,
  .mi-checkout-header,
  .mi-checkout-trust {
    grid-template-columns: 1fr;
  }

  .mi-checkout-trust article {
    min-height: 18rem;
  }
}

@media (max-width: 640px) {
  .mi-checkout-panel,
  .mi-checkout-trust article {
    padding: var(--mi-space-5);
  }

  .mi-checkout-item {
    grid-template-columns: 4rem minmax(0, 1fr);
  }

  .mi-checkout-item > strong {
    grid-column: 2;
  }
}

/* Step 10: Footer */
.mi-footer {
  position: relative;
  overflow: clip;
  padding: clamp(var(--mi-space-7), 9vw, var(--mi-space-10)) 0 var(--mi-space-5);
  border-top: 1px solid rgba(216, 154, 130, 0.2);
}

.mi-footer::before,
.mi-footer::after {
  content: "";
  position: absolute;
  z-index: -1;
  border-radius: 50%;
  pointer-events: none;
}

.mi-footer::before {
  inset: auto auto -32% -16%;
  width: min(44rem, 80vw);
  aspect-ratio: 1;
  background: radial-gradient(circle, rgba(242, 198, 181, 0.28), transparent 70%);
  filter: blur(24px);
}

.mi-footer::after {
  inset: 8% -18% auto auto;
  width: min(34rem, 70vw);
  aspect-ratio: 1;
  background: radial-gradient(circle, rgba(239, 127, 165, 0.16), transparent 70%);
  filter: blur(22px);
}

.mi-footer__inner {
  position: relative;
  z-index: 0;
  display: grid;
  grid-template-columns: minmax(18rem, 0.95fr) minmax(22rem, 1.15fr);
  gap: clamp(var(--mi-space-5), 6vw, var(--mi-space-8));
  align-items: start;
}

.mi-footer__brand {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: clamp(var(--mi-space-6), 5vw, var(--mi-space-8));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: radial-gradient(circle at 20% 12%, rgba(255,255,255,0.86), transparent 30%),
              linear-gradient(145deg, rgba(255, 245, 249, 0.88), rgba(255, 255, 255, 0.64) 50%, rgba(242, 198, 181, 0.36));
  box-shadow: var(--mi-shadow-lg);
  backdrop-filter: blur(24px) saturate(1.18);
}

.mi-footer__brand h2 {
  max-width: 11ch;
}

.mi-footer__brand > p:not(.mi-eyebrow) {
  max-width: 40rem;
  margin: var(--mi-space-4) 0 0;
  color: var(--mi-color-text-muted);
  line-height: 1.78;
}

.mi-footer__trust {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mi-space-2);
  margin-top: auto;
  padding-top: var(--mi-space-6);
}

.mi-footer__trust span {
  display: inline-flex;
  align-items: center;
  min-height: 2.45rem;
  padding: 0 var(--mi-space-4);
  border: 1px solid rgba(216, 154, 130, 0.22);
  border-radius: var(--mi-radius-pill);
  background: rgba(255, 255, 255, 0.56);
  color: var(--mi-color-primary-strong);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.mi-footer__nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--mi-space-4);
}

.mi-footer__nav > div,
.mi-footer__newsletter {
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(20px) saturate(1.18);
}

.mi-footer__nav > div {
  display: grid;
  gap: var(--mi-space-3);
  padding: var(--mi-space-5);
}

.mi-footer__nav h3 {
  margin: 0 0 var(--mi-space-2);
  color: var(--mi-color-text);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.mi-footer__nav a,
.mi-footer__bottom a {
  color: var(--mi-color-text-muted);
  text-decoration: none;
  transition: color var(--mi-duration-fast) var(--mi-ease-out),
              transform var(--mi-duration-fast) var(--mi-ease-out);
}

.mi-footer__nav a {
  width: fit-content;
  font-size: 0.94rem;
  font-weight: 700;
}

.mi-footer__nav a:hover,
.mi-footer__nav a:focus-visible,
.mi-footer__bottom a:hover,
.mi-footer__bottom a:focus-visible {
  color: var(--mi-color-primary-strong);
}

.mi-footer__nav a:hover,
.mi-footer__nav a:focus-visible {
  transform: translateX(4px);
}

.mi-footer__newsletter {
  grid-column: 2;
  display: grid;
  gap: var(--mi-space-3);
  margin-top: var(--mi-space-4);
  padding: clamp(var(--mi-space-5), 3vw, var(--mi-space-6));
}

.mi-footer__newsletter label {
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: clamp(2rem, 4vw, 3.3rem);
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: -0.06em;
}

.mi-footer__newsletter p {
  max-width: 48rem;
  margin: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.72;
}

.mi-footer__newsletter > div {
  display: flex;
  gap: var(--mi-space-2);
  margin-top: var(--mi-space-2);
}

.mi-footer__newsletter input {
  min-width: 0;
  flex: 1;
  min-height: 3.2rem;
  padding: 0 var(--mi-space-4);
  border: 1px solid rgba(216, 154, 130, 0.28);
  border-radius: var(--mi-radius-pill);
  background: rgba(255, 255, 255, 0.74);
  color: var(--mi-color-text);
  font: inherit;
  outline: none;
  transition: border-color var(--mi-duration-fast) var(--mi-ease-out),
              box-shadow var(--mi-duration-fast) var(--mi-ease-out);
}

.mi-footer__newsletter input:focus {
  border-color: rgba(239, 127, 165, 0.48);
  box-shadow: 0 0 0 4px rgba(239, 127, 165, 0.1);
}

.mi-footer__newsletter small {
  color: var(--mi-color-text-muted);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-footer__bottom {
  display: flex;
  justify-content: space-between;
  gap: var(--mi-space-4);
  margin-top: var(--mi-space-6);
  padding-top: var(--mi-space-4);
  border-top: 1px solid rgba(216, 154, 130, 0.18);
  color: var(--mi-color-text-muted);
  font-size: 0.82rem;
  font-weight: 700;
}

.mi-footer__bottom > div {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--mi-space-4);
}

@media (max-width: 1020px) {
  .mi-footer__inner,
  .mi-footer__nav,
  .mi-footer__newsletter {
    grid-template-columns: 1fr;
    grid-column: auto;
  }

  .mi-footer__brand {
    min-height: 28rem;
  }
}

@media (max-width: 640px) {
  .mi-footer__brand,
  .mi-footer__nav > div,
  .mi-footer__newsletter {
    padding: var(--mi-space-5);
  }

  .mi-footer__newsletter > div,
  .mi-footer__bottom {
    flex-direction: column;
  }

  .mi-footer__newsletter .mi-button {
    width: 100%;
  }

  .mi-footer__bottom > div {
    justify-content: flex-start;
  }
}

/* Step 11: Age Gate */
.mi-age-gate {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: var(--mi-page-gutter);
}

.mi-age-gate[hidden] {
  display: none;
}

.mi-age-gate__backdrop {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 18%, rgba(255, 220, 233, 0.22), transparent 34%),
              rgba(43, 28, 41, 0.72);
  backdrop-filter: blur(26px) saturate(1.12);
}

.mi-age-gate__panel {
  position: relative;
  width: min(100%, 32rem);
  overflow: hidden;
  padding: clamp(var(--mi-space-6), 6vw, var(--mi-space-8));
  border: 1px solid rgba(255, 255, 255, 0.38);
  border-radius: var(--mi-radius-xl);
  background: radial-gradient(circle at 18% 10%, rgba(255,255,255,0.92), transparent 30%),
              linear-gradient(145deg, rgba(255, 247, 250, 0.94), rgba(255, 255, 255, 0.78) 52%, rgba(242, 198, 181, 0.48));
  box-shadow: 0 2rem 7rem rgba(43, 28, 41, 0.34);
  text-align: center;
  backdrop-filter: blur(24px) saturate(1.18);
  animation: mi-age-gate-rise 680ms var(--mi-ease-luxury) both;
}

.mi-age-gate__panel::before {
  content: "18+";
  position: absolute;
  right: -0.18em;
  top: -0.22em;
  color: rgba(239, 127, 165, 0.1);
  font-family: var(--mi-font-display);
  font-size: clamp(8rem, 28vw, 15rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.08em;
  pointer-events: none;
}

.mi-age-gate__brand {
  position: relative;
  z-index: 1;
  margin: 0;
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 700;
  line-height: 0.95;
  letter-spacing: -0.04em;
}

.mi-age-gate__tagline {
  position: relative;
  z-index: 1;
  display: block;
  margin-top: var(--mi-space-2);
  color: var(--mi-color-primary-strong);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.mi-age-gate h2 {
  position: relative;
  z-index: 1;
  max-width: 12ch;
  margin: var(--mi-space-6) auto var(--mi-space-3);
  color: var(--mi-color-text);
  font-size: clamp(3rem, 8vw, 5rem);
  line-height: 0.9;
}

.mi-age-gate p[id] {
  position: relative;
  z-index: 1;
  max-width: 34rem;
  margin: 0 auto;
  color: var(--mi-color-text-muted);
  line-height: 1.76;
}

.mi-age-gate__actions {
  position: relative;
  z-index: 1;
  display: grid;
  gap: var(--mi-space-3);
  margin-top: var(--mi-space-6);
}

.mi-age-gate__actions .mi-button {
  width: 100%;
  min-height: 3.25rem;
}

.mi-age-gate small {
  position: relative;
  z-index: 1;
  display: block;
  margin-top: var(--mi-space-4);
  color: var(--mi-color-text-muted);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.mi-age-gate-open {
  overflow: hidden;
}

@keyframes mi-age-gate-rise {
  from {
    opacity: 0;
    transform: translateY(18px) scale(0.97);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (max-width: 640px) {
  .mi-age-gate {
    padding: var(--mi-space-4);
  }

  .mi-age-gate__panel {
    padding: var(--mi-space-6) var(--mi-space-5);
  }
}


/* Step 16: WooCommerce multi-template polish */
.woocommerce .mi-main,
.woocommerce-page .mi-main {
  min-height: 70vh;
}

.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--mi-space-4);
  margin: 0;
  padding: 0;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: auto;
  margin: 0;
  padding: var(--mi-space-4);
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(20px) saturate(1.14);
}

.woocommerce ul.products li.product a img {
  border-radius: var(--mi-radius-lg);
}

.woocommerce div.product,
.woocommerce-cart-form,
.woocommerce-checkout,
.woocommerce-MyAccount-content,
.woocommerce-MyAccount-navigation {
  padding: clamp(var(--mi-space-5), 4vw, var(--mi-space-6));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(20px) saturate(1.14);
}

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  border-radius: var(--mi-radius-pill);
  background: linear-gradient(135deg, var(--mi-color-primary), var(--mi-color-accent));
  color: #fff;
  font-weight: 900;
}

@media (max-width: 920px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: 1fr;
  }
}


/* Step 17: WooCommerce production template styling */
.mi-wc-shop__header {
  margin-bottom: var(--mi-space-4);
}

.mi-wc-trust-strip {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mi-space-2);
  margin-bottom: var(--mi-space-5);
}

.mi-wc-trust-strip span,
.mi-wc-single__promises span {
  padding: 0.72rem 1rem;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-pill);
  background: rgba(255, 255, 255, 0.62);
  color: var(--mi-color-muted);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-wc-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--mi-space-3);
  margin-bottom: var(--mi-space-4);
  color: var(--mi-color-muted);
}

.mi-wc-toolbar select,
.woocommerce .quantity .qty,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce input.input-text {
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-md);
  background: rgba(255, 255, 255, 0.76);
  color: var(--mi-color-text);
  min-height: 2.85rem;
  padding: 0.78rem 1rem;
}

.woocommerce ul.products {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--mi-space-4);
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
  display: none;
}

.woocommerce ul.products li.product.mi-wc-product-card {
  float: none;
  width: auto;
  margin: 0;
  padding: 0;
  overflow: hidden;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(20px) saturate(1.14);
  transition: transform var(--mi-transition), box-shadow var(--mi-transition), border-color var(--mi-transition);
}

.woocommerce ul.products li.product.mi-wc-product-card:hover,
.woocommerce ul.products li.product.mi-wc-product-card:focus-within {
  transform: translateY(-7px);
  border-color: rgba(183, 135, 92, 0.38);
  box-shadow: var(--mi-shadow-lg);
}

.mi-wc-product-card__media {
  position: relative;
  display: block;
  min-height: 18rem;
  padding: var(--mi-space-4);
  background: linear-gradient(145deg, rgba(255, 224, 233, 0.7), rgba(255, 255, 255, 0.46));
}

.mi-wc-product-card__media img {
  width: 100%;
  height: 16rem;
  object-fit: contain;
  border-radius: var(--mi-radius-lg);
}

.mi-wc-product-card__body {
  padding: var(--mi-space-4);
}

.mi-wc-product-card__category,
.mi-wc-product-card__category a {
  margin: 0 0 0.45rem;
  color: var(--mi-color-muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  padding: 0;
  margin: 0 0 var(--mi-space-2);
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: clamp(1.4rem, 2vw, 1.85rem);
  line-height: 1.04;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title a {
  color: inherit;
  text-decoration: none;
}

.mi-wc-product-card__rating .star-rating,
.mi-wc-single__rating .star-rating {
  color: var(--mi-color-accent);
}

.mi-wc-product-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--mi-space-3);
  margin-top: var(--mi-space-3);
}

.woocommerce ul.products li.product .price,
.mi-wc-single__price .price {
  color: var(--mi-color-text);
  font-size: 1.05rem;
  font-weight: 900;
}

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .checkout-button {
  border: 0;
  border-radius: var(--mi-radius-pill);
  background: linear-gradient(135deg, var(--mi-color-primary), var(--mi-color-accent));
  color: #fff;
  box-shadow: 0 16px 30px rgba(183, 135, 92, 0.18);
  font-weight: 900;
  transition: transform var(--mi-transition), box-shadow var(--mi-transition), opacity var(--mi-transition);
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce .checkout-button:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, var(--mi-color-accent), var(--mi-color-primary));
  color: #fff;
  box-shadow: 0 20px 36px rgba(183, 135, 92, 0.26);
}

.mi-wc-single__product {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
  gap: clamp(var(--mi-space-5), 5vw, var(--mi-space-7));
  align-items: start;
}

.mi-wc-single__gallery,
.mi-wc-single__summary,
.mi-wc-single__details,
.mi-wc-single__related,
.mi-wc-cart__panel,
.mi-wc-cart__totals .cart_totals,
.mi-wc-checkout__details,
.mi-wc-checkout__review,
.mi-wc-account-dashboard,
.woocommerce-MyAccount-navigation,
.woocommerce-MyAccount-content {
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-md);
  backdrop-filter: blur(20px) saturate(1.14);
}

.mi-wc-single__gallery,
.mi-wc-single__summary,
.mi-wc-single__details,
.mi-wc-single__related,
.mi-wc-cart__panel,
.mi-wc-checkout__details,
.mi-wc-checkout__review,
.mi-wc-account-dashboard,
.woocommerce-MyAccount-navigation,
.woocommerce-MyAccount-content {
  padding: clamp(var(--mi-space-4), 4vw, var(--mi-space-6));
}

.mi-wc-single__summary h1 {
  margin: 0 0 var(--mi-space-3);
  font-family: var(--mi-font-display);
  font-size: clamp(2.5rem, 6vw, 5rem);
  line-height: 0.92;
}

.mi-wc-single__excerpt {
  color: var(--mi-color-muted);
  font-size: 1.02rem;
  line-height: 1.8;
}

.mi-wc-single__promises {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mi-space-2);
  margin: var(--mi-space-4) 0;
}

.mi-wc-single__cart form.cart {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mi-space-3);
  align-items: center;
}

.mi-wc-single__details,
.mi-wc-single__related {
  margin-top: var(--mi-space-5);
}

.woocommerce table.shop_table {
  border: 0;
  border-collapse: separate;
  border-spacing: 0;
  margin: 0;
}

.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
  border-color: var(--mi-color-border);
  padding: 1.1rem;
}

.mi-wc-cart__coupon {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mi-space-2);
}

.mi-wc-cart__totals {
  margin-top: var(--mi-space-4);
  display: flex;
  justify-content: flex-end;
}

.mi-wc-cart__totals .cart_totals {
  width: min(100%, 30rem);
  padding: var(--mi-space-5);
}

.mi-wc-checkout__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(20rem, 0.46fr);
  gap: var(--mi-space-5);
  align-items: start;
}

.mi-wc-checkout__review {
  position: sticky;
  top: 7rem;
}

.mi-wc-account-shell {
  display: grid;
  grid-template-columns: minmax(13rem, 0.28fr) minmax(0, 1fr);
  gap: var(--mi-space-4);
}

.woocommerce-MyAccount-navigation ul {
  display: grid;
  gap: 0.55rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.woocommerce-MyAccount-navigation a {
  display: block;
  padding: 0.84rem 1rem;
  border-radius: var(--mi-radius-pill);
  color: var(--mi-color-muted);
  text-decoration: none;
  font-weight: 800;
}

.woocommerce-MyAccount-navigation .is-active a,
.woocommerce-MyAccount-navigation a:hover {
  background: rgba(255, 224, 233, 0.65);
  color: var(--mi-color-text);
}

.mi-wc-account-dashboard__cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--mi-space-3);
  margin: var(--mi-space-4) 0;
}

.mi-wc-account-dashboard__cards a {
  display: grid;
  gap: 0.45rem;
  padding: var(--mi-space-4);
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  background: rgba(255, 255, 255, 0.48);
  color: var(--mi-color-text);
  text-decoration: none;
}

.mi-wc-account-dashboard__cards span {
  color: var(--mi-color-accent);
  font-weight: 900;
}

.mi-wc-account-dashboard__cards small,
.mi-wc-account-dashboard__intro p,
.mi-wc-account-dashboard__note {
  color: var(--mi-color-muted);
  line-height: 1.7;
}

@media (max-width: 980px) {
  .woocommerce ul.products,
  .mi-wc-single__product,
  .mi-wc-checkout__grid,
  .mi-wc-account-shell,
  .mi-wc-account-dashboard__cards {
    grid-template-columns: 1fr;
  }

  .mi-wc-checkout__review {
    position: static;
  }
}


/* Step 18: Information pages */
.mi-policy-page__inner {
  max-width: 52rem;
}

.mi-policy-page__content,
.mi-policy-grid {
  display: grid;
  gap: var(--mi-space-4);
}

.mi-policy-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: var(--mi-space-4) 0;
}

.mi-policy-grid article {
  padding: var(--mi-space-4);
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  background: rgba(255, 255, 255, 0.55);
}

.mi-policy-grid span {
  color: var(--mi-color-accent);
  font-weight: 900;
}

.mi-policy-grid h2 {
  margin: 0.5rem 0 0.75rem;
  font-family: var(--mi-font-display);
  font-size: 1.5rem;
}

.mi-policy-grid p,
.mi-policy-page__content p {
  color: var(--mi-color-muted);
  line-height: 1.75;
}

@media (max-width: 900px) {
  .mi-policy-grid {
    grid-template-columns: 1fr;
  }
}

/* Step 19: Empty states, product placeholders, and 404 */
.mi-wc-product-card__placeholder {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  height: 16rem;
  border-radius: var(--mi-radius-lg);
  background:
    radial-gradient(circle at 35% 25%, rgba(255,255,255,0.95), transparent 32%),
    linear-gradient(145deg, rgba(255, 224, 233, 0.78), rgba(248, 235, 220, 0.5));
  overflow: hidden;
}

.mi-wc-product-card__placeholder::before,
.mi-wc-product-card__placeholder::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  filter: blur(0.2px);
}

.mi-wc-product-card__placeholder::before {
  width: 5.4rem;
  height: 11rem;
  background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(255, 194, 211, 0.72));
  box-shadow: inset 0 0 0 1px rgba(183, 135, 92, 0.16), 0 24px 40px rgba(132, 75, 97, 0.16);
  transform: rotate(10deg);
}

.mi-wc-product-card__placeholder::after {
  width: 3.4rem;
  height: 3.4rem;
  border: 0.7rem solid rgba(183, 135, 92, 0.26);
  right: 22%;
  bottom: 18%;
}

.mi-wc-product-card__placeholder-ring {
  position: absolute;
  width: 10rem;
  height: 10rem;
  border: 1px solid rgba(183, 135, 92, 0.2);
  border-radius: 50%;
}

.mi-wc-product-card__placeholder-core {
  position: absolute;
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  background: var(--mi-color-accent);
  box-shadow: 0 0 38px rgba(183, 135, 92, 0.42);
}

.mi-empty-state,
.mi-error-page__inner {
  position: relative;
  max-width: 50rem;
  margin: 0 auto;
  padding: clamp(var(--mi-space-6), 7vw, var(--mi-space-8));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-lg);
  text-align: center;
  overflow: hidden;
  backdrop-filter: blur(22px) saturate(1.16);
}

.mi-empty-state::before,
.mi-error-page__inner::before {
  content: "";
  position: absolute;
  inset: auto 10% -38% auto;
  width: 16rem;
  height: 16rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 194, 211, 0.32), transparent 68%);
  pointer-events: none;
}

.mi-empty-state h2,
.mi-error-page h1 {
  margin: 0 0 var(--mi-space-3);
  font-family: var(--mi-font-display);
  color: var(--mi-color-text);
  font-size: clamp(2.4rem, 6vw, 5rem);
  line-height: 0.95;
}

.mi-empty-state p,
.mi-error-page .mi-lede {
  margin-inline: auto;
  max-width: none;
  color: var(--mi-color-muted);
  line-height: 1.8;
}

.mi-empty-state__actions,
.mi-error-page__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--mi-space-3);
  margin-top: var(--mi-space-5);
}

.mi-empty-state--cart {
  margin-top: var(--mi-space-4);
}

@media (max-width: 720px) {
  .mi-empty-state__actions,
  .mi-error-page__actions {
    align-items: stretch;
    flex-direction: column;
  }
}


/* Step 20: Cart drawer high-fidelity polish */
.mi-cart-drawer {
  z-index: 100000;
}

.mi-cart-drawer__panel {
  grid-template-rows: auto auto minmax(0, 1fr) auto;
}

.mi-cart-drawer__thumb {
  overflow: hidden;
  display: grid;
  place-items: center;
}

.mi-cart-drawer__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
}

.mi-cart-drawer__item-main strong a {
  color: inherit;
  text-decoration: none;
}

.mi-cart-drawer__item-main strong a:hover {
  color: var(--mi-color-primary-strong);
}

.mi-cart-drawer__remove {
  display: inline-flex;
  width: fit-content;
  text-decoration: underline;
  text-underline-offset: 0.22rem;
}

.mi-cart-drawer__qty {
  gap: 0.45rem;
}

.mi-cart-drawer__qty strong,
.mi-cart-drawer__qty span {
  display: inline-grid;
  place-items: center;
  min-width: 1.55rem;
  height: 1.55rem;
  border-radius: 999px;
  color: var(--mi-color-text);
  font-size: 0.78rem;
  font-weight: 900;
}

.mi-cart-drawer__qty span {
  background: rgba(255, 255, 255, 0.58);
  color: var(--mi-color-text-muted);
}

.mi-cart-drawer__empty {
  position: relative;
  overflow: hidden;
}

.mi-cart-drawer__empty-orb {
  width: 5.2rem;
  aspect-ratio: 1;
  margin: 0 auto var(--mi-space-2);
  border-radius: 50%;
  background:
    radial-gradient(circle at 34% 28%, rgba(255,255,255,0.9), transparent 30%),
    linear-gradient(145deg, rgba(239,127,165,0.28), rgba(201,169,110,0.2));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7), 0 1.2rem 3rem rgba(99,64,79,0.14);
}

.mi-cart-drawer__checkout {
  min-height: 3.25rem;
}

@media (max-width: 540px) {
  .mi-cart-drawer__item {
    grid-template-columns: 4rem minmax(0, 1fr);
  }

  .mi-cart-drawer__item-side {
    grid-column: 2;
    justify-items: start;
  }
}


/* Step 21: Cart and checkout page luxury polish */
.mi-wc-cart-page,
.mi-wc-checkout-page {
  width: min(1180px, calc(100% - var(--mi-page-gutter) * 2));
  margin: 0 auto;
  padding: clamp(var(--mi-space-7), 8vw, var(--mi-space-10)) 0;
}

.mi-wc-cart-page__hero,
.mi-wc-checkout-page__hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.36fr);
  gap: clamp(var(--mi-space-5), 5vw, var(--mi-space-8));
  align-items: end;
  margin-bottom: var(--mi-space-5);
}

.mi-wc-cart-page__hero h1,
.mi-wc-checkout-page__hero h1 {
  max-width: 12ch;
  margin: 0;
  font-size: clamp(3rem, 7vw, 6.5rem);
  line-height: 0.9;
}

.mi-wc-cart-page__hero p,
.mi-wc-checkout-page__hero p {
  max-width: 42rem;
  color: var(--mi-color-text-muted);
  font-size: 1.05rem;
  line-height: 1.78;
}

.mi-wc-cart-page__status,
.mi-wc-checkout-page__privacy,
.mi-wc-trust-strip,
.mi-wc-cart__panel,
.mi-wc-cart__totals-shell,
.mi-wc-checkout__details,
.mi-wc-checkout__review {
  border: 1px solid var(--mi-color-border);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-lg);
  backdrop-filter: blur(22px) saturate(1.14);
}

.mi-wc-cart-page__status,
.mi-wc-checkout-page__privacy {
  display: grid;
  gap: var(--mi-space-2);
  padding: var(--mi-space-5);
  border-radius: var(--mi-radius-xl);
}

.mi-wc-cart-page__status span,
.mi-wc-cart-page__status small,
.mi-wc-checkout-page__privacy span {
  color: var(--mi-color-text-muted);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.mi-wc-cart-page__status strong {
  font-family: var(--mi-font-display);
  font-size: 2.8rem;
  line-height: 1;
}

.mi-wc-checkout-page__privacy span,
.mi-wc-trust-strip span {
  display: inline-flex;
  width: fit-content;
  padding: 0.65rem 0.9rem;
  border: 1px solid rgba(239,127,165,0.18);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.68);
}

.mi-wc-trust-strip {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mi-space-2);
  margin-bottom: var(--mi-space-5);
  padding: var(--mi-space-3);
  border-radius: var(--mi-radius-pill);
}

.mi-wc-trust-strip span {
  color: var(--mi-color-text-muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.mi-wc-cart__panel {
  overflow: hidden;
  border-radius: var(--mi-radius-xl);
}

.mi-wc-cart table.shop_table {
  border: 0;
  margin: 0;
  background: transparent;
}

.mi-wc-cart table.shop_table th {
  color: var(--mi-color-text-muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.mi-wc-cart table.shop_table td,
.mi-wc-cart table.shop_table th {
  border-color: var(--mi-color-border);
  padding: var(--mi-space-4);
}

.mi-wc-cart .product-thumbnail img {
  width: 5.5rem;
  border-radius: var(--mi-radius-lg);
  box-shadow: var(--mi-shadow-sm);
}

.mi-wc-cart .product-name a {
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: 1.55rem;
  line-height: 1;
  text-decoration: none;
}

.mi-wc-cart .product-remove .remove {
  display: inline-grid;
  place-items: center;
  width: 2rem;
  height: 2rem;
  border: 1px solid var(--mi-color-border);
  border-radius: 999px;
  background: rgba(255,255,255,0.72);
  color: var(--mi-color-text-muted) !important;
}

.mi-wc-cart .quantity .qty,
.mi-wc-checkout input.input-text,
.mi-wc-checkout textarea,
.mi-wc-checkout select {
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-md);
  background: rgba(255,255,255,0.74);
  color: var(--mi-color-text);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.56);
}

.mi-wc-cart .actions {
  background: rgba(255,255,255,0.36);
}

.mi-wc-cart__coupon {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mi-space-2);
}

.mi-wc-cart__coupon input {
  min-height: 3rem;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.74);
  padding: 0 1rem;
}

.mi-wc-cart__totals {
  margin-top: var(--mi-space-5);
}

.mi-wc-cart__totals-shell {
  padding: clamp(var(--mi-space-5), 4vw, var(--mi-space-6));
  border-radius: var(--mi-radius-xl);
}

.mi-wc-cart__totals .cart_totals {
  width: 100%;
  float: none;
}

.mi-wc-cart__totals .cart_totals h2 {
  margin-top: 0;
  font-size: clamp(2.2rem, 4vw, 4rem);
}

.mi-wc-checkout__grid {
  align-items: start;
}

.mi-wc-checkout__details,
.mi-wc-checkout__review {
  border-radius: var(--mi-radius-xl);
}

.mi-wc-checkout__details h3,
.mi-wc-checkout__review h3 {
  margin-top: 0;
  font-size: clamp(2.1rem, 4vw, 3.8rem);
}

.mi-wc-checkout .form-row label {
  color: var(--mi-color-text-muted);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.mi-wc-checkout #order_review table.shop_table {
  border: 0;
  background: rgba(255,255,255,0.38);
  border-radius: var(--mi-radius-lg);
  overflow: hidden;
}

.mi-wc-checkout #payment {
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  background: rgba(255,255,255,0.52);
}

.mi-wc-checkout #place_order {
  width: 100%;
  min-height: 3.35rem;
  border-radius: var(--mi-radius-pill);
}

@media (max-width: 900px) {
  .mi-wc-cart-page__hero,
  .mi-wc-checkout-page__hero {
    grid-template-columns: 1fr;
  }

  .mi-wc-trust-strip {
    border-radius: var(--mi-radius-xl);
  }
}


/* Step 22: Product browse and detail luxury polish */
.mi-wc-shop {
  position: relative;
  overflow: hidden;
}

.mi-wc-shop::before,
.mi-wc-single::before {
  content: '';
  position: absolute;
  z-index: -1;
  width: clamp(16rem, 28vw, 30rem);
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(239, 127, 165, 0.18), transparent 68%);
  filter: blur(4px);
  pointer-events: none;
}

.mi-wc-shop::before {
  right: -8rem;
  top: 7rem;
}

.mi-wc-single {
  position: relative;
  overflow: hidden;
}

.mi-wc-single::before {
  left: -10rem;
  top: 10rem;
}

.mi-wc-shop__header {
  align-items: end;
  padding: clamp(var(--mi-space-5), 5vw, var(--mi-space-7));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-2xl);
  background:
    radial-gradient(circle at 12% 18%, rgba(255,255,255,0.9), transparent 24%),
    var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-lg);
  backdrop-filter: blur(22px) saturate(1.14);
}

.mi-wc-shop__header h1 {
  max-width: 11ch;
  font-size: clamp(3rem, 7vw, 6.8rem);
  line-height: 0.88;
}

.mi-wc-toolbar {
  margin-bottom: var(--mi-space-5);
  border-radius: var(--mi-radius-xl);
}

.mi-wc-toolbar .woocommerce-result-count {
  margin: 0;
  color: var(--mi-color-text-muted);
  font-weight: 800;
}

.mi-wc-toolbar .woocommerce-ordering {
  margin: 0;
}

.mi-wc-toolbar select {
  min-height: 2.8rem;
}

.woocommerce ul.products li.product.mi-wc-product-card {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.woocommerce ul.products li.product.mi-wc-product-card::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background: radial-gradient(circle at 24% 18%, rgba(255,255,255,0.78), transparent 30%), radial-gradient(circle at 80% 0%, rgba(239,127,165,0.12), transparent 36%);
  opacity: 0;
  transition: opacity var(--mi-duration-base) var(--mi-ease-out);
}

.woocommerce ul.products li.product.mi-wc-product-card:hover::before,
.woocommerce ul.products li.product.mi-wc-product-card:focus-within::before {
  opacity: 1;
}

.mi-wc-product-card__media {
  margin: calc(var(--mi-space-4) * -1) calc(var(--mi-space-4) * -1) 0;
  padding: var(--mi-space-4);
  min-height: 18rem;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 50% 20%, rgba(255,255,255,0.84), transparent 32%),
    linear-gradient(145deg, rgba(255,255,255,0.58), rgba(247,220,228,0.28));
}

.mi-wc-product-card__media img {
  max-height: 16rem;
  object-fit: contain;
  filter: drop-shadow(0 1.3rem 2.4rem rgba(82,60,55,0.14));
  transition: transform var(--mi-duration-base) var(--mi-ease-luxury);
}

.mi-wc-product-card:hover .mi-wc-product-card__media img {
  transform: translateY(-6px) scale(1.025);
}

.mi-product-badge,
.woocommerce span.onsale {
  min-height: auto;
  min-width: auto;
  padding: 0.55rem 0.8rem;
  border: 1px solid rgba(255,255,255,0.72);
  border-radius: var(--mi-radius-pill);
  background: linear-gradient(135deg, var(--mi-color-primary), var(--mi-color-accent));
  color: #fff;
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  line-height: 1;
  text-transform: uppercase;
  box-shadow: var(--mi-shadow-md);
}

.mi-wc-product-card__category,
.mi-wc-product-card__category a {
  color: var(--mi-color-primary-strong);
}

.mi-wc-product-card__footer {
  align-items: end;
}

.mi-wc-product-card__price .price {
  font-family: var(--mi-font-display);
  font-size: 1.55rem;
}

.mi-wc-product-card__button .button {
  min-height: 2.75rem;
  padding-inline: 1.05rem;
  white-space: nowrap;
}

.mi-wc-pagination {
  display: flex;
  justify-content: center;
  margin-top: var(--mi-space-6);
}

.mi-wc-pagination .page-numbers {
  display: inline-flex;
  gap: 0.4rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.mi-wc-pagination .page-numbers a,
.mi-wc-pagination .page-numbers span {
  display: inline-grid;
  place-items: center;
  min-width: 2.65rem;
  height: 2.65rem;
  border: 1px solid var(--mi-color-border);
  border-radius: 999px;
  background: rgba(255,255,255,0.68);
  color: var(--mi-color-text-muted);
  font-weight: 900;
  text-decoration: none;
}

.mi-wc-pagination .page-numbers .current {
  background: var(--mi-gradient-primary);
  color: #fff;
}

.mi-wc-single__product {
  gap: clamp(var(--mi-space-5), 6vw, var(--mi-space-9));
  align-items: start;
}

.mi-wc-single__gallery {
  position: sticky;
  top: calc(var(--mi-header-height, 5rem) + var(--mi-space-4));
  overflow: hidden;
}

.mi-wc-single__gallery .woocommerce-product-gallery {
  margin: 0;
}

.mi-wc-single__gallery .woocommerce-product-gallery__wrapper {
  margin: 0;
}

.mi-wc-single__gallery img {
  border-radius: var(--mi-radius-xl);
  background: rgba(255,255,255,0.58);
  box-shadow: var(--mi-shadow-md);
}

.mi-wc-single__summary {
  position: relative;
  overflow: hidden;
}

.mi-wc-single__summary::before {
  content: '';
  position: absolute;
  right: -5rem;
  top: -5rem;
  width: 12rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(239,127,165,0.14), transparent 70%);
}

.mi-wc-single__summary > * {
  position: relative;
  z-index: 1;
}

.mi-wc-single__summary h1 {
  max-width: 10ch;
}

.mi-wc-single__price .price {
  display: inline-flex;
  align-items: baseline;
  gap: 0.45rem;
  padding: 0.55rem 0.9rem;
  border: 1px solid rgba(239,127,165,0.18);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.68);
}

.mi-wc-single__promises {
  margin-block: var(--mi-space-4);
}

.mi-wc-single__cart {
  padding: var(--mi-space-4);
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  background: rgba(255,255,255,0.52);
}

.mi-wc-single__cart .quantity .qty {
  min-height: 3rem;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.72);
}

.mi-wc-single__cart .single_add_to_cart_button {
  min-height: 3rem;
}

.mi-wc-single__meta {
  color: var(--mi-color-text-muted);
  font-size: 0.86rem;
  line-height: 1.8;
}

.mi-wc-single__details .woocommerce-tabs ul.tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mi-space-2);
  margin: 0 0 var(--mi-space-4);
  padding: 0;
}

.mi-wc-single__details .woocommerce-tabs ul.tabs::before,
.mi-wc-single__details .woocommerce-tabs ul.tabs li::before,
.mi-wc-single__details .woocommerce-tabs ul.tabs li::after {
  display: none !important;
}

.mi-wc-single__details .woocommerce-tabs ul.tabs li {
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.62);
  padding: 0;
}

.mi-wc-single__details .woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 0.85rem 1.1rem;
  color: var(--mi-color-text-muted);
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-wc-single__details .woocommerce-tabs ul.tabs li.active {
  background: var(--mi-gradient-primary);
}

.mi-wc-single__details .woocommerce-tabs ul.tabs li.active a {
  color: #fff;
}

.mi-wc-single__related h2 {
  font-size: clamp(2.4rem, 5vw, 4.8rem);
}

@media (max-width: 900px) {
  .mi-wc-single__gallery {
    position: static;
  }

  .mi-wc-product-card__media {
    min-height: 14rem;
  }
}

@media (max-width: 560px) {
  .mi-wc-product-card__footer {
    display: grid;
    gap: var(--mi-space-3);
  }

  .mi-wc-product-card__button .button {
    width: 100%;
  }
}


/* Step 23: Global navigation and footer polish */
.mi-nav-shell {
  --mi-nav-glow: rgba(239,127,165,0.12);
}

.mi-nav {
  position: relative;
  overflow: visible;
}

.mi-nav::before {
  content: '';
  position: absolute;
  inset: -1px;
  z-index: -1;
  border-radius: inherit;
  background: radial-gradient(circle at 18% 0%, rgba(255,255,255,0.82), transparent 32%), radial-gradient(circle at 84% 0%, var(--mi-nav-glow), transparent 34%);
  pointer-events: none;
}

.mi-mobile-menu__search input::placeholder {
  color: var(--mi-color-text-muted);
}

.mi-nav__account {
  white-space: nowrap;
}

.mi-mobile-menu__search {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--mi-space-2);
  padding: var(--mi-space-3);
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  background: rgba(255,255,255,0.58);
}

.mi-mobile-menu__search input {
  min-width: 0;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.78);
  color: var(--mi-color-text);
  padding: 0 1rem;
}

.mi-mobile-menu__search button {
  min-height: 2.85rem;
}

.mi-mobile-menu__actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--mi-space-2);
  padding-top: var(--mi-space-2);
}

.mi-mobile-menu__actions a,
.mi-mobile-menu__actions button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  min-height: 3rem;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.7);
  color: var(--mi-color-text);
  font: inherit;
  font-weight: 900;
  text-decoration: none;
}

.mi-mobile-menu__actions button {
  cursor: pointer;
}

.mi-mobile-menu__actions strong {
  display: inline-grid;
  place-items: center;
  min-width: 1.55rem;
  height: 1.55rem;
  border-radius: 999px;
  background: var(--mi-gradient-primary);
  color: #fff;
  font-size: 0.72rem;
}

.mi-footer {
  position: relative;
  overflow: hidden;
}

.mi-footer::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 12% 0%, rgba(255,255,255,0.74), transparent 28%), radial-gradient(circle at 86% 8%, rgba(239,127,165,0.13), transparent 32%);
  pointer-events: none;
}

.mi-footer > * {
  position: relative;
  z-index: 1;
}

.mi-footer__brand,
.mi-footer__newsletter {
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: rgba(255,255,255,0.46);
  box-shadow: var(--mi-shadow-sm);
}

.mi-footer__brand {
  padding: clamp(var(--mi-space-5), 4vw, var(--mi-space-6));
}

.mi-footer__newsletter {
  padding: var(--mi-space-5);
}

.mi-footer__nav > div {
  padding: var(--mi-space-4);
  border: 1px solid rgba(255,255,255,0.34);
  border-radius: var(--mi-radius-lg);
  background: rgba(255,255,255,0.28);
}

.mi-footer__nav a {
  width: fit-content;
  text-underline-offset: 0.22rem;
}

.mi-footer__nav a:hover,
.mi-footer__bottom a:hover {
  color: var(--mi-color-primary-strong);
  text-decoration: underline;
}

.mi-footer__age-note {
  margin: var(--mi-space-3) 0 0;
  padding-top: var(--mi-space-3);
  border-top: 1px solid var(--mi-color-border);
  color: var(--mi-color-text-muted);
  font-size: 0.82rem;
  line-height: 1.65;
}

.mi-footer__bottom {
  border-top: 1px solid rgba(255,255,255,0.38);
}

@media (max-width: 1180px) {
  .mi-nav__links {
    display: none;
  }
}

@media (max-width: 760px) {
  .mi-nav__account {
    display: none;
  }

  .mi-mobile-menu__search {
    grid-template-columns: 1fr;
  }

  .mi-mobile-menu__search input,
  .mi-mobile-menu__search button {
    width: 100%;
  }
}

@media (max-width: 520px) {
  .mi-mobile-menu__actions {
    grid-template-columns: 1fr;
  }
}

/* Step 24: My Account page private studio redesign */
.mi-wc-account-page {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.mi-wc-account-page::before,
.mi-wc-account-page::after {
  content: '';
  position: absolute;
  z-index: -1;
  border-radius: 999px;
  pointer-events: none;
}

.mi-wc-account-page::before {
  right: -12rem;
  top: 5rem;
  width: clamp(20rem, 34vw, 38rem);
  aspect-ratio: 1;
  background: radial-gradient(circle, rgba(239,127,165,0.18), transparent 68%);
}

.mi-wc-account-page::after {
  left: -16rem;
  top: 34rem;
  width: clamp(22rem, 38vw, 42rem);
  aspect-ratio: 1;
  background: radial-gradient(circle, rgba(217,185,142,0.16), transparent 68%);
}

.mi-account-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.38fr);
  gap: clamp(var(--mi-space-5), 5vw, var(--mi-space-8));
  align-items: stretch;
  margin-bottom: var(--mi-space-4);
  padding: clamp(var(--mi-space-5), 5vw, var(--mi-space-7));
  border: 1px solid rgba(217,185,142,0.24);
  border-radius: var(--mi-radius-2xl);
  background: radial-gradient(circle at 12% 4%, rgba(255,255,255,0.88), transparent 32%), linear-gradient(135deg, rgba(255,255,255,0.72), rgba(255,244,248,0.58));
  box-shadow: var(--mi-shadow-lg);
  backdrop-filter: blur(24px) saturate(1.16);
  overflow: hidden;
}

.mi-account-hero::before {
  content: '';
  position: absolute;
  right: 30%;
  top: -45%;
  width: clamp(14rem, 25vw, 28rem);
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,0.78), transparent 64%);
  pointer-events: none;
}

.mi-account-hero__copy,
.mi-account-hero__card {
  position: relative;
  z-index: 1;
}

.mi-account-hero__copy {
  display: grid;
  align-content: center;
  gap: var(--mi-space-3);
}

.mi-account-hero__copy h1 {
  max-width: 12ch;
  margin: 0;
  font-size: clamp(3rem, 7vw, 6.6rem);
  line-height: 0.88;
  letter-spacing: -0.045em;
}

.mi-account-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mi-space-3);
  margin-top: var(--mi-space-3);
}

.mi-account-hero__card {
  display: grid;
  gap: var(--mi-space-3);
  align-content: end;
  min-height: 100%;
  padding: clamp(var(--mi-space-4), 4vw, var(--mi-space-5));
  border: 1px solid rgba(217,185,142,0.24);
  border-radius: var(--mi-radius-xl);
  background: linear-gradient(180deg, rgba(255,255,255,0.76), rgba(255,255,255,0.48)), rgba(255,255,255,0.54);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 22px 42px rgba(183,135,92,0.12);
}

.mi-account-hero__label,
.mi-account-quickbar span,
.mi-account-dashboard__tile span,
.mi-account-dashboard__note span {
  color: var(--mi-color-primary-strong);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.mi-account-hero__card strong {
  font-family: var(--mi-font-display);
  font-size: clamp(2rem, 4vw, 3.35rem);
  line-height: 0.95;
}

.mi-account-hero__meta {
  display: block;
  color: var(--mi-color-text-muted);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.6;
  overflow-wrap: anywhere;
}

.mi-account-hero__card ul {
  display: grid;
  gap: 0.72rem;
  margin: var(--mi-space-2) 0 0;
  padding: 0;
  list-style: none;
}

.mi-account-hero__card li {
  position: relative;
  padding-left: 1.45rem;
  color: var(--mi-color-text-muted);
  font-size: 0.9rem;
  font-weight: 700;
}

.mi-account-hero__card li::before,
.mi-account-service-strip span::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 0.48rem;
  height: 0.48rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--mi-color-primary), var(--mi-color-accent));
  box-shadow: 0 0 0 0.24rem rgba(217,185,142,0.12);
}

.mi-account-service-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--mi-space-3);
  margin-bottom: var(--mi-space-4);
}

.mi-account-service-strip span {
  position: relative;
  min-height: 4.2rem;
  padding: 1rem 1rem 1rem 2.55rem;
  border: 1px solid rgba(217,185,142,0.2);
  border-radius: var(--mi-radius-lg);
  background: rgba(255,255,255,0.58);
  color: var(--mi-color-text-muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  box-shadow: var(--mi-shadow-sm);
}

.mi-account-service-strip span::before {
  left: 1rem;
  top: 1.36rem;
}

.mi-account-quickbar,
.mi-account-dashboard__grid {
  display: grid;
  gap: var(--mi-space-3);
}

.mi-account-quickbar {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: var(--mi-space-5);
}

.mi-account-quickbar a,
.mi-account-dashboard__tile {
  position: relative;
  display: grid;
  align-content: start;
  gap: var(--mi-space-2);
  border: 1px solid rgba(217,185,142,0.22);
  border-radius: var(--mi-radius-xl);
  background: rgba(255,255,255,0.58);
  color: var(--mi-color-text);
  text-decoration: none;
  box-shadow: var(--mi-shadow-sm);
  overflow: hidden;
  transition: transform var(--mi-duration-base) var(--mi-ease-luxury), box-shadow var(--mi-duration-base) var(--mi-ease-out), background var(--mi-duration-base) var(--mi-ease-out);
}

.mi-account-quickbar a {
  min-height: 8.5rem;
  padding: var(--mi-space-4);
}

.mi-account-quickbar a:hover,
.mi-account-dashboard__tile:hover {
  transform: translateY(-4px);
  background: rgba(255,255,255,0.72);
  box-shadow: var(--mi-shadow-md);
}

.mi-account-quickbar strong,
.mi-account-dashboard__tile strong {
  position: relative;
  z-index: 1;
  font-family: var(--mi-font-display);
  font-size: 1.8rem;
  line-height: 1;
}

.mi-account-quickbar small,
.mi-account-dashboard__tile small {
  position: relative;
  z-index: 1;
  color: var(--mi-color-text-muted);
  font-weight: 700;
  line-height: 1.65;
}

.mi-account-layout {
  display: grid;
  grid-template-columns: minmax(14rem, 0.26fr) minmax(0, 1fr);
  gap: clamp(var(--mi-space-4), 4vw, var(--mi-space-6));
  align-items: start;
}

.mi-account-layout__nav {
  position: sticky;
  top: calc(var(--mi-header-height, 5rem) + var(--mi-space-4));
  padding: var(--mi-space-4);
  border: 1px solid rgba(217,185,142,0.22);
  border-radius: var(--mi-radius-xl);
  background: rgba(255,255,255,0.6);
  box-shadow: var(--mi-shadow-sm);
  backdrop-filter: blur(18px) saturate(1.12);
}

.mi-account-layout__nav .mi-eyebrow {
  margin-bottom: var(--mi-space-3);
}

.woocommerce-MyAccount-navigation {
  position: static;
}

.woocommerce-MyAccount-navigation ul {
  display: grid;
  gap: 0.55rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.woocommerce-MyAccount-navigation ul li a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--mi-space-2);
  min-height: 3.15rem;
  padding: 0.85rem 2.35rem 0.85rem 1rem;
  border: 1px solid transparent;
  border-radius: var(--mi-radius-pill);
  color: var(--mi-color-text-muted);
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-decoration: none;
  overflow: hidden;
  transition: color var(--mi-duration-base) var(--mi-ease-out), background var(--mi-duration-base) var(--mi-ease-out), border-color var(--mi-duration-base) var(--mi-ease-out), transform var(--mi-duration-base) var(--mi-ease-out);
}

.woocommerce-MyAccount-navigation ul li a::after {
  content: '';
  position: absolute;
  right: 1.05rem;
  width: 0.48rem;
  height: 0.48rem;
  top: 50%;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  opacity: 0.45;
  transform: translate(-0.25rem, -50%) rotate(45deg);
  transition: opacity var(--mi-duration-base) var(--mi-ease-out), transform var(--mi-duration-base) var(--mi-ease-out);
}

.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li a:hover {
  color: var(--mi-color-text);
  border-color: rgba(239,127,165,0.18);
  background: rgba(255,244,248,0.68);
  transform: translateX(0.18rem);
}

.woocommerce-MyAccount-navigation ul li.is-active a::after,
.woocommerce-MyAccount-navigation ul li a:hover::after {
  opacity: 1;
  transform: translate(0, -50%) rotate(45deg);
}

.mi-account-layout__content,
.woocommerce-MyAccount-content {
  min-width: 0;
}

.mi-account-dashboard {
  display: grid;
  gap: var(--mi-space-4);
}

.mi-account-dashboard__welcome {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--mi-space-4);
  align-items: end;
  padding: clamp(var(--mi-space-4), 4vw, var(--mi-space-5));
  border: 1px solid rgba(217,185,142,0.22);
  border-radius: var(--mi-radius-xl);
  background: rgba(255,255,255,0.58);
  box-shadow: var(--mi-shadow-sm);
}

.mi-account-dashboard__welcome h2,
.woocommerce-account .woocommerce h2,
.woocommerce form.login h2,
.woocommerce form.register h2 {
  margin: 0;
  font-size: clamp(2.2rem, 5vw, 4.4rem);
  line-height: 0.95;
  letter-spacing: -0.035em;
}

.mi-account-dashboard__welcome p {
  max-width: 48rem;
  margin-bottom: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.75;
}

.mi-account-dashboard__grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mi-account-dashboard__tile {
  min-height: 14rem;
  padding: var(--mi-space-4);
}

.mi-account-dashboard__tile::before {
  content: '';
  position: absolute;
  right: -3.5rem;
  bottom: -3.5rem;
  width: 8rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(239,127,165,0.12), transparent 70%);
  pointer-events: none;
}

.mi-account-dashboard__panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.42fr);
  gap: var(--mi-space-3);
}

.mi-account-dashboard__note,
.mi-wc-account-dashboard__privacy-note,
.mi-wc-account-dashboard__support,
.mi-empty-state--soft {
  position: relative;
  overflow: hidden;
  padding: clamp(var(--mi-space-4), 4vw, var(--mi-space-5));
  border: 1px solid rgba(217,185,142,0.22);
  border-radius: var(--mi-radius-xl);
  background: rgba(255,255,255,0.58);
  box-shadow: var(--mi-shadow-sm);
}

.mi-account-dashboard__note--soft {
  background: linear-gradient(145deg, rgba(255,244,248,0.68), rgba(255,255,255,0.54));
}

.mi-account-dashboard__note strong {
  display: block;
  margin: 0.55rem 0;
  font-family: var(--mi-font-display);
  font-size: clamp(1.7rem, 3vw, 2.55rem);
  line-height: 1;
}

.mi-account-dashboard__note p,
.mi-account-dashboard__woocommerce-note {
  color: var(--mi-color-text-muted);
  line-height: 1.75;
}

.mi-account-dashboard__note a,
.woocommerce-LostPassword a,
.woocommerce-MyAccount-content a:not(.button):not(.edit) {
  color: var(--mi-color-primary-strong);
  font-weight: 900;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.18em;
}

.mi-account-dashboard__woocommerce-note {
  margin: 0;
  padding: 0 var(--mi-space-2);
  font-size: 0.95rem;
}

.woocommerce-account .woocommerce-MyAccount-content > p:first-child {
  margin-top: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.75;
}

.woocommerce-account .woocommerce-MyAccount-content table.shop_table {
  overflow: hidden;
  border: 1px solid rgba(217,185,142,0.22);
  border-radius: var(--mi-radius-xl);
  background: rgba(255,255,255,0.6);
  box-shadow: var(--mi-shadow-sm);
}

.woocommerce-account .woocommerce-MyAccount-content table.shop_table thead th {
  background: rgba(255,244,248,0.72);
  color: var(--mi-color-text);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.woocommerce-account .woocommerce-MyAccount-content table.shop_table tbody tr {
  background: rgba(255,255,255,0.44);
}

.woocommerce-account .woocommerce-MyAccount-content table.shop_table a.button,
.woocommerce-MyAccount-content .woocommerce-Address a.edit,
.woocommerce-MyAccount-content button.button,
.woocommerce form.login .button,
.woocommerce form.register .button,
.woocommerce form.lost_reset_password .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.75rem;
  padding: 0.75rem 1.1rem;
  border-radius: var(--mi-radius-pill);
  text-decoration: none;
}

.woocommerce-MyAccount-content .woocommerce-Addresses {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--mi-space-4);
}

.woocommerce-MyAccount-content .woocommerce-Address,
.woocommerce-MyAccount-content form.edit-account,
.woocommerce-MyAccount-content form.edit-address,
.woocommerce-MyAccount-content form.woocommerce-EditAccountForm,
.woocommerce form.login,
.woocommerce form.register,
.woocommerce form.lost_reset_password {
  padding: clamp(var(--mi-space-4), 4vw, var(--mi-space-5));
  border: 1px solid rgba(217,185,142,0.22);
  border-radius: var(--mi-radius-xl);
  background: radial-gradient(circle at 12% 0%, rgba(255,255,255,0.76), transparent 38%), rgba(255,255,255,0.58);
  box-shadow: var(--mi-shadow-sm);
}

.woocommerce-MyAccount-content .woocommerce-Address-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--mi-space-3);
}

.woocommerce-MyAccount-content .woocommerce-Address-title h2 {
  margin: 0;
  font-size: clamp(1.8rem, 3vw, 2.8rem);
}

.woocommerce-MyAccount-content form,
.woocommerce form.login,
.woocommerce form.register,
.woocommerce form.lost_reset_password {
  display: grid;
  gap: var(--mi-space-3);
}

.woocommerce-MyAccount-content input.input-text,
.woocommerce-MyAccount-content textarea,
.woocommerce-MyAccount-content select,
.woocommerce form.login input.input-text,
.woocommerce form.register input.input-text,
.woocommerce form.lost_reset_password input.input-text {
  width: 100%;
  min-height: 3.2rem;
  border: 1px solid rgba(217,185,142,0.28);
  border-radius: var(--mi-radius-md);
  background: rgba(255,255,255,0.78);
  color: var(--mi-color-text);
  padding-inline: 1rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
}

.woocommerce-MyAccount-content input.input-text:focus,
.woocommerce-MyAccount-content textarea:focus,
.woocommerce-MyAccount-content select:focus,
.woocommerce form.login input.input-text:focus,
.woocommerce form.register input.input-text:focus,
.woocommerce form.lost_reset_password input.input-text:focus {
  border-color: rgba(239,127,165,0.48);
  outline: 3px solid rgba(239,127,165,0.12);
}

.woocommerce-MyAccount-content label,
.woocommerce form.login label,
.woocommerce form.register label,
.woocommerce form.lost_reset_password label {
  color: var(--mi-color-text);
  font-size: 0.8rem;
  font-weight: 900;
  letter-spacing: 0.06em;
}

.woocommerce-MyAccount-content .form-row,
.woocommerce form.login .form-row,
.woocommerce form.register .form-row,
.woocommerce form.lost_reset_password .form-row {
  margin-bottom: var(--mi-space-3);
}

.woocommerce-MyAccount-content fieldset {
  margin-top: var(--mi-space-4);
  padding: var(--mi-space-4);
  border: 1px solid rgba(217,185,142,0.22);
  border-radius: var(--mi-radius-lg);
  background: rgba(255,255,255,0.42);
}

.woocommerce-MyAccount-content legend {
  padding-inline: 0.5rem;
  color: var(--mi-color-primary-strong);
  font-weight: 900;
}

.woocommerce-MyAccount-content mark,
.woocommerce-MyAccount-content .order-number,
.woocommerce-MyAccount-content .order-date,
.woocommerce-MyAccount-content .order-status {
  border-radius: var(--mi-radius-sm);
  background: rgba(255,224,233,0.72);
  color: var(--mi-color-text);
  padding: 0.08rem 0.35rem;
}

.woocommerce-MyAccount-content address {
  padding: var(--mi-space-4);
  border: 1px solid rgba(217,185,142,0.22);
  border-radius: var(--mi-radius-lg);
  background: rgba(255,255,255,0.46);
  color: var(--mi-color-text-muted);
  line-height: 1.75;
}

.woocommerce .woocommerce-form-login__rememberme {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: var(--mi-color-text-muted);
}

.woocommerce .woocommerce-error,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-message {
  border: 1px solid rgba(217,185,142,0.22);
  border-radius: var(--mi-radius-lg);
  background: rgba(255,255,255,0.78);
  box-shadow: var(--mi-shadow-sm);
  color: var(--mi-color-text);
}

.woocommerce .woocommerce-error::before,
.woocommerce .woocommerce-info::before,
.woocommerce .woocommerce-message::before {
  color: var(--mi-color-accent);
}

.woocommerce table.shop_table_responsive tbody th,
.woocommerce table.shop_table_responsive tbody td {
  word-break: break-word;
}

@media (max-width: 1100px) {
  .mi-account-dashboard__grid,
  .mi-account-service-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .mi-account-hero,
  .mi-account-layout,
  .mi-account-dashboard__welcome,
  .mi-account-dashboard__panel {
    grid-template-columns: 1fr;
  }

  .mi-account-layout__nav {
    position: static;
  }

  .woocommerce-MyAccount-navigation ul {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .mi-account-hero__actions,
  .mi-account-dashboard__welcome .mi-button {
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
  }

  .mi-account-hero__actions .mi-button,
  .mi-account-dashboard__welcome .mi-button {
    width: 100%;
  }

  .mi-account-quickbar,
  .mi-account-dashboard__grid,
  .mi-account-service-strip,
  .woocommerce-MyAccount-content .woocommerce-Addresses {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .mi-account-hero,
  .mi-account-hero__card,
  .mi-account-layout__nav,
  .mi-account-dashboard__welcome,
  .mi-account-dashboard__tile,
  .mi-account-dashboard__note {
    border-radius: var(--mi-radius-lg);
  }

  .woocommerce-MyAccount-navigation ul {
    grid-template-columns: 1fr;
  }
}
/* Step 25: Search results and fallback pages */
.mi-error-page,
.mi-search-page {
  position: relative;
  overflow: hidden;
}

.mi-error-page::before,
.mi-search-page::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 0;
  z-index: -1;
  width: min(42rem, 82vw);
  aspect-ratio: 1;
  transform: translateX(-50%);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(239,127,165,0.12), transparent 66%);
  pointer-events: none;
}

.mi-error-page__inner,
.mi-search-page__hero {
  display: grid;
  gap: var(--mi-space-4);
  padding: clamp(var(--mi-space-5), 5vw, var(--mi-space-7));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-2xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-lg);
  backdrop-filter: blur(22px) saturate(1.12);
}

.mi-error-page__inner h1,
.mi-search-page__hero h1 {
  margin: 0;
  max-width: 13ch;
  font-size: clamp(3rem, 7vw, 6.5rem);
  line-height: 0.9;
}

.mi-error-page__actions,
.mi-empty-state__actions,
.mi-search-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mi-space-2);
}

.mi-search-page__panel {
  display: grid;
  gap: var(--mi-space-2);
  align-self: end;
  padding: var(--mi-space-5);
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: rgba(255,255,255,0.56);
}

.mi-search-page__panel span {
  display: inline-flex;
  width: fit-content;
  padding: 0.65rem 0.9rem;
  border: 1px solid rgba(239,127,165,0.18);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.68);
  color: var(--mi-color-text-muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.mi-search-page__grid {
  display: grid;
  gap: var(--mi-space-4);
  margin-top: var(--mi-space-5);
}

.mi-search-card {
  padding: var(--mi-space-5);
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: rgba(255,255,255,0.56);
  box-shadow: var(--mi-shadow-sm);
}

.mi-search-card__meta {
  display: flex;
  justify-content: space-between;
  gap: var(--mi-space-3);
  margin-bottom: var(--mi-space-3);
  color: var(--mi-color-text-muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.mi-search-card h2 {
  margin: 0 0 var(--mi-space-2);
  font-family: var(--mi-font-display);
  font-size: clamp(1.8rem, 4vw, 3rem);
  line-height: 0.95;
}

.mi-search-card h2 a {
  color: var(--mi-color-text);
  text-decoration: none;
}

.mi-search-card__excerpt {
  color: var(--mi-color-text-muted);
  line-height: 1.75;
}

.mi-search-page__empty {
  margin-top: var(--mi-space-5);
}

.mi-search-page__pagination {
  margin-top: var(--mi-space-4);
}

.mi-search-page__pagination .page-numbers {
  display: inline-flex;
  gap: 0.45rem;
  align-items: center;
  flex-wrap: wrap;
  list-style: none;
  margin: 0;
  padding: 0;
}

.mi-search-page__pagination .page-numbers a,
.mi-search-page__pagination .page-numbers span {
  display: inline-grid;
  place-items: center;
  min-width: 2.6rem;
  height: 2.6rem;
  padding: 0 0.85rem;
  border: 1px solid var(--mi-color-border);
  border-radius: 999px;
  background: rgba(255,255,255,0.68);
  color: var(--mi-color-text-muted);
  font-weight: 900;
  text-decoration: none;
}

.mi-search-page__pagination .page-numbers .current {
  background: var(--mi-gradient-primary);
  color: #fff;
}

@media (min-width: 860px) {
  .mi-search-page__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .mi-error-page__actions,
  .mi-empty-state__actions,
  .mi-search-card__actions {
    flex-direction: column;
  }

  .mi-error-page__actions .mi-button,
  .mi-empty-state__actions .mi-button,
  .mi-search-card__actions .mi-button {
    width: 100%;
  }
}


/* Step 26: WooCommerce empty and account maintenance polish */
.mi-empty-state--soft,
.mi-wc-account-dashboard__support {
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: rgba(255,255,255,0.56);
  box-shadow: var(--mi-shadow-sm);
}

.mi-empty-state--soft {
  padding: clamp(var(--mi-space-5), 4vw, var(--mi-space-6));
}

.mi-empty-state--soft h2 {
  margin-top: 0;
  font-size: clamp(2.1rem, 5vw, 4rem);
}

.woocommerce .woocommerce-error,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-message {
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  background: rgba(255,255,255,0.74);
  box-shadow: var(--mi-shadow-sm);
  color: var(--mi-color-text);
}

.woocommerce .woocommerce-error::before,
.woocommerce .woocommerce-info::before,
.woocommerce .woocommerce-message::before {
  color: var(--mi-color-accent);
}

.woocommerce form.login,
.woocommerce form.register,
.woocommerce form.lost_reset_password {
  padding: clamp(var(--mi-space-5), 4vw, var(--mi-space-6));
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-md);
}

.woocommerce form.login .button,
.woocommerce form.register .button,
.woocommerce form.lost_reset_password .button {
  min-height: 3rem;
}

.woocommerce table.shop_table_responsive tbody th,
.woocommerce table.shop_table_responsive tbody td {
  word-break: break-word;
}

.woocommerce-account .woocommerce-MyAccount-content table.shop_table {
  overflow: hidden;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  background: rgba(255,255,255,0.44);
}

.woocommerce-account .woocommerce-MyAccount-content table.shop_table td,
.woocommerce-account .woocommerce-MyAccount-content table.shop_table th {
  padding: 1rem;
}

.mi-wc-account-dashboard__support {
  margin: var(--mi-space-4) 0;
  padding: var(--mi-space-4);
}

.mi-wc-account-dashboard__support strong {
  display: block;
  margin-bottom: 0.35rem;
  color: var(--mi-color-primary-strong);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.mi-wc-account-dashboard__support p {
  margin: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.7;
}

@media (max-width: 760px) {
  .woocommerce form.login,
  .woocommerce form.register,
  .woocommerce form.lost_reset_password {
    padding: var(--mi-space-4);
  }

  .woocommerce table.shop_table_responsive tr {
    display: grid;
    gap: 0.4rem;
  }
}


/* Step 27: Mobile and accessibility polish */
html {
  scroll-behavior: smooth;
}

body {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body,
.mi-site-shell,
.mi-section,
.mi-footer,
.mi-cart-drawer,
.mi-mobile-menu {
  max-width: 100vw;
}

:focus-visible {
  outline: none;
}

.mi-button:focus-visible,
.mi-icon-button:focus-visible,
.mi-menu-button:focus-visible,
.mi-cart-button:focus-visible,
.mi-smart-search__form input:focus-visible,
.mi-mobile-menu__search input:focus-visible,
.woocommerce a.button:focus-visible,
.woocommerce button.button:focus-visible,
.woocommerce input.button:focus-visible,
.woocommerce input.input-text:focus-visible,
.woocommerce select:focus-visible,
.woocommerce textarea:focus-visible {
  box-shadow: var(--mi-focus-ring);
}

button,
.mi-button,
.mi-icon-button,
.mi-menu-button,
.mi-cart-button,
.mi-mobile-menu__actions a,
.mi-mobile-menu__actions button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  touch-action: manipulation;
}

.mi-cart-drawer__panel {
  max-height: min(100vh, 100dvh);
}

.mi-cart-drawer__items {
  overscroll-behavior: contain;
}

.mi-cart-drawer__footer {
  position: sticky;
  bottom: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.1), rgba(255,255,255,0.86) 20%);
}

.mi-mobile-menu {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

@media (max-width: 1080px) {
  .mi-nav-shell {
    padding-inline: var(--mi-space-3);
  }

  .mi-nav {
    min-height: 4.4rem;
  }
}

@media (max-width: 760px) {
  .mi-cart-drawer__panel {
    padding: var(--mi-space-4);
  }

  .mi-cart-drawer__header,
  .mi-cart-drawer__summary,
  .mi-cart-drawer__footer {
    padding-inline: 0;
  }

  .mi-cart-drawer__checkout,
  .mi-cart-drawer__continue {
    min-height: 3.1rem;
  }

  .mi-error-page__inner,
  .mi-search-page__hero,
  .mi-wc-account-page__hero,
  .mi-wc-cart-page__hero,
  .mi-wc-checkout-page__hero {
    padding: var(--mi-space-4);
  }
}

@media (max-width: 520px) {
  .mi-nav-shell {
    padding-inline: var(--mi-space-2);
  }

  .mi-mobile-menu {
    width: min(100vw - 1rem, 24rem);
    right: 0.5rem;
    left: 0.5rem;
  }

  .mi-cart-drawer__item {
    grid-template-columns: 4.2rem minmax(0, 1fr);
  }

  .mi-cart-drawer__thumb {
    width: 4.2rem;
    height: 5.6rem;
  }

  .mi-empty-state__actions,
  .mi-error-page__actions,
  .mi-search-card__actions {
    gap: 0.75rem;
  }
}

@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;
  }

  .mi-product-card:hover .mi-product-media img,
  .woocommerce ul.products li.product.mi-wc-product-card:hover .mi-wc-product-card__media img {
    transform: none;
  }
}


/* Step 28: Cart drawer repair and premium UX */
.mi-cart-drawer {
  --mi-cart-panel-width: min(100vw - 1.25rem, 31rem);
}

.mi-cart-drawer__backdrop {
  cursor: pointer;
}

.mi-cart-drawer__panel {
  width: var(--mi-cart-panel-width);
  border-left: 1px solid rgba(255,255,255,0.58);
  background:
    radial-gradient(circle at 18% 0%, rgba(255,248,250,0.86), transparent 28%),
    radial-gradient(circle at 86% 14%, rgba(239,127,165,0.1), transparent 30%),
    linear-gradient(155deg, rgba(255,246,249,0.92), rgba(250,236,241,0.86));
  box-shadow: -1.4rem 0 4rem rgba(74,47,56,0.14);
}

.mi-cart-drawer__header {
  align-items: start;
}

.mi-cart-drawer__eyebrow {
  color: var(--mi-color-primary-strong);
}

.mi-cart-drawer__close {
  flex: 0 0 auto;
  background: rgba(255,255,255,0.72);
}

.mi-cart-drawer__microcopy {
  margin: var(--mi-space-3) 0 0;
  color: var(--mi-color-text-muted);
  font-size: 0.86rem;
  line-height: 1.65;
}

.mi-cart-drawer__items {
  padding-right: 0.15rem;
}

.mi-cart-drawer__item {
  position: relative;
  grid-template-columns: 5.4rem minmax(0, 1fr) auto;
  gap: var(--mi-space-3);
  background: rgba(255,255,255,0.58);
  transition: transform var(--mi-duration-base) var(--mi-ease-luxury), box-shadow var(--mi-duration-base) var(--mi-ease-out), background var(--mi-duration-base) var(--mi-ease-out);
}

.mi-cart-drawer__item:hover {
  transform: translateY(-2px);
  background: rgba(255,255,255,0.82);
  box-shadow: var(--mi-shadow-sm);
}

.mi-cart-drawer__thumb {
  width: 5.4rem;
  height: 6.7rem;
  border: 1px solid rgba(255,255,255,0.68);
  background:
    radial-gradient(circle at 40% 20%, rgba(255,255,255,0.86), transparent 32%),
    linear-gradient(145deg, rgba(255,238,244,0.74), rgba(255,255,255,0.58));
}

.mi-cart-drawer__item-main > span {
  color: var(--mi-color-primary-strong);
}

.mi-cart-drawer__item-main small {
  color: var(--mi-color-text-muted);
}

.mi-cart-drawer__remove {
  margin-top: 0.25rem;
  color: var(--mi-color-text-muted);
  font-size: 0.78rem;
  font-weight: 800;
}

.mi-cart-drawer__remove:hover {
  color: var(--mi-color-primary-strong);
}

.mi-cart-drawer__item-side b {
  font-family: var(--mi-font-display);
  font-size: 1.25rem;
}

.mi-cart-drawer__qty {
  display: inline-flex;
  padding: 0.18rem;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.64);
}

.mi-cart-drawer__qty span {
  opacity: 0.62;
}

.mi-cart-drawer__footer {
  padding-top: var(--mi-space-4);
  border-top: 1px solid rgba(239,127,165,0.14);
  background: linear-gradient(180deg, rgba(255,255,255,0.1), rgba(255,244,247,0.66) 24%, rgba(255,241,245,0.9));
}

.mi-cart-drawer__footer-perks {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: var(--mi-space-2);
}

.mi-cart-drawer__footer-perks span {
  padding: 0.45rem 0.65rem;
  border: 1px solid rgba(239,127,165,0.16);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,249,251,0.82);
  color: var(--mi-color-text-muted);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-cart-drawer__checkout {
  width: 100%;
  justify-content: center;
  box-shadow: 0 0.85rem 2rem rgba(239,127,165,0.18);
}

.mi-cart-drawer__continue {
  display: inline-flex;
  justify-content: center;
  width: 100%;
  border: 1px solid rgba(239,127,165,0.14);
  background: rgba(255,255,255,0.64);
}

/* Step 29: Cart quantity encoding hardening */
.mi-cart-drawer__qty {
  display: inline-flex;
  align-items: center;
  gap: 0.38rem;
  padding: 0.24rem 0.55rem;
  border: 1px solid rgba(239,127,165,0.16);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,249,251,0.74);
}

.mi-cart-drawer__qty small {
  color: var(--mi-color-text-muted);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-cart-drawer__qty strong {
  display: inline-grid;
  place-items: center;
  min-width: 1.4rem;
  height: 1.4rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.76);
  color: var(--mi-color-text);
  font-size: 0.78rem;
  font-weight: 900;
}

.mi-cart-drawer__qty span {
  display: none !important;
}

@media (max-width: 540px) {
  .mi-cart-drawer {
    --mi-cart-panel-width: calc(100vw - 0.75rem);
  }

  .mi-cart-drawer__panel {
    right: 0.375rem;
    top: 0.375rem;
    bottom: 0.375rem;
    height: auto;
    border-radius: var(--mi-radius-xl);
  }

  .mi-cart-drawer__item {
    grid-template-columns: 4.8rem minmax(0, 1fr);
  }

  .mi-cart-drawer__thumb {
    width: 4.8rem;
    height: 6rem;
  }
}


/* Step 30: Header search anti-overlap layout */
.mi-nav {
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: clamp(0.75rem, 2vw, var(--mi-space-4));
}

.mi-nav__links {
  min-width: 0;
  justify-content: center;
}

.mi-nav__links a {
  white-space: nowrap;
}

.mi-nav__actions {
  min-width: 0;
  justify-content: flex-end;
  gap: 0.5rem;
}

@media (max-width: 1320px) {
  .mi-nav__links {
    gap: clamp(0.65rem, 1.2vw, var(--mi-space-3));
  }

  .mi-nav__links a {
    font-size: 0.75rem;
  }

  .mi-nav__account {
    display: none;
  }
}

@media (max-width: 1180px) {
  .mi-nav__links {
    display: none;
  }
}

/* Step 32: Inline live search */
.mi-nav__actions {
  position: relative;
  z-index: calc(var(--mi-z-sticky) + 12);
  align-items: center;
}

.mi-nav-search {
  position: relative;
  display: inline-grid;
  grid-template-columns: minmax(8rem, 11.5rem) 2.35rem;
  align-items: center;
  align-self: center;
  gap: 0.25rem;
  width: clamp(13rem, 17vw, 16.5rem);
  height: 2.75rem;
  min-height: 2.75rem;
  padding: 0.18rem 0.2rem 0.18rem 0.4rem;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.72);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.68), var(--mi-shadow-sm);
  backdrop-filter: blur(18px) saturate(1.12);
  z-index: calc(var(--mi-z-modal) + 24);
}

.mi-nav-search input[type='search'] {
  width: 100%;
  min-width: 0;
  height: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--mi-color-text);
  font: inherit;
  font-size: 0.86rem;
  line-height: 1;
  padding: 0 0.5rem;
}

.mi-nav-search input[type='search']::placeholder,
.mi-mobile-menu__search input::placeholder {
  color: var(--mi-color-text-muted);
}

.mi-nav-search .mi-search-button {
  width: 2.35rem;
  height: 2.35rem;
  min-height: 2.35rem;
  box-shadow: none;
}

.mi-nav-search__panel {
  position: absolute;
  top: calc(100% + 0.65rem);
  right: 0;
  z-index: calc(var(--mi-z-modal) + 30);
  width: min(38rem, 88vw);
  display: none;
  gap: var(--mi-space-3);
  padding: var(--mi-space-4);
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-xl);
  background: var(--mi-gradient-glass);
  box-shadow: var(--mi-shadow-xl);
  backdrop-filter: blur(28px) saturate(1.18);
}

.mi-nav-search.is-search-active .mi-nav-search__panel {
  display: grid;
}

.mi-smart-search__status {
  min-height: 1.1rem;
  color: var(--mi-color-text-muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-smart-search__results,
.mi-mobile-search-results {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.55rem;
}

.mi-smart-search__item {
  display: grid;
  grid-template-columns: 3.9rem minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--mi-space-3);
  min-width: 0;
  min-height: 4.85rem;
  padding: 0.55rem 0.7rem;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-lg);
  background: rgba(255,255,255,0.72);
  color: var(--mi-color-text);
  text-decoration: none;
  transition: transform var(--mi-duration-base) var(--mi-ease-out), border-color var(--mi-duration-base) var(--mi-ease-out), box-shadow var(--mi-duration-base) var(--mi-ease-out), background var(--mi-duration-base) var(--mi-ease-out);
}

.mi-smart-search__item:hover,
.mi-smart-search__item:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(239,127,165,0.34);
  background: rgba(255,255,255,0.9);
  box-shadow: var(--mi-shadow-md);
}

.mi-smart-search__thumb {
  width: 3.9rem;
  height: 3.9rem;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: var(--mi-radius-md);
  background: radial-gradient(circle at 30% 20%, rgba(255,255,255,0.88), rgba(239,127,165,0.12));
}

.mi-smart-search__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mi-smart-search__thumb i {
  width: 1.15rem;
  height: 1.15rem;
  border: 2px solid var(--mi-color-primary-strong);
  border-radius: 50%;
  opacity: 0.54;
}

.mi-smart-search__name {
  min-width: 0;
  display: grid;
  gap: 0.18rem;
}

.mi-smart-search__name strong {
  overflow: hidden;
  color: var(--mi-color-text);
  font-size: 0.95rem;
  font-weight: 850;
  line-height: 1.18;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mi-smart-search__name small {
  color: var(--mi-color-primary-strong);
  font-size: 0.66rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-smart-search__price {
  justify-self: end;
  white-space: nowrap;
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: 1.08rem;
  font-weight: 700;
}

.mi-smart-search__empty {
  color: var(--mi-color-text-muted);
  font-size: 0.78rem;
  font-style: normal;
}

.mi-mobile-search-results,
.mi-mobile-menu__search .mi-smart-search__status {
  grid-column: 1 / -1;
}

.mi-mobile-menu__search.is-search-active {
  box-shadow: var(--mi-shadow-md);
}

@media (min-width: 1480px) {
  .mi-nav-search__panel {
    width: min(38rem, 90vw);
  }
}

@media (max-width: 1320px) {
  .mi-nav-search {
    grid-template-columns: minmax(6.2rem, 1fr) 2.35rem;
    width: clamp(10.75rem, 14vw, 13rem);
  }
}

@media (max-width: 1180px) {
  .mi-nav-search {
    display: none;
  }
}

@media (max-width: 520px) {
  .mi-smart-search__item {
    grid-template-columns: 3.4rem minmax(0, 1fr);
  }

  .mi-smart-search__price {
    grid-column: 2;
    justify-self: start;
    font-size: 0.98rem;
  }

  .mi-smart-search__thumb {
    width: 3.4rem;
    height: 3.4rem;
  }
}

/* Step 31: Cart drawer real quantity controls */
.mi-cart-drawer.is-updating .mi-cart-drawer__items,
.mi-cart-drawer.is-updating .mi-cart-drawer__footer {
  opacity: 0.58;
  pointer-events: none;
}

.mi-cart-drawer__qty button {
  display: inline-grid;
  place-items: center;
  width: 1.55rem;
  height: 1.55rem;
  border: 1px solid rgba(239,127,165,0.16);
  border-radius: 999px;
  background: rgba(255,255,255,0.78);
  color: var(--mi-color-text);
  font-size: 0.88rem;
  font-weight: 900;
  line-height: 1;
}

.mi-cart-drawer__qty button:hover {
  background: var(--mi-gradient-primary);
  color: #fff;
}

.mi-cart-drawer__qty button:disabled {
  cursor: wait;
  opacity: 0.55;
}

.mi-cart-drawer__qty small {
  display: none;
}


/* Step 32: Home product CTA centering and real product fallback */
.mi-add-button,
a.mi-add-button,
button.mi-add-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
}

.mi-add-button.is-loading {
  opacity: 0.72;
  cursor: wait;
}


/* Step 33: Cart drawer reveal cache hardening */
.mi-cart-drawer [data-reveal],
.mi-cart-drawer__item,
.mi-cart-drawer__item[data-reveal] {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}


/* Step 34: Footer layout polish */
.mi-footer {
  padding-top: clamp(4.5rem, 8vw, 7rem);
  padding-bottom: clamp(2rem, 4vw, 3rem);
}

.mi-footer__inner {
  display: grid;
  grid-template-columns: minmax(18rem, 1.1fr) minmax(0, 1fr) minmax(20rem, 0.95fr);
  gap: clamp(1.25rem, 3vw, 2rem);
  align-items: start;
}

.mi-footer__brand,
.mi-footer__nav,
.mi-footer__newsletter {
  position: relative;
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
  border: 1px solid rgba(239, 127, 165, 0.12);
  border-radius: calc(var(--mi-radius-xl) + 0.25rem);
  background: linear-gradient(180deg, rgba(255,255,255,0.82), rgba(255,246,250,0.94));
  box-shadow: 0 24px 60px rgba(120, 73, 90, 0.08);
  backdrop-filter: blur(18px) saturate(1.16);
}

.mi-footer__brand {
  display: flex;
  flex-direction: column;
  gap: var(--mi-space-4);
}

.mi-footer__brand h2 {
  max-width: 10ch;
  margin: 0;
  font-size: clamp(2.2rem, 3vw, 3.2rem);
  line-height: 0.95;
}

.mi-footer__brand > p {
  max-width: 34rem;
  margin: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.8;
}

.mi-footer__trust {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

.mi-footer__trust span {
  padding: 0.55rem 0.85rem;
  border: 1px solid rgba(239, 127, 165, 0.14);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.72);
  color: var(--mi-color-text-muted);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-footer__nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.mi-footer__nav > div {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}

.mi-footer__nav h3 {
  margin: 0 0 0.25rem;
  color: var(--mi-color-primary-strong);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.mi-footer__nav a {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  color: var(--mi-color-text-muted);
  font-size: 0.94rem;
  font-weight: 700;
  line-height: 1.5;
  transition: color var(--mi-duration-base) var(--mi-ease-out), transform var(--mi-duration-base) var(--mi-ease-out);
}

.mi-footer__nav a:hover,
.mi-footer__nav a:focus-visible {
  color: var(--mi-color-text);
  transform: translateX(3px);
}

.mi-footer__newsletter {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}

.mi-footer__newsletter label {
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: clamp(1.4rem, 2vw, 2rem);
  line-height: 1.1;
}

.mi-footer__newsletter > p {
  margin: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.75;
}

.mi-footer__newsletter > div {
  display: flex;
  gap: 0.7rem;
  align-items: center;
}

.mi-footer__newsletter input {
  flex: 1;
  min-width: 0;
  min-height: 3.2rem;
  border-radius: var(--mi-radius-pill);
  border: 1px solid rgba(239, 127, 165, 0.18);
  background: rgba(255,255,255,0.86);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.8);
}

.mi-footer__newsletter .mi-button {
  flex: 0 0 auto;
  min-height: 3.2rem;
}

.mi-footer__newsletter small,
.mi-footer__age-note {
  color: var(--mi-color-text-muted);
}

.mi-footer__age-note {
  margin: 0;
  padding-top: 0.9rem;
  border-top: 1px solid rgba(239, 127, 165, 0.12);
}

.mi-footer__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: clamp(1.4rem, 2vw, 2rem);
  padding-top: 1rem;
  border-top: 1px solid rgba(239, 127, 165, 0.12);
  color: var(--mi-color-text-muted);
}

.mi-footer__bottom > div {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 1rem;
}

@media (max-width: 1180px) {
  .mi-footer__inner {
    grid-template-columns: 1fr 1fr;
  }

  .mi-footer__newsletter {
    grid-column: 1 / -1;
  }
}

@media (max-width: 780px) {
  .mi-footer__inner {
    grid-template-columns: 1fr;
  }

  .mi-footer__nav {
    grid-template-columns: 1fr;
  }

  .mi-footer__newsletter > div {
    flex-direction: column;
    align-items: stretch;
  }

  .mi-footer__bottom {
    flex-direction: column;
    align-items: flex-start;
  }

  .mi-footer__bottom > div {
    justify-content: flex-start;
  }
}


/* Step 35: Unified footer panel with line dividers */
.mi-footer {
  padding: clamp(4.5rem, 8vw, 7rem) var(--mi-page-gutter) clamp(2rem, 4vw, 3rem);
  background:
    radial-gradient(circle at 14% 0%, rgba(255, 226, 235, 0.74), transparent 34%),
    linear-gradient(180deg, rgba(255, 252, 253, 0.98), rgba(255, 244, 249, 0.96));
}

.mi-footer .mi-container {
  max-width: min(var(--mi-container-wide), calc(100vw - var(--mi-page-gutter) * 2));
}

.mi-footer__inner {
  display: grid;
  grid-template-columns: minmax(17rem, 0.95fr) minmax(24rem, 1.2fr) minmax(20rem, 0.9fr);
  gap: 0;
  align-items: stretch;
  padding: clamp(1.5rem, 3vw, 2.4rem);
  border: 1px solid rgba(215, 167, 160, 0.28);
  border-radius: calc(var(--mi-radius-xl) + 0.45rem);
  background: linear-gradient(135deg, rgba(255,255,255,0.82), rgba(255,247,250,0.9));
  box-shadow: none;
}

.mi-footer__brand,
.mi-footer__nav,
.mi-footer__newsletter {
  padding: clamp(1rem, 2vw, 1.4rem);
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.mi-footer__brand {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: clamp(1.25rem, 3vw, 2rem);
  padding-left: 0;
}

.mi-footer__brand h2 {
  max-width: 11ch;
  margin: 0;
  font-size: clamp(2.35rem, 3.6vw, 4.1rem);
  line-height: 0.92;
}

.mi-footer__brand > p {
  max-width: 32rem;
  margin: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.8;
}

.mi-footer__trust {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.mi-footer__trust span {
  padding: 0.56rem 0.82rem;
  border: 1px solid rgba(215, 167, 160, 0.28);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.56);
  color: var(--mi-color-text-muted);
  font-size: 0.7rem;
  font-weight: 850;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.mi-footer__nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1.1rem, 2vw, 1.7rem);
  border-left: 1px solid rgba(215, 167, 160, 0.24);
  border-right: 1px solid rgba(215, 167, 160, 0.24);
}

.mi-footer__nav > div {
  display: flex;
  flex-direction: column;
  gap: 0.66rem;
}

.mi-footer__nav h3 {
  margin: 0 0 0.36rem;
  color: var(--mi-color-primary-strong);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.mi-footer__nav a {
  width: fit-content;
  color: var(--mi-color-text-muted);
  font-size: 0.94rem;
  font-weight: 650;
  line-height: 1.5;
  text-decoration: none;
}

.mi-footer__nav a:hover,
.mi-footer__nav a:focus-visible {
  color: var(--mi-color-text);
  transform: none;
  text-decoration: underline;
  text-underline-offset: 0.24em;
}

.mi-footer__newsletter {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.85rem;
  padding-right: 0;
}

.mi-footer__newsletter label {
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: clamp(1.55rem, 2.2vw, 2.25rem);
  line-height: 1.05;
}

.mi-footer__newsletter > p {
  margin: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.72;
}

.mi-footer__newsletter > div {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.62rem;
  align-items: center;
}

.mi-footer__newsletter input {
  width: 100%;
  min-width: 0;
  min-height: 3.1rem;
  border: 1px solid rgba(215, 167, 160, 0.34);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.78);
  box-shadow: none;
}

.mi-footer__newsletter .mi-button {
  min-height: 3.1rem;
  white-space: nowrap;
}

.mi-footer__newsletter small,
.mi-footer__age-note {
  color: var(--mi-color-text-muted);
}

.mi-footer__age-note {
  margin: 0;
  padding-top: 0.85rem;
  border-top: 1px solid rgba(215, 167, 160, 0.2);
}

.mi-footer__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.1rem clamp(1.5rem, 3vw, 2.4rem) 0;
  margin-top: 0;
  color: var(--mi-color-text-muted);
}

.mi-footer__bottom > div {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 1rem;
}

@media (max-width: 1180px) {
  .mi-footer__inner {
    grid-template-columns: 1fr;
  }

  .mi-footer__brand,
  .mi-footer__nav,
  .mi-footer__newsletter {
    padding-inline: 0;
  }

  .mi-footer__brand {
    padding-top: 0;
    padding-bottom: clamp(1.4rem, 3vw, 2rem);
  }

  .mi-footer__nav {
    padding-block: clamp(1.4rem, 3vw, 2rem);
    border-left: 0;
    border-right: 0;
    border-top: 1px solid rgba(215, 167, 160, 0.24);
    border-bottom: 1px solid rgba(215, 167, 160, 0.24);
  }

  .mi-footer__newsletter {
    padding-top: clamp(1.4rem, 3vw, 2rem);
    padding-bottom: 0;
  }
}

@media (max-width: 780px) {
  .mi-footer {
    padding-inline: var(--mi-page-gutter);
  }

  .mi-footer__inner {
    padding: clamp(1.1rem, 5vw, 1.5rem);
  }

  .mi-footer__nav {
    grid-template-columns: 1fr;
  }

  .mi-footer__newsletter > div {
    grid-template-columns: 1fr;
  }

  .mi-footer__bottom {
    flex-direction: column;
    align-items: flex-start;
    padding-inline: clamp(1.1rem, 5vw, 1.5rem);
  }

  .mi-footer__bottom > div {
    justify-content: flex-start;
  }
}


/* Step 36: Four-column unified footer */
.mi-footer {
  padding: clamp(5.5rem, 9vw, 8rem) var(--mi-page-gutter) clamp(3rem, 5vw, 4.5rem);
  background:
    radial-gradient(circle at 10% 0%, rgba(255, 226, 235, 0.72), transparent 36%),
    linear-gradient(180deg, rgba(255, 253, 254, 1), rgba(255, 244, 249, 0.98));
  text-align: left;
}

.mi-footer *,
.mi-footer *::before,
.mi-footer *::after {
  text-align: left;
}

.mi-footer .mi-container {
  max-width: min(var(--mi-container-wide), calc(100vw - var(--mi-page-gutter) * 2));
}

.mi-footer__inner {
  display: grid;
  grid-template-columns: minmax(18rem, 1.25fr) minmax(9rem, 0.62fr) minmax(11rem, 0.72fr) minmax(20rem, 1fr);
  gap: clamp(2.2rem, 4.6vw, 5.25rem);
  align-items: start;
  padding: clamp(2.6rem, 5vw, 4.4rem) 0;
  border: 0;
  border-top: 1px solid rgba(215, 167, 160, 0.28);
  border-bottom: 1px solid rgba(215, 167, 160, 0.22);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.mi-footer__brand,
.mi-footer__column,
.mi-footer__menu,
.mi-footer__nav,
.mi-footer__newsletter {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0;
  min-width: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none;
}

.mi-footer__brand .mi-eyebrow {
  margin: 0 0 1.1rem;
  color: var(--mi-color-primary-strong);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.mi-footer__brand h2 {
  max-width: 10.5ch;
  margin: 0;
  font-size: clamp(2.45rem, 4vw, 4.4rem);
  line-height: 0.9;
  letter-spacing: -0.045em;
}

.mi-footer__brand > p:not(.mi-eyebrow) {
  display: none;
}

.mi-footer__trust {
  display: flex;
  flex-wrap: wrap;
  gap: 0.48rem;
  margin-top: clamp(1.25rem, 2vw, 1.8rem);
}

.mi-footer__trust span {
  padding: 0.42rem 0.72rem;
  border: 1px solid rgba(215, 167, 160, 0.32);
  border-radius: var(--mi-radius-pill);
  background: transparent;
  color: var(--mi-color-text-muted);
  font-size: 0.68rem;
  font-weight: 850;
  letter-spacing: 0.1em;
  line-height: 1;
  text-transform: uppercase;
}

.mi-footer__menu h3 {
  width: 100%;
  margin: 0 0 0.95rem;
  padding-top: 0.95rem;
  border-top: 1px solid rgba(215, 167, 160, 0.42);
  color: var(--mi-color-primary-strong);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  line-height: 1;
  text-transform: uppercase;
}

.mi-footer__menu a {
  display: inline-flex;
  width: fit-content;
  margin: 0 0 0.48rem;
  color: var(--mi-color-text-muted);
  font-size: 0.92rem;
  font-weight: 650;
  line-height: 1.18;
  text-decoration: none;
}

.mi-footer__menu a:hover,
.mi-footer__menu a:focus-visible {
  color: var(--mi-color-text);
  text-decoration: underline;
  text-underline-offset: 0.24em;
  transform: none;
}

.mi-footer__newsletter label {
  margin: 0 0 0.8rem;
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: clamp(1.55rem, 2.3vw, 2.35rem);
  line-height: 1.02;
  letter-spacing: -0.025em;
}

.mi-footer__newsletter > p {
  max-width: 28rem;
  margin: 0 0 1rem;
  color: var(--mi-color-text-muted);
  line-height: 1.55;
}

.mi-footer__newsletter > div {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.55rem;
  width: 100%;
  align-items: center;
  margin-bottom: 0.9rem;
}

.mi-footer__newsletter input {
  width: 100%;
  min-width: 0;
  min-height: 3rem;
  border: 1px solid rgba(215, 167, 160, 0.36);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.52);
  box-shadow: none;
}

.mi-footer__newsletter .mi-button {
  min-height: 3rem;
  white-space: nowrap;
}

.mi-footer__newsletter small {
  display: none;
}

.mi-footer__age-note {
  margin: 0;
  padding-top: 0.9rem;
  border-top: 1px solid rgba(215, 167, 160, 0.24);
  color: var(--mi-color-text-muted);
  font-size: 0.78rem;
  line-height: 1.5;
}

.mi-footer__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding: 1.35rem 0 0;
  margin-top: 0;
  border: 0;
  color: var(--mi-color-text-muted);
}

.mi-footer__bottom > div {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 1rem;
}

@media (max-width: 1180px) {
  .mi-footer__inner {
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
    gap: clamp(2rem, 5vw, 3.5rem);
  }
}

@media (max-width: 780px) {
  .mi-footer__inner {
    grid-template-columns: 1fr;
    gap: clamp(1.8rem, 7vw, 2.5rem);
    padding-block: clamp(2.2rem, 8vw, 3rem);
  }

  .mi-footer__menu h3 {
    padding-top: 0.8rem;
  }

  .mi-footer__newsletter > div {
    grid-template-columns: 1fr;
  }

  .mi-footer__bottom {
    flex-direction: column;
    align-items: flex-start;
  }

  .mi-footer__bottom > div {
    justify-content: flex-start;
  }
}


/* Step 37: Compact parallel footer alignment */
.mi-footer {
  padding-top: clamp(4.5rem, 7vw, 6rem);
  padding-bottom: clamp(2.6rem, 4vw, 3.6rem);
}

.mi-footer .mi-container {
  max-width: min(1120px, calc(100vw - var(--mi-page-gutter) * 2));
}

.mi-footer__inner {
  grid-template-columns: minmax(15.5rem, 1.12fr) minmax(7.5rem, 0.55fr) minmax(8.5rem, 0.62fr) minmax(17rem, 1fr);
  gap: clamp(1.25rem, 2.5vw, 2.35rem);
  align-items: start;
  padding-block: clamp(2.1rem, 4vw, 3.2rem);
}

.mi-footer__brand h2 {
  max-width: 10ch;
  font-size: clamp(2rem, 3.1vw, 3.35rem);
}

.mi-footer__brand .mi-eyebrow,
.mi-footer__menu h3 {
  min-height: 1.1rem;
}

.mi-footer__menu h3 {
  margin-bottom: 0.72rem;
  padding-top: 0.72rem;
}

.mi-footer__menu a {
  margin-bottom: 0.36rem;
  font-size: 0.9rem;
  line-height: 1.08;
}

.mi-footer__trust {
  max-width: 14rem;
  gap: 0.38rem;
}

.mi-footer__trust span {
  padding: 0.36rem 0.58rem;
  font-size: 0.62rem;
}

.mi-footer__newsletter label {
  margin-bottom: 0.65rem;
  font-size: clamp(1.35rem, 2vw, 1.9rem);
}

.mi-footer__newsletter > p {
  margin-bottom: 0.78rem;
  font-size: 0.92rem;
  line-height: 1.45;
}

.mi-footer__newsletter > div {
  gap: 0.45rem;
  margin-bottom: 0.72rem;
}

.mi-footer__newsletter input,
.mi-footer__newsletter .mi-button {
  min-height: 2.85rem;
}

.mi-footer__age-note {
  padding-top: 0.72rem;
  font-size: 0.73rem;
  line-height: 1.42;
}

.mi-footer__bottom {
  max-width: min(1120px, calc(100vw - var(--mi-page-gutter) * 2));
  margin-inline: auto;
  padding-top: 1rem;
}

@media (max-width: 1180px) {
  .mi-footer .mi-container {
    max-width: min(920px, calc(100vw - var(--mi-page-gutter) * 2));
  }

  .mi-footer__inner {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1.8rem, 4vw, 2.6rem);
  }
}

@media (max-width: 780px) {
  .mi-footer__inner {
    grid-template-columns: 1fr;
  }
}


/* Step 38: Flex grid footer rebuild */
.mi-footer {
  padding: clamp(5rem, 8vw, 7rem) var(--mi-page-gutter) clamp(3rem, 5vw, 4rem);
  background: linear-gradient(180deg, rgba(255, 252, 253, 1), rgba(255, 246, 250, 0.96));
}

.mi-footer .mi-container {
  max-width: min(1180px, calc(100vw - var(--mi-page-gutter) * 2));
}

.mi-footer__inner {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 40px !important;
  width: 100%;
  padding: clamp(2.4rem, 4vw, 3.6rem) 0 !important;
  margin: 0 auto !important;
  border: 0 !important;
  border-top: 1px solid rgba(0, 0, 0, 0.08) !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.mi-footer__brand,
.mi-footer__shop,
.mi-footer__support,
.mi-footer__newsletter {
  display: block !important;
  min-width: 0;
  margin: 0 !important;
  margin-bottom: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  text-align: left !important;
}

.mi-footer__brand {
  flex: 1.25 1 0;
}

.mi-footer__shop,
.mi-footer__support {
  flex: 0.62 1 0;
}

.mi-footer__newsletter {
  flex: 1.25 1 0;
}

.mi-footer__brand .mi-eyebrow {
  margin: 0 0 0.75rem !important;
  color: var(--mi-color-primary-strong);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.2em;
  line-height: 1;
  text-transform: uppercase;
  text-align: left !important;
}

.mi-footer__brand h2,
.mi-footer__shop h3,
.mi-footer__support h3,
.mi-footer__newsletter label {
  display: block !important;
  width: 100%;
  margin: 0 !important;
  padding: 0 0 0.85rem !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1) !important;
  color: var(--mi-color-text);
  text-align: left !important;
}

.mi-footer__brand h2 {
  max-width: 11ch;
  font-size: clamp(2rem, 3vw, 3.25rem);
  line-height: 0.96;
  letter-spacing: -0.04em;
}

.mi-footer__shop h3,
.mi-footer__support h3 {
  color: var(--mi-color-primary-strong);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  line-height: 1;
  text-transform: uppercase;
}

.mi-footer__newsletter label {
  font-family: var(--mi-font-display);
  font-size: clamp(1.45rem, 2vw, 2rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
}

.mi-footer__trust {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap;
  gap: 0.85rem !important;
  margin: 1rem 0 0 !important;
  padding: 0 !important;
}

.mi-footer__trust span {
  display: inline !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--mi-color-text-muted);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1.35;
  text-transform: uppercase;
}

.mi-footer__shop a,
.mi-footer__support a {
  display: block !important;
  width: fit-content;
  margin: 0 !important;
  padding: 0 !important;
  color: var(--mi-color-text-muted);
  font-size: 0.92rem;
  font-weight: 650;
  line-height: 1.25;
  text-align: left !important;
  text-decoration: none;
}

.mi-footer__shop h3 + a,
.mi-footer__support h3 + a {
  margin-top: 1rem !important;
}

.mi-footer__shop a + a,
.mi-footer__support a + a {
  margin-top: 0.45rem !important;
}

.mi-footer__shop a:hover,
.mi-footer__support a:hover,
.mi-footer__shop a:focus-visible,
.mi-footer__support a:focus-visible {
  color: var(--mi-color-text);
  text-decoration: underline;
  text-underline-offset: 0.25em;
  transform: none !important;
}

.mi-footer__newsletter > p {
  margin: 1rem 0 1rem !important;
  color: var(--mi-color-text-muted);
  font-size: 0.92rem;
  line-height: 1.55;
  text-align: left !important;
}

.mi-footer__newsletter > div {
  display: flex !important;
  align-items: stretch !important;
  gap: 0.55rem !important;
  width: 100%;
  margin: 0 0 0.9rem !important;
  padding: 0 !important;
}

.mi-footer__newsletter input {
  flex: 1 1 auto;
  min-width: 0;
  min-height: 2.9rem;
  margin: 0 !important;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: var(--mi-radius-pill);
  background: rgba(255, 255, 255, 0.42);
  box-shadow: none !important;
}

.mi-footer__newsletter .mi-button {
  flex: 0 0 auto;
  min-height: 2.9rem;
  margin: 0 !important;
  white-space: nowrap;
}

.mi-footer__age-note {
  margin: 0 !important;
  padding: 0.8rem 0 0 !important;
  border: 0 !important;
  border-top: 1px solid rgba(0, 0, 0, 0.1) !important;
  color: var(--mi-color-text-muted);
  font-size: 0.74rem;
  line-height: 1.45;
  text-align: left !important;
}

.mi-footer__bottom {
  max-width: min(1180px, calc(100vw - var(--mi-page-gutter) * 2));
  margin: 0 auto !important;
  padding-top: 1.15rem !important;
  border: 0 !important;
}

@media (max-width: 980px) {
  .mi-footer__inner {
    flex-wrap: wrap !important;
    gap: 36px 40px !important;
  }

  .mi-footer__brand,
  .mi-footer__newsletter {
    flex: 1 1 calc(58% - 20px);
  }

  .mi-footer__shop,
  .mi-footer__support {
    flex: 1 1 calc(42% - 20px);
  }
}

@media (max-width: 680px) {
  .mi-footer__inner {
    flex-direction: column !important;
    flex-wrap: nowrap !important;
    gap: 2rem !important;
  }

  .mi-footer__brand,
  .mi-footer__shop,
  .mi-footer__support,
  .mi-footer__newsletter {
    flex: 0 0 auto !important;
    width: 100% !important;
  }

  .mi-footer__brand h2 {
    max-width: 12ch;
  }

  .mi-footer__newsletter > div {
    flex-direction: column !important;
  }

  .mi-footer__newsletter .mi-button {
    width: 100%;
  }
}


/* Step 35: Header/Hero vertical rhythm refinement */
.mi-nav-shell {
  padding-block: clamp(0.45rem, 1.2vw, 0.8rem);
}

.mi-nav {
  min-height: 3.65rem;
  align-items: center;
  padding-block: 0.38rem;
}

.mi-wordmark,
.mi-nav__links,
.mi-nav__actions {
  align-items: center;
  align-self: center;
}

.mi-wordmark {
  justify-content: center;
  line-height: 1;
}

.mi-wordmark span,
.mi-wordmark small {
  line-height: 1;
}

.mi-nav__links a {
  display: inline-flex;
  align-items: center;
  min-height: 2.35rem;
}

.mi-nav-search,
.mi-cart-button,
.mi-theme-toggle,
.mi-menu-button,
.mi-nav__account {
  align-self: center;
}

.home .mi-section--hero,
.front-page .mi-section--hero,
body:not(.woocommerce-page) .mi-section--hero {
  min-height: calc(var(--mi-hero-min-h) - 7.5rem);
  padding-top: clamp(1.7rem, 4.2vw, 3.25rem);
  padding-bottom: clamp(3.5rem, 7vw, 6.25rem);
}

.home .mi-container--hero,
.front-page .mi-container--hero,
body:not(.woocommerce-page) .mi-container--hero {
  align-items: center;
}

@media (max-width: 1080px) {
  .mi-nav-shell {
    padding-block: clamp(0.45rem, 1.4vw, 0.75rem);
  }

  .mi-nav {
    min-height: 3.8rem;
    padding-block: 0.42rem;
  }
}

@media (max-width: 920px) {
  .home .mi-section--hero,
  .front-page .mi-section--hero,
  body:not(.woocommerce-page) .mi-section--hero {
    min-height: auto;
    padding-top: clamp(2.1rem, 6vw, 3.4rem);
    padding-bottom: clamp(3.6rem, 8vw, 5rem);
  }
}

@media (max-width: 640px) {
  .mi-nav-shell {
    padding-block: 0.55rem;
  }

  .mi-nav {
    min-height: 3.9rem;
    padding-block: 0.48rem;
  }

  .home .mi-section--hero,
  .front-page .mi-section--hero,
  body:not(.woocommerce-page) .mi-section--hero {
    padding-top: clamp(2.25rem, 8vw, 3.25rem);
    padding-bottom: clamp(3rem, 9vw, 4.4rem);
  }
}


/* Step 36: WPForms newsletter integration */
.mi-footer__newsletter--wpforms {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  padding: clamp(1.15rem, 3vw, 1.45rem) !important;
  border: 1px solid rgba(217, 185, 142, 0.28);
  border-radius: calc(var(--mi-radius-lg) + 0.35rem);
  background:
    radial-gradient(circle at 12% 8%, rgba(255, 255, 255, 0.86), transparent 34%),
    radial-gradient(circle at 92% 12%, rgba(239, 127, 165, 0.14), transparent 32%),
    linear-gradient(145deg, rgba(255, 252, 248, 0.78), rgba(248, 244, 239, 0.58));
  box-shadow: 0 22px 60px rgba(58, 46, 42, 0.08);
}

.mi-footer__newsletter--wpforms::before {
  content: '';
  position: absolute;
  inset: 0.55rem;
  z-index: -1;
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: calc(var(--mi-radius-lg) + 0.05rem);
  pointer-events: none;
}

.mi-footer__newsletter--wpforms::after {
  content: 'Private updates';
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin: 0 0 0.72rem;
  padding: 0.35rem 0.64rem;
  border: 1px solid rgba(217, 185, 142, 0.38);
  border-radius: var(--mi-radius-pill);
  background: rgba(255, 255, 255, 0.5);
  color: rgba(88, 64, 56, 0.72);
  font-size: 0.66rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  line-height: 1;
  text-transform: uppercase;
  pointer-events: none;
}

.mi-footer__newsletter--wpforms .wpforms-container,
.mi-footer__newsletter--wpforms .wpforms-container-full,
.mi-footer__newsletter--wpforms .wpforms-form,
.mi-footer__newsletter--wpforms .wpforms-field-container,
.mi-footer__newsletter--wpforms .wpforms-field,
.mi-footer__newsletter--wpforms .wpforms-submit-container {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.mi-footer__newsletter--wpforms .wpforms-form {
  position: relative;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.62rem !important;
  align-items: stretch !important;
  margin: 0 0 0.78rem !important;
}

.mi-footer__newsletter--wpforms .wpforms-field-container,
.mi-footer__newsletter--wpforms .wpforms-field-email,
.mi-footer__newsletter--wpforms .wpforms-submit-container {
  display: contents !important;
}

.mi-footer__newsletter--wpforms .wpforms-field-label,
.mi-footer__newsletter--wpforms .wpforms-field-sublabel,
.mi-footer__newsletter--wpforms .wpforms-field-description {
  display: none !important;
}

.mi-footer__newsletter--wpforms input[type='email'],
.mi-footer__newsletter--wpforms .wpforms-field input[type='email'] {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  min-height: 3.15rem !important;
  margin: 0 !important;
  padding: 0 1.12rem !important;
  border: 1px solid rgba(217, 185, 142, 0.36) !important;
  border-radius: var(--mi-radius-pill) !important;
  background: rgba(255, 255, 255, 0.72) !important;
  color: var(--mi-color-text) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82), 0 10px 24px rgba(58, 46, 42, 0.045) !important;
  caret-color: #c75c7c !important;
  cursor: text !important;
  font: inherit !important;
  font-size: 0.9rem !important;
  transition: border-color var(--mi-duration-base) var(--mi-ease-out), box-shadow var(--mi-duration-base) var(--mi-ease-out), background var(--mi-duration-base) var(--mi-ease-out), transform var(--mi-duration-base) var(--mi-ease-out) !important;
}

.mi-footer__newsletter--wpforms input[type='email']::placeholder,
.mi-footer__newsletter--wpforms .wpforms-field input[type='email']::placeholder {
  color: rgba(88, 64, 56, 0.48) !important;
}

.mi-footer__newsletter--wpforms input[type='email']:hover,
.mi-footer__newsletter--wpforms .wpforms-field input[type='email']:hover {
  border-color: rgba(199, 92, 124, 0.38) !important;
  background: rgba(255, 255, 255, 0.88) !important;
}

.mi-footer__newsletter--wpforms input[type='email']:focus,
.mi-footer__newsletter--wpforms .wpforms-field input[type='email']:focus,
.mi-footer__newsletter--wpforms input[type='email']:focus-visible,
.mi-footer__newsletter--wpforms .wpforms-field input[type='email']:focus-visible {
  border-color: rgba(199, 92, 124, 0.62) !important;
  outline: none !important;
  background: rgba(255, 255, 255, 0.96) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92), 0 0 0 4px rgba(199, 92, 124, 0.11), 0 16px 34px rgba(58, 46, 42, 0.08) !important;
  transform: translateY(-1px);
}

.mi-footer__newsletter--wpforms .wpforms-submit,
.mi-footer__newsletter--wpforms button[type='submit'] {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 auto !important;
  min-height: 3.15rem !important;
  margin: 0 !important;
  padding: 0.78rem 1.42rem !important;
  border: 0 !important;
  border-radius: var(--mi-radius-pill) !important;
  background: linear-gradient(135deg, #3a2e2a 0%, #7f4d58 52%, #c75c7c 100%) !important;
  color: #fff !important;
  box-shadow: 0 15px 34px rgba(127, 77, 88, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.22) !important;
  font-size: 0.78rem !important;
  font-weight: 900 !important;
  letter-spacing: 0.12em !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  cursor: pointer !important;
  transition: transform var(--mi-duration-base) var(--mi-ease-out), box-shadow var(--mi-duration-base) var(--mi-ease-out), filter var(--mi-duration-base) var(--mi-ease-out) !important;
}

.mi-footer__newsletter--wpforms .wpforms-submit::after,
.mi-footer__newsletter--wpforms button[type='submit']::after {
  content: '';
  margin-left: 0.45rem;
  font-size: 0.9rem;
  line-height: 1;
  transform: translateX(0);
  transition: transform var(--mi-duration-base) var(--mi-ease-out);
}

.mi-footer__newsletter--wpforms .wpforms-submit:hover,
.mi-footer__newsletter--wpforms button[type='submit']:hover,
.mi-footer__newsletter--wpforms .wpforms-submit:focus-visible,
.mi-footer__newsletter--wpforms button[type='submit']:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 20px 42px rgba(127, 77, 88, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.25) !important;
  filter: saturate(1.05) brightness(1.02);
  outline: none !important;
}

.mi-footer__newsletter--wpforms .wpforms-submit:hover::after,
.mi-footer__newsletter--wpforms button[type='submit']:hover::after {
  transform: translateX(3px);
}

.mi-footer__newsletter--wpforms .wpforms-submit:active,
.mi-footer__newsletter--wpforms button[type='submit']:active {
  transform: translateY(0);
}

.mi-footer__newsletter--wpforms .wpforms-submit:disabled,
.mi-footer__newsletter--wpforms button[type='submit']:disabled,
.mi-footer__newsletter--wpforms .wpforms-submit.wpforms-disabled,
.mi-footer__newsletter--wpforms button[type='submit'].wpforms-disabled {
  cursor: progress !important;
  opacity: 0.74 !important;
  filter: grayscale(0.08) !important;
}

.mi-footer__newsletter--wpforms .wpforms-error,
.mi-footer__newsletter--wpforms label.wpforms-error,
.mi-footer__newsletter--wpforms em.wpforms-error {
  grid-column: 1 / -1;
  margin: -0.22rem 0 0 !important;
  padding: 0.66rem 0.78rem !important;
  border: 1px solid rgba(194, 65, 75, 0.2) !important;
  border-radius: 1rem !important;
  background: rgba(255, 244, 244, 0.76) !important;
  color: #a63842 !important;
  box-shadow: 0 10px 22px rgba(194, 65, 75, 0.08) !important;
  font-size: 0.78rem !important;
  font-style: normal !important;
  font-weight: 800 !important;
  line-height: 1.35 !important;
  text-align: left !important;
}

.mi-footer__newsletter--wpforms .wpforms-confirmation-container-full,
.mi-footer__newsletter--wpforms .wpforms-confirmation-container {
  width: 100% !important;
  margin: 0 0 0.95rem !important;
  padding: 0.92rem 1rem !important;
  border: 1px solid rgba(80, 143, 112, 0.28) !important;
  border-radius: 1.15rem !important;
  background: linear-gradient(135deg, rgba(235, 249, 242, 0.9), rgba(255, 255, 255, 0.62)) !important;
  color: #2f6f55 !important;
  box-shadow: 0 14px 32px rgba(80, 143, 112, 0.12) !important;
  font-size: 0.84rem !important;
  font-weight: 850 !important;
  line-height: 1.45 !important;
}

.mi-footer__newsletter--wpforms .wpforms-confirmation-container-full p,
.mi-footer__newsletter--wpforms .wpforms-confirmation-container p {
  margin: 0 !important;
}

@media (max-width: 760px) {
  .mi-footer__newsletter--wpforms {
    padding: 1rem !important;
    border-radius: var(--mi-radius-lg);
  }

  .mi-footer__newsletter--wpforms::before {
    inset: 0.42rem;
    border-radius: calc(var(--mi-radius-lg) - 0.15rem);
  }

  .mi-footer__newsletter--wpforms .wpforms-form {
    grid-template-columns: 1fr;
    gap: 0.7rem !important;
  }

  .mi-footer__newsletter--wpforms .wpforms-submit,
  .mi-footer__newsletter--wpforms button[type='submit'] {
    width: 100% !important;
  }
}

/* Step 32: Premium WooCommerce single product detail polish */
.mi-wc-single__gallery {
  isolation: isolate;
}

.mi-wc-single__gallery-shell {
  position: relative;
  min-height: 100%;
  padding: clamp(0.85rem, 2vw, 1.25rem);
  border-radius: calc(var(--mi-radius-xl) - 0.35rem);
  background:
    radial-gradient(circle at 18% 12%, rgba(255,255,255,0.92), transparent 34%),
    radial-gradient(circle at 86% 8%, rgba(239,127,165,0.13), transparent 34%),
    linear-gradient(145deg, rgba(255,250,247,0.72), rgba(255,255,255,0.42));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.78);
}

.mi-wc-single__gallery-note {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin: 0 0 var(--mi-space-3);
  padding: 0.48rem 0.78rem;
  border: 1px solid rgba(217,185,142,0.28);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.68);
  color: var(--mi-color-muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.mi-wc-single__gallery-note::before {
  content: '';
  width: 0.48rem;
  height: 0.48rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--mi-color-primary), var(--mi-color-accent));
  box-shadow: 0 0 0 0.28rem rgba(217,185,142,0.12);
}

.mi-wc-single__gallery .onsale,
.woocommerce .mi-wc-single__gallery span.onsale {
  position: absolute;
  z-index: 5;
  top: clamp(1.2rem, 2.5vw, 1.7rem);
  right: clamp(1.2rem, 2.5vw, 1.7rem);
  left: auto;
  min-width: 0;
  min-height: 0;
  padding: 0.55rem 0.9rem;
  border: 1px solid rgba(255,255,255,0.72);
  border-radius: var(--mi-radius-pill);
  background: linear-gradient(135deg, rgba(183,135,92,0.96), rgba(239,127,165,0.88));
  color: #fff;
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  line-height: 1;
  text-transform: uppercase;
  box-shadow: 0 16px 36px rgba(183,135,92,0.22);
}

.mi-wc-single__gallery .woocommerce-product-gallery {
  border-radius: var(--mi-radius-xl);
}

.mi-wc-single__gallery .woocommerce-product-gallery__wrapper {
  display: grid;
  gap: var(--mi-space-3);
}

.mi-wc-single__gallery .woocommerce-product-gallery__image {
  overflow: hidden;
  border-radius: var(--mi-radius-xl);
  background:
    radial-gradient(circle at 50% 10%, rgba(255,255,255,0.95), transparent 42%),
    linear-gradient(145deg, rgba(248,244,239,0.92), rgba(255,244,248,0.72));
}

.mi-wc-single__gallery .woocommerce-product-gallery__image a {
  display: block;
}

.mi-wc-single__gallery .woocommerce-product-gallery__image img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  padding: clamp(0.65rem, 2vw, 1.1rem);
  border-radius: inherit;
  background: transparent;
  box-shadow: none;
  transition: transform var(--mi-transition), filter var(--mi-transition);
}

.mi-wc-single__gallery .woocommerce-product-gallery__image:hover img {
  transform: scale(1.018);
  filter: saturate(1.03) contrast(1.01);
}

.mi-wc-single__gallery .flex-control-thumbs {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.65rem;
  margin: var(--mi-space-3) 0 0;
  padding: 0;
}

.mi-wc-single__gallery .flex-control-thumbs li {
  width: auto !important;
  float: none !important;
  list-style: none;
}

.mi-wc-single__gallery .flex-control-thumbs img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  padding: 0.22rem;
  border: 1px solid rgba(217,185,142,0.22);
  border-radius: var(--mi-radius-md);
  background: rgba(255,255,255,0.72);
  opacity: 0.72;
  cursor: pointer;
  box-shadow: none;
}

.mi-wc-single__gallery .flex-control-thumbs img.flex-active,
.mi-wc-single__gallery .flex-control-thumbs img:hover {
  opacity: 1;
  border-color: rgba(239,127,165,0.46);
  box-shadow: 0 10px 24px rgba(183,135,92,0.13);
}

.mi-wc-single__eyebrow {
  margin-bottom: var(--mi-space-2);
}

.mi-wc-single__summary h1 {
  max-width: 14ch;
  letter-spacing: -0.035em;
}

.mi-wc-single__rating {
  min-height: 0;
}

.mi-wc-single__rating:empty {
  display: none;
}

.mi-wc-single__rating .woocommerce-product-rating {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem;
  margin: 0 0 var(--mi-space-3);
  color: var(--mi-color-muted);
  font-size: 0.88rem;
}

.mi-wc-single__price {
  margin: var(--mi-space-3) 0;
}

.mi-wc-single__price .price {
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  font-weight: 900;
  color: var(--mi-color-text);
  box-shadow: 0 12px 30px rgba(183,135,92,0.1);
}

.mi-wc-single__price del {
  color: var(--mi-color-muted);
  opacity: 0.62;
  font-size: 0.82em;
}

.mi-wc-single__price ins {
  color: var(--mi-color-accent);
  text-decoration: none;
}

.mi-wc-single__excerpt {
  max-width: 42rem;
  padding-top: var(--mi-space-2);
  border-top: 1px solid rgba(217,185,142,0.18);
}

.mi-wc-single__trust {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--mi-space-3);
  margin: var(--mi-space-5) 0;
  padding: 0;
  list-style: none;
}

.mi-wc-single__trust li {
  position: relative;
  overflow: hidden;
  min-height: 8.2rem;
  padding: 1rem;
  border: 1px solid rgba(217,185,142,0.22);
  border-radius: var(--mi-radius-lg);
  background: linear-gradient(145deg, rgba(255,255,255,0.74), rgba(255,244,248,0.52));
  box-shadow: 0 14px 30px rgba(183,135,92,0.08);
}

.mi-wc-single__trust li::before {
  content: '';
  display: block;
  width: 1.95rem;
  height: 1.95rem;
  margin-bottom: 0.75rem;
  border-radius: 50%;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.85), rgba(255,255,255,0.18)) padding-box,
    linear-gradient(135deg, var(--mi-color-primary), var(--mi-color-accent)) border-box;
  border: 1px solid transparent;
  box-shadow: 0 10px 22px rgba(183,135,92,0.14);
}

.mi-wc-single__trust li::after {
  content: '';
  position: absolute;
  right: -2.5rem;
  bottom: -2.5rem;
  width: 6rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(239,127,165,0.12), transparent 70%);
}

.mi-wc-single__trust strong,
.mi-wc-single__trust span {
  position: relative;
  z-index: 1;
  display: block;
}

.mi-wc-single__trust strong {
  color: var(--mi-color-text);
  font-size: 0.86rem;
  letter-spacing: 0.04em;
}

.mi-wc-single__trust span {
  margin-top: 0.35rem;
  color: var(--mi-color-muted);
  font-size: 0.78rem;
  line-height: 1.55;
}

.mi-wc-single__promises {
  display: none;
}

.mi-wc-single__cart {
  background:
    radial-gradient(circle at 12% 0%, rgba(255,255,255,0.88), transparent 38%),
    linear-gradient(145deg, rgba(255,255,255,0.7), rgba(255,244,248,0.48));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.72), 0 18px 36px rgba(183,135,92,0.1);
}

.mi-wc-single__cart form.cart {
  align-items: stretch;
}

.mi-wc-single__cart .quantity {
  display: inline-flex;
}

.mi-wc-single__cart .quantity .qty {
  width: 5.25rem;
  padding-inline: 0.85rem;
  color: var(--mi-color-text);
  font-weight: 900;
  text-align: center;
}

.mi-wc-single__cart .single_add_to_cart_button {
  min-height: 3.25rem;
  padding-inline: 1.45rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.mi-wc-single__cart .variations_form {
  display: grid;
  gap: var(--mi-space-3);
  width: 100%;
}

.mi-wc-single__cart table.variations {
  width: 100%;
  margin: 0;
  border: 0;
}

.mi-wc-single__cart table.variations tr {
  display: grid;
  gap: 0.45rem;
  margin-bottom: var(--mi-space-3);
}

.mi-wc-single__cart table.variations th,
.mi-wc-single__cart table.variations td {
  display: block;
  padding: 0;
  border: 0;
  text-align: left;
}

.mi-wc-single__cart table.variations label {
  color: var(--mi-color-text);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.mi-wc-single__cart select,
.mi-wc-single__cart table.variations select {
  width: 100%;
  min-height: 3rem;
  padding: 0 1rem;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.78);
  color: var(--mi-color-text);
  font-weight: 800;
}

.mi-wc-single__cart .reset_variations {
  display: inline-flex;
  margin-top: 0.45rem;
  color: var(--mi-color-muted);
  font-size: 0.82rem;
  font-weight: 800;
}

.mi-wc-single__cart .single_variation_wrap {
  display: grid;
  gap: var(--mi-space-3);
}

.mi-wc-single__cart .woocommerce-variation-price,
.mi-wc-single__cart .woocommerce-variation-availability,
.mi-wc-single__cart .stock {
  color: var(--mi-color-muted);
  font-size: 0.9rem;
  font-weight: 800;
}

.mi-wc-single__cart .woocommerce-variation-price .price {
  color: var(--mi-color-text);
  font-size: 1.1rem;
  font-weight: 900;
}

.mi-wc-single__cart-note {
  margin: var(--mi-space-3) 0 0;
  padding-top: var(--mi-space-3);
  border-top: 1px solid rgba(217,185,142,0.18);
  color: var(--mi-color-muted);
  font-size: 0.82rem;
  line-height: 1.6;
}

@media (max-width: 900px) {
  .mi-wc-single__trust {
    grid-template-columns: 1fr;
  }

  .mi-wc-single__trust li {
    min-height: 0;
  }
}

@media (max-width: 640px) {
  .mi-wc-single__gallery-shell {
    padding: 0.65rem;
  }

  .mi-wc-single__gallery-note {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .mi-wc-single__gallery .flex-control-thumbs {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.45rem;
  }

  .mi-wc-single__summary h1 {
    max-width: 100%;
    font-size: clamp(2.3rem, 14vw, 3.6rem);
  }

  .mi-wc-single__cart form.cart,
  .mi-wc-single__cart .variations_button {
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
  }

  .mi-wc-single__cart .quantity,
  .mi-wc-single__cart .quantity .qty,
  .mi-wc-single__cart .single_add_to_cart_button {
    width: 100%;
  }

  .mi-wc-single__cart .single_add_to_cart_button {
    min-height: 3.45rem;
    font-size: 0.98rem;
  }
}
/* Step 34: Account page full-width expansion */
.woocommerce-account .mi-wc-account-page > .mi-container {
  width: min(100% - clamp(1rem, 2vw, 2rem), 118rem);
  max-width: none;
}

.woocommerce-account .mi-account-hero {
  grid-template-columns: minmax(0, 1.36fr) minmax(22rem, 0.48fr);
}

.woocommerce-account .mi-account-layout {
  grid-template-columns: minmax(14rem, 18rem) minmax(0, 1fr);
  gap: clamp(var(--mi-space-4), 2.6vw, var(--mi-space-7));
}

.woocommerce-account .mi-account-layout__content {
  width: 100%;
}

.woocommerce-account .mi-account-dashboard__grid {
  grid-template-columns: repeat(3, minmax(16rem, 1fr));
}

.woocommerce-account .mi-account-dashboard__panel {
  grid-template-columns: minmax(0, 1.15fr) minmax(24rem, 0.85fr);
}

.woocommerce-account:not(.logged-in) .mi-account-layout {
  max-width: none;
}

.woocommerce-account:not(.logged-in) .woocommerce form.login,
.woocommerce-account:not(.logged-in) .woocommerce form.register {
  max-width: none;
}

@media (min-width: 1500px) {
  .woocommerce-account .mi-wc-account-page > .mi-container {
    width: min(100% - 2rem, 124rem);
  }

  .woocommerce-account .mi-account-layout {
    grid-template-columns: minmax(15rem, 19rem) minmax(0, 1fr);
  }
}

@media (max-width: 1180px) {
  .woocommerce-account .mi-account-dashboard__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .woocommerce-account .mi-wc-account-page > .mi-container {
    width: min(100% - 1.5rem, 100%);
  }

  .woocommerce-account .mi-account-hero,
  .woocommerce-account .mi-account-layout,
  .woocommerce-account .mi-account-dashboard__panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .woocommerce-account .mi-wc-account-page > .mi-container {
    width: min(100% - 1rem, 100%);
  }

  .woocommerce-account .mi-account-dashboard__grid {
    grid-template-columns: 1fr;
  }
}
/* Step 33: Private member account center final pass */
.woocommerce-account .woocommerce-MyAccount-content table.shop_table,
.woocommerce-MyAccount-content .woocommerce-Address,
.woocommerce-MyAccount-content form.edit-account,
.woocommerce-MyAccount-content form.edit-address,
.woocommerce-MyAccount-content form.woocommerce-EditAccountForm,
.woocommerce form.login,
.woocommerce form.register,
.woocommerce form.lost_reset_password {
  backdrop-filter: blur(18px) saturate(1.12);
}

.woocommerce-account .woocommerce-MyAccount-content table.shop_table a.button:hover,
.woocommerce-MyAccount-content .woocommerce-Address a.edit:hover,
.woocommerce-MyAccount-content button.button:hover,
.woocommerce form.login .button:hover,
.woocommerce form.register .button:hover,
.woocommerce form.lost_reset_password .button:hover {
  transform: translateY(-1px);
}

.woocommerce-account:not(.logged-in) .mi-account-layout {
  grid-template-columns: minmax(0, 1fr);
  max-width: none;
}

.woocommerce-account:not(.logged-in) .mi-account-layout__content {
  display: grid;
  gap: var(--mi-space-4);
}

.woocommerce-account:not(.logged-in) .woocommerce form.login,
.woocommerce-account:not(.logged-in) .woocommerce form.register {
  max-width: none;
}

@media (min-width: 980px) {
  .woocommerce-account:not(.logged-in) .woocommerce {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--mi-space-4);
    align-items: start;
  }

  .woocommerce-account:not(.logged-in) .woocommerce > h2 {
    grid-column: span 1;
  }
}
/* Step 34.1: Account endpoints full-page synchronization */
.woocommerce-account .mi-wc-account-page {
  width: 100%;
  min-height: calc(100svh - var(--mi-header-height, 5rem));
  padding-inline: 0;
  background:
    radial-gradient(circle at 8% 6%, rgba(255,255,255,0.96), transparent 28rem),
    radial-gradient(circle at 96% 12%, rgba(255,224,233,0.62), transparent 34rem),
    radial-gradient(circle at 20% 82%, rgba(242,198,181,0.34), transparent 32rem),
    linear-gradient(180deg, #fffafd 0%, #fff7fa 45%, #ffffff 100%);
}

.woocommerce-account .mi-wc-account-page > .mi-container,
.woocommerce-account.logged-in .mi-wc-account-page > .mi-container,
.woocommerce-account:not(.logged-in) .mi-wc-account-page > .mi-container {
  width: min(100% - clamp(1rem, 2vw, 2rem), 118rem);
  max-width: none;
}

.woocommerce-account .mi-wc-account-shell,
.woocommerce-account .mi-account-layout,
.woocommerce-account:not(.logged-in) .mi-account-layout {
  width: min(100% - clamp(1rem, 2vw, 2rem), 118rem);
  max-width: none;
  margin-inline: auto;
}

.woocommerce-account.logged-in .mi-account-layout {
  grid-template-columns: minmax(14rem, 18rem) minmax(0, 1fr);
}

.woocommerce-account:not(.logged-in) .mi-account-layout {
  grid-template-columns: minmax(0, 1fr);
}

.woocommerce-account .mi-account-layout__content,
.woocommerce-account .woocommerce,
.woocommerce-account .woocommerce-MyAccount-content {
  width: 100%;
  max-width: none;
  min-width: 0;
  background: transparent !important;
}

.woocommerce-account .woocommerce-MyAccount-content > *:not(.mi-account-dashboard):not(.woocommerce-Addresses):not(form):not(table):not(.woocommerce-info):not(.woocommerce-message):not(.woocommerce-error),
.woocommerce-account .woocommerce-MyAccount-content > p,
.woocommerce-account .woocommerce-MyAccount-content > header,
.woocommerce-account .woocommerce-MyAccount-content > section,
.woocommerce-account .woocommerce-MyAccount-content > div:not(.mi-account-dashboard):not(.woocommerce-Addresses) {
  max-width: none;
}

.woocommerce-account .woocommerce-MyAccount-content > p:first-child,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-info,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-message,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-error,
.woocommerce-account .woocommerce-notices-wrapper .woocommerce-info,
.woocommerce-account .woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-account .woocommerce-notices-wrapper .woocommerce-error {
  width: 100%;
  padding: clamp(var(--mi-space-4), 2.4vw, var(--mi-space-5));
  border: 1px solid rgba(217,185,142,0.22);
  border-radius: var(--mi-radius-xl);
  background: linear-gradient(145deg, rgba(255,255,255,0.82), rgba(255,244,248,0.58)) !important;
  box-shadow: var(--mi-shadow-sm);
}

.woocommerce-account .woocommerce-MyAccount-content table.shop_table,
.woocommerce-account .woocommerce-MyAccount-content table.woocommerce-orders-table,
.woocommerce-account .woocommerce-MyAccount-content table.woocommerce-table,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-MyAccount-orders,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-MyAccount-downloads,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-orders-table,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-table--order-downloads {
  width: 100% !important;
  max-width: none;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid rgba(217,185,142,0.22) !important;
  border-radius: var(--mi-radius-xl) !important;
  background: linear-gradient(145deg, rgba(255,255,255,0.82), rgba(255,244,248,0.48)) !important;
  box-shadow: var(--mi-shadow-sm);
  overflow: hidden;
}

.woocommerce-account .woocommerce-MyAccount-content table.shop_table th,
.woocommerce-account .woocommerce-MyAccount-content table.shop_table td,
.woocommerce-account .woocommerce-MyAccount-content table.woocommerce-orders-table th,
.woocommerce-account .woocommerce-MyAccount-content table.woocommerce-orders-table td,
.woocommerce-account .woocommerce-MyAccount-content table.woocommerce-table th,
.woocommerce-account .woocommerce-MyAccount-content table.woocommerce-table td {
  padding: 1.05rem 1.15rem;
  border-color: rgba(217,185,142,0.16) !important;
  background: transparent !important;
}

.woocommerce-account .woocommerce-MyAccount-content table.shop_table thead th,
.woocommerce-account .woocommerce-MyAccount-content table.woocommerce-orders-table thead th,
.woocommerce-account .woocommerce-MyAccount-content table.woocommerce-table thead th {
  background: rgba(255,224,233,0.54) !important;
  color: var(--mi-color-text);
}

.woocommerce-account .woocommerce-MyAccount-content table.shop_table tbody tr,
.woocommerce-account .woocommerce-MyAccount-content table.woocommerce-orders-table tbody tr,
.woocommerce-account .woocommerce-MyAccount-content table.woocommerce-table tbody tr {
  background: rgba(255,255,255,0.36) !important;
}

.woocommerce-account .woocommerce-MyAccount-content table.shop_table tbody tr:nth-child(even),
.woocommerce-account .woocommerce-MyAccount-content table.woocommerce-orders-table tbody tr:nth-child(even),
.woocommerce-account .woocommerce-MyAccount-content table.woocommerce-table tbody tr:nth-child(even) {
  background: rgba(255,244,248,0.38) !important;
}

.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses,
.woocommerce-account .woocommerce-MyAccount-content .u-columns.woocommerce-Addresses {
  width: 100%;
  max-width: none;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(var(--mi-space-4), 2.4vw, var(--mi-space-6));
}

.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address address,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-customer-details address {
  width: 100%;
  max-width: none;
  border: 1px solid rgba(217,185,142,0.22) !important;
  border-radius: var(--mi-radius-xl) !important;
  background: linear-gradient(145deg, rgba(255,255,255,0.82), rgba(255,244,248,0.48)) !important;
  box-shadow: var(--mi-shadow-sm);
}

.woocommerce-account .woocommerce-MyAccount-content form,
.woocommerce-account .woocommerce form.login,
.woocommerce-account .woocommerce form.register,
.woocommerce-account .woocommerce form.lost_reset_password,
.woocommerce-account .woocommerce-EditAccountForm,
.woocommerce-account form.edit-account,
.woocommerce-account form.edit-address {
  width: 100%;
  max-width: none !important;
  border: 1px solid rgba(217,185,142,0.22) !important;
  border-radius: var(--mi-radius-xl) !important;
  background:
    radial-gradient(circle at 10% 0%, rgba(255,255,255,0.96), transparent 32rem),
    linear-gradient(145deg, rgba(255,255,255,0.84), rgba(255,244,248,0.52)) !important;
  box-shadow: var(--mi-shadow-sm);
}

.woocommerce-account .woocommerce-MyAccount-content fieldset,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-address-fields,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-address-fields__field-wrapper {
  width: 100%;
  max-width: none;
}

.woocommerce-account:not(.logged-in) .woocommerce {
  width: 100%;
  max-width: none;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(var(--mi-space-4), 3vw, var(--mi-space-6));
  align-items: start;
  background: transparent !important;
}

.woocommerce-account:not(.logged-in) .woocommerce > h2 {
  margin: 0;
  padding-inline: var(--mi-space-2);
}

.woocommerce-account:not(.logged-in) .woocommerce > h2:nth-of-type(1) {
  grid-column: 1;
  grid-row: 1;
}

.woocommerce-account:not(.logged-in) .woocommerce form.login {
  grid-column: 1;
  grid-row: 2;
}

.woocommerce-account:not(.logged-in) .woocommerce > h2:nth-of-type(2) {
  grid-column: 2;
  grid-row: 1;
}

.woocommerce-account:not(.logged-in) .woocommerce form.register {
  grid-column: 2;
  grid-row: 2;
}

.woocommerce-account .woocommerce-MyAccount-content .button,
.woocommerce-account .woocommerce .button,
.woocommerce-account .woocommerce-button,
.woocommerce-account .edit {
  border-radius: var(--mi-radius-pill) !important;
}

@media (min-width: 1500px) {
  .woocommerce-account .mi-wc-account-page > .mi-container,
  .woocommerce-account.logged-in .mi-wc-account-page > .mi-container,
  .woocommerce-account:not(.logged-in) .mi-wc-account-page > .mi-container,
  .woocommerce-account .mi-wc-account-shell,
  .woocommerce-account .mi-account-layout,
  .woocommerce-account:not(.logged-in) .mi-account-layout {
    width: min(100% - 2rem, 124rem);
  }
}

@media (max-width: 980px) {
  .woocommerce-account:not(.logged-in) .woocommerce,
  .woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses,
  .woocommerce-account .woocommerce-MyAccount-content .u-columns.woocommerce-Addresses {
    grid-template-columns: 1fr;
  }

  .woocommerce-account:not(.logged-in) .woocommerce > h2,
  .woocommerce-account:not(.logged-in) .woocommerce form.login,
  .woocommerce-account:not(.logged-in) .woocommerce form.register {
    grid-column: auto !important;
    grid-row: auto !important;
  }
}

@media (max-width: 760px) {
  .woocommerce-account .mi-wc-account-page > .mi-container,
  .woocommerce-account.logged-in .mi-wc-account-page > .mi-container,
  .woocommerce-account:not(.logged-in) .mi-wc-account-page > .mi-container,
  .woocommerce-account .mi-wc-account-shell,
  .woocommerce-account .mi-account-layout,
  .woocommerce-account:not(.logged-in) .mi-account-layout {
    width: min(100% - 1rem, 100%);
  }
}
/* Step 34.2: Account form inline input and button layout */
.woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(.button),
.woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(button),
.woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(input[type="submit"]),
.woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(.button),
.woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(button),
.woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(input[type="submit"]),
.woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(.button),
.woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(button),
.woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(input[type="submit"]),
.woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(.button),
.woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(button),
.woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(input[type="submit"]) {
  display: flex !important;
  align-items: stretch !important;
  gap: 10px !important;
}

.woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(.button) input.input-text,
.woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(button) input.input-text,
.woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(input[type="submit"]) input.input-text,
.woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(.button) input.input-text,
.woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(button) input.input-text,
.woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(input[type="submit"]) input.input-text,
.woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(.button) input.input-text,
.woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(button) input.input-text,
.woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(input[type="submit"]) input.input-text,
.woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(.button) input.input-text,
.woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(button) input.input-text,
.woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(input[type="submit"]) input.input-text {
  flex: 1 1 auto !important;
  min-width: 0;
  height: auto;
}

.woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(.button) .button,
.woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(button) button,
.woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(input[type="submit"]) input[type="submit"],
.woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(.button) .button,
.woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(button) button,
.woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(input[type="submit"]) input[type="submit"],
.woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(.button) .button,
.woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(button) button,
.woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(input[type="submit"]) input[type="submit"],
.woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(.button) .button,
.woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(button) button,
.woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(input[type="submit"]) input[type="submit"] {
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: clamp(8.75rem, 12vw, 11.5rem);
  align-self: stretch !important;
  white-space: nowrap;
}

.woocommerce-account .woocommerce form.lost_reset_password .form-row:last-of-type,
.woocommerce-account .woocommerce-ResetPassword .form-row:last-of-type {
  display: flex !important;
  align-items: stretch !important;
  gap: 10px !important;
}

.woocommerce-account .woocommerce form.lost_reset_password .form-row:last-of-type input.input-text,
.woocommerce-account .woocommerce-ResetPassword .form-row:last-of-type input.input-text {
  flex: 1 1 auto !important;
  min-width: 0;
}

.woocommerce-account .woocommerce form.lost_reset_password .form-row:last-of-type .button,
.woocommerce-account .woocommerce-ResetPassword .form-row:last-of-type .button {
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: clamp(8.75rem, 12vw, 11.5rem);
  align-self: stretch !important;
  white-space: nowrap;
}

@media (max-width: 767px) {
  .woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(.button),
  .woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(button),
  .woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(input[type="submit"]),
  .woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(.button),
  .woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(button),
  .woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(input[type="submit"]),
  .woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(.button),
  .woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(button),
  .woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(input[type="submit"]),
  .woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(.button),
  .woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(button),
  .woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(input[type="submit"]),
  .woocommerce-account .woocommerce form.lost_reset_password .form-row:last-of-type,
  .woocommerce-account .woocommerce-ResetPassword .form-row:last-of-type {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(.button) .button,
  .woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(button) button,
  .woocommerce-account .woocommerce-MyAccount-content form .form-row:has(input.input-text):has(input[type="submit"]) input[type="submit"],
  .woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(.button) .button,
  .woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(button) button,
  .woocommerce-account .woocommerce form.login .form-row:has(input.input-text):has(input[type="submit"]) input[type="submit"],
  .woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(.button) .button,
  .woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(button) button,
  .woocommerce-account .woocommerce form.register .form-row:has(input.input-text):has(input[type="submit"]) input[type="submit"],
  .woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(.button) .button,
  .woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(button) button,
  .woocommerce-account .woocommerce form.lost_reset_password .form-row:has(input.input-text):has(input[type="submit"]) input[type="submit"],
  .woocommerce-account .woocommerce form.lost_reset_password .form-row:last-of-type .button,
  .woocommerce-account .woocommerce-ResetPassword .form-row:last-of-type .button {
    width: 100% !important;
    min-width: 0;
  }
}
/* Step 35: Cart and checkout conversion confidence polish */
.mi-checkout-header {
  position: relative;
  overflow: hidden;
}

.mi-checkout-header::before {
  content: '';
  position: absolute;
  right: -4rem;
  top: -5rem;
  width: clamp(13rem, 28vw, 27rem);
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,0.8), transparent 64%);
  pointer-events: none;
}

.mi-checkout-header > * {
  position: relative;
  z-index: 1;
}

.mi-checkout-header__side {
  display: grid;
  gap: var(--mi-space-4);
  justify-items: end;
  max-width: none;
}

.mi-checkout-header__badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.6rem;
}

.mi-checkout-header__badges span {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.58rem 0.82rem;
  border: 1px solid rgba(217,185,142,0.24);
  border-radius: var(--mi-radius-pill);
  background: rgba(255,255,255,0.68);
  color: var(--mi-color-muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-checkout-header__badges span::before,
.mi-wc-cart__steps span::before,
.mi-wc-checkout__steps span::before {
  content: '';
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--mi-color-primary), var(--mi-color-accent));
  box-shadow: 0 0 0 0.22rem rgba(217,185,142,0.12);
}

.mi-wc-cart__steps,
.mi-wc-checkout__steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--mi-space-3);
  margin: var(--mi-space-4) 0 var(--mi-space-5);
}

.mi-wc-cart__steps span,
.mi-wc-checkout__steps span {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(217,185,142,0.2);
  border-radius: var(--mi-radius-lg);
  background: linear-gradient(145deg, rgba(255,255,255,0.68), rgba(255,244,248,0.44));
  color: var(--mi-color-muted);
  font-size: 0.82rem;
  font-weight: 850;
  box-shadow: 0 12px 28px rgba(183,135,92,0.07);
}

.mi-wc-cart__steps strong,
.mi-wc-checkout__steps strong {
  color: var(--mi-color-primary-strong);
  font-size: 0.76rem;
  letter-spacing: 0.1em;
}

.mi-wc-cart__panel,
.mi-wc-cart__totals-shell,
.mi-wc-checkout__details,
.mi-wc-checkout__review {
  position: relative;
  overflow: hidden;
}

.mi-wc-cart__panel::before,
.mi-wc-checkout__review::before {
  content: '';
  position: absolute;
  right: -4rem;
  top: -4rem;
  width: 10rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(239,127,165,0.1), transparent 70%);
  pointer-events: none;
}

.mi-wc-cart table.shop_table tbody tr.cart_item {
  transition: background var(--mi-duration-base) var(--mi-ease-out), transform var(--mi-duration-base) var(--mi-ease-out);
}

.mi-wc-cart table.shop_table tbody tr.cart_item:hover {
  background: rgba(255,255,255,0.52);
}

.mi-wc-cart .product-name dl.variation {
  margin: 0.45rem 0 0;
  color: var(--mi-color-muted);
  font-size: 0.82rem;
}

.mi-wc-cart .product-subtotal,
.mi-wc-cart .product-price {
  color: var(--mi-color-text);
  font-weight: 900;
}

.mi-wc-cart__coupon input,
.mi-wc-cart__coupon .button,
.mi-wc-cart .actions > .button {
  min-height: 3rem;
}

.mi-wc-cart .actions > .button {
  border-radius: var(--mi-radius-pill);
}

.mi-wc-cart__privacy-note,
.mi-wc-cart__support-note,
.mi-wc-checkout__review-note {
  display: grid;
  gap: 0.55rem;
  margin: var(--mi-space-3) 0;
  padding: var(--mi-space-3);
  border: 1px solid rgba(217,185,142,0.2);
  border-radius: var(--mi-radius-lg);
  background: rgba(255,255,255,0.56);
}

.mi-wc-cart__privacy-note strong,
.mi-wc-cart__support-note span {
  color: var(--mi-color-primary-strong);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.mi-wc-cart__privacy-note p {
  margin: 0;
  color: var(--mi-color-muted);
  font-size: 0.86rem;
  line-height: 1.65;
}

.mi-wc-cart__support-note {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.mi-wc-cart__support-note a {
  color: var(--mi-color-primary-strong);
  font-weight: 900;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.18em;
}

.mi-wc-checkout__details #customer_details {
  display: grid;
  gap: var(--mi-space-4);
}

.mi-wc-checkout__billing,
.mi-wc-checkout__shipping {
  padding: clamp(var(--mi-space-4), 4vw, var(--mi-space-5));
  border: 1px solid rgba(217,185,142,0.18);
  border-radius: var(--mi-radius-xl);
  background: rgba(255,255,255,0.44);
}

.mi-wc-checkout__details h3,
.mi-wc-checkout__review h3 {
  margin-top: 0;
  font-family: var(--mi-font-display);
  line-height: 0.98;
}

.mi-wc-checkout .form-row {
  margin-bottom: var(--mi-space-3);
}

.mi-wc-checkout .form-row label {
  display: inline-flex;
  margin-bottom: 0.45rem;
}

.mi-wc-checkout .select2-container .select2-selection--single {
  min-height: 3.05rem;
  border: 1px solid var(--mi-color-border);
  border-radius: var(--mi-radius-md);
  background: rgba(255,255,255,0.78);
}

.mi-wc-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 3.05rem;
  padding-inline: 1rem;
  color: var(--mi-color-text);
}

.mi-wc-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 3.05rem;
}

.mi-wc-checkout__review-note {
  grid-template-columns: 1fr;
}

.mi-wc-checkout__review-note span {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: var(--mi-color-muted);
  font-size: 0.78rem;
  font-weight: 850;
}

.mi-wc-checkout__review-note span::before {
  content: '';
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--mi-color-primary), var(--mi-color-accent));
}

.mi-wc-checkout #order_review table.shop_table th,
.mi-wc-checkout #order_review table.shop_table td {
  padding: 0.95rem 0.35rem;
}

.mi-wc-checkout #payment {
  margin-top: var(--mi-space-4);
  border: 1px solid rgba(217,185,142,0.2);
  border-radius: var(--mi-radius-xl);
  background: linear-gradient(145deg, rgba(255,255,255,0.68), rgba(255,244,248,0.42));
  box-shadow: var(--mi-shadow-sm);
}

.mi-wc-checkout #payment ul.payment_methods {
  border-bottom-color: rgba(217,185,142,0.18);
}

.mi-wc-checkout #payment div.payment_box {
  border-radius: var(--mi-radius-md);
  background: rgba(255,255,255,0.72);
  color: var(--mi-color-muted);
}

.mi-wc-checkout #payment div.payment_box::before {
  border-bottom-color: rgba(255,255,255,0.72);
}

.mi-wc-checkout #place_order {
  width: 100%;
  min-height: 3.45rem;
  margin-top: var(--mi-space-3);
  font-size: 0.95rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
  color: var(--mi-color-muted);
  font-size: 0.86rem;
  line-height: 1.65;
}

@media (max-width: 980px) {
  .mi-checkout-header__side {
    justify-items: start;
  }

  .mi-checkout-header__badges {
    justify-content: flex-start;
  }

  .mi-wc-cart__steps,
  .mi-wc-checkout__steps {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .mi-wc-cart__support-note {
    grid-template-columns: 1fr;
  }

  .mi-wc-cart__coupon,
  .mi-wc-cart .actions {
    grid-template-columns: 1fr;
  }

  .mi-wc-cart__coupon input,
  .mi-wc-cart__coupon .button,
  .mi-wc-cart .actions > .button {
    width: 100%;
  }

  .mi-wc-checkout__billing,
  .mi-wc-checkout__shipping {
    padding: var(--mi-space-4);
  }
}
/* Step 35: WooCommerce My Account layout repair - v2.9.5 */
.woocommerce-account.logged-in .mi-account-layout {
  display: grid !important;
  grid-template-columns: 260px minmax(0, 1fr) !important;
  gap: clamp(1.5rem, 3vw, 3rem) !important;
  align-items: start !important;
  width: 100% !important;
  max-width: 1180px !important;
  margin-inline: auto !important;
  padding: clamp(1.25rem, 2.5vw, 2.25rem) !important;
  border-radius: clamp(1.5rem, 3vw, 2.5rem) !important;
  background: linear-gradient(145deg, rgba(255, 244, 248, 0.92), rgba(255, 250, 246, 0.78)) !important;
  box-shadow: none !important;
}

.woocommerce-account.logged-in .mi-account-layout > *,
.woocommerce-account.logged-in .mi-account-layout__content,
.woocommerce-account.logged-in .woocommerce,
.woocommerce-account.logged-in .woocommerce-MyAccount-navigation,
.woocommerce-account.logged-in .woocommerce-MyAccount-content {
  min-width: 0 !important;
  max-width: 100% !important;
  float: none !important;
  clear: none !important;
  box-sizing: border-box !important;
}

.woocommerce-account.logged-in .woocommerce,
.woocommerce-account.logged-in .woocommerce::before,
.woocommerce-account.logged-in .woocommerce::after {
  display: block !important;
  content: none !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-navigation {
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  position: relative !important;
  z-index: 1 !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-content {
  width: 100% !important;
  margin: 0 !important;
  min-width: 0 !important;
  padding: clamp(1.1rem, 2vw, 1.6rem) !important;
  border: 1px solid rgba(217, 185, 142, 0.22) !important;
  border-radius: var(--mi-radius-xl) !important;
  background: rgba(255, 255, 255, 0.72) !important;
  box-shadow: none !important;
  overflow: visible !important;
  position: relative !important;
  z-index: 0 !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 0.6rem !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li {
  margin: 0 !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-navigation a {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  overflow-wrap: anywhere !important;
  box-shadow: none !important;
}

.woocommerce-account.logged-in .mi-account-dashboard__grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
  gap: clamp(1rem, 2vw, 1.5rem) !important;
  align-items: stretch !important;
}

.woocommerce-account.logged-in .mi-account-dashboard__tile {
  width: 100% !important;
  min-width: 0 !important;
  height: 100% !important;
  overflow: hidden !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
  box-shadow: none !important;
}

.woocommerce-account.logged-in .mi-account-dashboard__tile *,
.woocommerce-account.logged-in .woocommerce-MyAccount-content * {
  max-width: 100%;
}

.woocommerce-account.logged-in .mi-account-dashboard__tile span,
.woocommerce-account.logged-in .mi-account-dashboard__tile strong,
.woocommerce-account.logged-in .mi-account-dashboard__tile small,
.woocommerce-account.logged-in .woocommerce-MyAccount-content p,
.woocommerce-account.logged-in .woocommerce-MyAccount-content a,
.woocommerce-account.logged-in .woocommerce-MyAccount-content td,
.woocommerce-account.logged-in .woocommerce-MyAccount-content th {
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-Addresses,
.woocommerce-account.logged-in .woocommerce-MyAccount-content .u-columns.woocommerce-Addresses {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important;
  gap: clamp(1rem, 2.2vw, 1.75rem) !important;
  width: 100% !important;
  max-width: none !important;
  margin-top: clamp(1rem, 2vw, 1.5rem) !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-Addresses::before,
.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-Addresses::after,
.woocommerce-account.logged-in .woocommerce-MyAccount-content .u-columns.woocommerce-Addresses::before,
.woocommerce-account.logged-in .woocommerce-MyAccount-content .u-columns.woocommerce-Addresses::after {
  display: none !important;
  content: none !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-Addresses .u-column1,
.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-Addresses .u-column2,
.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-Address {
  width: 100% !important;
  min-width: 0 !important;
  float: none !important;
  clear: none !important;
  margin: 0 !important;
  box-shadow: none !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-Address,
.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-Address address,
.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-customer-details address,
.woocommerce-account.logged-in .woocommerce-MyAccount-content table.shop_table,
.woocommerce-account.logged-in .woocommerce-MyAccount-content table.woocommerce-orders-table,
.woocommerce-account.logged-in .woocommerce-MyAccount-content table.woocommerce-table,
.woocommerce-account.logged-in .woocommerce-MyAccount-content form,
.woocommerce-account.logged-in .woocommerce-MyAccount-content fieldset,
.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-info,
.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-message,
.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-error,
.woocommerce-account.logged-in .mi-account-dashboard__welcome,
.woocommerce-account.logged-in .mi-account-dashboard__panel,
.woocommerce-account.logged-in .mi-account-dashboard__note {
  box-shadow: none !important;
}

@media (max-width: 980px) {
  .woocommerce-account.logged-in .mi-account-layout {
    grid-template-columns: 1fr !important;
  }

  .woocommerce-account.logged-in .mi-account-dashboard__grid {
    grid-template-columns: 1fr !important;
  }

  .woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-Addresses,
  .woocommerce-account.logged-in .woocommerce-MyAccount-content .u-columns.woocommerce-Addresses {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px) {
  .woocommerce-account.logged-in .mi-account-layout {
    padding: 1rem !important;
    border-radius: 1.5rem !important;
  }

  .woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul {
    grid-template-columns: 1fr !important;
  }
}

/* Step 38: Account and content polish - v3.10.1 */
.mi-account-layout--guest {
  display: block;
}

.mi-account-auth {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(20rem, 0.78fr);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: stretch;
}

.mi-account-auth__panel,
.mi-account-subpage,
.mi-account-form--lost-password,
.mi-account-form--details {
  position: relative;
  overflow: hidden;
  padding: clamp(1.35rem, 3vw, 2.25rem);
  border: 1px solid rgba(184, 94, 117, 0.16);
  border-radius: clamp(1.25rem, 2.8vw, 1.75rem);
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.88), rgba(255, 246, 249, 0.72));
  box-shadow: 0 18px 46px rgba(74, 49, 53, 0.08);
  backdrop-filter: blur(18px) saturate(1.08);
}

.mi-account-auth__intro {
  display: grid;
  gap: 0.7rem;
  margin-bottom: clamp(1.1rem, 2vw, 1.6rem);
}

.mi-account-auth__intro h2,
.mi-account-subpage__header h2,
.mi-account-form--details .mi-account-subpage__header h2 {
  margin: 0;
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: clamp(2.3rem, 4.8vw, 4.4rem);
  line-height: 0.96;
  letter-spacing: 0;
}

.mi-account-auth__intro p,
.mi-account-subpage__header p,
.mi-account-form__hint,
.mi-account-auth__panel small {
  color: var(--mi-color-text-muted);
  line-height: 1.75;
}

.mi-account-form,
.woocommerce-account form.login,
.woocommerce-account form.register,
.woocommerce-account form.lost_reset_password,
.woocommerce-account form.edit-account {
  display: grid;
  gap: 1rem;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
}

.mi-account-form .form-row {
  margin: 0;
  padding: 0;
}

.mi-account-form label,
.woocommerce-account .woocommerce-form-row label,
.woocommerce-account .form-row label {
  display: grid;
  gap: 0.45rem;
  color: var(--mi-color-text);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.mi-account-form input[type='text'],
.mi-account-form input[type='email'],
.mi-account-form input[type='password'],
.woocommerce-account input.input-text,
.woocommerce-account .woocommerce-Input {
  min-height: 3.35rem;
  width: 100%;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(184, 94, 117, 0.18);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.82);
  color: var(--mi-color-text);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
  transition: border-color 180ms ease, box-shadow 180ms ease, background 180ms ease;
}

.mi-account-form input:focus-visible,
.woocommerce-account input.input-text:focus-visible,
.woocommerce-account .woocommerce-Input:focus-visible {
  border-color: rgba(184, 94, 117, 0.46);
  background: #fff;
  box-shadow: 0 0 0 0.25rem rgba(184, 94, 117, 0.12);
  outline: none;
}

.mi-account-form__row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem 1rem;
  align-items: center;
  justify-content: space-between;
}

.mi-account-form__row label {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: 0.55rem;
  text-transform: none;
  letter-spacing: 0;
}

.mi-account-form__link,
.mi-account-dashboard__note a,
.mi-account-subpage a.edit {
  color: var(--mi-color-primary-strong);
  font-weight: 900;
  text-decoration: underline;
  text-underline-offset: 0.22em;
}

.mi-account-auth__benefits {
  display: grid;
  gap: 0.75rem;
  margin: 0 0 1.3rem;
  padding: 0;
  list-style: none;
}

.mi-account-auth__benefits li {
  position: relative;
  padding-left: 1.45rem;
  color: var(--mi-color-text-muted);
  font-weight: 750;
  line-height: 1.55;
}

.mi-account-auth__benefits li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.58em;
  width: 0.48rem;
  height: 0.48rem;
  border-radius: 999px;
  background: var(--mi-gradient-primary);
  box-shadow: 0 0 0 0.24rem rgba(184, 94, 117, 0.1);
}

.mi-account-quickbar {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.woocommerce-account.logged-in .mi-account-dashboard__grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.mi-account-subpage {
  display: grid;
  gap: clamp(1rem, 2.4vw, 1.75rem);
}

.mi-account-subpage__header {
  display: grid;
  gap: 0.7rem;
  max-width: 48rem;
}

.mi-account-subpage .shop_table {
  overflow: hidden;
  border-radius: 1.25rem;
}

.mi-account-subpage .woocommerce-Address {
  padding: clamp(1rem, 2vw, 1.5rem);
  border: 1px solid rgba(184, 94, 117, 0.14);
  border-radius: 1.25rem;
  background: rgba(255, 255, 255, 0.7);
}

.mi-account-form fieldset {
  display: grid;
  gap: 1rem;
  margin: 0;
  padding: clamp(1rem, 2vw, 1.5rem);
  border: 1px solid rgba(184, 94, 117, 0.14);
  border-radius: 1.25rem;
}

.mi-account-form legend {
  padding-inline: 0.4rem;
  color: var(--mi-color-primary-strong);
  font-weight: 900;
}

.mi-mood-entry-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.5rem);
}

.mi-mood-entry-card {
  display: grid;
  gap: 0.8rem;
  min-height: 14rem;
  padding: clamp(1.25rem, 2.5vw, 2rem);
  border: 1px solid rgba(184, 94, 117, 0.16);
  border-radius: 1.35rem;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.82), rgba(255, 246, 249, 0.7));
  box-shadow: 0 16px 42px rgba(74, 49, 53, 0.08);
}

.mi-mood-entry-card span {
  color: var(--mi-color-primary-strong);
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.14em;
}

.mi-mood-entry-card strong {
  font-family: var(--mi-font-display);
  font-size: clamp(2rem, 3.5vw, 3.1rem);
  line-height: 0.95;
}

.mi-mood-entry-card small {
  color: var(--mi-color-text-muted);
  font-size: 0.95rem;
  line-height: 1.7;
}

@media (max-width: 980px) {
  .mi-account-auth,
  .mi-mood-entry-grid,
  .mi-account-quickbar,
  .woocommerce-account.logged-in .mi-account-dashboard__grid {
    grid-template-columns: 1fr !important;
  }
}

/* Step 37: Editorial storefront refinement */
:root {
  --mi-color-bg: #fffdfc;
  --mi-color-bg-soft: #fbf6f5;
  --mi-color-border: rgba(100, 69, 73, 0.14);
  --mi-color-text: #35272b;
  --mi-color-text-muted: #79676c;
  --mi-color-primary: #b85e75;
  --mi-color-primary-strong: #98465e;
  --mi-color-accent: #ad8668;
  --mi-gradient-page: linear-gradient(180deg, #fffdfc 0%, #fbf6f5 100%);
  --mi-gradient-primary: linear-gradient(135deg, #bd6078 0%, #9b4b62 100%);
  --mi-gradient-glass: rgba(255, 255, 255, 0.86);
  --mi-shadow-sm: 0 8px 24px rgba(74, 49, 53, 0.07);
  --mi-shadow-md: 0 18px 50px rgba(74, 49, 53, 0.1);
  --mi-shadow-lg: 0 26px 68px rgba(74, 49, 53, 0.15);
  --mi-shadow-glow: 0 14px 34px rgba(152, 70, 94, 0.2);
}

[data-theme="dark"] {
  --mi-color-bg: #1f1719;
  --mi-color-bg-soft: #2a1e21;
  --mi-color-border: rgba(241, 205, 211, 0.15);
  --mi-color-text: #fff8f7;
  --mi-color-text-muted: #cdb9bc;
  --mi-color-primary: #e292a3;
  --mi-color-primary-strong: #f1b1bf;
  --mi-color-accent: #d2a989;
  --mi-gradient-page: linear-gradient(180deg, #1f1719 0%, #291d20 100%);
  --mi-gradient-primary: linear-gradient(135deg, #cf7d91 0%, #a7566c 100%);
  --mi-gradient-glass: rgba(45, 32, 36, 0.92);
  --mi-shadow-sm: 0 8px 24px rgba(0, 0, 0, 0.18);
  --mi-shadow-md: 0 18px 50px rgba(0, 0, 0, 0.25);
  --mi-shadow-lg: 0 26px 68px rgba(0, 0, 0, 0.32);
  --mi-shadow-glow: 0 14px 34px rgba(207, 125, 145, 0.16);
}

body,
body::before {
  background: var(--mi-gradient-page);
  animation: none;
}

body::after,
.mi-section--hero::before {
  display: none;
}

.mi-nav-shell {
  padding-block: 0;
  border-bottom: 1px solid rgba(100, 69, 73, 0.1);
  background: rgba(255, 253, 252, 0.94);
  backdrop-filter: blur(18px);
}

.mi-nav-shell.is-scrolled,
.mi-nav-shell:focus-within,
.mi-nav-shell:hover {
  background: rgba(255, 253, 252, 0.98);
  box-shadow: 0 8px 24px rgba(74, 49, 53, 0.06);
}

[data-theme="dark"] .mi-nav-shell,
[data-theme="dark"] .mi-nav-shell.is-scrolled,
[data-theme="dark"] .mi-nav-shell:focus-within,
[data-theme="dark"] .mi-nav-shell:hover {
  background: rgba(31, 23, 25, 0.96);
}

.mi-nav {
  min-height: 4.5rem;
  padding: 0;
  border: 0;
  border-radius: 0;
}

.mi-nav-shell.is-scrolled .mi-nav,
.mi-nav-shell:hover .mi-nav,
.mi-nav-shell:focus-within .mi-nav {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}

.mi-wordmark span {
  color: #4b3038;
  font-size: 1.85rem;
  letter-spacing: 0;
}

.mi-wordmark small,
.mi-nav__links a,
.mi-nav__account {
  letter-spacing: 0;
}

.home .mi-section--hero,
.front-page .mi-section--hero {
  min-height: min(50rem, calc(100svh - 4.5rem));
  padding-block: clamp(2.5rem, 5vw, 4.5rem);
  background: #f9f2f0;
}

[data-theme="dark"] .home .mi-section--hero,
[data-theme="dark"] .front-page .mi-section--hero {
  background: #251a1d;
}

.home .mi-container--hero,
.front-page .mi-container--hero {
  grid-template-columns: minmax(19rem, 0.78fr) minmax(32rem, 1.22fr);
  gap: clamp(2rem, 4vw, 5rem);
}

.mi-hero-copy h1 {
  max-width: 8.5ch;
  color: #422d34;
  font-size: clamp(4.4rem, 7vw, 7.4rem);
  line-height: 0.88;
  letter-spacing: 0;
}

.mi-hero-copy .mi-lede {
  max-width: 35rem;
  color: #705f63;
  font-size: 1.02rem;
}

.mi-button {
  min-height: 3.15rem;
  border-radius: 0.25rem;
  letter-spacing: 0;
}

.mi-hero-proof {
  gap: 0;
  padding-top: 0.25rem;
}

.mi-hero-proof span {
  min-height: auto;
  padding: 0 0.85rem;
  border: 0;
  border-right: 1px solid rgba(100, 69, 73, 0.16);
  border-radius: 0;
  background: transparent;
  font-size: 0.72rem;
  letter-spacing: 0;
  backdrop-filter: none;
}

.mi-hero-proof span:first-child {
  padding-left: 0;
}

.mi-hero-proof span:last-child {
  border-right: 0;
}

.mi-hero-proof span::before {
  width: 0.35rem;
  background: #b85e75;
  box-shadow: none;
}

.mi-hero-editorial {
  min-height: 35rem;
  overflow: hidden;
  border-radius: 0.5rem;
  background: #eadfdc;
  box-shadow: 0 22px 60px rgba(87, 54, 59, 0.14);
}

.mi-hero-editorial > img {
  width: 100%;
  height: 100%;
  min-height: 35rem;
  display: block;
  object-fit: cover;
}

.mi-hero-editorial__label {
  position: absolute;
  left: 1.25rem;
  bottom: 1.25rem;
  width: min(19rem, calc(100% - 2.5rem));
  padding: 1.15rem;
  background: rgba(255, 253, 252, 0.9);
  backdrop-filter: blur(14px);
}

.mi-hero-editorial__label p,
.mi-hero-editorial__label strong,
.mi-hero-editorial__label a {
  display: block;
}

.mi-hero-editorial__label p,
.mi-hero-editorial__note span {
  margin: 0 0 0.4rem;
  color: #98465e;
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.mi-hero-editorial__label strong {
  color: #422d34;
  font-family: var(--mi-font-display);
  font-size: 1.7rem;
  line-height: 1;
}

.mi-hero-editorial__label a {
  margin-top: 0.75rem;
  color: #98465e;
  font-size: 0.75rem;
  font-weight: 900;
  text-decoration: underline;
  text-underline-offset: 0.22rem;
}

.mi-hero-editorial__note {
  position: absolute;
  top: 1.25rem;
  right: 1.25rem;
  width: min(14rem, calc(100% - 2.5rem));
  padding: 0.9rem 1rem;
  border-left: 2px solid #b85e75;
  background: rgba(255, 253, 252, 0.86);
}

.mi-hero-editorial__note p {
  margin: 0;
  color: #5c474d;
  font-size: 0.76rem;
  line-height: 1.55;
}

[data-theme="dark"] .mi-hero-editorial__label,
[data-theme="dark"] .mi-hero-editorial__note {
  background: rgba(39, 28, 31, 0.88);
}

[data-theme="dark"] .mi-hero-editorial__label strong,
[data-theme="dark"] .mi-hero-editorial__note p {
  color: #fff8f7;
}

.mi-section--categories,
.mi-section--products {
  background: #fffdfc;
}

[data-theme="dark"] .mi-section--categories,
[data-theme="dark"] .mi-section--products {
  background: #21181a;
}

.mi-section-heading h2 {
  color: #422d34;
  letter-spacing: 0;
}

.mi-category-grid {
  grid-auto-rows: minmax(15rem, auto);
  gap: 0.75rem;
}

.mi-category-card,
.mi-product-card,
.mi-promise-card,
.mi-guide-card {
  border-radius: 0.4rem;
}

.mi-category-card {
  min-height: 15rem;
  padding: 1.5rem;
  background: #f7efee;
  box-shadow: none;
  backdrop-filter: none;
}

.mi-category-card::before {
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.42), rgba(234, 210, 210, 0.22));
}

.mi-category-card::after {
  display: none;
}

.mi-category-card:hover,
.mi-category-card:focus-visible {
  transform: translateY(-4px);
  border-color: rgba(152, 70, 94, 0.3);
  box-shadow: var(--mi-shadow-sm);
}

.mi-category-card--large {
  min-height: 31rem;
  background: #ecd9dc;
}

[data-theme="dark"] .mi-category-card {
  background: #302326;
}

[data-theme="dark"] .mi-category-card--large {
  background: #493036;
}

.mi-category-card--large::before {
  background: linear-gradient(145deg, rgba(255, 253, 252, 0.36), rgba(187, 114, 130, 0.12));
}

.mi-category-card__index {
  width: auto;
  height: auto;
  display: block;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.mi-category-card h3 {
  font-size: clamp(2.5rem, 5vw, 4.9rem);
  letter-spacing: 0;
}

.mi-category-card:not(.mi-category-card--large) h3 {
  font-size: clamp(2rem, 3vw, 3rem);
}

.mi-product-badge,
.mi-add-button {
  border-radius: 0.25rem;
  letter-spacing: 0;
}

.mi-product-grid {
  gap: 0.9rem;
}

.mi-product-card {
  box-shadow: none;
}

.mi-product-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--mi-shadow-sm);
}

.mi-section--privacy {
  background: #f4ebe8;
}

[data-theme="dark"] .mi-section--privacy {
  background: #2a1e21;
}

@media (max-width: 920px) {
  .home .mi-container--hero,
  .front-page .mi-container--hero {
    grid-template-columns: 1fr;
  }

  .mi-hero-copy h1 {
    max-width: 9ch;
  }
}

@media (max-width: 640px) {
  .mi-nav {
    min-height: 4rem;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.35rem;
    width: min(100% - 1rem, var(--mi-container-wide));
  }

  .mi-wordmark {
    min-width: 0;
  }

  .mi-wordmark span {
    font-size: 1.35rem;
  }

  .mi-wordmark small {
    font-size: 0.46rem;
    letter-spacing: 0.08em;
  }

  .mi-nav__actions {
    gap: 0.3rem;
  }

  .mi-nav__account,
  .mi-theme-toggle {
    display: none;
  }

  .mi-cart-button {
    min-height: 2.55rem;
    gap: 0.35rem;
    padding-inline: 0.7rem 0.35rem;
  }

  .mi-cart-button strong {
    min-width: 1.75rem;
    height: 1.75rem;
  }

  .mi-menu-button {
    width: 2.55rem;
    height: 2.55rem;
  }

  .home .mi-section--hero,
  .front-page .mi-section--hero {
    padding-block: 2rem 2.5rem;
  }

  .mi-hero-copy h1 {
    font-size: clamp(3.9rem, 20vw, 5.5rem);
  }

  .mi-hero-proof {
    display: flex;
    gap: 0.45rem 0;
  }

  .mi-hero-proof span {
    width: auto;
    padding-inline: 0.55rem;
  }

  .mi-hero-editorial,
  .mi-hero-editorial > img {
    min-height: 25rem;
  }

  .mi-hero-editorial__note {
    top: 0.75rem;
    right: 0.75rem;
  }

  .mi-hero-editorial__label {
    left: 0.75rem;
    bottom: 0.75rem;
  }

  .mi-category-card--large {
    min-height: 20rem;
  }
}

/* Step 38: Cart drawer four-region layout and mobile fit */
.mi-cart-drawer__panel {
  grid-template-rows: auto auto minmax(0, 1fr) auto;
}

/* Step 39: Demo catalog image fallbacks */
.mi-demo-product-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mi-wc-single__demo-image {
  overflow: hidden;
  border-radius: var(--mi-radius-xl);
  background: var(--mi-color-surface-strong);
}

.mi-demo-product-image--single {
  aspect-ratio: 1;
}

.mi-mobile-menu a::after {
  content: none;
}

.mi-mobile-menu > a::after {
  content: ">";
}

/* Step 43: Consolidated storefront category navigation */
.mi-mega-menu {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.mi-nav-shell.is-mega-open .mi-mega-menu {
  max-height: 19rem;
}

.mi-mega-menu > div {
  grid-column: span 2;
}

.mi-mega-menu > div,
.mi-mega-menu > a {
  min-height: 5rem;
}

.mi-mega-menu > a {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  justify-content: flex-end;
  background: #f7efee;
}

.mi-mega-menu > a::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image: var(--mi-menu-image);
  background-position: center;
  background-size: cover;
  transition: transform var(--mi-duration-slow) var(--mi-ease-out);
}

.mi-mega-menu > a::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(90deg, rgba(255, 253, 252, 0.96), rgba(255, 253, 252, 0.72) 44%, rgba(255, 253, 252, 0.12));
}

.mi-mega-menu > a:hover::before,
.mi-mega-menu > a:focus-visible::before {
  transform: scale(1.06);
}

.mi-mega-menu > a span {
  max-width: 12ch;
  text-shadow: 0 1px 8px rgba(255, 255, 255, 0.78);
}

.mi-mega-menu__all {
  color: var(--mi-color-primary-strong);
}

@media (max-width: 1080px) {
  .mi-mobile-shop {
    display: grid;
    gap: 0.35rem;
  }

  .mi-mobile-shop > button {
    min-height: 3.3rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-inline: var(--mi-space-4);
    border: 0;
    border-radius: var(--mi-radius-md);
    background: rgba(255, 255, 255, 0.22);
    color: var(--mi-color-text);
    cursor: pointer;
    font-family: var(--mi-font-display);
    font-size: 1.55rem;
    font-weight: 600;
    text-align: left;
  }

  .mi-mobile-shop > button span:last-child {
    color: var(--mi-color-primary-strong);
    font-family: var(--mi-font-body);
    font-size: 1.35rem;
    transition: transform var(--mi-duration-base) var(--mi-ease-out);
  }

  .mi-mobile-shop > button[aria-expanded="true"] span:last-child {
    transform: rotate(45deg);
  }

  .mi-mobile-shop__categories {
    display: grid;
    gap: 0.25rem;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height var(--mi-duration-slow) var(--mi-ease-out),
                opacity var(--mi-duration-base) var(--mi-ease-out);
  }

  .mi-mobile-shop__categories.is-open {
    max-height: 36rem;
    opacity: 1;
  }

  .mi-mobile-shop__categories a {
    min-height: 2.5rem;
    padding-inline: var(--mi-space-5);
    background: rgba(255, 255, 255, 0.12);
    font-family: var(--mi-font-body);
    font-size: 0.92rem;
    font-weight: 800;
  }

  .mi-mobile-shop__categories a::after {
    content: ">";
    color: var(--mi-color-primary-strong);
  }
}

/* Step 44: Homepage merchandising rhythm */
.home .mi-section--hero,
.front-page .mi-section--hero {
  min-height: auto;
  padding-block: clamp(2.75rem, 5vw, 5rem);
}

.home .mi-container--hero,
.front-page .mi-container--hero {
  grid-template-columns: minmax(0, 0.82fr) minmax(24rem, 1.18fr);
  gap: clamp(2rem, 4vw, 4.5rem);
}

.home .mi-hero-copy h1,
.front-page .mi-hero-copy h1 {
  max-width: 9ch;
  font-size: clamp(4.6rem, 7.6vw, 8.4rem);
}

.home .mi-hero-editorial,
.front-page .mi-hero-editorial {
  min-height: clamp(25rem, 42vw, 38rem);
}

.mi-home-trust {
  border-block: 1px solid var(--mi-color-border);
  background: #fffaf9;
}

[data-theme="dark"] .mi-home-trust {
  background: #2b2022;
}

.mi-home-trust__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mi-home-trust article {
  min-height: 6rem;
  display: flex;
  align-items: center;
  gap: 0.9rem;
  padding: 1.15rem 1.25rem;
  border-inline-end: 1px solid var(--mi-color-border);
}

.mi-home-trust article:last-child {
  border-inline-end: 0;
}

.mi-home-trust article > span {
  color: var(--mi-color-primary-strong);
  font-family: var(--mi-font-display);
  font-size: 1.55rem;
  font-weight: 700;
}

.mi-home-trust article div {
  display: grid;
  gap: 0.18rem;
}

.mi-home-trust strong {
  color: var(--mi-color-text);
  font-size: 0.82rem;
}

.mi-home-trust small {
  color: var(--mi-color-text-muted);
  font-size: 0.7rem;
  line-height: 1.45;
}

.mi-section-heading__aside {
  max-width: 35rem;
  display: grid;
  justify-items: start;
  gap: 0.8rem;
}

.mi-section-heading__aside p {
  margin: 0;
}

.mi-section-heading__aside a {
  color: var(--mi-color-primary-strong);
  font-size: 0.76rem;
  font-weight: 900;
  text-transform: uppercase;
}

.mi-section--bestsellers {
  background: #fffdfc;
}

[data-theme="dark"] .mi-section--bestsellers {
  background: #241a1c;
}

.mi-category-grid--editorial {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-auto-rows: minmax(22rem, auto);
}

.mi-category-grid--editorial .mi-category-card,
.mi-category-grid--editorial .mi-category-card--large {
  min-height: 22rem;
}

.mi-category-card--image {
  isolation: isolate;
  overflow: hidden;
  justify-content: flex-end;
  background: #eadbdd;
}

.mi-category-card--image::before {
  inset: 0;
  background-image: linear-gradient(180deg, rgba(255,255,255,0.03) 18%, rgba(255,251,250,0.94) 100%), var(--mi-category-image);
  background-position: center;
  background-size: cover;
  opacity: 1;
  transform: scale(1);
}

.mi-category-card--image:hover::before,
.mi-category-card--image:focus-visible::before {
  transform: scale(1.05);
}

.mi-category-card--image .mi-category-card__index,
.mi-category-card--image div {
  position: relative;
  z-index: 1;
}

.mi-category-card--image h3 {
  font-size: clamp(2rem, 2.9vw, 3.2rem);
}

.mi-category-card--image p {
  color: #654e55;
  font-size: 0.82rem;
}

/* Step 45: Homepage alignment and compact storefront spacing */
.home .mi-section--hero,
.front-page .mi-section--hero {
  padding-block: clamp(2.25rem, 4vw, 4rem) clamp(2.5rem, 4vw, 4rem);
}

.home .mi-section--products,
.home .mi-section--categories,
.front-page .mi-section--products,
.front-page .mi-section--categories {
  padding-block: clamp(3.5rem, 5vw, 5.25rem);
}

.home .mi-section-heading,
.front-page .mi-section-heading {
  margin-bottom: clamp(1.75rem, 3vw, 2.75rem);
}

.home .mi-section-heading--split,
.front-page .mi-section-heading--split {
  grid-template-columns: minmax(0, 0.95fr) minmax(20rem, 0.52fr);
  align-items: end;
  gap: clamp(1.5rem, 4vw, 4rem);
}

.home .mi-section-heading--split h2,
.front-page .mi-section-heading--split h2 {
  max-width: 13ch;
  margin-bottom: 0;
  font-size: clamp(3.75rem, 5.5vw, 5.65rem);
  line-height: 0.92;
}

.home .mi-section-heading__aside,
.front-page .mi-section-heading__aside {
  padding-bottom: 0.25rem;
}

.home .mi-section-heading__aside p,
.front-page .mi-section-heading__aside p,
.home .mi-section-heading--split > p,
.front-page .mi-section-heading--split > p {
  max-width: 31rem;
  font-size: 0.96rem;
  line-height: 1.7;
}

.home .mi-product-card--live .mi-product-info h3,
.front-page .mi-product-card--live .mi-product-info h3 {
  font-size: clamp(1.45rem, 1.85vw, 1.9rem);
  line-height: 1.02;
}

.home .mi-category-grid--editorial,
.front-page .mi-category-grid--editorial {
  margin-top: 0.25rem;
}

.home .mi-section--categories .mi-section-heading--stack,
.front-page .mi-section--categories .mi-section-heading--stack {
  max-width: 58rem;
  display: grid;
  gap: 0.85rem;
}

.home .mi-section--categories .mi-section-heading--stack h2,
.front-page .mi-section--categories .mi-section-heading--stack h2 {
  max-width: 13ch;
  margin-bottom: 0;
  font-size: clamp(3.75rem, 5.5vw, 5.65rem);
  line-height: 0.92;
}

.home .mi-section--categories .mi-section-heading--stack > p,
.front-page .mi-section--categories .mi-section-heading--stack > p {
  max-width: 43rem;
  margin: 0;
  color: var(--mi-color-text-muted);
  font-size: 0.96rem;
  line-height: 1.7;
}

.home .mi-category-grid--editorial .mi-category-card,
.home .mi-category-grid--editorial .mi-category-card--large,
.front-page .mi-category-grid--editorial .mi-category-card,
.front-page .mi-category-grid--editorial .mi-category-card--large {
  grid-row: auto;
  min-height: 22rem;
}


@media (max-width: 920px) {
  .home .mi-container--hero,
  .front-page .mi-container--hero {
    grid-template-columns: 1fr;
  }

  .mi-home-trust__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mi-home-trust article:nth-child(2) {
    border-inline-end: 0;
  }

  .mi-home-trust article:nth-child(-n + 2) {
    border-block-end: 1px solid var(--mi-color-border);
  }

  .mi-category-grid--editorial {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-auto-rows: minmax(18rem, auto);
  }

  .mi-category-grid--editorial .mi-category-card,
  .mi-category-grid--editorial .mi-category-card--large {
    min-height: 18rem;
  }

  .home .mi-section-heading--split,
  .front-page .mi-section-heading--split {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }

  .home .mi-section-heading--split h2,
  .front-page .mi-section-heading--split h2 {
    font-size: clamp(3.5rem, 9vw, 5rem);
  }

  .home .mi-section--categories .mi-section-heading--stack h2,
  .front-page .mi-section--categories .mi-section-heading--stack h2 {
    font-size: clamp(3.5rem, 9vw, 5rem);
  }
}

@media (max-width: 640px) {
  .home .mi-section--hero,
  .front-page .mi-section--hero {
    padding-block: 2.25rem 2.75rem;
  }

  .home .mi-hero-copy h1,
  .front-page .mi-hero-copy h1 {
    font-size: clamp(4.1rem, 18vw, 6.2rem);
  }

  .home .mi-hero-editorial,
  .front-page .mi-hero-editorial {
    min-height: 21rem;
  }

  .mi-home-trust__grid {
    display: flex;
    gap: 0;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
  }

  .mi-home-trust__grid::-webkit-scrollbar,
  .mi-category-grid--editorial::-webkit-scrollbar {
    display: none;
  }

  .mi-home-trust article {
    flex: 0 0 78vw;
    min-height: 5.25rem;
    padding: 0.9rem 0.75rem;
    border-block-end: 0;
    scroll-snap-align: start;
  }

  .mi-home-trust article:nth-child(-n + 2) {
    border-block-end: 0;
  }

  .mi-home-trust article > span {
    font-size: 1.25rem;
  }

  .mi-home-trust strong {
    font-size: 0.75rem;
  }

  .mi-home-trust small {
    font-size: 0.64rem;
  }

  .mi-category-grid--editorial {
    display: flex;
    gap: 0.75rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
  }

  .mi-category-grid--editorial .mi-category-card,
  .mi-category-grid--editorial .mi-category-card--large {
    flex: 0 0 min(82vw, 21rem);
    min-height: 15rem;
    scroll-snap-align: start;
  }

  .home .mi-section--products,
  .home .mi-section--categories,
  .front-page .mi-section--products,
  .front-page .mi-section--categories {
    padding-block: 3rem;
  }

  .home .mi-section-heading--split h2,
  .front-page .mi-section-heading--split h2 {
    max-width: 10ch;
    font-size: clamp(3.1rem, 14vw, 4.25rem);
  }

  .home .mi-section--categories .mi-section-heading--stack h2,
  .front-page .mi-section--categories .mi-section-heading--stack h2 {
    max-width: 10ch;
    font-size: clamp(3.1rem, 14vw, 4.25rem);
  }
}

/* Step 40: Launch-ready policy templates */
.mi-policy-review-note {
  display: grid;
  gap: 0.35rem;
  padding: 1rem 1.1rem;
  border-left: 3px solid var(--mi-color-primary);
  background: rgba(255, 255, 255, 0.7);
  color: var(--mi-color-text-muted);
}

.mi-policy-review-note strong {
  color: var(--mi-color-text);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mi-policy-review-note span {
  line-height: 1.7;
}

.mi-policy-stack {
  display: grid;
  gap: 0.85rem;
}

.mi-policy-stack article {
  padding: 1rem 1.1rem;
  border: 1px solid var(--mi-color-border);
  background: rgba(255, 255, 255, 0.58);
}

.mi-policy-stack h2 {
  margin-bottom: 0.35rem;
  font-size: 1.35rem;
}

.mi-policy-stack p {
  color: var(--mi-color-text-muted);
  line-height: 1.75;
}

.mi-shipping-faq {
  display: grid;
  gap: var(--mi-space-4);
  margin-top: var(--mi-space-6);
}

/* Step 41: Live WooCommerce homepage product grid */
.mi-product-media--live {
  display: block;
}

.mi-product-media--live::before {
  display: none;
}

.mi-home-product-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--mi-duration-slow) var(--mi-ease-luxury);
}

.mi-product-card--live:hover .mi-home-product-image,
.mi-product-card--live:focus-within .mi-home-product-image {
  transform: scale(1.04);
}

.mi-product-card--live .mi-product-info h3 {
  max-width: none;
  font-size: clamp(1.55rem, 2.3vw, 2.2rem);
}

.mi-product-card--live .mi-product-info h3 a {
  color: inherit;
  text-decoration: none;
}

.mi-product-card--live .mi-product-info > p {
  min-height: 2.2em;
}

.mi-product-card--live .mi-product-footer strong {
  font-size: 1.65rem;
}

@media (max-width: 540px) {
  .mi-cart-drawer__panel {
    gap: 0.7rem;
    padding: 1rem;
  }

  .mi-cart-drawer__eyebrow {
    margin-bottom: 0.35rem;
    font-size: 0.62rem;
  }

  .mi-cart-drawer__header h2 {
    font-size: 2.55rem;
  }

  .mi-cart-drawer__summary {
    gap: 0.5rem;
    padding: 0.75rem;
  }

  .mi-cart-drawer__perks,
  .mi-cart-drawer__microcopy {
    display: none;
  }

  .mi-cart-drawer__items {
    gap: 0.65rem;
  }

  .mi-cart-drawer__item {
    grid-template-columns: 3.5rem minmax(0, 1fr) auto;
    gap: 0.6rem;
    padding: 0.65rem;
  }

  .mi-cart-drawer__thumb {
    width: 3.5rem;
    height: 4.4rem;
    border-radius: 0.85rem;
  }

  .mi-cart-drawer__item-main strong {
    font-size: 1.05rem;
  }

  .mi-cart-drawer__item-side {
    gap: 0.35rem;
  }

  .mi-cart-drawer__item-side b {
    font-size: 1rem;
  }

  .mi-cart-drawer__qty {
    gap: 0.2rem;
    padding: 0.15rem;
  }

  .mi-cart-drawer__qty button {
    width: 1.45rem;
    height: 1.45rem;
  }

  .mi-cart-drawer__qty strong {
    min-width: 1.1rem;
    height: 1.1rem;
    font-size: 0.7rem;
  }

  .mi-cart-drawer__footer {
    gap: 0.55rem;
    padding-top: 0.7rem;
  }

  .mi-cart-drawer__totals {
    gap: 0.45rem;
  }

  .mi-cart-drawer__subtotal strong {
    font-size: 1.55rem;
  }

  .mi-cart-drawer__totals p {
    display: none;
  }

  .mi-cart-drawer__footer-perks {
    gap: 0.35rem;
    margin-top: 0;
  }

  .mi-cart-drawer__footer-perks span {
    padding: 0.32rem 0.45rem;
    font-size: 0.58rem;
    letter-spacing: 0.06em;
  }

  .mi-cart-drawer__checkout {
    min-height: 2.8rem;
  }

  .mi-cart-drawer__continue {
    min-height: 2.3rem;
    font-size: 0.68rem;
  }
}

/* Step 48: Shop and product detail editorial refinement */
.mi-wc-shop__header {
  border-radius: 0.5rem;
  background:
    radial-gradient(circle at 8% 10%, rgba(255, 255, 255, 0.86), transparent 28%),
    linear-gradient(135deg, rgba(255, 249, 247, 0.86), rgba(255, 238, 245, 0.54));
  box-shadow: 0 18px 54px rgba(75, 57, 66, 0.08);
  backdrop-filter: none;
}

.mi-wc-shop__header h1 {
  max-width: 12ch;
  letter-spacing: 0;
}

.mi-wc-shop__header > p {
  max-width: 34rem;
  color: var(--mi-color-text-muted);
  line-height: 1.75;
}

.mi-wc-trust-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
}

.mi-wc-trust-strip span {
  display: grid;
  min-height: 3.1rem;
  place-items: center;
  border-radius: 0.35rem;
  background: rgba(255, 255, 255, 0.58);
  color: var(--mi-color-text);
  letter-spacing: 0.04em;
}

.mi-wc-toolbar {
  padding: 0.85rem 1rem;
  border: 1px solid var(--mi-color-border);
  border-radius: 0.5rem;
  background: rgba(255, 255, 255, 0.58);
}

.mi-wc-toolbar select {
  border-radius: 0.35rem;
  background-color: rgba(255, 255, 255, 0.9);
}

.woocommerce ul.products {
  gap: 1rem;
}

.woocommerce ul.products li.product.mi-wc-product-card {
  border-radius: 0.45rem;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 46px rgba(75, 57, 66, 0.08);
  backdrop-filter: blur(14px) saturate(1.08);
}

.woocommerce ul.products li.product.mi-wc-product-card:hover,
.woocommerce ul.products li.product.mi-wc-product-card:focus-within {
  transform: translateY(-5px);
  border-color: rgba(239, 127, 165, 0.28);
  box-shadow: 0 22px 58px rgba(75, 57, 66, 0.12);
}

.mi-wc-product-card__media {
  min-height: auto;
  aspect-ratio: 1 / 0.94;
  background:
    radial-gradient(circle at 50% 16%, rgba(255, 255, 255, 0.92), transparent 34%),
    linear-gradient(145deg, rgba(255, 238, 245, 0.68), rgba(255, 253, 252, 0.5));
}

.mi-wc-product-card__media img,
.mi-wc-product-card__media .mi-demo-product-image {
  width: 100%;
  height: 100%;
  max-height: none;
  object-fit: cover;
  border-radius: 0.35rem;
}

.mi-wc-product-card__body {
  display: grid;
  gap: 0.55rem;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  min-height: 3.2em;
  margin: 0;
  font-size: clamp(1.45rem, 2.1vw, 1.95rem);
  line-height: 1.05;
}

.mi-wc-product-card__microcopy {
  margin: 0;
  color: var(--mi-color-text-muted);
  font-size: 0.78rem;
  line-height: 1.45;
}

.mi-product-badge--soft {
  background: rgba(184, 94, 117, 0.86);
  box-shadow: 0 12px 28px rgba(184, 94, 117, 0.16);
}

.mi-wc-product-card__footer {
  margin-top: 0.25rem;
}

.mi-wc-product-card__price .price {
  font-size: 1.35rem;
}

.mi-wc-product-card__button .button {
  border-radius: 0.35rem;
}

.mi-wc-single__product {
  align-items: start;
}

.mi-wc-single__summary {
  border-radius: 0.55rem;
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 195, 215, 0.2), transparent 36%),
    rgba(255, 255, 255, 0.72);
  box-shadow: 0 18px 54px rgba(75, 57, 66, 0.08);
}

.mi-wc-single__summary h1 {
  letter-spacing: 0;
}

.mi-wc-single__trust {
  grid-template-columns: 1fr;
  gap: 0.65rem;
  margin-block: var(--mi-space-4);
}

.mi-wc-single__trust li {
  min-height: auto;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.25rem 0.75rem;
  align-items: center;
  padding: 0.85rem;
  border-radius: 0.45rem;
  box-shadow: none;
}

.mi-wc-single__trust li::before {
  grid-row: span 2;
  width: 1.3rem;
  height: 1.3rem;
  margin: 0;
}

.mi-wc-single__trust li::after {
  display: none;
}

.mi-wc-single__trust span {
  margin-top: 0;
}

.mi-wc-single__cart {
  border-radius: 0.5rem;
  background:
    radial-gradient(circle at 12% 0%, rgba(255, 255, 255, 0.92), transparent 38%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.78), rgba(255, 238, 245, 0.5));
  box-shadow: 0 18px 40px rgba(75, 57, 66, 0.08);
}

.mi-wc-single__cart .single_add_to_cart_button {
  border-radius: 0.35rem;
}

@media (max-width: 920px) {
  .mi-wc-trust-strip {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .mi-wc-shop__header {
    padding: 1.25rem;
  }

  .mi-wc-toolbar {
    display: grid;
    justify-items: stretch;
  }

  .mi-wc-toolbar .woocommerce-ordering,
  .mi-wc-toolbar select {
    width: 100%;
  }

  .woocommerce ul.products li.product .woocommerce-loop-product__title {
    min-height: 0;
  }

  .mi-wc-product-card__media {
    aspect-ratio: 1 / 0.88;
  }
}

/* Step 42: Compact mobile category browsing */
@media (max-width: 640px) {
  .mi-category-grid {
    display: flex;
    gap: 0.75rem;
    overflow-x: auto;
    padding: 0 0 0.6rem;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .mi-category-grid::-webkit-scrollbar {
    display: none;
  }

  .mi-category-card,
  .mi-category-card--large {
    width: min(78vw, 19rem);
    min-width: min(78vw, 19rem);
    min-height: 15rem;
    scroll-snap-align: start;
  }

  .mi-category-card h3,
  .mi-category-card:not(.mi-category-card--large) h3 {
    font-size: 2.5rem;
  }
}

/* Step 49: Checkout path refinement */
.mi-section--checkout.mi-wc-cart-page,
.mi-section--checkout.mi-wc-checkout-page {
  padding-block: clamp(2.75rem, 5vw, 5rem);
}

.mi-wc-cart-page,
.mi-wc-checkout-page {
  width: min(100%, var(--mi-container));
  padding: 0;
}

.mi-wc-cart-page__hero,
.mi-wc-checkout-page__hero {
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
  padding: clamp(1.25rem, 3vw, 2rem);
  border: 1px solid var(--mi-color-border);
  border-radius: 0.55rem;
  background:
    radial-gradient(circle at 8% 8%, rgba(255, 255, 255, 0.9), transparent 28%),
    linear-gradient(135deg, rgba(255, 249, 247, 0.88), rgba(255, 238, 245, 0.54));
  box-shadow: 0 18px 54px rgba(75, 57, 66, 0.08);
}

.mi-wc-cart-page__hero h1,
.mi-wc-checkout-page__hero h1 {
  max-width: 13ch;
  letter-spacing: 0;
}

.mi-wc-cart-page__status,
.mi-wc-checkout-page__privacy {
  border-radius: 0.45rem;
  background: rgba(255, 255, 255, 0.62);
  box-shadow: none;
  backdrop-filter: none;
}

.mi-wc-cart-page__status strong {
  font-size: clamp(2rem, 4vw, 2.8rem);
}

.mi-wc-cart__steps,
.mi-wc-checkout__steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
}

.mi-wc-cart__steps span,
.mi-wc-checkout__steps span {
  min-height: 3.2rem;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.7rem 0.9rem;
  border: 1px solid var(--mi-color-border);
  border-radius: 0.4rem;
  background: rgba(255, 255, 255, 0.58);
  color: var(--mi-color-text-muted);
  font-size: 0.78rem;
  font-weight: 800;
}

.mi-wc-cart__steps strong,
.mi-wc-checkout__steps strong {
  color: var(--mi-color-primary-strong);
  font-family: var(--mi-font-display);
  font-size: 1.3rem;
}

.mi-wc-cart__panel,
.mi-wc-cart__totals-shell,
.mi-wc-checkout__details,
.mi-wc-checkout__review {
  border-radius: 0.55rem;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 18px 54px rgba(75, 57, 66, 0.08);
  backdrop-filter: blur(14px) saturate(1.08);
}

.mi-wc-cart table.shop_table td,
.mi-wc-cart table.shop_table th {
  padding: 1rem;
}

.mi-wc-cart .product-thumbnail img {
  width: 4.75rem;
  border-radius: 0.35rem;
}

.mi-wc-cart .product-name a {
  font-size: 1.35rem;
  letter-spacing: 0;
}

.mi-wc-cart__coupon input,
.mi-wc-checkout input.input-text,
.mi-wc-checkout textarea,
.mi-wc-checkout select {
  border-radius: 0.35rem;
  background: rgba(255, 255, 255, 0.88);
}

.mi-wc-cart .product-remove .remove,
.mi-wc-cart .quantity .qty {
  border-radius: 0.35rem;
}

.mi-wc-cart__privacy-note,
.mi-wc-cart__support-note,
.mi-wc-checkout__review-note {
  border-radius: 0.4rem;
  background: rgba(255, 238, 245, 0.42);
}

.mi-wc-checkout__grid {
  gap: clamp(1rem, 3vw, 1.5rem);
}

.mi-wc-checkout__details,
.mi-wc-checkout__review {
  padding: clamp(1rem, 3vw, 1.5rem);
}

.mi-wc-checkout #payment,
.mi-wc-checkout #order_review table.shop_table {
  border-radius: 0.45rem;
}

.mi-wc-checkout #place_order,
.mi-wc-cart__coupon .button,
.mi-wc-cart .actions > .button,
.mi-wc-cart__totals .checkout-button {
  border-radius: 0.35rem;
}

.mi-account-service-strip {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mi-account-service-strip span {
  border-radius: 0.4rem;
}

.mi-account-hero,
.mi-account-layout,
.mi-account-dashboard__welcome,
.mi-account-dashboard__tile,
.mi-account-dashboard__note,
.woocommerce-account .woocommerce-MyAccount-content table.shop_table,
.woocommerce-account .woocommerce-MyAccount-content form,
.woocommerce-account .woocommerce form.login,
.woocommerce-account .woocommerce form.register {
  border-radius: 0.55rem !important;
}

@media (max-width: 760px) {
  .mi-wc-cart-page__hero,
  .mi-wc-checkout-page__hero,
  .mi-wc-cart__steps,
  .mi-wc-checkout__steps,
  .mi-account-service-strip {
    grid-template-columns: 1fr;
  }

  .mi-wc-cart table.shop_table thead {
    display: none;
  }

  .mi-wc-cart table.shop_table tr.cart_item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.65rem;
    padding: 0.85rem;
    border-bottom: 1px solid var(--mi-color-border);
  }

  .mi-wc-cart table.shop_table tr.cart_item td {
    display: block;
    padding: 0;
    border: 0;
  }

  .mi-wc-cart .product-remove {
    grid-column: 2;
    justify-self: end;
  }

  .mi-wc-cart .product-thumbnail {
    grid-row: span 4;
  }

  .mi-wc-cart .product-price,
  .mi-wc-cart .product-quantity,
  .mi-wc-cart .product-subtotal {
    display: flex !important;
    justify-content: space-between;
    gap: 1rem;
  }
}

@media (max-width: 520px) {
  .mi-section--checkout.mi-wc-cart-page,
  .mi-section--checkout.mi-wc-checkout-page {
    padding-block: 2rem;
  }

  .mi-wc-cart-page__hero,
  .mi-wc-checkout-page__hero,
  .mi-wc-cart__panel,
  .mi-wc-cart__totals-shell,
  .mi-wc-checkout__details,
  .mi-wc-checkout__review {
    border-radius: 0.45rem;
  }
}

/* Step 39: My Account hotfix - v3.10.2 */
.mi-account-hero {
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 24rem);
}

.mi-account-hero__copy h1 {
  max-width: none;
  font-size: clamp(2.8rem, 5vw, 5rem);
  line-height: 0.96;
}

.mi-account-quickbar,
.mi-account-dashboard__grid {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.mi-account-layout {
  grid-template-columns: 260px minmax(0, 1fr);
  width: 100%;
  max-width: 1180px;
  margin-inline: auto;
}

.woocommerce-account.logged-in .mi-account-hero {
  grid-template-columns: 1fr;
  align-items: start;
}

.woocommerce-account.logged-in .mi-account-hero__copy h1 {
  max-width: none;
  font-size: clamp(2.4rem, 4vw, 4rem);
  line-height: 1;
}

.woocommerce-account.logged-in .mi-account-hero__card strong {
  font-size: clamp(1.45rem, 2.2vw, 2rem);
  line-height: 1.08;
  overflow-wrap: anywhere;
}

.woocommerce-account.logged-in .mi-account-hero__card {
  max-width: 34rem;
}

.woocommerce-account.logged-in .mi-account-layout {
  grid-template-columns: 260px minmax(0, 1fr) !important;
  gap: clamp(1.25rem, 2.6vw, 2.25rem) !important;
  width: 100% !important;
  max-width: 1180px !important;
  padding: clamp(1rem, 2vw, 1.5rem) !important;
}

.woocommerce-account.logged-in .mi-account-layout__nav {
  min-width: 0;
}

.woocommerce-account.logged-in .woocommerce,
.woocommerce-account.logged-in .woocommerce::before,
.woocommerce-account.logged-in .woocommerce::after {
  display: block !important;
  content: none !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-navigation {
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-content {
  width: 100% !important;
  min-width: 0 !important;
  padding: clamp(1.1rem, 2vw, 1.6rem) !important;
  overflow: visible !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul {
  grid-template-columns: 1fr !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-content h2 {
  font-size: clamp(1.65rem, 3vw, 2.45rem) !important;
  line-height: 1.08 !important;
  letter-spacing: 0 !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-Addresses,
.woocommerce-account.logged-in .woocommerce-MyAccount-content .u-columns.woocommerce-Addresses {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important;
}

@media (max-width: 980px) {
  .woocommerce-account.logged-in .mi-account-hero,
  .woocommerce-account.logged-in .mi-account-layout {
    grid-template-columns: 1fr !important;
  }

  .woocommerce-account.logged-in .mi-account-hero__copy h1 {
    max-width: none;
  }

  .woocommerce-account.logged-in .mi-account-layout__nav {
    position: static;
  }
}

@media (max-width: 760px) {
  .mi-account-quickbar,
  .mi-account-dashboard__grid,
  .woocommerce-account.logged-in .mi-account-dashboard__grid {
    grid-template-columns: 1fr !important;
  }

  .woocommerce-account.logged-in .mi-account-layout {
    padding: 1rem !important;
  }
}

/* Step 40: Dedicated My Account page template polish - v3.10.3 */
body.page-template-page-my-account .mi-main,
body.woocommerce-account .mi-main {
  overflow: hidden;
}

body.page-template-page-my-account .mi-wc-account-page,
body.woocommerce-account .mi-wc-account-page {
  padding-block: clamp(3rem, 6vw, 5.5rem);
}

body.page-template-page-my-account .mi-account-hero,
body.woocommerce-account .mi-account-hero {
  max-width: 1180px;
  margin-inline: auto;
  margin-bottom: clamp(1.25rem, 2.5vw, 2rem);
}

body.page-template-page-my-account .mi-account-hero__copy h1,
body.woocommerce-account .mi-account-hero__copy h1 {
  font-size: clamp(2.7rem, 5vw, 4.8rem);
  line-height: 0.98;
  letter-spacing: 0;
}

body.page-template-page-my-account:not(.logged-in) .mi-account-hero,
body.woocommerce-account:not(.logged-in) .mi-account-hero {
  grid-template-columns: minmax(0, 0.9fr) minmax(18rem, 25rem);
  align-items: center;
}

body.page-template-page-my-account:not(.logged-in) .mi-account-layout,
body.woocommerce-account:not(.logged-in) .mi-account-layout {
  display: block;
  max-width: 1080px;
}

body.page-template-page-my-account:not(.logged-in) .mi-account-auth,
body.woocommerce-account:not(.logged-in) .mi-account-auth {
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 24rem);
  align-items: stretch;
}

body.page-template-page-my-account:not(.logged-in) .mi-account-auth__intro h2,
body.page-template-page-my-account:not(.logged-in) .mi-account-subpage__header h2,
body.woocommerce-account:not(.logged-in) .mi-account-auth__intro h2,
body.woocommerce-account:not(.logged-in) .mi-account-subpage__header h2 {
  font-size: clamp(1.9rem, 3vw, 2.8rem);
  line-height: 1.08;
  letter-spacing: 0;
}

body.page-template-page-my-account:not(.logged-in) .mi-account-auth__panel,
body.woocommerce-account:not(.logged-in) .mi-account-auth__panel {
  min-width: 0;
}

body.page-template-page-my-account .mi-account-auth__panel--support,
body.woocommerce-account .mi-account-auth__panel--support {
  display: grid;
  align-content: center;
}

body.page-template-page-my-account .mi-account-auth__panel--support .mi-account-auth__intro,
body.woocommerce-account .mi-account-auth__panel--support .mi-account-auth__intro {
  margin-bottom: 1rem;
}

body.page-template-page-my-account .mi-account-auth__panel--support::before,
body.woocommerce-account .mi-account-auth__panel--support::before {
  opacity: 0.42;
}

@media (max-width: 980px) {
  body.page-template-page-my-account:not(.logged-in) .mi-account-hero,
  body.page-template-page-my-account:not(.logged-in) .mi-account-auth,
  body.woocommerce-account:not(.logged-in) .mi-account-hero,
  body.woocommerce-account:not(.logged-in) .mi-account-auth {
    grid-template-columns: 1fr;
  }
}

/* Step 41: Compact luxury account flow - v3.10.4 */
body.page-template-page-my-account,
body.woocommerce-account {
  background: linear-gradient(135deg, #fffdfd 0%, #fff7fa 48%, #fffaf6 100%);
}

body.page-template-page-my-account .mi-wc-account-page,
body.woocommerce-account .mi-wc-account-page {
  padding-block: clamp(2rem, 4vw, 3.75rem);
}

body.page-template-page-my-account .mi-account-hero--compact,
body.woocommerce-account .mi-account-hero--compact {
  display: block;
  max-width: 980px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  overflow: visible;
}

body.page-template-page-my-account .mi-account-hero--compact::before,
body.woocommerce-account .mi-account-hero--compact::before {
  display: none;
}

body.page-template-page-my-account .mi-account-hero--compact .mi-account-hero__copy,
body.woocommerce-account .mi-account-hero--compact .mi-account-hero__copy {
  max-width: 42rem;
  gap: 0.8rem;
}

body.page-template-page-my-account .mi-account-hero--compact h1,
body.woocommerce-account .mi-account-hero--compact h1 {
  font-size: clamp(2.35rem, 4vw, 3.7rem);
  line-height: 1.02;
}

body.page-template-page-my-account .mi-account-hero--compact .mi-lede,
body.woocommerce-account .mi-account-hero--compact .mi-lede {
  max-width: 38rem;
  font-size: 1rem;
  line-height: 1.7;
}

body.page-template-page-my-account .mi-account-layout,
body.woocommerce-account .mi-account-layout,
body.page-template-page-my-account:not(.logged-in) .mi-account-layout,
body.woocommerce-account:not(.logged-in) .mi-account-layout {
  max-width: 980px;
  padding: 0 !important;
  border: 0;
  background: transparent !important;
  box-shadow: none !important;
}

body.page-template-page-my-account.logged-in .mi-account-layout,
body.woocommerce-account.logged-in .mi-account-layout,
.woocommerce-account.logged-in .mi-account-layout {
  grid-template-columns: 1fr !important;
  max-width: 1040px !important;
}

body.page-template-page-my-account .mi-account-auth,
body.woocommerce-account .mi-account-auth,
body.page-template-page-my-account:not(.logged-in) .mi-account-auth,
body.woocommerce-account:not(.logged-in) .mi-account-auth {
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 22rem);
  gap: clamp(1rem, 2.4vw, 1.5rem);
}

body.page-template-page-my-account .mi-account-auth__panel,
body.woocommerce-account .mi-account-auth__panel,
body.page-template-page-my-account .woocommerce-MyAccount-content,
body.woocommerce-account .woocommerce-MyAccount-content,
body.page-template-page-my-account .mi-account-layout__nav,
body.woocommerce-account .mi-account-layout__nav {
  border: 1px solid rgba(184, 94, 117, 0.16) !important;
  border-radius: 24px !important;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(255, 247, 250, 0.74)) !important;
  box-shadow: 0 18px 46px rgba(74, 49, 53, 0.08) !important;
  backdrop-filter: blur(18px) saturate(1.08);
}

body.page-template-page-my-account .mi-account-auth__panel,
body.woocommerce-account .mi-account-auth__panel {
  padding: clamp(1.25rem, 3vw, 2rem);
}

body.page-template-page-my-account .mi-account-auth__intro h2,
body.woocommerce-account .mi-account-auth__intro h2,
body.page-template-page-my-account .mi-account-dashboard__welcome h2,
body.woocommerce-account .mi-account-dashboard__welcome h2,
body.page-template-page-my-account .mi-account-subpage__header h2,
body.woocommerce-account .mi-account-subpage__header h2 {
  font-size: clamp(1.7rem, 3vw, 2.45rem);
  line-height: 1.08;
  letter-spacing: 0;
}

body.page-template-page-my-account .mi-account-dashboard__welcome,
body.woocommerce-account .mi-account-dashboard__welcome,
body.page-template-page-my-account .mi-account-dashboard__tile,
body.woocommerce-account .mi-account-dashboard__tile {
  border-radius: 24px;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.88), rgba(255, 247, 250, 0.72));
  border-color: rgba(184, 94, 117, 0.16);
  box-shadow: 0 18px 42px rgba(74, 49, 53, 0.07);
}

body.page-template-page-my-account .mi-account-dashboard__welcome,
body.woocommerce-account .mi-account-dashboard__welcome {
  grid-template-columns: 1fr;
  padding: clamp(1.25rem, 3vw, 2rem);
}

body.page-template-page-my-account .mi-account-dashboard__welcome,
body.woocommerce-account .mi-account-dashboard__welcome {
  align-items: start;
}

.mi-account-dashboard__logout {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.65rem;
  margin-top: 1rem;
  padding: 0.68rem 1rem;
  border: 1px solid rgba(184, 94, 117, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.58);
  color: var(--mi-color-primary-strong);
  font-size: 0.82rem;
  font-weight: 900;
  text-decoration: none;
  transition: transform var(--mi-duration-fast) var(--mi-ease-out), border-color var(--mi-duration-fast) var(--mi-ease-out), background var(--mi-duration-fast) var(--mi-ease-out);
}

.mi-account-dashboard__logout:hover,
.mi-account-dashboard__logout:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(184, 94, 117, 0.32);
  background: rgba(255, 224, 233, 0.78);
}

body.page-template-page-my-account .mi-account-dashboard__grid,
body.woocommerce-account .mi-account-dashboard__grid,
.woocommerce-account.logged-in .mi-account-dashboard__grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

body.page-template-page-my-account .mi-account-dashboard__tile,
body.woocommerce-account .mi-account-dashboard__tile {
  min-height: 10rem;
  padding: clamp(1.1rem, 2vw, 1.5rem);
}

body.page-template-page-my-account .mi-account-dashboard__tile strong,
body.woocommerce-account .mi-account-dashboard__tile strong {
  font-size: clamp(1.45rem, 2.4vw, 2rem);
  letter-spacing: 0;
}

body.page-template-page-my-account .mi-account-layout__nav,
body.woocommerce-account .mi-account-layout__nav {
  position: static;
  padding: 0.7rem;
}

body.page-template-page-my-account .mi-account-layout__nav .mi-eyebrow,
body.woocommerce-account .mi-account-layout__nav .mi-eyebrow {
  display: none;
}

body.page-template-page-my-account .woocommerce-MyAccount-navigation ul,
body.woocommerce-account .woocommerce-MyAccount-navigation ul,
.woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul {
  display: flex !important;
  flex-wrap: wrap;
  gap: 0.55rem;
}

body.page-template-page-my-account .woocommerce-MyAccount-navigation ul li a,
body.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  min-height: 2.65rem;
  padding: 0.72rem 1rem;
  border-radius: 999px;
  border-color: rgba(184, 94, 117, 0.14);
  background: rgba(255, 255, 255, 0.56);
}

body.page-template-page-my-account .woocommerce-MyAccount-navigation ul li a::after,
body.woocommerce-account .woocommerce-MyAccount-navigation ul li a::after {
  display: none;
}

body.page-template-page-my-account .woocommerce-MyAccount-navigation ul li.is-active a,
body.page-template-page-my-account .woocommerce-MyAccount-navigation ul li a:hover,
body.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
body.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  background: rgba(255, 224, 233, 0.78);
  border-color: rgba(184, 94, 117, 0.24);
  color: var(--mi-color-primary-strong);
  transform: translateY(-1px);
}

body.page-template-page-my-account input.input-text,
body.page-template-page-my-account .woocommerce-Input,
body.woocommerce-account input.input-text,
body.woocommerce-account .woocommerce-Input {
  border-radius: 16px;
}

body.page-template-page-my-account .mi-button,
body.page-template-page-my-account .woocommerce-button.button,
body.woocommerce-account .mi-button,
body.woocommerce-account .woocommerce-button.button {
  border-radius: 999px;
}

body.page-template-page-my-account .mi-account-service-strip,
body.page-template-page-my-account .mi-account-quickbar,
body.page-template-page-my-account .mi-account-dashboard__panel,
body.page-template-page-my-account .mi-account-dashboard__woocommerce-note,
body.woocommerce-account .mi-account-service-strip,
body.woocommerce-account .mi-account-quickbar,
body.woocommerce-account .mi-account-dashboard__panel,
body.woocommerce-account .mi-account-dashboard__woocommerce-note {
  display: none !important;
}

@media (max-width: 860px) {
  body.page-template-page-my-account .mi-account-auth,
  body.woocommerce-account .mi-account-auth,
  body.page-template-page-my-account:not(.logged-in) .mi-account-auth,
  body.woocommerce-account:not(.logged-in) .mi-account-auth,
  body.page-template-page-my-account .mi-account-dashboard__grid,
  body.woocommerce-account .mi-account-dashboard__grid,
  .woocommerce-account.logged-in .mi-account-dashboard__grid {
    grid-template-columns: 1fr !important;
  }

  body.page-template-page-my-account .woocommerce-MyAccount-navigation ul,
  body.woocommerce-account .woocommerce-MyAccount-navigation ul {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 560px) {
  body.page-template-page-my-account .mi-wc-account-page,
  body.woocommerce-account .mi-wc-account-page {
    padding-block: 1.5rem;
  }

  body.page-template-page-my-account .woocommerce-MyAccount-navigation ul,
  body.woocommerce-account .woocommerce-MyAccount-navigation ul {
    grid-template-columns: 1fr !important;
  }

  body.page-template-page-my-account .mi-account-auth__panel,
  body.page-template-page-my-account .woocommerce-MyAccount-content,
  body.woocommerce-account .mi-account-auth__panel,
  body.woocommerce-account .woocommerce-MyAccount-content {
    padding: 1rem !important;
  }
}

/* Step 49: Dark mode UI harmony - v3.10.17 */
[data-theme="dark"] {
  --mi-color-bg: #1a1016;
  --mi-color-bg-soft: #21141b;
  --mi-color-border: rgba(255, 214, 226, 0.16);
  --mi-color-text: #fff7fb;
  --mi-color-text-muted: #d8bfca;
  --mi-color-primary: #f09ab7;
  --mi-color-primary-strong: #ffc1d4;
  --mi-color-accent: #e4b59d;
  --mi-color-surface: rgba(38, 23, 32, 0.74);
  --mi-color-surface-strong: rgba(45, 27, 38, 0.9);
  --mi-gradient-page:
    radial-gradient(circle at 14% 8%, rgba(160, 72, 111, 0.24), transparent 32%),
    radial-gradient(circle at 90% 18%, rgba(229, 160, 186, 0.16), transparent 30%),
    linear-gradient(180deg, #170d13 0%, #21141b 48%, #190f15 100%);
  --mi-gradient-glass: linear-gradient(145deg, rgba(48, 30, 42, 0.86), rgba(31, 18, 27, 0.72));
  --mi-shadow-sm: 0 10px 26px rgba(0, 0, 0, 0.22);
  --mi-shadow-md: 0 20px 54px rgba(0, 0, 0, 0.28);
  --mi-shadow-lg: 0 34px 90px rgba(0, 0, 0, 0.36);
  --mi-shadow-glow: 0 18px 46px rgba(240, 154, 183, 0.14);
}

[data-theme="dark"] body,
[data-theme="dark"] body::before {
  background: var(--mi-gradient-page);
}

[data-theme="dark"] .mi-nav-shell,
[data-theme="dark"] .mi-nav-shell.is-scrolled,
[data-theme="dark"] .mi-nav-shell:focus-within,
[data-theme="dark"] .mi-nav-shell:hover {
  border-bottom-color: rgba(255, 214, 226, 0.12);
  background: rgba(24, 14, 20, 0.82);
  box-shadow: 0 14px 42px rgba(0, 0, 0, 0.2);
}

[data-theme="dark"] .mi-wordmark span,
[data-theme="dark"] .mi-section-heading h2,
[data-theme="dark"] .mi-hero-copy h1 {
  color: #fff4f8;
}

[data-theme="dark"] .mi-wordmark small,
[data-theme="dark"] .mi-nav__links a,
[data-theme="dark"] .mi-nav__account,
[data-theme="dark"] .mi-hero-copy .mi-lede,
[data-theme="dark"] .mi-section-heading p {
  color: rgba(255, 238, 245, 0.72);
}

[data-theme="dark"] .mi-nav-search input,
[data-theme="dark"] .mi-footer__newsletter input,
[data-theme="dark"] .mi-footer__newsletter--wpforms input[type='email'],
[data-theme="dark"] .mi-footer__newsletter--wpforms .wpforms-field input[type='email'] {
  border-color: rgba(255, 214, 226, 0.18);
  background: rgba(255, 247, 250, 0.1);
  color: #fff7fb;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

[data-theme="dark"] .mi-nav-search input::placeholder,
[data-theme="dark"] .mi-footer__newsletter input::placeholder,
[data-theme="dark"] .mi-footer__newsletter--wpforms input[type='email']::placeholder,
[data-theme="dark"] .mi-footer__newsletter--wpforms .wpforms-field input[type='email']::placeholder {
  color: rgba(255, 238, 245, 0.5);
}

[data-theme="dark"] .home .mi-section--hero,
[data-theme="dark"] .front-page .mi-section--hero,
[data-theme="dark"] .mi-section--categories,
[data-theme="dark"] .mi-section--products,
[data-theme="dark"] .mi-section--bestsellers,
[data-theme="dark"] .mi-section--privacy,
[data-theme="dark"] .mi-main {
  background:
    radial-gradient(circle at 12% 0%, rgba(150, 68, 105, 0.18), transparent 32%),
    linear-gradient(180deg, rgba(31, 18, 27, 0.94), rgba(24, 14, 20, 0.98));
}

[data-theme="dark"] .mi-category-card,
[data-theme="dark"] .mi-product-card,
[data-theme="dark"] .mi-promise-card,
[data-theme="dark"] .mi-guide-card,
[data-theme="dark"] .woocommerce ul.products li.product.mi-wc-product-card,
[data-theme="dark"] .woocommerce div.product,
[data-theme="dark"] .woocommerce-cart-form,
[data-theme="dark"] .woocommerce-checkout,
[data-theme="dark"] .woocommerce-MyAccount-content,
[data-theme="dark"] .woocommerce-MyAccount-navigation {
  border-color: rgba(255, 214, 226, 0.15);
  background: linear-gradient(145deg, rgba(47, 29, 40, 0.82), rgba(29, 17, 25, 0.72));
  box-shadow: 0 18px 52px rgba(0, 0, 0, 0.22);
}

[data-theme="dark"] .mi-product-info,
[data-theme="dark"] .mi-product-card--live .mi-product-info {
  background: rgba(30, 18, 26, 0.74);
}

[data-theme="dark"] .mi-product-card--live .mi-product-info h3 a,
[data-theme="dark"] .mi-product-card--live .mi-product-footer strong,
[data-theme="dark"] .woocommerce ul.products li.product .woocommerce-loop-product__title,
[data-theme="dark"] .woocommerce ul.products li.product .woocommerce-loop-product__title a,
[data-theme="dark"] .woocommerce ul.products li.product .price {
  color: #fff7fb;
}

[data-theme="dark"] .mi-product-card--live .mi-product-info > p,
[data-theme="dark"] .mi-product-card__meta,
[data-theme="dark"] .woocommerce ul.products li.product .price del {
  color: rgba(255, 238, 245, 0.68);
}

[data-theme="dark"] .mi-footer {
  background:
    radial-gradient(circle at 18% 20%, rgba(173, 76, 116, 0.2), transparent 34%),
    radial-gradient(circle at 86% 12%, rgba(255, 188, 209, 0.12), transparent 28%),
    linear-gradient(180deg, #1e1219 0%, #170d13 100%) !important;
  color: #fff7fb;
}

[data-theme="dark"] .mi-footer__inner {
  border-top-color: rgba(255, 214, 226, 0.16) !important;
  border-bottom-color: rgba(255, 214, 226, 0.12) !important;
}

[data-theme="dark"] .mi-footer__brand,
[data-theme="dark"] .mi-footer__shop,
[data-theme="dark"] .mi-footer__support,
[data-theme="dark"] .mi-footer__newsletter {
  background: transparent !important;
}

[data-theme="dark"] .mi-footer__brand h2,
[data-theme="dark"] .mi-footer__shop h3,
[data-theme="dark"] .mi-footer__support h3,
[data-theme="dark"] .mi-footer__newsletter label {
  border-bottom-color: rgba(255, 214, 226, 0.14) !important;
}

[data-theme="dark"] .mi-footer__brand h2,
[data-theme="dark"] .mi-footer__newsletter label {
  color: #fff7fb;
  text-shadow: 0 16px 40px rgba(255, 193, 212, 0.08);
}

[data-theme="dark"] .mi-footer__brand .mi-eyebrow,
[data-theme="dark"] .mi-footer__shop h3,
[data-theme="dark"] .mi-footer__support h3 {
  color: #ffc1d4;
}

[data-theme="dark"] .mi-footer__shop a,
[data-theme="dark"] .mi-footer__support a,
[data-theme="dark"] .mi-footer__newsletter > p,
[data-theme="dark"] .mi-footer__age-note,
[data-theme="dark"] .mi-footer__bottom,
[data-theme="dark"] .mi-footer__bottom a {
  color: rgba(255, 238, 245, 0.7);
}

[data-theme="dark"] .mi-footer__shop a:hover,
[data-theme="dark"] .mi-footer__support a:hover,
[data-theme="dark"] .mi-footer__bottom a:hover {
  color: #fff7fb;
}

[data-theme="dark"] .mi-footer__newsletter--wpforms {
  border: 1px solid rgba(255, 214, 226, 0.12) !important;
  border-radius: 1.4rem !important;
  padding: 1.4rem !important;
  background: linear-gradient(145deg, rgba(48, 29, 40, 0.52), rgba(24, 14, 20, 0.42)) !important;
}

[data-theme="dark"] .mi-footer__age-note {
  border-top-color: rgba(255, 214, 226, 0.12) !important;
}

[data-theme="dark"] .mi-footer__bottom {
  border-top-color: rgba(255, 214, 226, 0.1) !important;
}

/* Step 51: WooCommerce connected account registration - v3.10.20 */
.mi-account-drawer__register {
  display: grid;
  gap: 0.95rem;
  margin-top: 0.35rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(184, 94, 117, 0.14);
}

.mi-account-drawer__register-heading {
  display: grid;
  gap: 0.2rem;
}

.mi-account-drawer__register-heading span {
  color: var(--mi-color-primary-strong);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.mi-account-drawer__register-heading strong {
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: 1.45rem;
  line-height: 1.05;
}

.mi-account-drawer__form--register {
  padding: 1rem;
  border: 1px solid rgba(184, 94, 117, 0.14);
  border-radius: 20px;
  background: rgba(255, 247, 250, 0.62);
}

.mi-account-drawer__form--register .mi-account-form__hint {
  margin: 0;
  color: var(--mi-color-text-muted);
  font-size: 0.82rem;
  line-height: 1.55;
}

[data-theme="dark"] .mi-account-drawer__register {
  border-top-color: rgba(255, 214, 226, 0.14);
}

[data-theme="dark"] .mi-account-drawer__form--register {
  border-color: rgba(255, 214, 226, 0.14);
  background: rgba(255, 247, 250, 0.08);
}

/* Step 50: Ecommerce account dashboard - v3.10.18 */
.mi-account-dashboard--commerce {
  display: grid;
  gap: clamp(1rem, 2.2vw, 1.5rem);
}

body.page-template-page-my-account .mi-account-dashboard--commerce .mi-account-dashboard__welcome,
body.woocommerce-account .mi-account-dashboard--commerce .mi-account-dashboard__welcome {
  min-height: auto;
}

body.page-template-page-my-account .mi-account-dashboard--commerce .mi-account-dashboard__tile,
body.woocommerce-account .mi-account-dashboard--commerce .mi-account-dashboard__tile {
  min-height: 9rem;
  display: grid;
  align-content: space-between;
}

.mi-account-dashboard--commerce .mi-account-dashboard__tile span {
  color: var(--mi-color-primary-strong);
}

.mi-account-dashboard--commerce .mi-account-dashboard__tile strong {
  font-family: var(--mi-font-display);
  font-size: clamp(2rem, 4vw, 3.15rem);
  line-height: 0.95;
}

.mi-account-commerce-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(18rem, 0.8fr);
  gap: clamp(1rem, 2vw, 1.25rem);
  align-items: start;
}

.mi-account-commerce-panel {
  display: grid;
  gap: 1rem;
  padding: clamp(1.15rem, 2.5vw, 1.6rem);
  border: 1px solid rgba(184, 94, 117, 0.16);
  border-radius: 24px;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(255, 247, 250, 0.74));
  box-shadow: 0 18px 42px rgba(74, 49, 53, 0.07);
}

.mi-account-commerce-panel__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.mi-account-commerce-panel__header span,
.mi-account-status-list dt,
.mi-account-order-row small,
.mi-account-order-row em {
  color: var(--mi-color-primary-strong);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.mi-account-commerce-panel__header h3,
.mi-account-empty-state h3 {
  margin: 0.2rem 0 0;
  color: var(--mi-color-text);
  font-family: var(--mi-font-display);
  font-size: clamp(1.45rem, 2.5vw, 2rem);
  line-height: 1.05;
}

.mi-account-commerce-panel__header a,
.mi-account-form__link {
  color: var(--mi-color-primary-strong);
  font-size: 0.82rem;
  font-weight: 900;
  text-decoration: underline;
  text-underline-offset: 0.25em;
}

.mi-account-order-list {
  display: grid;
  gap: 0.65rem;
}

.mi-account-order-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(184, 94, 117, 0.14);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.58);
  color: var(--mi-color-text);
  text-decoration: none;
  transition: transform var(--mi-duration-fast) var(--mi-ease-out), border-color var(--mi-duration-fast) var(--mi-ease-out), background var(--mi-duration-fast) var(--mi-ease-out);
}

.mi-account-order-row:hover,
.mi-account-order-row:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(184, 94, 117, 0.28);
  background: rgba(255, 246, 250, 0.9);
}

.mi-account-order-row > span {
  display: grid;
  gap: 0.2rem;
}

.mi-account-order-row > span:last-child {
  justify-items: end;
}

.mi-account-order-row strong,
.mi-account-order-row b {
  color: var(--mi-color-text);
}

.mi-account-order-row b {
  font-family: var(--mi-font-display);
  font-size: 1.25rem;
  line-height: 1;
}

.mi-account-empty-state {
  display: grid;
  gap: 0.8rem;
  justify-items: start;
  min-height: 13rem;
  align-content: center;
  padding: clamp(1.1rem, 3vw, 1.5rem);
  border: 1px dashed rgba(184, 94, 117, 0.24);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.5);
}

.mi-account-empty-state p {
  max-width: 30rem;
  margin: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.65;
}

.mi-account-status-list {
  display: grid;
  gap: 0.7rem;
  margin: 0;
}

.mi-account-status-list div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.82rem 0;
  border-bottom: 1px solid rgba(184, 94, 117, 0.12);
}

.mi-account-status-list div:last-child {
  border-bottom: 0;
}

.mi-account-status-list dd {
  margin: 0;
  color: var(--mi-color-text);
  font-weight: 800;
  text-align: right;
}

.mi-account-commerce-actions {
  display: grid;
  gap: 0.75rem;
  justify-items: start;
  padding-top: 0.2rem;
}

.mi-account-close-panel {
  border-style: dashed;
}

.mi-account-close-panel p {
  max-width: 44rem;
  margin: 0;
  color: var(--mi-color-text-muted);
  line-height: 1.65;
}

.mi-account-close-form {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.85rem 1rem;
}

.mi-account-close-form label {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  color: var(--mi-color-text);
  font-size: 0.9rem;
  font-weight: 750;
}

.mi-account-close-form input[type="checkbox"] {
  width: 1.05rem;
  height: 1.05rem;
  accent-color: var(--mi-color-primary-strong);
}

.mi-account-close-button {
  min-height: 2.65rem;
  padding: 0.68rem 1rem;
  border: 1px solid rgba(152, 70, 94, 0.28);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.58);
  color: #98465e;
  font-size: 0.82rem;
  font-weight: 900;
  cursor: pointer;
  transition: transform var(--mi-duration-fast) var(--mi-ease-out), border-color var(--mi-duration-fast) var(--mi-ease-out), background var(--mi-duration-fast) var(--mi-ease-out);
}

.mi-account-close-button:hover,
.mi-account-close-button:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(152, 70, 94, 0.46);
  background: rgba(255, 224, 233, 0.78);
}

body.page-template-page-my-account .woocommerce .woocommerce-info,
body.page-template-page-my-account .woocommerce .woocommerce-message,
body.page-template-page-my-account .woocommerce .woocommerce-error,
body.woocommerce-account .woocommerce .woocommerce-info,
body.woocommerce-account .woocommerce .woocommerce-message,
body.woocommerce-account .woocommerce .woocommerce-error {
  border: 1px solid rgba(184, 94, 117, 0.18);
  border-radius: 18px;
  background: rgba(255, 247, 250, 0.82);
  color: var(--mi-color-text);
  box-shadow: 0 12px 32px rgba(74, 49, 53, 0.06);
}

[data-theme="dark"] .mi-account-commerce-panel,
[data-theme="dark"] .mi-account-order-row,
[data-theme="dark"] .mi-account-empty-state,
[data-theme="dark"] body.page-template-page-my-account .woocommerce .woocommerce-info,
[data-theme="dark"] body.page-template-page-my-account .woocommerce .woocommerce-message,
[data-theme="dark"] body.page-template-page-my-account .woocommerce .woocommerce-error,
[data-theme="dark"] body.woocommerce-account .woocommerce .woocommerce-info,
[data-theme="dark"] body.woocommerce-account .woocommerce .woocommerce-message,
[data-theme="dark"] body.woocommerce-account .woocommerce .woocommerce-error {
  border-color: rgba(255, 214, 226, 0.14);
  background: linear-gradient(145deg, rgba(48, 30, 42, 0.86), rgba(28, 16, 24, 0.72));
  box-shadow: 0 18px 52px rgba(0, 0, 0, 0.22);
}

[data-theme="dark"] .mi-account-order-row:hover,
[data-theme="dark"] .mi-account-order-row:focus-visible {
  border-color: rgba(255, 193, 212, 0.26);
  background: rgba(64, 38, 52, 0.84);
}

[data-theme="dark"] .mi-account-status-list div {
  border-bottom-color: rgba(255, 214, 226, 0.12);
}

[data-theme="dark"] .mi-account-close-button {
  border-color: rgba(255, 193, 212, 0.22);
  background: rgba(255, 247, 250, 0.08);
  color: #ffc1d4;
}

[data-theme="dark"] .mi-account-close-button:hover,
[data-theme="dark"] .mi-account-close-button:focus-visible {
  border-color: rgba(255, 193, 212, 0.34);
  background: rgba(64, 38, 52, 0.84);
}

[data-theme="dark"] .mi-account-dashboard__logout {
  border-color: rgba(255, 214, 226, 0.16);
  background: rgba(255, 247, 250, 0.08);
  color: #ffc1d4;
}

[data-theme="dark"] .mi-account-dashboard__logout:hover,
[data-theme="dark"] .mi-account-dashboard__logout:focus-visible {
  border-color: rgba(255, 193, 212, 0.28);
  background: rgba(64, 38, 52, 0.84);
}

/* Step 53: Separate account auth pages - v3.10.24 */
body.page-template-page-my-account .mi-account-auth--single,
body.woocommerce-account .mi-account-auth--single {
  width: min(100%, 34rem);
  display: block !important;
  margin-inline: auto;
}

body.page-template-page-my-account .mi-account-auth--single .mi-account-auth__panel,
body.woocommerce-account .mi-account-auth--single .mi-account-auth__panel {
  width: 100%;
}

.mi-account-auth__switch {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(184, 94, 117, 0.14);
  color: var(--mi-color-text-muted);
  font-size: 0.92rem;
}

[data-theme="dark"] .mi-account-auth__switch {
  border-top-color: rgba(255, 214, 226, 0.14);
}

@media (max-width: 900px) {
  .mi-account-commerce-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .mi-account-commerce-panel__header,
  .mi-account-order-row,
  .mi-account-status-list div {
    align-items: flex-start;
    flex-direction: column;
  }

  .mi-account-order-row > span:last-child,
  .mi-account-status-list dd {
    justify-items: start;
    text-align: left;
  }
}

/* Step 52: Global form borders and dark surface consistency - v3.10.23 */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="url"],
input[type="number"],
textarea,
select,
.woocommerce input.input-text,
.woocommerce textarea,
.woocommerce select,
.woocommerce .select2-container--default .select2-selection--single,
.woocommerce .select2-container--default .select2-selection--multiple,
.wpforms-field input,
.wpforms-field textarea,
.wpforms-field select,
.mi-account-drawer__form input.input-text,
.mi-account-drawer__form .woocommerce-Input,
.mi-footer__newsletter input,
.mi-footer__newsletter--wpforms input[type='email'],
.mi-nav-search input {
  border: 1.35px solid rgba(152, 70, 94, 0.34) !important;
  background-color: rgba(255, 255, 255, 0.82) !important;
  color: var(--mi-color-text) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), 0 8px 24px rgba(74, 49, 53, 0.045) !important;
}

input[type="text"]:hover,
input[type="email"]:hover,
input[type="password"]:hover,
input[type="search"]:hover,
input[type="tel"]:hover,
input[type="url"]:hover,
input[type="number"]:hover,
textarea:hover,
select:hover,
.woocommerce input.input-text:hover,
.woocommerce textarea:hover,
.woocommerce select:hover,
.wpforms-field input:hover,
.wpforms-field textarea:hover,
.wpforms-field select:hover,
.mi-account-drawer__form input.input-text:hover,
.mi-footer__newsletter input:hover,
.mi-nav-search input:hover {
  border-color: rgba(152, 70, 94, 0.48) !important;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
input[type="number"]:focus,
textarea:focus,
select:focus,
.woocommerce input.input-text:focus,
.woocommerce textarea:focus,
.woocommerce select:focus,
.wpforms-field input:focus,
.wpforms-field textarea:focus,
.wpforms-field select:focus,
.mi-account-drawer__form input.input-text:focus,
.mi-footer__newsletter input:focus,
.mi-nav-search input:focus {
  border-color: rgba(152, 70, 94, 0.72) !important;
  box-shadow: 0 0 0 4px rgba(184, 94, 117, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.7) !important;
  outline: none !important;
}

input::placeholder,
textarea::placeholder,
.woocommerce input.input-text::placeholder,
.wpforms-field input::placeholder,
.wpforms-field textarea::placeholder,
.mi-nav-search input::placeholder {
  color: rgba(75, 57, 66, 0.58) !important;
  opacity: 1;
}

[data-theme="dark"] body,
[data-theme="dark"] .mi-shell,
[data-theme="dark"] .mi-main,
[data-theme="dark"] .mi-wc-account-page,
[data-theme="dark"] .mi-section,
[data-theme="dark"] .mi-section--hero,
[data-theme="dark"] .mi-section--intro,
[data-theme="dark"] .mi-section--categories,
[data-theme="dark"] .mi-section--products,
[data-theme="dark"] .mi-section--bestsellers,
[data-theme="dark"] .mi-section--reviews,
[data-theme="dark"] .mi-section--brand-promise,
[data-theme="dark"] .mi-section--privacy,
[data-theme="dark"] .mi-section--faq,
[data-theme="dark"] .mi-section--guides,
[data-theme="dark"] .mi-section--contact,
[data-theme="dark"] .mi-section--checkout,
[data-theme="dark"] .mi-search-page,
[data-theme="dark"] .woocommerce .mi-main,
[data-theme="dark"] .woocommerce-page .mi-main,
[data-theme="dark"] body.page-template-page-my-account,
[data-theme="dark"] body.woocommerce-account {
  background:
    radial-gradient(circle at 12% 6%, rgba(168, 72, 112, 0.16), transparent 30%),
    radial-gradient(circle at 88% 12%, rgba(255, 188, 209, 0.1), transparent 28%),
    linear-gradient(180deg, #170d13 0%, #21141b 48%, #190f15 100%) !important;
  color: #fff7fb;
}

[data-theme="dark"] .mi-container,
[data-theme="dark"] .mi-wc-account-shell,
[data-theme="dark"] .mi-account-layout {
  color: #fff7fb;
}

[data-theme="dark"] .mi-account-auth__panel,
[data-theme="dark"] .mi-account-layout__nav,
[data-theme="dark"] .mi-account-dashboard__welcome,
[data-theme="dark"] .mi-account-dashboard__tile,
[data-theme="dark"] .mi-account-commerce-panel,
[data-theme="dark"] .mi-account-order-row,
[data-theme="dark"] .mi-account-empty-state,
[data-theme="dark"] .mi-category-card,
[data-theme="dark"] .mi-product-card,
[data-theme="dark"] .mi-promise-card,
[data-theme="dark"] .mi-guide-card,
[data-theme="dark"] .mi-search-card,
[data-theme="dark"] .mi-search-page__panel,
[data-theme="dark"] .mi-contact-card,
[data-theme="dark"] .mi-contact-form,
[data-theme="dark"] .mi-checkout-panel,
[data-theme="dark"] .woocommerce div.product,
[data-theme="dark"] .woocommerce-cart-form,
[data-theme="dark"] .woocommerce-checkout,
[data-theme="dark"] .woocommerce-MyAccount-content,
[data-theme="dark"] .woocommerce-MyAccount-navigation,
[data-theme="dark"] .woocommerce ul.products li.product.mi-wc-product-card,
[data-theme="dark"] .woocommerce table.shop_table,
[data-theme="dark"] .woocommerce form.login,
[data-theme="dark"] .woocommerce form.register,
[data-theme="dark"] .woocommerce form.lost_reset_password,
[data-theme="dark"] .woocommerce form.checkout_coupon,
[data-theme="dark"] .woocommerce form.edit-account,
[data-theme="dark"] .woocommerce form.edit-address {
  border-color: rgba(255, 214, 226, 0.18) !important;
  background: linear-gradient(145deg, rgba(48, 30, 42, 0.9), rgba(28, 16, 24, 0.78)) !important;
  color: #fff7fb !important;
  box-shadow: 0 18px 52px rgba(0, 0, 0, 0.24) !important;
}

[data-theme="dark"] input[type="text"],
[data-theme="dark"] input[type="email"],
[data-theme="dark"] input[type="password"],
[data-theme="dark"] input[type="search"],
[data-theme="dark"] input[type="tel"],
[data-theme="dark"] input[type="url"],
[data-theme="dark"] input[type="number"],
[data-theme="dark"] textarea,
[data-theme="dark"] select,
[data-theme="dark"] .woocommerce input.input-text,
[data-theme="dark"] .woocommerce textarea,
[data-theme="dark"] .woocommerce select,
[data-theme="dark"] .woocommerce .select2-container--default .select2-selection--single,
[data-theme="dark"] .woocommerce .select2-container--default .select2-selection--multiple,
[data-theme="dark"] .wpforms-field input,
[data-theme="dark"] .wpforms-field textarea,
[data-theme="dark"] .wpforms-field select,
[data-theme="dark"] .mi-account-drawer__form input.input-text,
[data-theme="dark"] .mi-account-drawer__form .woocommerce-Input,
[data-theme="dark"] .mi-footer__newsletter input,
[data-theme="dark"] .mi-footer__newsletter--wpforms input[type='email'],
[data-theme="dark"] .mi-nav-search input {
  border-color: rgba(255, 193, 212, 0.42) !important;
  background-color: rgba(255, 247, 250, 0.1) !important;
  color: #fff7fb !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.055), 0 10px 28px rgba(0, 0, 0, 0.18) !important;
}

[data-theme="dark"] input[type="text"]:hover,
[data-theme="dark"] input[type="email"]:hover,
[data-theme="dark"] input[type="password"]:hover,
[data-theme="dark"] input[type="search"]:hover,
[data-theme="dark"] input[type="tel"]:hover,
[data-theme="dark"] input[type="url"]:hover,
[data-theme="dark"] input[type="number"]:hover,
[data-theme="dark"] textarea:hover,
[data-theme="dark"] select:hover,
[data-theme="dark"] .woocommerce input.input-text:hover,
[data-theme="dark"] .woocommerce textarea:hover,
[data-theme="dark"] .woocommerce select:hover,
[data-theme="dark"] .wpforms-field input:hover,
[data-theme="dark"] .wpforms-field textarea:hover,
[data-theme="dark"] .wpforms-field select:hover,
[data-theme="dark"] .mi-account-drawer__form input.input-text:hover,
[data-theme="dark"] .mi-footer__newsletter input:hover,
[data-theme="dark"] .mi-nav-search input:hover {
  border-color: rgba(255, 193, 212, 0.62) !important;
}

[data-theme="dark"] input[type="text"]:focus,
[data-theme="dark"] input[type="email"]:focus,
[data-theme="dark"] input[type="password"]:focus,
[data-theme="dark"] input[type="search"]:focus,
[data-theme="dark"] input[type="tel"]:focus,
[data-theme="dark"] input[type="url"]:focus,
[data-theme="dark"] input[type="number"]:focus,
[data-theme="dark"] textarea:focus,
[data-theme="dark"] select:focus,
[data-theme="dark"] .woocommerce input.input-text:focus,
[data-theme="dark"] .woocommerce textarea:focus,
[data-theme="dark"] .woocommerce select:focus,
[data-theme="dark"] .wpforms-field input:focus,
[data-theme="dark"] .wpforms-field textarea:focus,
[data-theme="dark"] .wpforms-field select:focus,
[data-theme="dark"] .mi-account-drawer__form input.input-text:focus,
[data-theme="dark"] .mi-footer__newsletter input:focus,
[data-theme="dark"] .mi-nav-search input:focus {
  border-color: rgba(255, 193, 212, 0.86) !important;
  box-shadow: 0 0 0 4px rgba(240, 154, 183, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.06) !important;
}

[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder,
[data-theme="dark"] .woocommerce input.input-text::placeholder,
[data-theme="dark"] .wpforms-field input::placeholder,
[data-theme="dark"] .wpforms-field textarea::placeholder,
[data-theme="dark"] .mi-nav-search input::placeholder {
  color: rgba(255, 238, 245, 0.55) !important;
}

[data-theme="dark"] label,
[data-theme="dark"] .woocommerce label,
[data-theme="dark"] .woocommerce form .form-row label,
[data-theme="dark"] .woocommerce-MyAccount-content p,
[data-theme="dark"] .woocommerce-MyAccount-content td,
[data-theme="dark"] .woocommerce-MyAccount-content th,
[data-theme="dark"] .mi-account-auth__intro p,
[data-theme="dark"] .mi-account-commerce-panel p,
[data-theme="dark"] .mi-account-status-list dd,
[data-theme="dark"] .mi-account-empty-state p {
  color: rgba(255, 238, 245, 0.78) !important;
}

/* Phase 1: Design system foundation - light/dark mode */
.mi-shell,
.mi-main {
  background: transparent;
  color: var(--mi-color-text);
}

.mi-section,
.woocommerce-page .mi-main,
.woocommerce .mi-main {
  color: var(--mi-color-text);
}

.mi-button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .checkout-button {
  border-color: transparent;
  color: #fff;
}

.mi-button--secondary,
.mi-button--ghost,
.woocommerce a.button.alt.disabled,
.woocommerce button.button.alt.disabled,
.woocommerce input.button.alt.disabled {
  border-color: var(--mi-color-border);
  background: var(--mi-color-surface-strong);
  color: var(--mi-color-text);
}

.mi-category-card,
.mi-product-card,
.mi-promise-card,
.mi-guide-card,
.mi-search-card,
.mi-contact-card,
.mi-contact-form,
.mi-checkout-panel,
.mi-account-auth__panel,
.mi-account-layout__nav,
.mi-account-dashboard__welcome,
.mi-account-dashboard__tile,
.mi-account-commerce-panel,
.mi-wc-cart__panel,
.mi-wc-cart__totals-shell,
.mi-wc-checkout__details,
.mi-wc-checkout__review,
.woocommerce div.product,
.woocommerce-cart-form,
.woocommerce-checkout,
.woocommerce-MyAccount-content,
.woocommerce-MyAccount-navigation,
.woocommerce table.shop_table,
.woocommerce ul.products li.product.mi-wc-product-card {
  border-color: var(--mi-color-border);
  background: var(--mi-gradient-glass);
  color: var(--mi-color-text);
}

.mi-nav-shell,
.mi-mobile-menu,
.mi-mega-menu,
.mi-nav-search__panel,
.mi-cart-drawer__panel,
.mi-account-drawer__panel,
.mi-age-gate__panel {
  border-color: var(--mi-color-border);
  background: var(--mi-color-modal);
  color: var(--mi-color-text);
}

.mi-cart-drawer__backdrop,
.mi-account-drawer__backdrop,
.mi-age-gate__backdrop {
  background: var(--mi-color-overlay);
}

.mi-footer {
  background: linear-gradient(180deg, transparent, var(--mi-color-surface-soft));
  color: var(--mi-color-text);
}

.mi-footer__brand,
.mi-footer__shop,
.mi-footer__support,
.mi-footer__newsletter {
  border-color: var(--mi-color-border);
  background: var(--mi-color-surface);
  color: var(--mi-color-text);
}

.mi-footer__shop a,
.mi-footer__support a,
.mi-footer__bottom a,
.mi-account-form__link,
.woocommerce a {
  color: var(--mi-color-link);
}

.mi-footer__shop a:hover,
.mi-footer__support a:hover,
.mi-footer__bottom a:hover,
.mi-account-form__link:hover,
.woocommerce a:hover {
  color: var(--mi-color-link-hover);
}

.woocommerce-error,
.woocommerce-info,
.woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-error,
.woocommerce-notices-wrapper .woocommerce-info,
.woocommerce-notices-wrapper .woocommerce-message {
  border: 1px solid var(--mi-color-notice-border);
  border-radius: var(--mi-radius-md);
  background: var(--mi-color-notice-bg);
  color: var(--mi-color-text);
  box-shadow: var(--mi-shadow-sm);
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce input.input-text,
.woocommerce textarea,
.woocommerce select,
.woocommerce .select2-container--default .select2-selection--single,
.woocommerce .select2-container--default .select2-selection--multiple,
.wpforms-field input,
.wpforms-field textarea,
.wpforms-field select,
.mi-nav-search input,
.mi-footer__newsletter input,
.mi-footer__newsletter--wpforms input[type='email'],
.mi-account-drawer__form input.input-text,
.mi-account-drawer__form .woocommerce-Input {
  border-color: var(--mi-color-input-border);
  background-color: var(--mi-color-input-bg);
  color: var(--mi-color-text);
}

.woocommerce form .form-row input.input-text:hover,
.woocommerce form .form-row textarea:hover,
.woocommerce form .form-row select:hover,
.woocommerce input.input-text:hover,
.woocommerce textarea:hover,
.woocommerce select:hover,
.woocommerce .select2-container--default .select2-selection--single:hover,
.woocommerce .select2-container--default .select2-selection--multiple:hover,
.wpforms-field input:hover,
.wpforms-field textarea:hover,
.wpforms-field select:hover,
.mi-nav-search input:hover,
.mi-footer__newsletter input:hover,
.mi-footer__newsletter--wpforms input[type='email']:hover,
.mi-account-drawer__form input.input-text:hover,
.mi-account-drawer__form .woocommerce-Input:hover {
  border-color: var(--mi-color-input-border-hover);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus,
.woocommerce input.input-text:focus,
.woocommerce textarea:focus,
.woocommerce select:focus,
.woocommerce .select2-container--default.select2-container--focus .select2-selection--single,
.woocommerce .select2-container--default.select2-container--focus .select2-selection--multiple,
.wpforms-field input:focus,
.wpforms-field textarea:focus,
.wpforms-field select:focus,
.mi-nav-search input:focus,
.mi-footer__newsletter input:focus,
.mi-footer__newsletter--wpforms input[type='email']:focus,
.mi-account-drawer__form input.input-text:focus,
.mi-account-drawer__form .woocommerce-Input:focus {
  border-color: var(--mi-color-primary);
  box-shadow: var(--mi-focus-ring);
}

html[data-theme="dark"] .mi-nav-shell,
html[data-theme="dark"] .mi-mobile-menu,
html[data-theme="dark"] .mi-mega-menu,
html[data-theme="dark"] .mi-nav-search__panel,
html[data-theme="dark"] .mi-cart-drawer__panel,
html[data-theme="dark"] .mi-account-drawer__panel,
html[data-theme="dark"] .mi-age-gate__panel {
  background: linear-gradient(145deg, rgba(35, 20, 37, 0.94), rgba(19, 11, 20, 0.92));
}

html[data-theme="dark"] .mi-footer {
  background: linear-gradient(180deg, transparent, rgba(19, 11, 20, 0.96));
}

html[data-theme="dark"] img,
html[data-theme="dark"] picture,
html[data-theme="dark"] video,
html[data-theme="dark"] canvas {
  filter: none;
}
