/** Shopify CDN: Minification failed

Line 1346:0 Unexpected "}"

**/
@charset "UTF-8";
:root {
  --tl-brand-primary: #4D4D4D;
  --tl-brand-secondary: #7e6085;
  --tl-brand-accent: #c329bd;
  --tl-color-text-primary: #4D4D4D;
  --tl-color-text-secondary: #4D4D4D;
  --tl-color-text-muted: #757575;
  --tl-color-text-disabled: #9d9d9d;
  --tl-color-bg-primary: #ffffff;
  --tl-color-bg-secondary: #f4f4f4;
  --tl-color-bg-tertiary: #e4e4e4;
  --tl-color-bg-overlay: rgba(77, 77, 77, 0.8);
  --tl-color-interactive-default: #feff04;
  --tl-color-interactive-hover: #f6f600;
  --tl-color-interactive-active: #feff04;
  --tl-color-interactive-disabled: #d2d2d2;
  --tl-color-border-default: #d2d2d2;
  --tl-color-border-focus: #feff04;
  --tl-color-border-error: #d13359;
  --tl-color-border-success: #1da089;
  --tl-color-success: #1da089;
  --tl-color-error: #d13359;
  --tl-color-warning: #feff04;
  --tl-color-info: #ebe9f6;
  --tl-font-heading: sofia-pro;
  --tl-font-body: sofia-pro;
  --tl-font-label: sofia-pro;
  --tl-font-weight-bold: 700;
  --tl-font-weight-semibold: 600;
  --tl-font-weight-medium: 500;
  --tl-font-weight-regular: 400;
  --tl-font-weight-light: 300;
  --tl-font-size-xs: 12px;
  --tl-font-size-sm: 14px;
  --tl-font-size-base: 16px;
  --tl-font-size-lg: 20px;
  --tl-font-size-xl: 28px;
  --tl-font-size-2xl: 40px;
  --tl-font-size-3xl: 52px;
  --tl-font-size-4xl: 72px;
  --tl-space-xs: 4px;
  --tl-space-sm: 8px;
  --tl-space-md: 16px;
  --tl-space-lg: 24px;
  --tl-space-xl: 32px;
  --tl-space-2xl: 48px;
  --tl-space-3xl: 64px;
  --tl-radius-none: 0;
  --tl-radius-sm: 2px;
  --tl-radius-md: 4px;
  --tl-radius-lg: 8px;
  --tl-radius-xl: 12px;
  --tl-radius-full: 9999px;
  --tl-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --tl-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --tl-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --tl-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --tl-z-dropdown: 1000;
  --tl-z-sticky: 1020;
  --tl-z-fixed: 1030;
  --tl-z-modal-backdrop: 1040;
  --tl-z-modal: 1050;
  --tl-z-popover: 1060;
  --tl-z-tooltip: 1070;
  --tl-z-toast: 1080;
  --Radius_M: var(--tl-radius-lg); /* Maps to 8px */
  --Radius_3XS: var(--tl-radius-none); /* Maps to 0px */
  --Colour-Brand-Grey05: var(--tl-color-bg-secondary); /* Maps to #F4F4F4 */
  --Colour-Brand-Grey70: var(--tl-color-text-secondary); /* Maps to #4D4D4D */
  --Colour-Brand-Grey80: var(--tlColorSemanticGrey80); /* Maps to #353535 */
  --Colour-Brand-White: #FFFFFF;
}

@media (prefers-contrast: high) {
  :root {
    --tl-color-border-default: #353535;
    --tl-color-interactive-default: #d13359;
    --tl-font-weight-bold: 800;
  }
}
@media (prefers-reduced-motion: reduce) {
  :root {
    --tl-transition-duration-fast: 0ms;
    --tl-transition-duration-normal: 0ms;
    --tl-transition-duration-slow: 0ms;
  }
}
:root {
  /* Dawn slots → Trinny Tokens */
  --color-button: 255, 0, 255;
  --color-button-text: 255, 255, 255;
  --color-base-background-1: 255, 255, 255;
}

:root {
  --color-base-accent-1: var(--tl-color-interactive-default) !important;
  --color-button: var(--tl-color-interactive-default) !important;
  --color-button-text: #000000 !important;
  --font-heading-family: "sofia-pro", sans-serif !important;
  --font-heading-weight: 700 !important;
  --buttons-border-radius: 0 !important;
  --inputs-border-radius: 0 !important;
  --buttons-radius: 0 !important;
  --inputs-radius: 0 !important;
}

.product-form__quantity,
.quantity {
  display: none !important;
}

body {
  background-color: var(--tl-color-bg-secondary);
  color: var(--tl-color-text-primary);
  font-family: var(--tl-font-body), sans-serif;
  font-weight: var(--tl-font-weight-regular);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  transition: background-color 0.3s ease, color 0.3s ease;
}

h1,
.tl-h1 {
  font-family: var(--tl-font-heading);
  font-size: 40px !important;
  font-weight: var(--tl-font-weight-bold);
  line-height: 1.2;
}

.product__title h1,
.product__title .h1 {
  font-size: 40px !important;
  line-height: 1.2 !important;
}

h2,
.tl-h2 {
  font-family: var(--tl-font-heading);
  font-size: var(--tl-font-size-3xl);
  font-weight: var(--tl-font-weight-bold);
  line-height: 1.2;
  letter-spacing: -0.01em;
}
@media (min-width: 750px) {
  h2,
  .tl-h2 {
    font-size: var(--tl-responsive-font-size-h2);
  }
}

h3,
.tl-h3 {
  font-family: var(--tl-font-heading);
  font-size: var(--tl-font-size-2xl);
  font-weight: var(--tl-font-weight-semibold);
  line-height: 1.3;
}
@media (min-width: 750px) {
  h3,
  .tl-h3 {
    font-size: var(--tl-responsive-font-size-h3);
  }
}

h4,
.tl-h4 {
  font-family: var(--tl-font-heading);
  font-size: var(--tl-font-size-xl);
  font-weight: var(--tl-font-weight-semibold);
  line-height: 1.4;
}
@media (min-width: 750px) {
  h4,
  .tl-h4 {
    font-size: var(--tl-responsive-font-size-h4);
  }
}

h5,
.tl-h5 {
  font-family: var(--tl-font-heading);
  font-size: var(--tl-font-size-lg);
  font-weight: var(--tl-font-weight-medium);
  line-height: 1.5;
}
@media (min-width: 750px) {
  h5,
  .tl-h5 {
    font-size: var(--tl-responsive-font-size-h5);
  }
}

.tl-p16 {
  font-family: var(--tl-font-body);
  font-size: var(--tl-font-size-base);
  font-weight: var(--tl-font-weight-regular);
  line-height: 1.6;
}
@media (min-width: 750px) {
  .tl-p16 {
    font-size: var(--tl-responsive-font-size-body);
  }
}

.tl-p14 {
  font-family: var(--tl-font-body);
  font-size: var(--tl-font-size-sm);
  font-weight: var(--tl-font-weight-regular);
  line-height: 1.5;
}
@media (min-width: 750px) {
  .tl-p14 {
    font-size: var(--tl-responsive-font-size-small);
  }
}

.tl-p12 {
  font-family: var(--tl-font-body);
  font-size: var(--tl-font-size-xs);
  font-weight: var(--tl-font-weight-regular);
  line-height: 1.4;
}

.tl-label-14 {
  font-family: var(--tl-font-label);
  font-size: var(--tl-font-size-sm);
  font-weight: var(--tl-font-weight-semibold);
  line-height: 1.4;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.tl-label-12 {
  font-family: var(--tl-font-label);
  font-size: var(--tl-font-size-xs);
  font-weight: var(--tl-font-weight-semibold);
  line-height: 1.3;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.tl-h1-responsive {
  font-family: var(--tl-font-heading);
  font-size: var(--tl-responsive-font-size-h1);
  font-weight: var(--tl-font-weight-bold);
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.tl-h2-responsive {
  font-family: var(--tl-font-heading);
  font-size: var(--tl-responsive-font-size-h2);
  font-weight: var(--tl-font-weight-bold);
  line-height: 1.2;
  letter-spacing: -0.01em;
}

.tl-body-responsive {
  font-family: var(--tl-font-body);
  font-size: var(--tl-responsive-font-size-body);
  font-weight: var(--tl-font-weight-regular);
  line-height: 1.6;
}

.tl-small-responsive {
  font-family: var(--tl-font-body);
  font-size: var(--tl-responsive-font-size-small);
  font-weight: var(--tl-font-weight-regular);
  line-height: 1.5;
}

@media (min-width: 375px) {
  h1,
  .tl-h1 {
    font-size: var(--tl-fluid-h1);
  }
  h2,
  .tl-h2 {
    font-size: var(--tl-fluid-h2);
  }
  h3,
  .tl-h3 {
    font-size: var(--tl-fluid-h3);
  }
  .tl-body-responsive {
    font-size: var(--tl-fluid-body);
  }
}
.tl-container {
  width: 100%;
  margin-inline: auto;
  padding-inline: 1rem;
}
@media (min-width: 768px) {
  .tl-container {
    max-width: 768px;
    padding-inline: 2rem;
  }
}
@media (min-width: 1024px) {
  .tl-container {
    max-width: 1024px;
  }
}
@media (min-width: 1280px) {
  .tl-container {
    max-width: 1280px;
  }
}

.tl-section {
  padding-block: 3rem;
}
@media (min-width: 1024px) {
  .tl-section {
    padding-block: 5rem;
  }
}

.tl-theme-toggle {
  position: relative;
  width: 60px;
  height: 30px;
  background-color: var(--tl-color-bg-tertiary);
  border: 2px solid var(--tl-color-border-default);
  border-radius: var(--tl-radius-full);
  cursor: pointer;
  transition: all 0.3s ease;
}
.tl-theme-toggle:focus {
  outline: 2px solid var(--tl-color-border-focus);
  outline-offset: 2px;
}
.tl-theme-toggle__slider {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 22px;
  height: 22px;
  background-color: var(--tl-brand-primary);
  border-radius: 50%;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  color: var(--tl-color-text-primary);
}
.tl-theme-toggle--dark .tl-theme-toggle__slider {
  transform: translateX(30px);
  background-color: var(--tl-brand-secondary);
}
.tl-theme-toggle__icon {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-size: 14px;
  transition: opacity 0.3s ease;
}
.tl-theme-toggle__icon--sun {
  left: 8px;
  opacity: 1;
}
.tl-theme-toggle__icon--moon {
  right: 8px;
  opacity: 0.3;
}
.tl-theme-toggle--dark .tl-theme-toggle__icon--sun {
  opacity: 0.3;
}
.tl-theme-toggle--dark .tl-theme-toggle__icon--moon {
  opacity: 1;
}
.tl-theme-toggle:hover {
  border-color: var(--tl-color-border-focus);
  box-shadow: var(--tl-shadow-sm);
}
.tl-theme-toggle:active {
  transform: scale(0.95);
}

.tl-theme-switcher {
  position: relative;
  display: inline-block;
}
.tl-theme-switcher__trigger {
  background-color: var(--tl-color-bg-secondary);
  border: 1px solid var(--tl-color-border-default);
  border-radius: var(--tl-radius-md);
  padding: var(--tl-space-sm) var(--tl-space-md);
  font-family: var(--tl-font-label);
  font-size: var(--tl-font-size-sm);
  font-weight: var(--tl-font-weight-semibold);
  color: var(--tl-color-text-primary);
  cursor: pointer;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  gap: var(--tl-space-sm);
}
.tl-theme-switcher__trigger:hover {
  background-color: var(--tl-color-bg-tertiary);
  border-color: var(--tl-color-border-focus);
}
.tl-theme-switcher__trigger:focus {
  outline: 2px solid var(--tl-color-border-focus);
  outline-offset: 2px;
}
.tl-theme-switcher__dropdown {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: var(--tl-space-xs);
  background-color: var(--tl-color-bg-primary);
  border: 1px solid var(--tl-color-border-default);
  border-radius: var(--tl-radius-lg);
  box-shadow: var(--tl-shadow-lg);
  min-width: 200px;
  z-index: var(--tl-z-dropdown);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all 0.3s ease;
}
.tl-theme-switcher--open .tl-theme-switcher__dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.tl-theme-switcher__option {
  display: flex;
  align-items: center;
  gap: var(--tl-space-sm);
  padding: var(--tl-space-sm) var(--tl-space-md);
  font-family: var(--tl-font-body);
  font-size: var(--tl-font-size-sm);
  color: var(--tl-color-text-primary);
  cursor: pointer;
  transition: background-color 0.3s ease;
  border-bottom: 1px solid var(--tl-color-border-default);
}
.tl-theme-switcher__option:last-child {
  border-bottom: none;
}
.tl-theme-switcher__option:hover {
  background-color: var(--tl-color-bg-secondary);
}
.tl-theme-switcher__option:focus {
  outline: 2px solid var(--tl-color-border-focus);
  outline-offset: -2px;
}
.tl-theme-switcher__option--active {
  background-color: var(--tl-color-bg-tertiary);
  font-weight: var(--tl-font-weight-semibold);
}
.tl-theme-switcher__option--active::before {
  content: "✓";
  margin-right: var(--tl-space-xs);
  color: var(--tl-brand-primary);
}
.tl-theme-switcher__icon {
  width: 20px;
  height: 20px;
  border-radius: var(--tl-radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
}
.tl-theme-switcher__icon--light {
  background-color: var(--tl-color-bg-primary);
  border: 1px solid var(--tl-color-border-default);
  color: var(--tl-color-text-primary);
}
.tl-theme-switcher__icon--dark {
  background-color: var(--tl-color-text-primary);
  border: 1px solid var(--tl-color-border-default);
  color: var(--tl-color-bg-primary);
}
.tl-theme-switcher__icon--auto {
  background: linear-gradient(45deg, var(--tl-color-bg-primary) 50%, var(--tl-color-text-primary) 50%);
  border: 1px solid var(--tl-color-border-default);
  color: var(--tl-color-text-primary);
}

.tl-auto-theme-indicator {
  position: fixed;
  bottom: var(--tl-space-md);
  right: var(--tl-space-md);
  background-color: var(--tl-color-bg-primary);
  border: 1px solid var(--tl-color-border-default);
  border-radius: var(--tl-radius-lg);
  padding: var(--tl-space-sm) var(--tl-space-md);
  font-family: var(--tl-font-label);
  font-size: var(--tl-font-size-xs);
  color: var(--tl-color-text-secondary);
  box-shadow: var(--tl-shadow-md);
  z-index: var(--tl-z-toast);
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: all 0.3s ease;
}
.tl-auto-theme-indicator--visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.tl-auto-theme-indicator__icon {
  margin-right: var(--tl-space-xs);
}

* {
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

@media (prefers-reduced-motion: reduce) {
  * {
    transition: none !important;
  }
}
@media (prefers-contrast: high) {
  .tl-theme-toggle {
    border-width: 3px;
  }
  .tl-theme-toggle__slider {
    border: 1px solid var(--tl-color-text-primary);
  }
  .tl-theme-switcher__trigger {
    border-width: 2px;
  }
  .tl-theme-switcher__dropdown {
    border-width: 2px;
  }
}
@media (max-width: 749px) {
  .tl-theme-toggle {
    width: 50px;
    height: 25px;
  }
  .tl-theme-toggle__slider {
    width: 19px;
    height: 19px;
  }
  .tl-theme-toggle--dark .tl-theme-toggle__slider {
    transform: translateX(25px);
  }
  .tl-theme-toggle__icon {
    font-size: 12px;
  }
  .tl-theme-toggle__icon--sun {
    left: 6px;
  }
  .tl-theme-toggle__icon--moon {
    right: 6px;
  }
  .tl-theme-switcher__dropdown {
    min-width: 180px;
    right: -50px;
  }
}
.tl-text-primary {
  color: var(--tl-color-text-primary);
}

.tl-text-secondary {
  color: var(--tl-color-text-secondary);
}

.tl-text-muted {
  color: var(--tl-color-text-muted);
}

.tl-text-white {
  color: var(--tl-color-bg-primary);
}

.tl-text-yellow {
  color: var(--tl-color-interactive-default);
}

.tl-text-sale {
  color: var(--tl-color-success);
}

.tl-text-success {
  color: var(--tl-color-success);
}

.tl-text-error {
  color: var(--tl-color-error);
}

.tl-bg-grey05 {
  background-color: var(--tl-color-bg-secondary);
}

.tl-bg-grey10 {
  background-color: var(--tl-color-bg-tertiary);
}

.tl-bg-white {
  background-color: var(--tl-color-bg-primary);
}

.tl-bg-yellow {
  background-color: var(--tl-color-interactive-default);
}

.tl-bg-lilac {
  background-color: var(--tl-color-bg-secondary);
}

.tl-bg-serum-blue {
  background-color: var(--tl-brand-primary);
}

.tl-bg-sky-blue {
  background-color: var(--tl-brand-secondary);
}

.tl-bg-pink {
  background-color: var(--tl-brand-accent);
}

.tl-bg-orange {
  background-color: var(--tl-color-interactive-default);
}

.tl-uppercase {
  text-transform: uppercase;
}

.tl-lowercase {
  text-transform: none;
}

/* Primary Add to Cart / CTA button */
.product-form__submit,
.cart__submit,
.tl-button {
  background-color: var(--tl-color-interactive-default) !important;
  color: #000000 !important;
  border-radius: 0 !important;
  border: 0 !important;
  border-width: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  font-family: inherit;
  font-size: 16px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 20px 32px;
  width: 100% !important;
  min-height: 56px;
  display: flex !important;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  --border-width: 0 !important;
  --buttons-border-width: 0 !important;
}

/* Price inside the button */
.product-form__submit-price {
  font-weight: 700;
  font-size: 16px;
  margin-left: auto;
}

/* Kill Dawn's pseudo-element borders on CTA buttons */
.product-form__submit::before,
.product-form__submit::after,
.cart__submit::before,
.cart__submit::after {
  display: none !important;
  content: none !important;
}

.shopify-payment-button {
  display: none !important;
}

.tl-product-card {
  background-color: var(--tlColorFeedbackWhite);
  color: var(--tlColorFeedbackGrey80);
}
.tl-product-card__title {
  font-family: var(--tlTypographyH16FontFamily);
  font-size: var(--tlTypographyH16FontSize);
  font-weight: var(--tlTypographyH16FontWeight);
  line-height: var(--tlTypographyH16LineHeight);
  letter-spacing: var(--tlTypographyH16LetterSpacing);
}
.tl-product-card__price {
  font-family: var(--tlTypographyP14FontFamily);
  font-size: var(--tlTypographyP14FontSize);
  font-weight: var(--tlTypographyP14FontWeight);
  color: var(--tlColorFeedbackGrey80);
}
.tl-product-card__price--sale {
  color: var(--tlColorFeedbackSale);
}
.tl-product-card__badge {
  font-family: var(--tlTypographyL10FontFamily);
  font-size: var(--tlTypographyL10FontSize);
  font-weight: var(--tlTypographyL10FontWeight);
  font-style: var(--tlTypographyL10FontStyle);
  letter-spacing: var(--tlTypographyL10LetterSpacing);
  text-transform: uppercase;
  background-color: var(--tlColorFeedbackPrimaryYellow);
  color: var(--tlColorFeedbackGrey80);
  padding: 2px 8px;
}

.tl-shade-selector {
  display: flex;
  flex-wrap: wrap;
  gap: var(--tl-space-sm);
  padding: var(--tl-space-md);
  background-color: var(--tl-color-bg-primary);
  border-radius: var(--tl-radius-lg);
  border: 1px solid var(--tl-color-border-default);
  transition: background-color 0.3s ease, border-color 0.3s ease;
}
.tl-shade-selector__swatch {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid var(--tl-color-border-default);
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
}
.tl-shade-selector__swatch:focus {
  outline: 2px solid var(--tl-color-border-focus);
  outline-offset: 2px;
}
.tl-shade-selector__swatch:hover, .tl-shade-selector__swatch--active {
  border-color: var(--tl-color-text-primary);
  transform: scale(1.1);
  box-shadow: var(--tl-shadow-md);
}
.tl-shade-selector__swatch--active::after {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: white;
  font-size: 12px;
  font-weight: bold;
  text-shadow: 0 0 2px rgba(0, 0, 0, 0.5);
}
.tl-shade-selector__swatch--fair {
  background-color: var(--tl-color-bg-primary);
  border-color: var(--tl-color-border-default);
}
.tl-shade-selector__swatch--light {
  background-color: var(--tl-color-bg-tertiary);
  border-color: var(--tl-color-border-default);
}
.tl-shade-selector__swatch--medium {
  background-color: var(--tl-color-text-muted);
  border-color: var(--tl-color-border-default);
}
.tl-shade-selector__swatch--tan {
  background-color: var(--tl-brand-accent);
  border-color: var(--tl-color-border-default);
}
.tl-shade-selector__swatch--deep {
  background-color: var(--tl-color-text-primary);
  border-color: var(--tl-color-border-default);
}
.tl-shade-selector__swatch--rich {
  background-color: var(--tl-brand-secondary);
  border-color: var(--tl-color-border-default);
}
.tl-shade-selector__label {
  font-family: var(--tl-font-body);
  font-size: var(--tl-font-size-xs);
  font-weight: var(--tl-font-weight-regular);
  color: var(--tl-color-text-secondary);
  margin-top: var(--tl-space-xs);
  text-align: center;
  line-height: 1.3;
}
.tl-shade-selector__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--tl-space-xs);
  min-width: 60px;
}
.tl-shade-selector__tooltip {
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--tl-color-text-primary);
  color: var(--tl-color-bg-primary);
  padding: var(--tl-space-xs) var(--tl-space-sm);
  border-radius: var(--tl-radius-sm);
  font-size: var(--tl-font-size-xs);
  font-weight: var(--tl-font-weight-medium);
  white-space: nowrap;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
  z-index: var(--tl-z-tooltip);
  margin-bottom: var(--tl-space-xs);
}
.tl-shade-selector__tooltip::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 4px solid transparent;
  border-top-color: var(--tl-color-text-primary);
}
.tl-shade-selector__swatch:hover .tl-shade-selector__tooltip, .tl-shade-selector__swatch:focus .tl-shade-selector__tooltip {
  opacity: 1;
  visibility: visible;
}
@media (max-width: 749px) {
  .tl-shade-selector {
    gap: var(--tl-space-xs);
    padding: var(--tl-space-sm);
  }
  .tl-shade-selector__swatch {
    width: 24px;
    height: 24px;
  }
  .tl-shade-selector__item {
    min-width: 50px;
  }
}
@media (min-width: 750px) {
  .tl-shade-selector {
    gap: var(--tl-space-md);
  }
  .tl-shade-selector__swatch {
    width: 32px;
    height: 32px;
  }
  .tl-shade-selector__item {
    min-width: 70px;
  }
  .tl-shade-selector__label {
    font-size: var(--tl-font-size-sm);
  }
}

.tl-nav {
  background-color: var(--tl-color-bg-primary);
  border-bottom: 1px solid var(--tl-color-border-default);
  padding: var(--tl-space-md) 0;
  transition: background-color 0.3s ease, border-color 0.3s ease;
}
.tl-nav__list {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: var(--tl-space-lg);
}
.tl-nav__link {
  font-family: var(--tl-font-label);
  font-size: var(--tl-font-size-sm);
  font-weight: var(--tl-font-weight-semibold);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tl-color-text-primary);
  text-decoration: none;
  padding: var(--tl-space-sm) 0;
  border-bottom: 2px solid transparent;
  transition: all 0.3s ease;
  position: relative;
}
.tl-nav__link:hover {
  color: var(--tl-color-text-secondary);
  border-bottom-color: var(--tl-color-border-focus);
}
.tl-nav__link:focus {
  outline: 2px solid var(--tl-color-border-focus);
  outline-offset: 2px;
  border-radius: var(--tl-radius-sm);
}
.tl-nav__link--active {
  border-bottom-color: var(--tl-brand-primary);
  color: var(--tl-brand-primary);
  font-weight: var(--tl-font-weight-bold);
}
.tl-nav__mobile-toggle {
  display: none;
  background: transparent;
  border: none;
  color: var(--tl-color-text-primary);
  font-size: var(--tl-font-size-lg);
  cursor: pointer;
  padding: var(--tl-space-sm);
}
.tl-nav__mobile-toggle:focus {
  outline: 2px solid var(--tl-color-border-focus);
  outline-offset: 2px;
  border-radius: var(--tl-radius-sm);
}
@media (max-width: 749px) {
  .tl-nav__list {
    flex-direction: column;
    gap: var(--tl-space-sm);
    padding: var(--tl-space-md);
    background-color: var(--tl-color-bg-primary);
    border: 1px solid var(--tl-color-border-default);
    border-radius: var(--tl-radius-lg);
    position: absolute;
    top: 100%;
    left: var(--tl-space-md);
    right: var(--tl-space-md);
    z-index: var(--tl-z-dropdown);
    box-shadow: var(--tl-shadow-lg);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.3s ease;
  }
  .tl-nav__mobile-toggle {
    display: block;
  }
  .tl-nav--open .tl-nav__list {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }
}
@media (min-width: 750px) {
  .tl-nav {
    padding: var(--tl-space-lg) 0;
  }
  .tl-nav__list {
    gap: var(--tl-space-xl);
  }
  .tl-nav__link {
    font-size: var(--tl-font-size-base);
    padding: var(--tl-space-md) 0;
  }
}

/* placeholder */
/* === TL PROFESSIONAL PDP GALLERY - SINGLE HIT REBUILD === */
/* === SHARED GALLERY STYLES === */
.tl-gallery-thumb-item {
  display: flex !important;
  width: 62px !important;
  height: 70px !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  align-items: flex-start !important;
  overflow: hidden !important;
  border-radius: 0px !important;
  border: none !important;
  cursor: pointer;
  transition: transform 0.2s ease;
  background: var(--tlColorSemanticWhite, #ffffff);
  position: relative;
  padding-bottom: 6px !important;
}


/* Base style for the left-to-right animated bottom border */
.tl-gallery-thumb-item::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  height: 4px;
  background-color: var(--tlColorBaseBrandGrey1, #4D4D4D);
  transition: width 0.3s ease-out;
  z-index: 5;
  border-radius:  2px;
}

.tl-gallery-thumb-item.is-active {
  box-shadow: none;
  }

/* Expand the animated border when active */
.tl-gallery-thumb-item.is-active::after {
  width: 100%;
}

.tl-gallery-thumb-btn {
  width: 100%;
  height: 62px;
  border: none !important;
  background: none;
  padding: 0;
  cursor: pointer;
  display: block;
}

.tl-gallery-thumb-btn img {
  width: 100%;
  height: 100%;
  object-fit: contain !important;
  /* Changed from cover so entire image fits in frame */
}

/* === DESKTOP STYLES === */
@media screen and (min-width: 990px) {
  /* 1. Root Container - Figma: Image Gallery (display: flex, height: 594px, etc.) */
  .tl-gallery-wrapper {
    position: relative;
    z-index: 100 !important;
    display: flex !important;
    height: 594px !important;
    min-width: 596px !important;
    padding: 40px var(--space_11XL, 80px) 40px 0 !important;
    align-items: center !important;
    gap: var(--space_M, 20px) !important;
    grid-row: 1/span 1 !important;
    grid-column: 1/span 5 !important;
    justify-self: stretch !important;
    width: 100% !important;
    margin-bottom: 2rem;
    box-sizing: border-box !important;
    /* Bulletproof: Hide scrollbar in any browser/display size */
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
  }
  .tl-gallery-wrapper::-webkit-scrollbar {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
  }
  /* 3. Thumbnail Rail Section (width: 62px, fits exactly) */
  .tl-gallery-rail-section {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    position: sticky !important;
    top: 2rem !important;
    width: 62px !important;
    height: 514px !important; /* height is exactly 594px - 40px - 40px */
    justify-content: center !important;
    flex-shrink: 0 !important;
    box-sizing: border-box !important;
  }
  .tl-gallery-thumbs-viewport {
    width: 100% !important;
    max-height: 440px !important;
    overflow-y: hidden !important;
    margin: 12px 0 !important;
    scroll-behavior: smooth !important;
    /* Hide scrollbar inside viewport completely */
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
  }
  .tl-gallery-thumbs-viewport::-webkit-scrollbar {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
  }
  .tl-gallery-thumbs-list {
    display: flex !important;
    flex-direction: column !important;
    padding: 0 !important;
    margin: 0 !important;
  }
  /* 4. Viewer Section - Sits directly as child of wrapper, styled exactly as Figma */
  .tl-gallery-viewer-stage {
    display: flex !important;
    width: 593.5px !important; /* Force exact Figma width */
    height: 593.5px !important; /* Force exact Figma height */
    min-width: 593.5px !important; /* Lock minimum size */
    max-width: 593.5px !important; /* Lock maximum size */
    flex: 0 0 593.5px !important; /* Prevent shrinking or growing on desktop */
    padding: 0 !important; /* Zero padding to match the seamless reference look */
    align-items: center !important; /* Center the image vertically */
    justify-content: center !important;
    gap: 0 !important;
    border-radius: 0px !important; /* Flat flat corners to match seamless floating jars */
    overflow: hidden !important;
    background: transparent !important; /* Seamless blending with white body background */
    border: none !important;
    box-sizing: border-box !important;
    position: relative !important;
    /* Prevent scrollbar here */
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
  }
  .tl-gallery-viewer-stage::-webkit-scrollbar {
    display: none !important;
  }
  .tl-gallery-viewer-item {
    width: 100% !important;
    height: 100% !important;
    align-items: center !important;
    justify-content: center !important;
    transition: opacity 0.4s ease !important;
    display: none; /* Inactive images will be hidden safely */
  }
  .tl-gallery-viewer-item.is-active {
    display: flex !important; /* Only active image will show as flex to center beautifully */
  }
  /* Make image fill the viewer cleanly */
  .tl-gallery-viewer-item img,
  .tl-gallery-viewer-item .product__media,
  .tl-gallery-main-img,
  .tl-gallery-main-video {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    display: block !important;
    border-radius: inherit !important;
  }
  /* 5. Navigation Arrows - Figma: Swatch / Navigation chevrons */
  .tl-gallery-arrow {
    display: none !important; /* Hide by default; shown by .tl-gallery--desktop-slider */
    background: none !important;
    border: none !important;
    width: 62px !important; /* matches thumbnail width for perfect vertical alignment */
    height: 32px !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    opacity: 0.6 !important;
    transition: all 0.2s ease-in-out !important;
    color: var(--tlColorSemantic1500, #1A1A1A) !important;
  }
  .tl-gallery-arrow:hover:not(.is-disabled) {
    opacity: 1 !important;
    transform: scale(1.1) !important;
  }
  .tl-gallery-arrow--prev {
    margin-bottom: 4px !important;
  }
  .tl-gallery-arrow--next {
    margin-top: 4px !important;
  }
  .tl-gallery-arrow.is-disabled {
    opacity: 0.15 !important;
    cursor: default !important;
    pointer-events: none !important;
  }
  .tl-gallery--desktop-slider .tl-gallery-arrow {
    display: flex !important;
  }
  /* 6. Play Badge Overlays */
  .tl-gallery-play-badge {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    min-height: 32px !important;
    border-radius: 50% !important;
    background: rgba(255, 255, 255, 0.92) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 2 !important;
    pointer-events: none !important;
  }
  .tl-gallery-play-badge svg {
    width: 12px !important;
    height: 12px !important;
    fill: #000 !important;
    margin-left: 2px !important;
  }
}
/* === MOBILE STYLES === */
@media screen and (max-width: 989px) {
  .tl-gallery-wrapper {
    position: relative !important;
    z-index: 10 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
    height: auto !important;
    padding: 0 var(--space_S, 16px) !important;
    width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    /* Prevent scrollbar here */
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
  }
  .tl-gallery-wrapper::-webkit-scrollbar {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
  }
  .tl-gallery-rail-section {
    order: -1 !important;
    /* Move Thumbnails ABOVE Image */
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    width: 100% !important;
    height: auto !important;
    position: relative !important;
    gap: 12px !important;
    box-sizing: border-box !important;
  }
  /* Force Horizontal scrolling list on mobile */
  .tl-gallery-thumbs-viewport {
    flex: 1 !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    margin: 0 !important;
    max-height: none !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    /* Hide scrollbar completely on mobile devices */
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
  }
  .tl-gallery-thumbs-viewport::-webkit-scrollbar {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
  }
  .tl-gallery-thumbs-list {
    display: flex !important;
    flex-direction: row !important;
    padding: 0 !important;
    margin: 0 !important;
    gap: 8px !important; /* Adjusted for 5 thumbnails on mobile */
  }
  .tl-gallery-thumb-item {
    width: 60.4px !important; /* Adjusted for 5 thumbnails on mobile */
    height: 66.4px !important; /* Adjusted for 5 thumbnails on mobile */
    flex-shrink: 0 !important;
    margin: 0 !important;
  }
  .tl-gallery-thumb-item:last-child {
    margin-right: 0 !important;
  }
}

@media screen and (max-width: 749px) {
  .tl-gallery-thumbs-list {
    gap: 6px !important; /* Adjusted for smaller mobile screens */
  }
  .tl-gallery-thumb-item {
    width: 66.4px !important; /* Adjusted for smaller mobile screens */
    height: 60.4px !important; /* Adjusted for smaller mobile screens */
  }
}
  /* Mobile Arrows: Disabled completely in favor of touch scroll */
  .tl-gallery-arrow {
    display: none !important;
  }
  .tl-gallery-viewer-stage {
    display: flex !important;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1/1 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    border-radius: 0px !important;
    overflow: hidden !important;
    background: transparent !important;
    border: none !important;
    position: relative !important;
    /* Hide scrollbar completely */
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
  }
  .tl-gallery-viewer-stage::-webkit-scrollbar {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
  }
  .tl-gallery-viewer-item {
    width: 100% !important;
    height: 100% !important;
    align-items: center !important;
    justify-content: center !important;
    display: none;
  }
  .tl-gallery-viewer-item.is-active {
    display: flex !important;
  }
  .tl-gallery-viewer-item img,
  .tl-gallery-main-img,
  .tl-gallery-main-video {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    display: block !important;
    border-radius: inherit !important;
  }
  .tl-gallery-thumb-btn {
    position: relative;
    width: 100% !important;
    height: 100% !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
  }
  .tl-gallery-play-badge {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    min-height: 32px !important;
    border-radius: 50% !important;
    background: rgba(255, 255, 255, 0.92) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 2 !important;
    pointer-events: none !important;
  }
  .tl-gallery-play-badge svg,
  .tl-gallery-play-badge .icon,
  .tl-gallery-play-badge .icon-play {
    width: 12px !important;
    height: 12px !important;
    max-width: 12px !important;
    max-height: 12px !important;
    display: block !important;
    flex: 0 0 12px !important;
  }
  .tl-gallery-thumb-btn img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
  }
}
@media screen and (min-width: 990px) {
  .product:not(.product--no-media) .product__media-wrapper {
    max-width: calc(100% - 449px - 4rem) !important;
    width: calc(100% - 449px - 4rem) !important;
    flex-grow: 1 !important;
  }
  .product:not(.product--no-media) .product__info-wrapper {
    max-width: 449px !important;
    width: 449px !important;
    flex: 0 0 449px !important;
    box-sizing: border-box !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 4rem !important;
  }
}
@media screen and (min-width: 750px) and (max-width: 989px) {
  .product__info-container {
    max-width: 449px !important;
    margin-inline: auto !important;
    width: 100% !important;
  }
}
.product__info-container {
  width: 100%;
  box-sizing: border-box;
}

.product__info-container .product__text {
  font-family: "sofia-pro", sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 18px !important;
  letter-spacing: 0.4px !important;
  text-transform: uppercase !important;
  color: var(--Colour-Brand-Grey70, #4d4d4d);
  margin-top: 0 !important;
  margin-bottom: var(--tl-space-sm) !important;
  display: block !important;
}
/* Deployment Test */
.product__info-container .product__title h1 {
  font-family: "sofia-pro", sans-serif !important;
  font-size: var(--tlTypographyH40SofiaFontSize, 40px) !important;
  font-weight: var(--tlTypographyH40SofiaFontWeight, 700) !important;
  line-height: var(--tlTypographyH40SofiaLineHeight, 46px) !important;
  letter-spacing: var(--tlTypographyH40SofiaLetterSpacing, -0.4px) !important;
  color: var(--Colour-Brand-Grey70, #4d4d4d) !important;
  margin: 0 !important;
  text-transform: none !important;
}

.product__info-container .price {
  margin-top: var(--tl-space-sm) !important;
  margin-bottom: var(--tl-space-sm) !important;
  display: block !important;
}
.product__info-container .price .price-item {
  font-family: sofia-pro, sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  line-height: 20px !important;
  letter-spacing: normal !important;
  color: var(--tl-color-text-primary) !important;
}
.product__info-container .price--on-sale .price-item--sale {
  color: var(--tl-color-error) !important;
}

.product__info-container .product__description {
  display: block !important;
  width: 100% !important;
  box-sizing: border-box !important;
  padding: 16px 0 24px 0 !important;
  margin: 0 !important;
  text-align: left !important;
  font-family: "sofia-pro", sans-serif !important;
  font-size: 14px !important;
  font-weight: 300 !important;
  line-height: 20px !important;
  letter-spacing: 0px !important;
  color: #4D4D4D !important;
}
.product__info-container .product__description p, .product__info-container .product__description span, .product__info-container .product__description div, .product__info-container .product__description li, .product__info-container .product__description strong, .product__info-container .product__description a {
  font-family: inherit !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  line-height: inherit !important;
  letter-spacing: inherit !important;
  color: inherit !important;
}

.product__description strong {
  font-weight: 700 !important;
}

.product__info-container .product__description strong{
  font-family: "sofia-pro" !important;
  font-weight: 700 !important;
}
.product__info-container .product__description p {
  margin-top: 0 !important;
  margin-bottom: 20px !important;
}

.trinny-product-features {
  width: 100% !important;
  box-sizing: border-box !important;
  margin-top: 16px !important;
  margin-bottom: 24px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  align-self: stretch !important;
  background-color: var(--Colour-Brand-Grey05, #f4f4f4) !important;
  border: 1px solid var(--Colour-Brand-Grey10, #e4e4e4) !important;
  border-radius: 0px !important;
  padding: var(--space_L, 24px) !important;
}
.trinny-product-features .feature-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  row-gap: var(--space_M, 20px) !important;
  column-gap: 16px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
@media screen and (max-width: 989px) {
  .trinny-product-features .feature-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    row-gap: var(--space_M, 20px) !important;
  }
}
.trinny-product-features .feature-item {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  min-height: auto !important;
  box-sizing: border-box !important;
}
.trinny-product-features .feature-label {
  font-family: "sofia-pro", sans-serif !important;
  font-size: var(--font-size-M, 14px) !important;
  font-style: normal !important;
  font-weight: 500 !important;
  line-height: var(--font-line-height-S, 16px) !important;
  letter-spacing: var(--font-letter-spacing-5XL, 0.4px) !important;
  text-transform: uppercase !important;
  color: var(--Colour-Brand-Grey70, #4D4D4D) !important;
  /* leading-trim: both !important; */
  /* text-edge: cap !important; */
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  margin-top: 0 !important;
  margin-bottom: 4px !important;
  display: block !important;
}
.trinny-product-features .feature-value {
  font-family: "sofia-pro", sans-serif !important;
  font-size: var(--font-size-M, 14px) !important;
  font-style: normal !important;
  font-weight: 300 !important;
  line-height: var(--font-line-height-L, 20px) !important;
  letter-spacing: var(--font-letter-spacing-2XL, 0) !important;
  color: var(--Colour-Brand-Grey70, #4D4D4D) !important;
  /* leading-trim: both !important; */
  /* text-edge: cap !important; */
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  margin: 0 !important;
  text-transform: none !important;
}
