/** Shopify CDN: Minification failed

Line 70:19 Unexpected "*"
Line 1019:0 Unexpected "}"
Line 3941:21 Unexpected "*"

**/


/* ============================================
   FONT OVERRIDES - Force Caelora typography
   ============================================ */
:root {
  --font-heading-family: 'roma', serif !important;
  --font-body-family: 'Manrope', sans-serif !important;
  --font-heading-weight: 400 !important;
  --font-body-weight: 400 !important;
}

* {
  font-family: 'Manrope', sans-serif;
}

h1, h2, h3, h4, h5, h6,
.h0, .h1, .h2, .h3, .h4, .h5,
.banner__heading,
.inline-richtext,
.rich-text__heading,
.image-banner h1,
.image-banner h2,
[class*="heading"],
.title {
  font-family: 'roma', serif !important;
}

.banner__heading.h0,
.banner__heading.inline-richtext.h0 {
  font-family: 'roma', serif !important;
  font-weight: 400 !important;
}

body, p, a, span, li, input, button, textarea, select,
.banner__text, .button, .subtitle {
  font-family: 'Manrope', sans-serif !important;
}
/* ============================================
   CAELORA-INSPIRED DARK LUXURY THEME FOR OUD DESIRE
   Fonts: Melodrama (display), Manrope (body)
   Palette: #0f0f0f backgrounds, #fff text, warm accents
   ============================================ */


/* ---- Custom Font: Melodrama-like serif display ---- */

/* ============ ROOT VARIABLES ============ */
:root {
  --color-bg-primary: #0f0f0f;
  --color-bg-secondary: #000000;
  --color-text-primary: #ffffff;
  --color-text-secondary: #b3b3b3;
  --color-accent: #c9a96e;
  --color-border: rgba(255,255,255,0.12);
  --font-display: 'Melodrama', 'Playfair Display', 'Times New Roman', serif;
  --font-body: 'Manrope', 'Helvetica Neue', sans-serif;
}

/* ============ GLOBAL OVERRIDES ============ */
body,
.shopify-section,
.section-template--*,
main#MainContent {
  background-color: var(--color-bg-primary) !important;
  color: var(--color-text-primary) !important;
  font-family: var(--font-body) !important;
}

h1, h2, h3, h4, h5, h6,
.h0, .h1, .h2, .h3, .h4, .h5,
.title, .banner__heading,
.rich-text__heading,
.collection-hero__title {
  font-family: var(--font-display) !important;
  color: var(--color-text-primary) !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 400;
}

p, span, a, li, label, input, textarea, select {
  font-family: var(--font-body) !important;
}

a {
  color: var(--color-text-primary) !important;
}

/* ============ HEADER / NAVIGATION ============ */
.header-wrapper,
.section-header,
header.header,
.shopify-section-header {
  background-color: var(--caelora-bg, #000) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3) !important;
  position: absolute !important;
  width: 100% !important;
  z-index: 100 !important;
}

.header-wrapper {
  border-bottom: none !important;
  background: var(--caelora-bg, #000) !important;
  background-color: var(--caelora-bg, #000) !important;
  position: relative !important;
  top: 0px;
  transition: top 0.35s ease, opacity 0.35s ease !important;
}

header.header {
  padding: 20px 40px !important;
}

.header__heading-logo-image,
.header__heading-logo {
  filter: brightness(0) invert(1) !important;
}

.header__heading-link {
  color: var(--color-text-primary) !important;
}

header a,
.header__menu-item,
.header__icon,
.header__icon span,
.header__active-menu-item {
  color: var(--color-text-primary) !important;
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
  text-decoration: none !important;
}

/* Force remove ALL underlines from nav links */
.header .link,
.header .link--text,
.header__menu-item.link,
.header__menu-item.link--text,
.header a.link,
.header a.link--text,
a.header__menu-item.link,
a.header__menu-item.link--text,
.header__menu-item:hover span,
details[open] > .header__menu-item {
  text-decoration: none !important;
  text-underline-offset: unset !important;
}

@media (min-width: 990px) {
/* Roll-up hover animation for nav links */
.header__menu-item.link {
  position: relative !important;
  overflow: hidden !important;
  display: inline-block !important;
  opacity: 1 !important;
}
.header__menu-item.link:hover {
  opacity: 1 !important;
}
.header__menu-item .nav-roll-original {
  display: inline-block !important;
  transition: transform 0.4s cubic-bezier(0.76, 0, 0.24, 1) !important;
  opacity: 1 !important;
}
.header__menu-item .nav-roll-clone {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  display: inline-block !important;
  transform: translateY(100%) !important;
  transition: transform 0.4s cubic-bezier(0.76, 0, 0.24, 1) !important;
  opacity: 1 !important;
}
.header__menu-item:hover .nav-roll-original {
  transform: translateY(-100%) !important;
}
.header__menu-item:hover .nav-roll-clone {
  transform: translateY(0) !important;
}
.header__menu-item:hover span,
.header__menu-item span,
.header__menu-item.link:hover span,
.header__menu-item.link--text:hover span,
.header__menu-item.link:hover .nav-roll-original,
.header__menu-item.link:hover .nav-roll-clone,
.header .list-menu__item:hover span,
a.header__menu-item:hover span {
  opacity: 1 !important;
  text-decoration: none !important;
  color: var(--color-text-primary) !important;
}
}

/* Ensure Dawn underline styles are overridden */
.header__menu-item:hover,
.header__menu-item:focus,
.header__menu-item.link--text:hover,
.header__menu-item.link--text:focus,
.header a:hover,
.header a:focus,
.header a[aria-current],
.list-menu__item--active,
.header__active-menu-item,
a.header__menu-item {
  text-decoration: none !important;
  text-underline-offset: unset !important;
}

.header__icon svg,
.header__icon path {
  fill: var(--color-text-primary) !important;
  stroke: var(--color-text-primary) !important;
}

/* Menu drawer dark */
.menu-drawer,
.menu-drawer__inner-container {
  background-color: var(--color-bg-primary) !important;
  color: var(--color-text-primary) !important;
}

/* ============ HERO / IMAGE BANNER ============ */
.banner,
.banner--medium,
.banner--large,
.banner--adapt,
.image-banner,
.shopify-section .banner {
  min-height: 100vh !important;
  position: relative;
}

.banner__box {
  background: transparent !important;
  text-align: center;
}

.banner__heading {
  font-family: var(--font-display) !important;
  font-size: clamp(3rem, 10vw, 9rem) !important;
  font-weight: 400 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: var(--color-text-primary) !important;
  line-height: 0.95 !important;
}

.banner__text,
.banner__text p {
  font-family: var(--font-body) !important;
  color: var(--color-text-secondary) !important;
  font-size: 15px !important;
  letter-spacing: 0.04em !important;
}

.banner .button,
.banner__buttons .button {
  background-color: transparent !important;
  border: 1px solid var(--color-text-primary) !important;
  color: var(--color-text-primary) !important;
  font-family: var(--font-body) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.15em !important;
  font-size: 12px !important;
  padding: 16px 40px !important;
  transition: all var(--caelora-btn-hover-speed, 0.3s) ease !important;
}

.banner .button:hover {
  background-color: var(--color-text-primary) !important;
  color: var(--color-bg-primary) !important;
}

/* ============ RICH TEXT SECTIONS ============ */
.rich-text,
.rich-text-section,
.section-rich-text {
  background-color: var(--color-bg-primary) !important;
  padding: 80px 20px !important;
}

.rich-text__heading {
  font-family: var(--font-display) !important;
  font-size: clamp(2rem, 5vw, 4.5rem) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  color: var(--color-text-primary) !important;
  text-align: center !important;
  font-weight: 400 !important;
}

.rich-text__text,
.rich-text__text p {
  color: var(--color-text-secondary) !important;
  font-family: var(--font-body) !important;
  font-size: 16px !important;
  max-width: 700px !important;
  margin: 0 auto !important;
  text-align: center !important;
  line-height: 1.8 !important;
}

/* ============ COLLECTION LIST / PRODUCT GRID ============ */
.collection-list,
.featured-collection,
.collection-list-wrapper,
.product-grid-container {
  background-color: var(--color-bg-secondary) !important;
  padding: 60px 0 !important;
}

.collection-list__item,
.collection-card,
.card-wrapper {
  background-color: var(--color-bg-secondary) !important;
  border: 1px solid var(--color-border) !important;
  overflow: hidden;
}

.card__heading,
.collection-card__title,
.card__heading a,
.full-unstyled-link {
  font-family: var(--font-display) !important;
  color: var(--color-text-primary) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  font-weight: 400 !important;
}

.card__information {
  background-color: var(--color-bg-secondary) !important;
}

.price,
.price-item {
  color: var(--color-text-primary) !important;
  font-family: var(--font-body) !important;
}

/* ============ IMAGE WITH TEXT ============ */
.image-with-text,
.image-with-text-section {
  background-color: var(--color-bg-primary) !important;
}

.image-with-text__content {
  background-color: var(--color-bg-primary) !important;
  color: var(--color-text-primary) !important;
}

/* ============ NEWSLETTER / EMAIL SIGNUP ============ */
.newsletter,
.newsletter-section {
  background-color: var(--color-bg-primary) !important;
  padding: 100px 20px !important;
}

.newsletter__heading {
  font-family: var(--font-display) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
}

.newsletter input[type="email"],
.field__input {
  background-color: transparent !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text-primary) !important;
  font-family: var(--font-body) !important;
  padding: 16px 20px !important;
}

.newsletter .button,
.newsletter-form__button {
  background-color: var(--color-text-primary) !important;
  color: var(--color-bg-primary) !important;
  font-family: var(--font-body) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.15em !important;
  font-size: 12px !important;
  font-weight: 600 !important;
}

/* ============ FOOTER ============ */
.footer,
.section-footer,
.footer-block,
.shopify-section-footer {
  background-color: var(--color-bg-primary) !important;
  color: var(--color-text-primary) !important;
  border-top: 1px solid var(--color-border) !important;
}

.footer__title,
.footer-block__heading {
  font-family: var(--font-body) !important;
  color: var(--color-text-secondary) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  font-size: 12px !important;
  font-weight: 400 !important;
}

.footer a,
.footer-block a,
.copyright a {
  color: var(--color-text-primary) !important;
  font-family: var(--font-display) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  font-size: 14px !important;
}

.footer .copyright,
.footer .copyright__content {
  color: var(--color-text-secondary) !important;
  font-family: var(--font-body) !important;
}

/* ============ BUTTONS GLOBAL ============ */
.button,
.shopify-challenge__button,
button[type="submit"] {
  font-family: var(--font-body) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  border-radius: 0 !important;
  font-weight: 500 !important;
}

.button--primary {
  background-color: var(--color-text-primary) !important;
  color: var(--color-bg-primary) !important;
}

.button--secondary {
  background-color: transparent !important;
  border: 1px solid var(--color-text-primary) !important;
  color: var(--color-text-primary) !important;
}

/* ============ PRODUCT PAGE ============ */
.product,
.product-section {
  background-color: var(--color-bg-primary) !important;
}

.product__title {
  font-family: var(--font-display) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
}

.product__description,
.product__description p {
  color: var(--color-text-secondary) !important;
}

/* ============ COLLECTION PAGE ============ */
.collection,
.collection-hero {
  background-color: var(--color-bg-primary) !important;
}

.collection-hero__title {
  font-family: var(--font-display) !important;
}

/* ============ BLOG ============ */
.blog-articles,
.article-card {
  background-color: var(--color-bg-primary) !important;
}

.article-card__title,
.article-card__title a {
  font-family: var(--font-display) !important;
  color: var(--color-text-primary) !important;
  text-transform: uppercase !important;
}

/* ============ MISC / GLOBAL ============ */
.color-scheme-1,
.color-background-1,
.gradient {
  background: var(--color-bg-primary) !important;
  color: var(--color-text-primary) !important;
}

.page-width {
  max-width: 1400px !important;
}

/* Remove default Shopify borders and shadows */
.card,
.card--media {
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

/* Smooth scrolling */
html {
  scroll-behavior: smooth;
}

/* Selection color */
::selection {
  background: var(--color-accent);
  color: var(--color-bg-primary);
}

/* Hide announcement bar for cleaner look */
.announcement-bar {
  display: none !important;
}

/* Scrollbar styling */
::-webkit-scrollbar {
  width: 6px;
}
::-webkit-scrollbar-track {
  background: var(--color-bg-primary);
}
::-webkit-scrollbar-thumb {
  background: #333;
  border-radius: 3px;
}

/* Featured blog dark */
.blog-articles__article,
.article-card-wrapper {
  background-color: var(--color-bg-primary) !important;
}

/* Cart drawer dark */
.cart-drawer,
.drawer {
  background-color: var(--color-bg-primary) !important;
  color: var(--color-text-primary) !important;
}

/* Password page dark */
.password-main,
.password-header,
.password-footer {
  background-color: var(--color-bg-primary) !important;
  color: var(--color-text-primary) !important;
}


/* ============================================
   CAELORA FOOTER - Luxury Dark Footer
   ============================================ */

.footer {
  background-color: #0f0f0f !important;
  color: var(--caelora-text, #fff) !important;
  border-top: 1px solid rgba(255,255,255,0.1) !important;
}

.footer-block--menu a,
.footer-block a {
  color: #b3b3b3 !important;
  text-decoration: none !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 14px !important;
  letter-spacing: 0.5px !important;
  transition: color var(--caelora-btn-hover-speed, 0.3s) ease !important;
}

.footer-block--menu a:hover,
.footer-block a:hover {
  color: var(--caelora-text, #fff) !important;
}

.footer-block__heading,
.footer h2,
.footer h3 {
  color: var(--caelora-text, #fff) !important;
  font-family: 'Manrope', sans-serif !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 2px !important;
  font-size: 13px !important;
  margin-bottom: 64px !important;
}

.footer .list-social__link {
  color: #b3b3b3 !important;
  transition: color var(--caelora-btn-hover-speed, 0.3s) ease !important;
}

.footer .list-social__link:hover {
  color: var(--caelora-text, #fff) !important;
}

.footer .list-social__link svg {
  width: 20px !important;
  height: 20px !important;
}

/* Footer copyright bar */
.footer__content-bottom {
  border-top: 1px solid rgba(255,255,255,0.1) !important;
  padding-top: 24px !important;
  margin-top: 40px !important;
}

.footer__content-bottom-wrapper {
  color: #666 !important;
  font-size: 12px !important;
  letter-spacing: 0.5px !important;
}

.footer__copyright a,
.footer__content-bottom a {
  color: #666 !important;
}

/* Large brand name at bottom of footer - Caelora signature style */
.footer::after {
  content: 'OUD DESIRE';
  display: block;
  width: 100%;
  text-align: center;
  font-family: 'roma', serif;
  font-size: clamp(48px, 10vw, 120px);
  font-weight: 400;
  color: rgba(255,255,255,0.05);
  letter-spacing: 10px;
  line-height: 1;
  padding: 40px 0 20px;
  margin-top: 20px;
  pointer-events: none;
}

/* Footer grid layout - make columns even */
.footer__blocks-wrapper {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) !important;
  gap: 40px !important;
}

/* Remove Shopify branding from footer if possible */
.footer__brand {
  display: none !important;
}

@media (max-width: 749px) {
  .footer::after {
    font-size: 36px !important;
    letter-spacing: 5px !important;
  }
  
  .footer__blocks-wrapper {
    grid-template-columns: 1fr !important;
    gap: 30px !important;
  }
}


/* ============================================
   CAELORA HEADER - Matching reference nav
   ============================================ */

/* Overall header container */


.header {
  background: transparent !important;
  border-bottom: none !important;
  padding: 0 40px !important;
  height: 64px !important;
  min-height: 64px !important;
  max-height: 64px !important;
  display: flex !important;
  align-items: center !important;
}

/* Sticky header when scrolled */
.shopify-section-header-sticky {
  background: rgba(15, 15, 15, 0.95) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

/* Hide the logo image, replace with text */
.header__heading-logo-wrapper,
.header__heading-logo,
.header__heading img {
  display: none !important;
}

.header__heading-link {
  text-decoration: none !important;
}




/* Navigation links */
.header__menu-item,
.header__menu-item span,
.list-menu__item {
  font-family: 'Manrope', sans-serif !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  color: var(--caelora-text, #fff) !important;
  text-transform: capitalize !important;
  letter-spacing: 0.5px !important;
  text-decoration: none !important;
  transition: opacity var(--caelora-btn-hover-speed, 0.3s) ease !important;
  padding: 8px 16px !important;
}

.header__menu-item:hover,
.header__menu-item:hover span {
  opacity: 0.7 !important;
  color: var(--caelora-text, #fff) !important;
}

/* Underline effect on hover like Caelora */
.header__menu-item {
  position: relative !important;
  overflow: clip !important;
  height: 21px !important;
  padding: 0 16px !important;
  display: flex !important;
  align-items: center !important;
}

.header__menu-item::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 16px !important;
  right: 16px !important;
  height: 1px !important;
  background: #ffffff !important;
  transform: scaleX(0) !important;
  transition: transform var(--caelora-btn-hover-speed, 0.3s) ease !important;
}

.header__menu-item:hover::after {
  transform: scaleX(1) !important;
}

/* Header icons (search, cart) */
.header__icon,
.header__icon .icon {
  color: var(--caelora-text, #fff) !important;
  width: 20px !important;
  height: 20px !important;
}

.header__icon:hover {
  opacity: 0.7 !important;
}

/* Cart count badge */
.cart-count-bubble {
  background: #ffffff !important;
  color: #0f0f0f !important;
  font-size: 10px !important;
}

/* Remove any header borders or separators */
.header__inline-menu {
  border: none !important;
}

/* Hide country/language selectors in header */
.header localization-form,
.header .disclosure {
  display: none !important;
}

/* Social icons in header */
.header .list-social {
  display: none !important;
}

/* Menu drawer styling */
.menu-drawer {
  background: #0f0f0f !important;
  color: var(--caelora-text, #fff) !important;
}

.menu-drawer a {
  color: var(--caelora-text, #fff) !important;
}

/* Log in link styling */
.header a[href*="customer_authentication"] {
  display: none !important;
}

@media (max-width: 989px) {
  .header {
    padding: 0 20px !important;
    height: 56px !important;
    min-height: 56px !important;
    max-height: 56px !important;
  }
  
}


/* Header layout - nav left, logo center, icons right */
.header.header--middle-center {
  display: grid !important;
  grid-template-columns: 1fr auto 1fr !important;
  align-items: center !important;
  width: 100% !important;
}

.header__inline-menu {
  justify-self: start !important;
}



.header__icons {
  justify-self: end !important;
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
}

/* Ensure search and cart icons are visible and properly styled */
.header__icon {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--caelora-text, #fff) !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
}

.header__icon svg,
.header__icon .icon {
  color: var(--caelora-text, #fff) !important;
  fill: none !important;
  stroke: #ffffff !important;
}

/* Hide the mobile menu drawer button on desktop */
@media (min-width: 990px) {
  header-drawer {
    display: none !important;
  }
}

/* Mobile: show hamburger, hide inline menu */
@media (max-width: 989px) {
  .header__inline-menu {
    display: none !important;
  }
  
  header-drawer {
    display: block !important;
  }
  
  .header.header--middle-center {
    grid-template-columns: auto 1fr auto !important;
  }
  
  header-drawer .header__icon {
    color: var(--caelora-text, #fff) !important;
  }
}


/* Force full-width header like Caelora */
.header.page-width {
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 40px !important;
  box-sizing: border-box !important;
}

.header.header--middle-center.page-width {
  display: grid !important;
  grid-template-columns: 1fr auto 1fr !important;
}

.section-header .header-wrapper {
  max-width: 100% !important;
}


/* ============================================
   CAELORA NAV - White lines + scroll behavior
   ============================================ */

/* White horizontal lines extending from logo */




/* Sticky header - slides up on scroll down, slides back on scroll up */
.shopify-section-group-header-group.section-header,
.shopify-section-group-header-group {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 1000 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}





/* Ensure hero sits below the fixed header properly */
main .shopify-section:first-child .banner {
  padding-top: 0 !important;
}

/* When scrolled, add a subtle dark bg to header */
.shopify-section-group-header-group.header-scrolled .header {
  background: rgba(15, 15, 15, 0.92) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
}

/* Section header positioning handled by header group selector */











/* Header scroll hide/show via position:relative + top */
.header-wrapper {
  position: relative !important;
  top: 0px;
  transition: top 0.35s ease, opacity 0.35s ease !important;
}

.header__heading {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0 !important;
  margin: 0 !important;
  line-height: 1 !important;
  border-left: 1px solid rgba(255, 255, 255, 0.5) !important;
  border-right: 1px solid rgba(255, 255, 255, 0.5) !important;
  padding: 0 40px !important;
  align-self: stretch !important;
}






/* ===== HERO BANNER ANIMATIONS ===== */

.banner {
  position: relative !important;
}

/* DESIRE overlay text - with specificity chain to override Shopify app font */
.desire-hero-text,
.desire-hero-text:not(.fa):not([class*="pe-"]):not(.lni):not(i[class*="iccl-"]):not(i[class*="la"]):not(i[class*="fa"]):not(.jdgm-star) {
  position: absolute !important;
  bottom: 13% !important;
  top: auto !important;
  left: 0 !important;
  right: 0 !important;
  text-align: center !important;
  font-family: "Melodrama", sans-serif !important;
  font-size: 21vw !important;
  font-weight: 400 !important;
  color: var(--caelora-text, #fff) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  line-height: 0.8 !important;
  z-index: 3 !important;
  pointer-events: none !important;
  white-space: nowrap !important;
  transform: scale(0.08);
  opacity: 0;
}

.desire-hero-text.animate-in {
  animation: heroScaleIn var(--caelora-hero-zoom-speed, 2.08s) cubic-bezier(0.16, 1, 0.3, 1) forwards !important;
}

@keyframes heroScaleIn {
  0% { transform: scale(0.08); opacity: 1; }
  100% { transform: scale(1); opacity: 1; }
}

}

}

/* Hide existing banner heading */
.banner .banner__heading {
  display: none !important;
}

/* Content to bottom-left */


/* Subtitle fade-up */
.banner__text.rte {
  opacity: 0;
  font-size: 13px !important;
  letter-spacing: 1px !important;
  max-width: 280px !important;
  text-align: left !important;
}

.banner__text.rte.animate-in {
  animation: slideUpIn var(--caelora-hero-text-speed, 1.3s) cubic-bezier(0.16, 1, 0.3, 1) forwards !important;
}

/* Hide button */
.banner__buttons {
  display: none !important;
}

@keyframes slideUpIn {
  0% {
    margin-top: 40px;
    opacity: 0;
  }
  30% {
    opacity: 1;
  }
  100% {
    margin-top: 0;
    opacity: 1;
  }
}


/* Bottom-right description text */
.desire-hero-desc,
.desire-hero-desc:not(.fa):not([class*="pe-"]):not(.lni):not(i[class*="iccl-"]):not(i[class*="la"]):not(i[class*="fa"]):not(.jdgm-star) {
  position: absolute !important;
  bottom: 40px !important;
  right: 40px !important;
  text-align: right !important;
  font-family: "Manrope", Georgia, serif !important;
  font-size: 20px !important;
  font-weight: 400 !important;
  color: var(--caelora-text, #fff) !important;
  letter-spacing: 0.5px !important;
  line-height: 1.3 !important;
  z-index: 3 !important;
  max-width: 320px !important;
  text-transform: none !important;
  opacity: 0;
}

.desire-hero-desc.animate-in {
  animation: slideUpIn var(--caelora-hero-text-speed, 1.04s) cubic-bezier(0.25, 0.1, 0.25, 1) forwards !important;
}

/* Bottom-left subtitle text */
.desire-hero-subtitle,
.desire-hero-subtitle:not(.fa):not([class*="pe-"]):not(.lni):not(i[class*="iccl-"]):not(i[class*="la"]):not(i[class*="fa"]):not(.jdgm-star) {
  position: absolute !important;
  bottom: 40px !important;
  left: 40px !important;
  text-align: left !important;
  font-family: "Manrope", Georgia, serif !important;
  font-size: 20px !important;
  font-weight: 400 !important;
  color: var(--caelora-text, #fff) !important;
  letter-spacing: 0.5px !important;
  line-height: 1.3 !important;
  z-index: 3 !important;
  max-width: 280px !important;
  text-transform: none !important;
  opacity: 0;
}

.desire-hero-subtitle.animate-in {
  animation: slideUpIn var(--caelora-hero-text-speed, 1.04s) cubic-bezier(0.25, 0.1, 0.25, 1) forwards !important;
}

/* Hide banner box and content - using section ID for specificity */
#shopify-section-template--27511469408522__hero_banner .banner__box,
#shopify-section-template--27511469408522__hero_banner .banner__content {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
}

/* Header nav title case */
.header__menu-item,
.header__menu-item span,
.header__inline-menu .header__menu-item,
.list-menu__item {
  text-transform: capitalize !important;
}
/* Solid black header - high specificity */
.shopify-section-group-header-group .header-wrapper,
.section-header .header-wrapper,
header.header-wrapper,
.header-wrapper {
  background: var(--caelora-bg, #000) !important;
  background-color: var(--caelora-bg, #000) !important;
}

/* Cart text styling */
.cart-text-label,
.cart-text-label:not(.fa):not([class*="pe-"]):not(.lni):not(i[class*="iccl-"]):not(i[class*="la"]):not(i[class*="fa"]):not(.jdgm-star) {
  font-family: "Manrope", Georgia, serif !important;
  font-size: 14px !important;
  color: var(--caelora-text, #fff) !important;
  letter-spacing: 0.5px !important;
  white-space: nowrap !important;
  text-transform: none !important;
}

/* Hide search icon */
.header__icon--search {
  display: none !important;
}

/* Fix cart icon area */
.header__icon--cart svg,
.header__icon--cart .icon-cart {
  display: none !important;
}

/* Cart link override */
.header__icon--cart {
  text-transform: none !important;
}


/* Hide Shopify default nav underline */
.header__menu-item::after {
  display: none !important;
}

/* ===== NAV LINK ROLLING HOVER ===== */
.header__menu-item {
  position: relative !important;
}

/* The span inside menu item acts as clip container */
.header__menu-item > span {
  display: block !important;
  overflow: clip !important;
  height: 21px !important;
  padding: 0 !important;
  box-sizing: content-box !important;
}

.header__menu-item .nav-roll-wrapper {
  display: flex !important;
  flex-direction: column !important;
  transition: transform 0.35s cubic-bezier(0.65, 0, 0.35, 1) !important;
}

.header__menu-item:hover .nav-roll-wrapper {
  transform: translateY(-50%) !important;
}

.header__menu-item .nav-roll-text {
  display: block !important;
  line-height: 1 !important;
  padding: 4px 0 !important;
  height: 21px !important;
  box-sizing: border-box !important;
}


/* ===== LIFESTYLE IMAGE SECTION ===== */
.desire-lifestyle-image {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  background-color: var(--caelora-bg, #000) !important;
  padding: 80px 0 !important;
  width: 100% !important;
  opacity: 0 !important;
  transform: scale(0.95) !important;
  transition: opacity var(--caelora-scroll-speed, 1.04s) ease, transform var(--caelora-scroll-speed, 1.04s) cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.desire-lifestyle-image.animate-visible {
  opacity: 1 !important;
  transform: scale(1) !important;
}

.desire-lifestyle-image img {
  display: block !important;
  max-width: 38% !important;
  height: auto !important;
  object-fit: contain !important;
}

@media (max-width: 749px) {
  .desire-lifestyle-image img {
    max-width: 70% !important;
  }
  .desire-lifestyle-image {
    padding: 50px 0 !important;
  }
}

/* Remove any default section padding from custom-liquid containing lifestyle image */
.desire-lifestyle-image-wrapper .section-template--27511469408522__lifestyle_image-padding,
section:has(.desire-lifestyle-image) {
  background-color: #111111 !important;
  padding: 0 !important;
  margin: 0 !important;
}


/* ===== CAELORA-STYLE COLLECTION GRID ===== */
/* ========== COLLECTION GRID (Full-bleed images + hover overlay) ========== */
.desire-collection-heading {
  background-color: #0f0f0f !important;
  padding: 60px 40px 40px !important;
  border-top: 2px solid rgba(255, 255, 255, 0.45) !important;
}

.desire-collection-heading h2 {
  font-family: "Melodrama", sans-serif !important;
  font-size: clamp(36px, 5vw, 64px) !important;
  font-weight: 400 !important;
  color: var(--caelora-text, #fff) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  line-height: 1.1 !important;
  margin: 0 !important;
}

.desire-product-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 0 !important;
  width: 100% !important;
  background-color: #0f0f0f !important;
  border-top: 2px solid rgba(255, 255, 255, 0.45) !important;
}

.desire-product-cell {
  position: relative !important;
  display: block !important;
  overflow: hidden !important;
  aspect-ratio: 3 / 4 !important;
  border-right: 2px solid rgba(255, 255, 255, 0.45) !important;
  border-bottom: 2px solid rgba(255, 255, 255, 0.45) !important;
  text-decoration: none !important;
  cursor: pointer !important;
  background-color: #1a1a1a !important;
}

.desire-product-cell:nth-child(3n) {
  border-right: none !important;
}

.desire-product-cell img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.4s ease !important;
}

.desire-product-cell:hover img {
  transform: scale(1.05) !important;
  opacity: 0.3 !important;
}

.desire-product-overlay {
  position: absolute !important;
  inset: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  padding: 40px !important;
  opacity: 0 !important;
  transition: opacity 0.4s ease !important;
  z-index: 2 !important;
  pointer-events: none !important;
}

.desire-product-cell:hover .desire-product-overlay {
  opacity: 1 !important;
}

.desire-product-overlay h3 {
  font-family: "Melodrama", sans-serif !important;
  font-size: clamp(22px, 2.5vw, 32px) !important;
  font-weight: 400 !important;
  color: var(--caelora-text, #fff) !important;
  letter-spacing: 0 !important;
  margin: 0 0 12px 0 !important;
  line-height: 1.2 !important;
}

.desire-product-overlay p {
  font-family: "Manrope", serif !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  color: rgba(255, 255, 255, 0.8) !important;
  line-height: 1.5 !important;
  margin: 0 !important;
  letter-spacing: 0.01em !important;
}

.desire-see-all-cell {
  grid-column: 1 / -1 !important;
  aspect-ratio: auto !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 32px 40px !important;
  background-color: #0f0f0f !important;
  text-decoration: none !important;
  border-right: none !important;
  border-bottom: none !important;
  border-top: 2px solid rgba(255, 255, 255, 0.45) !important;
  transition: background-color var(--caelora-btn-hover-speed, 0.3s) ease !important;
  min-height: auto !important;
  height: auto !important;
  overflow: visible !important;
}

.desire-see-all-cell:hover {
  background-color: #1a1a1a !important;
}

.desire-see-all-cell span {
  font-family: "Melodrama", sans-serif !important;
  font-size: clamp(20px, 2.5vw, 32px) !important;
  font-weight: 400 !important;
  color: var(--caelora-text, #fff) !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
}

.desire-see-all-arrow {
  font-size: clamp(24px, 2.5vw, 36px) !important;
  transition: transform var(--caelora-btn-hover-speed, 0.3s) ease !important;
}

.desire-see-all-cell:hover .desire-see-all-arrow {
  transform: translateX(8px) !important;
}


@media (max-width: 749px) {
  .desire-product-grid {
    grid-template-columns: 1fr !important;
  }
  .desire-product-cell {
    border-right: none !important;
  }
  .desire-product-overlay {
    padding: 24px !important;
  }
  .desire-collection-heading {
    padding: 40px 20px 30px !important;
  }
  .desire-see-all-cell {
    aspect-ratio: auto !important;
    min-height: 150px !important;
  }
}

@media (min-width: 750px) and (max-width: 989px) {
  .desire-product-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .desire-product-cell:nth-child(2n) {
    border-right: none !important;
  }
  .desire-product-cell:nth-child(3n) {
    border-right: 2px solid rgba(255, 255, 255, 0.45) !important;
  }
}

/* ========== BRAND STATEMENT LEARN MORE BUTTON ========== */
#shopify-section-template--27511469408522__brand_statement .button--secondary {
  font-family: "Melodrama", sans-serif !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  color: var(--caelora-text, #fff) !important;
  background: transparent !important;
  border: 1.5px solid rgba(255, 255, 255, 0.5) !important;
  border-radius: 0 !important;
  padding: 16px 48px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  transition: all var(--caelora-btn-hover-speed, 0.3s) ease !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 12px !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  min-width: auto !important;
  min-height: auto !important;
}

#shopify-section-template--27511469408522__brand_statement .button--secondary::after {
  content: "\2192" !important;
  font-size: 18px !important;
  display: inline !important;
  position: static !important;
  margin-left: 8px !important;
  transition: transform var(--caelora-btn-hover-speed, 0.3s) ease !important;
}

#shopify-section-template--27511469408522__brand_statement .button--secondary:hover {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255, 255, 255, 0.8) !important;
  color: var(--caelora-text, #fff) !important;
}

#shopify-section-template--27511469408522__brand_statement .button--secondary:hover::after {
  transform: translateX(4px) !important;
}


/* ========== VIDEO BANNER (Caelora-style: text flanking centred video) ========== */
.desire-video-banner {
  position: relative !important;
  width: 100% !important;
  background-color: #0f0f0f !important;
  padding: 0 !important;
  overflow: hidden !important;
  opacity: 0 !important;
  transform: scale(0.5) !important;
  transition: opacity 2.34s ease, transform 2.34s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.desire-video-banner.animate-visible {
  opacity: 1 !important;
  transform: scale(1) !important;
}

.desire-video-layout {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 100vh !important;
  padding: 40px !important;
  gap: 0 !important;
  background-color: #0f0f0f !important;
  box-sizing: border-box !important;
}

.desire-video-side-text {
  font-family: "Melodrama", sans-serif !important;
  font-size: clamp(16px, 2vw, 28px) !important;
  font-weight: 400 !important;
  color: var(--caelora-text, #fff) !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
  flex: 1 !important;
  text-align: center !important;
}

.desire-video-frame {
  position: relative !important;
  width: 45% !important;
  height: calc(100vh - 80px) !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
  border: 2px solid rgba(255, 255, 255, 0.45) !important;
  background: var(--caelora-bg, #000) !important;
}

.desire-video-frame video {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: contain !important;
}

/* Sound toggle button */
.desire-video-sound-btn {
  position: absolute !important;
  bottom: 16px !important;
  right: 16px !important;
  z-index: 3 !important;
  background: rgba(0, 0, 0, 0.5) !important;
  border: 1.5px solid rgba(255, 255, 255, 0.4) !important;
  border-radius: 50% !important;
  width: 44px !important;
  height: 44px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  transition: background 0.3s ease, border-color 0.3s ease !important;
  padding: 0 !important;
}
.desire-video-sound-btn:hover {
  background: rgba(255, 255, 255, 0.15) !important;
  border-color: rgba(255, 255, 255, 0.7) !important;
}

/* Mobile adjustments */
@media (max-width: 749px) {
  .desire-video-layout {
    flex-direction: column !important;
    padding: 20px !important;
    gap: 16px !important;
  }
  .desire-video-frame {
    height: auto !important;
    width: 90% !important;
    max-height: calc(100vh - 140px) !important;
    order: 1 !important;
  }
  .desire-video-frame video {
    width: 100% !important;
    height: auto !important;
  }
  .desire-video-side-text {
    font-size: 16px !important;
  }
  .desire-video-side-text:first-child { order: 0 !important; }
  .desire-video-side-text:last-child { order: 2 !important; }
}


/* ========== HERO BANNER LOAD SCALE ANIMATION (Caelora-style) ========== */
.hero-banner-scale {
  overflow: hidden !important;
}

.hero-banner-scale .banner__media img,
.hero-banner-scale .banner__media video {
  transform: scale(1.6) !important;
  transition: transform 3.25s cubic-bezier(0.16, 1, 0.3, 1) !important;
  will-change: transform !important;
}

.hero-banner-scale.hero-loaded .banner__media img,
.hero-banner-scale.hero-loaded .banner__media video {
  transform: scale(1) !important;
}


/* Force black background on lifestyle section wrapper */
#shopify-section-template--27511469408522__lifestyle_image,
#shopify-section-template--27511469408522__lifestyle_image .color-scheme-1 {
  background-color: var(--caelora-bg, #000) !important;
}


/* ========== HERO TEXT SYNCHRONIZED LOAD ANIMATION ========== */
.desire-hero-text,
.desire-hero-subtitle,
.desire-hero-desc {
  opacity: 0 !important;
  transform: translateY(30px) !important;
  animation: none !important;
  transition: opacity 1.82s cubic-bezier(0.16, 1, 0.3, 1), transform 1.82s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.hero-loaded .desire-hero-text,
.hero-loaded .desire-hero-subtitle,
.hero-loaded .desire-hero-desc {
  opacity: 1 !important;
  transform: translateY(0) !important;
}


/* ========== DAWN THEME OVERRIDES ========== */

/* Hide default banner heading/subheading/button when custom hero text is present */
.caelora-hero-wrapper .banner__content h2,
.caelora-hero-wrapper .banner__content .banner__heading,
.caelora-hero-wrapper .banner__content p:not(.banner__buttons) {
  display: none !important;
}
/* Position the button at bottom center of hero */
.caelora-hero-wrapper .banner__content {
  position: absolute !important;
  bottom: 60px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  z-index: 5 !important;
  display: flex !important;
  justify-content: center !important;
  width: auto !important;
  padding: 0 !important;
}
.caelora-hero-wrapper .banner__buttons .button {
  border: 1px solid var(--caelora-border-color, #fff) !important;
  color: var(--caelora-text, #fff) !important;
  background: transparent !important;
  padding: 12px 40px !important;
  font-family: "Cormorant", "Cormorant Garamond", serif !important;
  font-size: 15px !important;
  letter-spacing: var(--caelora-nav-letter-spacing, 3px) !important;
  text-transform: uppercase !important;
}

/* Header: transparent/black background, fix logo overlap */
.header-wrapper {
  background-color: var(--caelora-bg, #000) !important;
  border-bottom: none !important;
}
.header {
  background-color: transparent !important;
  padding: 15px 40px !important;
}
/* Hide the announcement bar text / secondary logo if present */
.header__heading-link {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
/* Style the header heading text */
.header h1,
.header .header__heading a {
  color: var(--caelora-text, #fff) !important;
  font-family: 'Cormorant', 'Cormorant Garamond', serif !important;
  font-size: 14px !important;
  letter-spacing: var(--caelora-nav-letter-spacing, 3px) !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
}
/* Navigation links */
.header__inline-menu .header__menu-item,
.header__inline-menu a,
.list-menu__item {
  color: var(--caelora-text, #fff) !important;
  font-family: 'Cormorant', 'Cormorant Garamond', serif !important;
  font-size: 12px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
}
/* Header icons (cart, search) */
.header__icon,
.header__icon svg,
.header .icon {
  color: var(--caelora-text, #fff) !important;
  fill: #FFFFFF !important;
}

/* Make header sticky and transparent over hero */
.section-header {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 1000 !important;
  background: transparent !important;
  border: none !important;
}
.header-wrapper {
  background: rgba(0,0,0,0.3) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}
/* Push content below fixed header */
main#MainContent {
  padding-top: 0 !important;
}
.shopify-section-group-header-group + main {
  margin-top: 0 !important;
}

/* Product card backgrounds - force dark */
.card-wrapper,
.card,
.card--card,
.card--standard,
.card__inner,
.product-card-wrapper {
  background-color: var(--caelora-bg, #000) !important;
  border: none !important;
}
.card__content,
.card__information {
  background-color: var(--caelora-bg, #000) !important;
}
.card__heading,
.card__heading a,
.card-information__text,
.price,
.price__regular,
.price-item {
  color: var(--caelora-text, #fff) !important;
}
/* Product card image background */
.card .media,
.card__media {
  background-color: #1a1a1a !important;
}

/* Remove Dawn section padding */
.section-template--index {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
.page-width {
  max-width: 100% !important;
  padding: 0 40px !important;
}

/* Collection section title */
.collection .title,
.title-wrapper-with-link .title,
h2.title {
  color: var(--caelora-text, #fff) !important;
  font-family: 'Cormorant', 'Cormorant Garamond', serif !important;
}

/* Video section full width */
.caelora-video-section {
  width: 100vw !important;
  margin-left: calc(-50vw + 50%) !important;
}

/* Newsletter / email signup */
.newsletter-form__field-wrapper input {
  background-color: transparent !important;
  border-color: var(--caelora-text, #fff) !important;
  color: var(--caelora-text, #fff) !important;
}
.newsletter-form__button {
  color: var(--caelora-text, #fff) !important;
}

/* Footer dark */
.footer,
.section-footer {
  background-color: var(--caelora-bg, #000) !important;
  color: var(--caelora-text, #fff) !important;
}
.footer a,
.footer__content-bottom a {
  color: var(--caelora-text, #fff) !important;
}

/* Remove Dawn default borders and dividers */
.content-container--full-width,
.grid__item,
.collection-product-card {
  border: none !important;
}

/* Fix rich text / brand statement section */
.rich-text {
  background-color: var(--caelora-bg, #000) !important;
}
.rich-text .rich-text__text,
.rich-text .rich-text__heading,
.rich-text p,
.rich-text h2 {
  color: var(--caelora-text, #fff) !important;
}
.rich-text .button {
  color: var(--caelora-text, #fff) !important;
  border-color: var(--caelora-text, #fff) !important;
  background-color: transparent !important;
}

/* Global body background */
body,
.shopify-section {
  background-color: var(--caelora-bg, #000) !important;
}


/* ========== HEADER FIX - SINGLE LINE ========== */
.header__heading-link {
  font-size: 11px !important;
  letter-spacing: 4px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  max-width: 400px !important;
}
/* Hide utility/announcement bar */
.utility-bar,
.announcement-bar,
[class*="announcement"] {
  display: none !important;
}
/* Ensure header stays on one line */
.header__heading {
  flex-shrink: 0 !important;
  max-width: 400px !important;
}


/* ========== HEADER MIDDLE-CENTER LAYOUT FIX ========== */
/* Override the truncation - heading now centered */
.header__heading-link {
  font-size: 13px !important;
  letter-spacing: 5px !important;
  white-space: nowrap !important;
  overflow: visible !important;
  text-overflow: unset !important;
  max-width: none !important;
}
.header__heading {
  flex-shrink: 0 !important;
  max-width: none !important;
  text-align: center !important;
}
/* Remove Dawn's header borders */
.header-wrapper--border-bottom {
  border-bottom: none !important;
}
/* Cart icon color */
.header__icon .icon-caret,
cart-notification {
  color: var(--caelora-text, #fff) !important;
}
/* Ensure logo position center works with dark theme */
.header--middle-center .header__heading {
  order: 0 !important;
}


/* ========== FOOTER DARK STYLING ========== */
.footer {
  background-color: var(--caelora-bg, #000) !important;
  color: var(--caelora-text, #fff) !important;
  border-top: 1px solid rgba(255,255,255,0.1) !important;
}
.footer a,
.footer .footer__content-bottom a,
.footer h2,
.footer .footer-block__heading,
.footer .list-social__link {
  color: var(--caelora-text, #fff) !important;
}
.footer .list-social__link svg {
  fill: #FFFFFF !important;
}
/* Footer copyright area */
.footer__content-bottom {
  border-top: 1px solid rgba(255,255,255,0.1) !important;
  color: rgba(255,255,255,0.5) !important;
}
.footer__content-bottom a {
  color: rgba(255,255,255,0.5) !important;
}
/* Remove payment icons if present */
.footer__payment {
  display: none !important;
}

/* ========== SCROLL ANIMATION FIX FOR DAWN ========== */
/* Ensure lifestyle section gets the fade animation class */
.caelora-lifestyle-section .desire-lifestyle-image {
  opacity: 0;
  transform: translateY(var(--caelora-scroll-distance, 40px));
  transition: opacity var(--caelora-scroll-speed, 1.04s) ease, transform var(--caelora-scroll-speed, 1.04s) ease;
}
.caelora-lifestyle-section .desire-lifestyle-image.visible {
  opacity: 1;
  transform: translateY(0);
}




/* ========== HERO BUTTON POSITION FIX ========== */
.caelora-hero-wrapper .banner__content {
  bottom: 45px !important;
  top: auto !important;
  right: auto !important;
  align-items: center !important;
  height: auto !important;
  min-height: unset !important;
}

/* FONT ASSIGNMENTS - MELODRAMA EVERYWHERE */
:root {
  --font-body-family: "Melodrama", serif !important;
  --font-heading-family: "Melodrama", serif !important;
  --font-display-family: "Melodrama", serif !important;
  --font-manrope: "Manrope", sans-serif;
  --font-melodrama: "Melodrama", serif;
  --font-cormorant: "Cormorant", "Cormorant Garamond", serif;
}
body, p, span, a, li, input, textarea, select, button {
  font-family: "Melodrama", serif !important;
}
h1, h2, h3, h4, h5, h6, .rich-text h2, .rich-text .rich-text__heading {
  font-family: "Melodrama", serif !important;
}
.header__heading-link, .header__inline-menu .header__menu-item, .header__inline-menu a, .list-menu__item {
  font-family: "Melodrama", serif !important;
}
.desire-hero-text, .desire-hero-subtitle, .desire-hero-desc {
  font-family: "Melodrama", serif !important;
}
.footer::after {
  font-family: "Melodrama", serif !important;
}
.font--melodrama { font-family: "Melodrama", serif !important; }
.font--manrope { font-family: "Manrope", sans-serif !important; }
.font--cormorant { font-family: "Cormorant", "Cormorant Garamond", serif !important; }

/* CUSTOMER REVIEWS SECTION */
.reviews-section { background: #000; padding: 80px 0; overflow: hidden; }
.reviews-header { position: relative; background: transparent !important; text-align: center; margin-bottom: 60px; }
.reviews-header h2, .reviews-title { font-size: clamp(2rem, 4vw, 3.5rem); color: #fff; letter-spacing: 0.15em; text-transform: uppercase; margin: 0; }
.reviews-subhead { font-size: 1rem; color: rgba(255,255,255,0.5); letter-spacing: 0.3em; text-transform: uppercase; margin-bottom: 16px; }
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; max-width: 1600px; margin: 0 auto; padding: 0 40px; }
.review-card { background: #0a0a0a; border: 1px solid rgba(255,255,255,0.08); padding: 48px 40px; display: flex; flex-direction: column; justify-content: space-between; min-height: 320px; transition: border-color 0.4s ease; }
.review-card:hover { border-color: rgba(255,255,255,0.2); }
.review-stars { color: #fff; font-size: 14px; letter-spacing: 6px; margin-bottom: 24px; }
.review-quote { font-size: 18px !important; color: rgba(255,255,255,0.85); font-size: 1.1rem; line-height: 1.8; font-style: italic; flex: 1; margin-bottom: 32px; }
.review-author { border-top: 1px solid rgba(255,255,255,0.1); padding-top: 20px; }
.review-author-name { color: #fff; font-size: 0.9rem; letter-spacing: 0.15em; text-transform: uppercase; margin: 0 0 4px 0; }
.review-author-detail { color: rgba(255,255,255,0.4); font-size: 0.8rem; letter-spacing: 0.1em; margin: 0; }
.review-verified { display: inline-block; color: rgba(255,255,255,0.3); font-size: 0.7rem; letter-spacing: 0.15em; text-transform: uppercase; margin-top: 8px; }
@media (max-width: 990px) { .reviews-grid { grid-template-columns: 1fr; padding: 0 20px; } .review-card { min-height: auto; } }

/* LIFESTYLE + NEWSLETTER OVERLAY (Caelora style) */
.lifestyle-newsletter-wrapper {
  position: relative;
  background: #000;
}
.lifestyle-sticky-image {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  z-index: 1;
}
.lifestyle-sticky-image .lifestyle-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(100%);
}
.lifestyle-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, #1a1a1a 0%, #000 100%);
}
.newsletter-overlay-panel {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: center;
  pointer-events: none;
  margin-top: -40vh;
}
.newsletter-overlay-inner {
  background: #ffffff;
  color: #000;
  width: 65%;
  max-width: 900px;
  padding: 80px 60px 60px;
  pointer-events: all;
}
.newsletter-overlay-heading {
  font-size: clamp(3rem, 8vw, 7rem) !important;
  line-height: 1.05 !important;
  color: #000 !important;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  margin: 0 0 60px 0;
  text-align: center;
}
.newsletter-overlay-form {
  margin: 0;
}
.newsletter-overlay-input-row {
  display: flex;
  gap: 0;
  align-items: stretch;
}
.newsletter-overlay-email {
  flex: 1;
  background: transparent !important;
  border: 1px solid #ccc !important;
  border-right: none !important;
  padding: 16px 20px !important;
  font-size: 1rem !important;
  color: #000 !important;
  outline: none;
  letter-spacing: 0.05em;
}
.newsletter-overlay-email::placeholder {
  color: #999 !important;
}
.newsletter-overlay-btn {
  background: var(--caelora-bg, #000) !important;
  color: var(--caelora-text, #fff) !important;
  border: 1px solid #000 !important;
  padding: 16px 32px !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase;
  cursor: pointer;
  transition: opacity var(--caelora-btn-hover-speed, 0.3s) ease;
  white-space: nowrap;
}
.newsletter-overlay-btn:hover {
  opacity: 0.8;
}
.newsletter-overlay-subtext {
  margin-top: 16px;
  font-size: 0.85rem !important;
  color: #666 !important;
  letter-spacing: 0.03em;
}
@media (max-width: 990px) {
  .newsletter-overlay-inner {
    width: 90%;
    padding: 48px 28px 36px;
  }
  .newsletter-overlay-heading {
    font-size: clamp(2rem, 10vw, 4rem) !important;
  }
}


/* === BATCH OVERRIDES === */

/* 1. Header logo + nav fonts → Melodrama */
.header h1 a,
.header .header__heading a,
.header .header__heading-link,
.header__heading-link {
  font-family: "Melodrama", serif !important;
}

/* 2. Lifestyle image section - double top padding */
.desire-lifestyle-image {
  padding: 160px 0 80px !important;
}

/* 3. Brand statement - 4x padding below Learn More */
[id*="brand_statement"] .rich-text.content-container,
[id*="brand_statement"] .rich-text__wrapper {
  padding-bottom: 160px !important;
}

/* 4. Collection heading - massive like reference */
.desire-collection-heading h2,
.desire-collection-heading {
  font-size: clamp(6rem, 12vw, 14rem) !important;
  line-height: 1.05 !important;
  text-transform: none !important;
}


/* === CAELORA-STYLE FOOTER === */
.caelora-footer { background: #111 !important; color: var(--caelora-text, #fff) !important; padding: 80px 60px 0 !important; font-family: "Melodrama", serif !important; }
.caelora-footer-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 40px; max-width: 1600px; margin: 0 auto; padding-bottom: 80px; }
.caelora-footer-col h4 { font-family: "Melodrama", serif !important; font-size: 16px !important; font-weight: 400 !important; color: rgba(255,255,255,0.5) !important; margin-bottom: 24px !important; text-transform: none !important; letter-spacing: 0 !important; }
.caelora-footer-col a, .caelora-footer-col p { font-family: "Melodrama", serif !important; font-size: 18px !important; color: var(--caelora-text, #fff) !important; text-decoration: none !important; display: block !important; margin-bottom: 12px !important; text-transform: uppercase !important; letter-spacing: 0.08em !important; transition: opacity 0.3s !important; }
.caelora-footer-col a:hover { opacity: 0.6 !important; }
.caelora-footer-col:last-child { text-align: right !important; }
.caelora-footer-col:nth-child(2) { text-align: center !important; }
.caelora-footer-bottom { display: flex; justify-content: space-between; align-items: center; padding: 30px 0; border-top: 1px solid rgba(255,255,255,0.1); max-width: 1600px; margin: 0 auto; font-size: 0.85rem; color: rgba(255,255,255,0.4); }
.caelora-footer-bottom a { color: rgba(255,255,255,0.4) !important; text-decoration: none !important; font-family: "Melodrama", serif !important; }
.caelora-footer-brand { max-width: 100%; margin: 0 auto; overflow: visible; padding: 40px 0 20px; text-align: center; }
.caelora-footer-brand-text { font-family: "Melodrama", serif !important; font-size: clamp(10rem, 25vw, 28rem) !important; font-weight: 400 !important; line-height: 1 !important; color: var(--caelora-text, #fff) !important; text-transform: uppercase !important; letter-spacing: -0.02em !important; text-align: center !important; overflow: visible !important; margin-bottom: 0 !important; padding-bottom: 20px !important; }
footer.footer, .section-footer { display: none !important; }

/* REVIEW TEXT SIZE FIX */
.review-quote { font-size: 18px !important; line-height: 1.7 !important; }
.review-author-name { font-size: 15px !important; letter-spacing: 0.12em !important; }
.review-author-detail { font-size: 13px !important; }
.review-verified { font-size: 12px !important; }
.review-stars { font-size: 18px !important; letter-spacing: 8px !important; }
.reviews-header h2 { font-size: 48px !important; }
.reviews-header .reviews-subhead { font-size: 14px !important; letter-spacing: 0.3em !important; }

/* VIDEO SECTION FIX */
[class*="video_banner"] .page-width, [class*="video-banner"] .page-width { max-width: 80% !important; margin: 0 auto !important; padding: 0 !important; }
[class*="video_banner"] video, [class*="video-banner"] video { width: 100% !important; height: auto !important; object-fit: contain !important; display: block !important; }
[class*="video_banner"] .deferred-media, [class*="video-banner"] .deferred-media { padding: 0 !important; width: 100% !important; max-width: 100% !important; background: var(--caelora-bg, #000) !important; }
[class*="video_banner"], [class*="video-banner"] { background: var(--caelora-bg, #000) !important; padding: 0 !important; }

/* === FINAL OVERRIDES === */

/* VIDEO: show full video, keep ratio, remove black edges, reduce frame */
.desire-video-frame {
  width: 45% !important;
  max-width: 450px !important;
  aspect-ratio: 9 / 16 !important;
  overflow: hidden !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}
.desire-video-frame video {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}
.desire-video-banner {
  background: var(--caelora-bg, #000) !important;
  border: none !important;
  padding: 40px 0 !important;
}

/* NEWSLETTER: anchor image longer before white panel overlays */
.lifestyle-newsletter-wrapper {
  min-height: 250vh !important;
}
.lifestyle-sticky-image {
  position: sticky !important;
  top: 0 !important;
  height: 100vh !important;
}
.newsletter-overlay-panel {
  margin-top: -20vh !important;
  padding-bottom: 80px !important;
}


/* === NEWSLETTER SECTION FIXES === */
/* Bigger subtext */
.newsletter-overlay-inner p,
.newsletter-overlay-inner .newsletter-subtext,
.newsletter-overlay-inner span {
  font-size: 16px !important;
  line-height: 1.6 !important;
  color: #555 !important;
}
/* Email input bigger */
.newsletter-overlay-inner input[type="email"] {
  font-size: 16px !important;
  padding: 18px 20px !important;
}
/* Subscribe button bigger */
.newsletter-overlay-btn {
  font-size: 16px !important;
  padding: 18px 36px !important;
}
/* Slow the white panel - barely overlap the image initially */
.newsletter-overlay-panel {
  margin-top: 60vh !important;
  padding-bottom: 120px !important;
}
/* Make wrapper much taller so you scroll through the full image first */
.lifestyle-newsletter-wrapper {
  min-height: 300vh !important;
}
/* Inner panel wider and more padding */
.newsletter-overlay-inner {
  width: 70% !important;
  max-width: 1000px !important;
  padding: 100px 80px 80px !important;
}

/* Newsletter heading size - match Caelora reference */
.newsletter-overlay-heading,
.newsletter-overlay-inner h2,
.newsletter-overlay-inner .newsletter-overlay-heading {
  font-size: clamp(60px, 12vw, 140px) !important;
  line-height: 1.0 !important;
  font-weight: 400 !important;
  text-transform: uppercase !important;
  letter-spacing: -0.01em !important;
}


/* === NEWSLETTER SCROLL - CLEAN IMPLEMENTATION === */
/* Wrapper: no fixed height, let content flow naturally */
.lifestyle-newsletter-wrapper {
  position: relative !important;
  background: var(--caelora-bg, #000) !important;
  min-height: auto !important;
}

/* Sticky image: stays in viewport while scrolling through wrapper */
.lifestyle-sticky-image {
  position: sticky !important;
  top: 0 !important;
  height: 100vh !important;
  overflow: hidden !important;
  z-index: 1 !important;
}

/* Scroll spacer: creates distance where you see just the image */
.scroll-spacer {
  height: 60vh;
  position: relative;
  z-index: 0;
}

/* Panel: overlaps bottom of image with negative margin, then scrolls with it */
.newsletter-overlay-panel {
  position: relative !important;
  z-index: 2 !important;
  display: flex !important;
  justify-content: center !important;
  margin-top: -100vh !important;
  padding-bottom: 0 !important;
}

/* Revert heading to original size */
.newsletter-overlay-heading,
.newsletter-overlay-inner h2,
.newsletter-overlay-inner .newsletter-overlay-heading {
  font-size: clamp(3rem, 8vw, 7rem) !important;
  line-height: 1.05 !important;
  font-weight: 400 !important;
  text-transform: uppercase !important;
  letter-spacing: -0.01em !important;
}


/* === NEWSLETTER SCROLL - FINAL FIX === */
.scroll-spacer {
  height: 80vh !important;
  min-height: 80vh !important;
  display: block !important;
}
.newsletter-overlay-panel {
  margin-top: -60vh !important;
}


/* === ALL FONTS → MELODRAMA === */
.desire-hero-subtitle,
.desire-hero-desc,
.caelora-hero-wrapper a.button,
.caelora-hero-wrapper .banner__content a,
[id*="brand_statement"] a.button,
[id*="brand_statement"] .button--secondary,
.desire-collection-heading,
.desire-collection-heading h2,
.review-author-name,
.review-author-detail,
.review-verified,
.card__heading,
.card-information__text,
.price-item,
.price,
.rich-text__text,
.rich-text__text p,
.button,
a.button,
button.button,
.newsletter-overlay-inner input,
.newsletter-overlay-btn {
  font-family: "Melodrama", serif !important;
}

/* Hero subtitle font fix - high specificity */
.caelora-hero-wrapper .desire-hero-subtitle:not(.x):not(.y),
.caelora-hero-wrapper .desire-hero-desc:not(.x):not(.y) {
  font-family: "Melodrama", serif !important;
}

/* Hero subtitle font - ultra high specificity override */
.desire-hero-subtitle:not(.fa):not([class*="pe-"]):not(.lni):not(i[class*="iccl-"]):not(i[class*="la"]):not(i[class*="fa"]):not(.jdgm-star),
.desire-hero-desc:not(.fa):not([class*="pe-"]):not(.lni):not(i[class*="iccl-"]):not(i[class*="la"]):not(i[class*="fa"]):not(.jdgm-star) {
  font-family: "Melodrama", serif !important;
}


/* VIDEO WHITE STROKE */
.desire-video-frame { border: 1px solid var(--caelora-border-color, #fff) !important; }


/* === MOBILE 768px === */
@media screen and (max-width: 768px) {
.header { padding: 12px 16px !important; }
.header__heading-link { font-size: 12px !important; letter-spacing: 2px !important; }
.caelora-hero-wrapper { height: 100svh !important; min-height: 600px !important; }
.desire-hero-text { font-size: clamp(3rem, 18vw, 6rem) !important; line-height: 1.0 !important; }
.desire-hero-subtitle, .desire-hero-desc { position: absolute !important; bottom: 20px !important; font-size: 11px !important; line-height: 1.5 !important; max-width: 45% !important; }
.desire-hero-subtitle { left: 16px !important; right: auto !important; text-align: left !important; }
.desire-hero-desc { right: 16px !important; left: auto !important; text-align: right !important; }
.caelora-hero-wrapper .banner__content { bottom: 20px !important; left: 50% !important; transform: translateX(-50%) !important; }
.caelora-hero-wrapper a.button { padding: 12px 28px !important; font-size: 12px !important; }
.desire-lifestyle-image { padding: 60px 0 !important; }
.desire-lifestyle-image img { max-width: 90% !important; margin: 0 auto !important; display: block !important; }
[id*="brand_statement"] .rich-text.content-container { padding: 60px 20px !important; }
[id*="brand_statement"] .rich-text__heading { font-size: 28px !important; line-height: 1.3 !important; }
[id*="brand_statement"] .rich-text__text { font-size: 14px !important; line-height: 1.7 !important; padding: 0 10px !important; }
[id*="brand_statement"] .rich-text__wrapper { padding-bottom: 60px !important; }
[id*="brand_statement"] a.button { font-size: 12px !important; padding: 12px 32px !important; }
.desire-collection-heading h2, .desire-collection-heading { font-size: clamp(3rem, 12vw, 5rem) !important; padding: 40px 20px 30px !important; }
.desire-collection-grid { grid-template-columns: 1fr !important; gap: 2px !important; padding: 0 !important; }

/* Video mobile */
.desire-video-banner { padding: 40px 16px !important; }
.desire-video-layout { flex-direction: column !important; align-items: center !important; }
.desire-video-frame { width: 70% !important; max-width: 300px !important; }
.desire-video-side-text { display: none !important; }
/* Reviews mobile */
.reviews-section { padding: 50px 0 !important; }
.reviews-header h2 { font-size: 28px !important; }
.reviews-header .reviews-subhead { font-size: 11px !important; letter-spacing: 0.2em !important; }
.reviews-grid { grid-template-columns: 1fr !important; gap: 2px !important; padding: 0 16px !important; }
.review-card { padding: 32px 24px !important; min-height: auto !important; }
.review-quote { font-size: 15px !important; line-height: 1.7 !important; }
.review-stars { font-size: 14px !important; letter-spacing: 4px !important; }
/* Newsletter mobile */
.lifestyle-sticky-image { height: 70vh !important; }
.scroll-spacer { height: 40vh !important; min-height: 40vh !important; }
.newsletter-overlay-panel { margin-top: -70vh !important; }
.newsletter-overlay-inner { width: 92% !important; max-width: none !important; padding: 50px 24px 40px !important; }
.newsletter-overlay-heading, .newsletter-overlay-inner h2, .newsletter-overlay-inner .newsletter-overlay-heading { font-size: clamp(2rem, 9vw, 3.5rem) !important; line-height: 1.1 !important; }
.newsletter-overlay-inner p { font-size: 13px !important; }
.newsletter-overlay-inner input[type="email"] { font-size: 14px !important; padding: 14px 16px !important; }
.newsletter-overlay-btn { font-size: 13px !important; padding: 14px 24px !important; white-space: nowrap !important; }
.newsletter-overlay-inner form, .newsletter-overlay-inner .newsletter-form { flex-direction: column !important; gap: 12px !important; }
/* Footer mobile */
.caelora-footer { padding: 50px 24px 0 !important; }
.caelora-footer-grid { grid-template-columns: 1fr !important; gap: 40px !important; padding-bottom: 50px !important; text-align: center !important; }
.caelora-footer-col:last-child, .caelora-footer-col:nth-child(2) { text-align: center !important; }
.caelora-footer-col h4 { font-size: 14px !important; margin-bottom: 16px !important; }
.caelora-footer-col a, .caelora-footer-col p { font-size: 15px !important; }
.caelora-footer-bottom { flex-direction: column !important; gap: 12px !important; text-align: center !important; padding: 24px 0 !important; font-size: 12px !important; }
.caelora-footer-brand-text { font-size: clamp(4rem, 18vw, 8rem) !important; line-height: 1 !important; }
}

@media screen and (max-width: 480px) {
.desire-hero-text { font-size: clamp(2.5rem, 16vw, 4.5rem) !important; }
.desire-hero-subtitle, .desire-hero-desc { font-size: 9px !important; max-width: 40% !important; bottom: 16px !important; }
.caelora-hero-wrapper .banner__content { bottom: 16px !important; }
.caelora-hero-wrapper a.button { padding: 10px 20px !important; font-size: 10px !important; }
.desire-video-frame { width: 85% !important; max-width: none !important; }
.newsletter-overlay-heading, .newsletter-overlay-inner h2, .newsletter-overlay-inner .newsletter-overlay-heading { font-size: clamp(1.8rem, 8vw, 2.8rem) !important; }
}


/* ============================================
   GLOBAL SITE-WIDE DARK THEME
   ============================================ */
body.gradient, body {
  background-color: #0f0f0f !important;
  color: var(--caelora-text, #fff) !important;
}
main.content-for-layout {
  background-color: #0f0f0f !important;
}

/* ============================================
   PRODUCT PAGE
   ============================================ */
.product {
  background: #0f0f0f !important;
  color: var(--caelora-text, #fff) !important;
}
/* Product title */
.product__title h1,
.product__title {
  font-family: "Melodrama", serif !important;
  font-size: clamp(2rem, 5vw, 3.5rem) !important;
  color: var(--caelora-text, #fff) !important;
  font-weight: 400 !important;
  letter-spacing: 0.02em !important;
}
/* Product price */
.product .price, .product .price-item,
.product .price__regular, .product .price__sale,
.price-item--regular, .price-item--sale {
  font-family: "Melodrama", serif !important;
  font-size: 20px !important;
  color: var(--caelora-text, #fff) !important;
}
.price .price-item--regular { color: rgba(255,255,255,0.5) !important; }
/* Product description */
.product__description, .product__description p,
.product-form, .product__info-container {
  font-family: "Melodrama", serif !important;
  color: rgba(255,255,255,0.85) !important;
  font-size: 16px !important;
  line-height: 1.7 !important;
}
/* Product form labels */
.product-form__group-label, .variant-picker label,
.product-form label, .form__label {
  font-family: "Melodrama", serif !important;
  color: rgba(255,255,255,0.6) !important;
  font-size: 14px !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
}
/* Variant buttons/selectors */
.product-form__input input[type="radio"] + label,
.product-form__input .product-form__input-label {
  border-color: rgba(255,255,255,0.3) !important;
  color: var(--caelora-text, #fff) !important;
  background: transparent !important;
  font-family: "Melodrama", serif !important;
}
.product-form__input input[type="radio"]:checked + label {
  border-color: var(--caelora-text, #fff) !important;
  background: #fff !important;
  color: #000 !important;
}
/* Add to cart button */
.product-form__submit, .product-form__submit span,
.product-form button[name="add"] {
  background: #fff !important;
  color: #000 !important;
  font-family: "Melodrama", serif !important;
  font-size: 16px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  border: none !important;
  padding: 18px 40px !important;
}
.product-form__submit:hover {
  background: rgba(255,255,255,0.85) !important;
}
/* Quantity selector */
.quantity, .quantity__button, .quantity__input {
  background: transparent !important;
  color: var(--caelora-text, #fff) !important;
  border-color: rgba(255,255,255,0.3) !important;
  font-family: "Melodrama", serif !important;
}
/* Product media/gallery */
.product__media-wrapper, .product__media-list,
.product__media-item {
  background: #0f0f0f !important;
}
.product__media-toggle, .slider-button {
  background: rgba(255,255,255,0.1) !important;
  color: var(--caelora-text, #fff) !important;
  border: 1px solid rgba(255,255,255,0.2) !important;
}
/* Share/wishlist buttons */
.share-button, .product__view-details {
  color: rgba(255,255,255,0.6) !important;
  font-family: "Melodrama", serif !important;
}
/* Product info wrapper */
.product__info-wrapper {
  background: #0f0f0f !important;
}
/* Accordion/tabs */
.accordion summary, .accordion .accordion__content,
.product__accordion {
  color: var(--caelora-text, #fff) !important;
  border-color: rgba(255,255,255,0.15) !important;
  font-family: "Melodrama", serif !important;
}


/* ============================================
   COLLECTION PAGE
   ============================================ */
.collection {
  background: #0f0f0f !important;
}
/* Collection title/banner */
.collection-hero, .collection-banner,
.collection-hero__inner {
  background: #0f0f0f !important;
}
.collection-hero__title, .collection__title,
h1.collection__title, .title--primary {
  font-family: "Melodrama", serif !important;
  font-size: clamp(2.5rem, 8vw, 5rem) !important;
  color: var(--caelora-text, #fff) !important;
  font-weight: 400 !important;
  text-align: center !important;
  text-transform: none !important;
}
/* Product grid on collection */
.collection-product-list, .product-grid,
.collection .grid {
  background: #0f0f0f !important;
}
/* Product cards in grid */
.product-card-wrapper, .card-wrapper,
.grid__item .card {
  background: #0f0f0f !important;
  border: none !important;
}
.card__inner, .card--standard .card__inner {
  background: #111 !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 0 !important;
}
.card__inner:hover {
  border-color: rgba(255,255,255,0.2) !important;
}
.card__content, .card__information {
  background: transparent !important;
  padding: 16px 0 !important;
}
/* Card title */
.card__heading a, .card-information__text,
.card__heading, .full-unstyled-link {
  font-family: "Melodrama", serif !important;
  color: var(--caelora-text, #fff) !important;
  font-size: 16px !important;
  text-decoration: none !important;
  font-weight: 400 !important;
}
/* Card price */
.card .price, .card .price-item {
  font-family: "Melodrama", serif !important;
  color: rgba(255,255,255,0.7) !important;
  font-size: 14px !important;
}
/* Card image */
.card__media, .media {
  background: #111 !important;
}
/* Pagination */
.pagination, .pagination__list {
  background: transparent !important;
}
.pagination__item a, .pagination__item span {
  color: var(--caelora-text, #fff) !important;
  font-family: "Melodrama", serif !important;
  border-color: rgba(255,255,255,0.2) !important;
}
.pagination__item--current {
  background: #fff !important;
  color: #000 !important;
}
/* Sort/filter */
.facets, .facet-filters, .active-facets,
.collection-filters {
  background: #0f0f0f !important;
  color: var(--caelora-text, #fff) !important;
}
.facets__summary, .facets__disclosure,
select.facet-filters__sort {
  color: var(--caelora-text, #fff) !important;
  background: transparent !important;
  border-color: rgba(255,255,255,0.2) !important;
  font-family: "Melodrama", serif !important;
}

/* ============================================
   CART PAGE
   ============================================ */
.cart {
  background: #0f0f0f !important;
}
.cart__empty-text, .cart-note {
  color: rgba(255,255,255,0.6) !important;
  font-family: "Melodrama", serif !important;
}
h1.cart__title, .cart .title {
  font-family: "Melodrama", serif !important;
  color: var(--caelora-text, #fff) !important;
  font-size: clamp(2rem, 5vw, 3rem) !important;
}
.cart-item, .cart-items {
  border-color: rgba(255,255,255,0.1) !important;
}
.cart-item__name, .cart-item__details a {
  font-family: "Melodrama", serif !important;
  color: var(--caelora-text, #fff) !important;
  font-size: 16px !important;
  text-decoration: none !important;
}
.cart-item__price, .cart-item .price {
  color: var(--caelora-text, #fff) !important;
  font-family: "Melodrama", serif !important;
}
.cart-item__quantity, .cart-item__quantity-wrapper {
  border-color: rgba(255,255,255,0.2) !important;
}
.cart-item__totals, .totals {
  color: var(--caelora-text, #fff) !important;
  font-family: "Melodrama", serif !important;
  border-color: rgba(255,255,255,0.1) !important;
}
.totals__subtotal-value, .totals__total-value {
  font-family: "Melodrama", serif !important;
  color: var(--caelora-text, #fff) !important;
  font-size: 20px !important;
}
/* Checkout button */
button[name="checkout"], .cart__checkout-button,
.cart__ctas button {
  background: #fff !important;
  color: #000 !important;
  font-family: "Melodrama", serif !important;
  font-size: 16px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  border: none !important;
  padding: 18px 40px !important;
}
/* Cart drawer */
.cart-drawer, cart-drawer {
  background: #0f0f0f !important;
  color: var(--caelora-text, #fff) !important;
}

/* ============================================
   GENERAL PAGES (About, Contact, Policies)
   ============================================ */
.page, .main-page, .shopify-policy__container {
  background: #0f0f0f !important;
  color: var(--caelora-text, #fff) !important;
}
.page .page-header h1, .page__title,
.shopify-policy__title {
  font-family: "Melodrama", serif !important;
  color: var(--caelora-text, #fff) !important;
  font-size: clamp(2rem, 5vw, 3.5rem) !important;
  font-weight: 400 !important;
  text-align: center !important;
}
.page .rte, .page .rte p, .page .rte li,
.shopify-policy__body, .shopify-policy__body p {
  font-family: "Melodrama", serif !important;
  color: rgba(255,255,255,0.85) !important;
  font-size: 16px !important;
  line-height: 1.7 !important;
}
.page .rte a, .shopify-policy__body a {
  color: var(--caelora-text, #fff) !important;
  text-decoration: underline !important;
}
/* Contact form */
.contact .field__input, .contact textarea,
.field__input, textarea {
  background: transparent !important;
  border: 1px solid rgba(255,255,255,0.2) !important;
  color: var(--caelora-text, #fff) !important;
  font-family: "Melodrama", serif !important;
  font-size: 15px !important;
}
.contact .field__label, .field__label {
  color: rgba(255,255,255,0.5) !important;
  font-family: "Melodrama", serif !important;
}
.contact .button, .form .button {
  background: #fff !important;
  color: #000 !important;
  font-family: "Melodrama", serif !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
}

/* ============================================
   SEARCH PAGE
   ============================================ */
.search, .template-search main {
  background: #0f0f0f !important;
}
.search__input, .search-modal__input {
  background: transparent !important;
  border-color: rgba(255,255,255,0.2) !important;
  color: var(--caelora-text, #fff) !important;
  font-family: "Melodrama", serif !important;
}

/* ============================================
   404 PAGE
   ============================================ */
.template-404 main {
  background: #0f0f0f !important;
  color: var(--caelora-text, #fff) !important;
}

/* ============================================
   GLOBAL OVERRIDES - DAWN COMPONENTS
   ============================================ */
/* Announcement bar */
.announcement-bar {
  background: var(--caelora-bg, #000) !important;
  color: var(--caelora-text, #fff) !important;
  font-family: "Melodrama", serif !important;
}
/* Breadcrumbs */
.breadcrumbs, .breadcrumbs a {
  color: rgba(255,255,255,0.5) !important;
  font-family: "Melodrama", serif !important;
}
/* Links */
a { color: #fff; }
/* Section padding overrides */
.section-template--padding {
  background: #0f0f0f !important;
}
/* Rich text sections on any page */
.rich-text, .rich-text .rich-text__wrapper {
  background: #0f0f0f !important;
}
/* Color scheme overrides */
.color-background-1, .color-background-2,
.color-scheme-1, .color-scheme-2,
[class*="color-"] {
  background: #0f0f0f !important;
  color: var(--caelora-text, #fff) !important;
}
/* Icon colors */
.icon-caret, svg.icon {
  color: var(--caelora-text, #fff) !important;
}
/* Shopify system buttons */
.shopify-challenge__button {
  font-family: "Melodrama", serif !important;
}


/* =============================================
   ADDITIONAL FONT & PAGE FIXES (April 1)
   ============================================= */

/* Fix cart page title - .title.title--primary uses Cormorant */
.title.title--primary,
h1.title.title--primary,
.cart .title,
.cart h1,
.template-cart h1,
.template-cart .title {
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
  color: var(--caelora-text, #fff) !important;
}

/* Fix cart notification heading */
.cart-notification__heading,
.cart-notification__heading.caption-large,
h2.cart-notification__heading {
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
  color: var(--caelora-text, #fff) !important;
}

/* Fix any remaining Dawn .title elements across all pages */
.title,
h1.title,
h2.title,
.collection-hero__title,
.template-collection h1,
.template-search h1,
.template-page h1,
.template-blog h1,
.template-article h1 {
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
  color: var(--caelora-text, #fff) !important;
}

/* Ensure Dawn color scheme backgrounds stay dark */
.color-scheme-1,
.color-background-1,
[class*="color-scheme"] {
  --color-background: 15, 15, 15 !important;
  --color-foreground: 255, 255, 255 !important;
  --gradient-background: #0f0f0f !important;
}

/* Fix Dawn's heading font variable override at root */
:root {
  --font-heading-family: Melodrama, serif !important;
  --font-body-family: Melodrama, serif !important;
}

/* Cart notification modal styling */
.cart-notification-wrapper {
  background-color: #1a1a1a !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
}
.cart-notification-wrapper .cart-notification__heading {
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
}

/* Fix Dawn's section-header and rich-text titles */
.section-header__title,
.rich-text__heading,
.rich-text h2,
.title-wrapper .title {
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
  color: var(--caelora-text, #fff) !important;
}

/* Fix breadcrumbs and pagination text */
.breadcrumbs a,
.breadcrumbs span,
.pagination a,
.pagination span {
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
  color: rgba(255,255,255,0.7) !important;
}
.pagination a:hover {
  color: var(--caelora-text, #fff) !important;
}

/* Fix collection card hover states */
.card:hover .card__heading a,
.card:hover .full-unstyled-link {
  color: var(--caelora-text, #fff) !important;
  text-decoration: none !important;
}

/* Fix empty cart state text */
.cart__empty-text,
.cart .caption-with-letter-spacing {
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
  color: rgba(255,255,255,0.7) !important;
}

/* Continue shopping link on empty cart */
.cart__empty-text a,
a[href="/collections/all"] {
  color: var(--caelora-text, #fff) !important;
  text-decoration: underline !important;
}

/* Fix search page styling */
.template-search .search__input,
.search__input,
.field__input {
  background-color: #1a1a1a !important;
  color: var(--caelora-text, #fff) !important;
  border: 1px solid rgba(255,255,255,0.2) !important;
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
}

/* Fix 404 page */
.template-404 h1,
.template-404 .title {
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
  color: var(--caelora-text, #fff) !important;
}
.template-404 a.button,
.template-404 .button {
  background-color: var(--caelora-text, #fff) !important;
  color: #000 !important;
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
}

/* Fix policy pages */
.template-policy h1,
.template-policy .title,
.template-policy h2 {
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
  color: var(--caelora-text, #fff) !important;
}
.template-policy .rte,
.template-policy .rte p,
.template-policy .rte li {
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
  color: rgba(255,255,255,0.85) !important;
}

/* Mobile responsive fixes for non-homepage */
@media (max-width: 768px) {
  .template-product .product__info-wrapper,
  .template-product .product__media-wrapper {
    width: 100% !important;
    max-width: 100% !important;
  }
  .template-product .product {
    flex-direction: column !important;
  }
  .template-collection .collection-product-list,
  .template-collection .grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 15px !important;
  }
  .template-cart .cart-items td {
    padding: 10px 5px !important;
    font-size: 14px !important;
  }
  .template-cart .cart-item__image {
    max-width: 80px !important;
  }
  .caelora-footer .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 30px !important;
    text-align: center !important;
  }
  .caelora-footer .footer-brand {
    font-size: clamp(4rem, 15vw, 8rem) !important;
  }
}

@media (max-width: 480px) {
  .template-collection .collection-product-list,
  .template-collection .grid {
    grid-template-columns: 1fr !important;
  }
  .template-product .product__title h1,
  .template-product h1 {
    font-size: clamp(1.8rem, 5vw, 2.5rem) !important;
  }
}


/* =============================================
   COLLECTION CARD WHITE STROKE + HOVER ANIMATION
   ============================================= */

/* White stroke border on each product card */
.desire-product-card {
  border: 1px solid rgba(255, 255, 255, 0.3) !important;
  transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
  overflow: hidden !important;
  position: relative !important;
}

/* Hover animation - subtle scale and border brightens */
.desire-product-card:hover {
  border-color: rgba(255, 255, 255, 0.8) !important;
  transform: scale(1.02) !important;
}

/* Image zoom on hover */
.desire-product-card img {
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
}
.desire-product-card:hover img {
  transform: scale(1.05) !important;
}

/* Overlay that appears on hover */
.desire-product-card::after {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(to top, rgba(0,0,0,0.5) 0%, transparent 50%) !important;
  opacity: 0 !important;
  transition: opacity 0.4s ease !important;
  pointer-events: none !important;
  z-index: 1 !important;
}
.desire-product-card:hover::after {
  opacity: 1 !important;
}

/* Product name overlay text on hover */
.desire-product-card .desire-card-title,
.desire-product-card .desire-card-price {
  position: relative !important;
  z-index: 2 !important;
  transition: opacity 0.4s ease, transform 0.4s ease !important;
}
.desire-product-card:hover .desire-card-title,
.desire-product-card:hover .desire-card-price {
  opacity: 1 !important;
  transform: translateY(-5px) !important;
}

/* Mobile: reduce hover effects */
@media (max-width: 768px) {
  .desire-product-card {
    border: 1px solid rgba(255, 255, 255, 0.25) !important;
  }
  .desire-product-card:hover {
    transform: none !important;
  }
  .desire-product-card:hover img {
    transform: none !important;
  }
}


/* =============================================
   NAVIGATION FIXES
   ============================================= */

/* Hide STOCKIST from navigation */
.header__menu-item[href*="stockist"],
.list-menu__item[href*="stockist"],
a[href*="stockist"].header__menu-item,
a[href*="/pages/stockist"] {
  display: none !important;
}
/* Also hide from mobile drawer */
.menu-drawer__menu-item[href*="stockist"],
a[href*="/pages/stockist"].menu-drawer__menu-item {
  display: none !important;
}

/* Reorder nav: put ABOUT before DESIRE VAULT using flexbox order */
.header__inline-menu .list-menu,
.header__inline-menu ul,
header nav ul {
  display: flex !important;
}
/* COLLECTION stays first (order 1) */
.header__menu-item[href*="collections"],
.list-menu__item[href*="collections"] {
  order: 1 !important;
}
/* ABOUT moves to second (order 2) */
.header__menu-item[href*="about"],
.list-menu__item[href*="about"] {
  order: 2 !important;
}
/* DESIRE VAULT moves to third (order 3) */
.header__menu-item[href*="blogs"],
.list-menu__item[href*="blogs"],
.header__menu-item[href*="news"],
.list-menu__item[href*="news"] {
  order: 3 !important;
}

/* Remove underline from DISCOVER NOW button */
.desire-hero-cta,
.desire-hero-cta:hover,
.desire-hero-cta:focus,
.desire-hero-cta:active,
a.button.button--secondary,
.banner__content a.button,
.banner__content .button--secondary,
.desire-hero .button,
.desire-hero a.button {
  text-decoration: none !important;
  text-decoration-line: none !important;
}
/* Also target with high specificity to override app-injected rules */
a.button.button--secondary:not(.fake-class):not(.another-fake) {
  text-decoration: none !important;
}


/* =============================================
   COLLECTION CARD HOVER OVERLAY - BLACK WITH INFO
   ============================================= */

/* Card container */
.desire-product-card {
  position: relative !important;
  overflow: hidden !important;
  border: 1px solid rgba(255, 255, 255, 0.3) !important;
  cursor: pointer !important;
}

/* Card link and image */
.desire-card-link {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}
.desire-product-card img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  transition: opacity 0.5s ease !important;
}

/* Hover overlay - full black cover */
.desire-card-hover-overlay {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(var(--caelora-overlay-color-rgb, 0, 0, 0), var(--caelora-overlay-opacity, 0.92)) !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transition: opacity var(--caelora-hover-speed, 0.4s) ease, visibility var(--caelora-hover-speed, 0.4s) ease !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  padding: 30px !important;
  z-index: 10 !important;
  pointer-events: none !important;
}

/* Show overlay on hover */
.desire-product-card:hover .desire-card-hover-overlay {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

/* Dim image on hover */
.desire-product-card:hover img {
  opacity: 0.15 !important;
}

/* Remove old hover effects that conflict */
.desire-product-card:hover {
  transform: none !important;
}
.desire-product-card::after {
  display: none !important;
}

/* Top-right: Add to Basket + Checkout */
.desire-hover-top-right {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap: 10px !important;
}

.desire-hover-btn {
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
  font-size: 13px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  padding: 10px 22px !important;
  border: 1px solid var(--caelora-border-color, #fff) !important;
  color: var(--caelora-text, #fff) !important;
  background: transparent !important;
  cursor: pointer !important;
  transition: background 0.3s ease, color 0.3s ease !important;
  text-decoration: none !important;
  display: inline-block !important;
  text-align: center !important;
  min-width: 160px !important;
}

.desire-hover-btn:hover {
  background: #fff !important;
  color: #000 !important;
}

.desire-add-btn {
  background: #fff !important;
  color: #000 !important;
}
.desire-add-btn:hover {
  background: transparent !important;
  color: var(--caelora-text, #fff) !important;
}

.desire-checkout-btn {
  background: transparent !important;
  color: var(--caelora-text, #fff) !important;
}

/* Center: Description */
.desire-hover-center {
  flex: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  padding: 20px 10px !important;
}

.desire-hover-description {
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
  font-size: 15px !important;
  line-height: 1.6 !important;
  color: rgba(255, 255, 255, 0.85) !important;
  margin: 0 !important;
  max-width: 90% !important;
}

/* Bottom: Price left, Size right */
.desire-hover-bottom {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-end !important;
}

.desire-hover-price {
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
  font-size: 22px !important;
  color: var(--caelora-text, #fff) !important;
  letter-spacing: 0.05em !important;
}

.desire-hover-size {
  font-family: var(--caelora-heading-font, Melodrama, serif) !important;
  font-size: 16px !important;
  color: rgba(255, 255, 255, 0.7) !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
}

/* Quick add form reset */
.desire-quick-add-form {
  margin: 0 !important;
  padding: 0 !important;
  display: inline !important;
}

/* Mobile adjustments for hover overlay */
@media (max-width: 768px) {
  .desire-card-hover-overlay {
    padding: 20px !important;
  }
  .desire-hover-btn {
    font-size: 11px !important;
    padding: 8px 16px !important;
    min-width: 130px !important;
  }
  .desire-hover-description {
    font-size: 13px !important;
  }
  .desire-hover-price {
    font-size: 18px !important;
  }
  .desire-hover-size {
    font-size: 14px !important;
  }
}


/* =============================================
   COLLECTION GRID FIX - FORCE GRID LAYOUT
   ============================================= */
.desire-collection-grid {
  display: grid !important;
  gap: 0 !important;
}

/* Ensure cards fill their grid cell properly */
.desire-product-card {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 1 / 1 !important;
  position: relative !important;
  overflow: hidden !important;
}

/* Card link fills the card */
.desire-card-link {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
}

/* Image fills the card */
.desire-product-card img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}


/* =============================================
   MOBILE/TABLET: BURGER MENU TO RIGHT SIDE
   ============================================= */
@media (max-width: 989px) {
  /* Swap burger menu and cart icons using grid */
  .header {
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    align-items: center !important;
  }

  /* Move burger (header-drawer) to the right */
  header-drawer,
  .menu-drawer-container {
    order: 3 !important;
    grid-column: 3 !important;
    justify-self: end !important;
  }

  /* Keep logo centered */
  .header__heading {
    order: 2 !important;
    grid-column: 2 !important;
    justify-self: center !important;
  }

  /* Move cart/icons to the left */
  .header__icons {
    order: 1 !important;
    grid-column: 1 !important;
    justify-self: start !important;
  }
}

/* =============================================
   MOBILE/TABLET: FIX HERO TEXT OVERLAPPING
   ============================================= */
@media (max-width: 989px) {
  /* Hero subtitle wrapper - stack vertically */
  .desire-hero-subtitle-wrapper,
  .desire-hero-subtitles,
  .desire-hero-bottom {
    flex-direction: column !important;
    align-items: center !important;
    gap: 10px !important;
    text-align: center !important;
  }

  /* Subtitle text - reduce size and center */
  .desire-hero-subtitle,
  .desire-hero-subtitle-left,
  .desire-hero-subtitle-right {
    font-size: 12px !important;
    line-height: 1.5 !important;
    text-align: center !important;
    max-width: 90% !important;
    white-space: normal !important;
  }

  /* Be Desired heading - scale down for mobile */
  .desire-hero-title {
    font-size: clamp(4rem, 14vw, 10rem) !important;
    line-height: 1 !important;
    margin-bottom: 15px !important;
  }

  /* DISCOVER NOW button - ensure it doesn't overlap */
  .desire-hero-cta,
  .desire-hero .button,
  .banner__content .button--secondary {
    position: relative !important;
    bottom: auto !important;
    margin-top: 15px !important;
    font-size: 12px !important;
    padding: 12px 30px !important;
    display: inline-block !important;
  }

  /* Hero content wrapper - ensure proper stacking */
  .desire-hero-content,
  .banner__content,
  .desire-hero-inner {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-end !important;
    padding-bottom: 30px !important;
    gap: 5px !important;
  }
}

@media (max-width: 480px) {
  .desire-hero-subtitle,
  .desire-hero-subtitle-left,
  .desire-hero-subtitle-right {
    font-size: 10px !important;
    line-height: 1.4 !important;
  }

  .desire-hero-title {
    font-size: clamp(3rem, 12vw, 7rem) !important;
  }

  .desire-hero-cta,
  .desire-hero .button,
  .banner__content .button--secondary {
    font-size: 11px !important;
    padding: 10px 25px !important;
  }
}


/* =============================================
   MOBILE/TABLET: HERO TEXT OVERLAP FIX (correct selectors)
   ============================================= */
@media (max-width: 989px) {
  /* Hero title "Be Desired" - scale down */
  .desire-hero-text {
    font-size: clamp(50px, 12vw, 105px) !important;
    bottom: auto !important;
    position: relative !important;
    text-align: center !important;
    margin-bottom: 10px !important;
  }

  /* Left subtitle + right desc - stack vertically centered */
  .desire-hero-subtitle,
  .desire-hero-desc {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    font-size: 13px !important;
    line-height: 1.5 !important;
    text-align: center !important;
    display: block !important;
    width: 100% !important;
    margin-bottom: 5px !important;
  }

  /* The hero inner wrapper needs to become a flex column */
  .desire-hero-inner,
  .desire-hero-overlay,
  .caelora-hero-section .desire-hero {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-end !important;
    padding: 0 20px 25px !important;
  }

  /* DISCOVER NOW button */
  .desire-hero-cta,
  .caelora-hero-section .button--secondary {
    position: relative !important;
    bottom: auto !important;
    margin-top: 12px !important;
    font-size: 12px !important;
    padding: 10px 28px !important;
  }
}

@media (max-width: 480px) {
  .desire-hero-text {
    font-size: clamp(40px, 11vw, 70px) !important;
  }

  .desire-hero-subtitle,
  .desire-hero-desc {
    font-size: 11px !important;
  }
}


/* =============================================
   MOBILE/TABLET: HERO WRAPPER FLEX LAYOUT
   ============================================= */
@media (max-width: 989px) {
  .caelora-hero-wrapper {
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-end !important;
    align-items: center !important;
    padding-bottom: 30px !important;
    min-height: 100vh !important;
  }

  /* Hero background image - keep as background, not affected by flex */
  .caelora-hero-wrapper .desire-hero-bg,
  .caelora-hero-wrapper img {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    z-index: 0 !important;
  }

  /* All text elements need z-index above the image */
  .desire-hero-text,
  .desire-hero-subtitle,
  .desire-hero-desc,
  .banner__content,
  .desire-hero-cta,
  .caelora-hero-wrapper .button--secondary {
    z-index: 2 !important;
  }
}


/* =============================================
   MOBILE: HIGH SPECIFICITY HERO TEXT FIX
   ============================================= */
@media (max-width: 989px) {
  .caelora-hero-section .caelora-hero-wrapper .desire-hero-text,
  .caelora-hero-section .desire-hero-text,
  section .desire-hero-text {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    font-size: clamp(50px, 12vw, 85px) !important;
    text-align: center !important;
    width: 100% !important;
    margin-bottom: 10px !important;
    z-index: 2 !important;
  }

  .caelora-hero-section .caelora-hero-wrapper .desire-hero-subtitle,
  .caelora-hero-section .desire-hero-subtitle,
  section .desire-hero-subtitle {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    font-size: 12px !important;
    line-height: 1.5 !important;
    text-align: center !important;
    width: 100% !important;
    margin-bottom: 5px !important;
    z-index: 2 !important;
  }

  .caelora-hero-section .caelora-hero-wrapper .desire-hero-desc,
  .caelora-hero-section .desire-hero-desc,
  section .desire-hero-desc {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    font-size: 12px !important;
    line-height: 1.5 !important;
    text-align: center !important;
    width: 100% !important;
    margin-bottom: 10px !important;
    z-index: 2 !important;
  }

  .caelora-hero-section .caelora-hero-wrapper .banner__content,
  .caelora-hero-section .banner__content {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    display: flex !important;
    justify-content: center !important;
    z-index: 2 !important;
  }

  .caelora-hero-section .caelora-hero-wrapper .button--secondary,
  .caelora-hero-section .button--secondary {
    position: relative !important;
    bottom: auto !important;
    font-size: 12px !important;
    padding: 10px 28px !important;
  }
}

@media (max-width: 480px) {
  .caelora-hero-section .caelora-hero-wrapper .desire-hero-text,
  .caelora-hero-section .desire-hero-text,
  section .desire-hero-text {
    font-size: clamp(36px, 10vw, 60px) !important;
  }

  .caelora-hero-section .caelora-hero-wrapper .desire-hero-subtitle,
  .caelora-hero-section .desire-hero-subtitle,
  section .desire-hero-subtitle,
  .caelora-hero-section .caelora-hero-wrapper .desire-hero-desc,
  .caelora-hero-section .desire-hero-desc,
  section .desire-hero-desc {
    font-size: 10px !important;
  }
}


/* =============================================
   MOBILE: ULTRA-HIGH SPECIFICITY HERO OVERRIDES
   (matches :not() chain from app-injected CSS)
   ============================================= */
@media (max-width: 989px) {
  .desire-hero-text:not(.fa):not([class*="pe-"]):not(.lni):not(i[class*="iccl-"]):not(i[class*="la"]):not(i[class*="fa"]):not(.jdgm-star) {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    font-size: clamp(50px, 12vw, 85px) !important;
    text-align: center !important;
    width: 100% !important;
    margin-bottom: 10px !important;
  }

  .desire-hero-subtitle:not(.fa):not([class*="pe-"]):not(.lni):not(i[class*="iccl-"]):not(i[class*="la"]):not(i[class*="fa"]):not(.jdgm-star) {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    font-size: 12px !important;
    line-height: 1.5 !important;
    text-align: center !important;
    width: 100% !important;
    margin-bottom: 5px !important;
  }

  .desire-hero-desc:not(.fa):not([class*="pe-"]):not(.lni):not(i[class*="iccl-"]):not(i[class*="la"]):not(i[class*="fa"]):not(.jdgm-star) {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    font-size: 12px !important;
    line-height: 1.5 !important;
    text-align: center !important;
    width: 100% !important;
    margin-bottom: 10px !important;
  }
}

@media (max-width: 480px) {
  .desire-hero-text:not(.fa):not([class*="pe-"]):not(.lni):not(i[class*="iccl-"]):not(i[class*="la"]):not(i[class*="fa"]):not(.jdgm-star) {
    font-size: clamp(36px, 10vw, 60px) !important;
  }
  .desire-hero-subtitle:not(.fa):not([class*="pe-"]):not(.lni):not(i[class*="iccl-"]):not(i[class*="la"]):not(i[class*="fa"]):not(.jdgm-star),
  .desire-hero-desc:not(.fa):not([class*="pe-"]):not(.lni):not(i[class*="iccl-"]):not(i[class*="la"]):not(i[class*="fa"]):not(.jdgm-star) {
    font-size: 10px !important;
  }
}


/* =============================================
   CART ICON: REPLACE CIRCLE WITH SHOPPING CART
   ============================================= */

/* Hide the default Dawn shopping bag SVG */
.header__icon--cart svg.icon.icon-cart {
  display: none !important;
}
a[href="/cart"] svg,
.header__icon--cart svg {
  display: none !important;
}

/* Show a shopping cart icon instead */
.header__icon--cart,
a[href="/cart"].header__icon {
  position: relative !important;
}
.header__icon--cart::before,
a[href="/cart"].header__icon::before {
  content: '' !important;
  display: inline-block !important;
  width: 24px !important;
  height: 24px !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'/%3E%3Ccircle cx='20' cy='21' r='1'/%3E%3Cpath d='M1 1h4l2.68 13.39a2 2 0 0 0 2 1.61h9.72a2 2 0 0 0 2-1.61L23 6H6'/%3E%3C/svg%3E") !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  vertical-align: middle !important;
}
/* ===== CART ICON REPLACEMENT ===== */
a[href="/cart"] svg,
.header__icon--cart svg {
  display: none !important;
}

.header__icon--cart::before,
a[href="/cart"].header__icon::before {
  content: '' !important;
  display: inline-block !important;
  width: 24px !important;
  height: 24px !important;
  min-width: 24px !important;
  min-height: 24px !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'/%3E%3Ccircle cx='20' cy='21' r='1'/%3E%3Cpath d='M1 1h4l2.68 13.39a2 2 0 0 0 2 1.61h9.72a2 2 0 0 0 2-1.61L23 6H6'/%3E%3C/svg%3E") !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
}

/* ===== CART COUNT BUBBLE - VISIBLE NUMBER ===== */
.cart-count-bubble {
  z-index: 50 !important;
  position: absolute !important;
  top: -6px !important;
  right: -10px !important;
  background: var(--caelora-accent, #c8a86e) !important;
  color: #000 !important;
  border: none !important;
  border-radius: 50% !important;
  min-width: 18px !important;
  height: 18px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  font-family: Arial, sans-serif !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  padding: 0 4px !important;
  pointer-events: none !important;
}

.cart-count-bubble span[aria-hidden="true"] {
  color: #000 !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  font-family: Arial, sans-serif !important;
  line-height: 1 !important;
}

.cart-count-bubble .visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
}


/* Vertical centering fix for nav items in header - desktop only */
@media (min-width: 990px) {
  .header__inline-menu {
    display: flex !important;
    align-items: center !important;
    height: 100% !important;
  }
  .header__inline-menu .list-menu--inline {
    display: flex !important;
    align-items: center !important;
  }
  .header__inline-menu .list-menu--inline > li {
    display: flex !important;
    align-items: center !important;
  }
  /* Optical centering for uppercase nav text (no descenders) */
  .header__menu-item.link {
    padding-top: 1px !important;
  }
  /* Fix roll-up spans baseline alignment */
  .header__menu-item .nav-roll-original {
    vertical-align: middle !important;
  }
}



/* =====================================================
   COMPREHENSIVE MOBILE RESPONSIVENESS FIXES
   ===================================================== */

/* --- MOBILE HEADER FIX --- */
@media (max-width: 989px) {
  /* Reset Dawn header grid for mobile - 3 column: menu | heading | cart */
  .header.header--middle-center {
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    grid-template-areas: "left-icons heading icons" !important;
    align-items: center !important;
    padding: 0 16px !important;
    height: 56px !important;
    min-height: 56px !important;
    gap: 0 !important;
  }

  /* Hide desktop nav on mobile */
  .header__inline-menu {
    display: none !important;
  }

  /* Show mobile hamburger menu */
  header-drawer {
    display: block !important;
    grid-area: left-icons !important;
    justify-self: start !important;
  }

  /* Center the heading/logo */
  .header__heading {
    grid-area: heading !important;
    justify-self: center !important;
    text-align: center !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .header__heading-link {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-decoration: none !important;
  }

  .header__heading .h2 {
    font-size: 18px !important;
    text-align: center !important;
    white-space: nowrap !important;
  }

  /* Cart and icons to the right */
  .header__icons {
    grid-area: icons !important;
    justify-self: end !important;
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
  }

  /* Ensure cart icon is visible and properly positioned */
  .header__icon--cart {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  /* Fix any logo sizing on mobile */
  .header__heading-logo {
    max-width: 120px !important;
    height: auto !important;
  }
}

/* --- MOBILE HERO / BANNER SECTION FIX --- */
@media (max-width: 989px) {
  /* Hero banner section */
  .banner__content {
    text-align: center !important;
    padding: 40px 20px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 16px !important;
  }

  .banner__heading {
    font-size: 32px !important;
    line-height: 1.2 !important;
    margin-bottom: 8px !important;
    text-align: center !important;
  }

  .banner__text {
    font-size: 14px !important;
    line-height: 1.5 !important;
    margin-bottom: 12px !important;
    text-align: center !important;
    padding: 0 10px !important;
  }

  .banner__buttons {
    display: flex !important;
    justify-content: center !important;
    width: 100% !important;
    margin-top: 8px !important;
  }

  .banner__buttons .button,
  .banner__buttons a.button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 auto !important;
    text-align: center !important;
  }

  /* Slideshow / image banner specific */
  .slideshow__text {
    text-align: center !important;
    padding: 30px 20px !important;
  }

  /* Image banner content wrapper */
  .image-banner__content,
  .banner--content-align-center {
    align-items: center !important;
    text-align: center !important;
  }

  /* Rich text section centering */
  .rich-text__wrapper {
    text-align: center !important;
    padding: 0 20px !important;
  }

  .rich-text__heading {
    text-align: center !important;
  }

  .rich-text__text {
    text-align: center !important;
  }

  .rich-text__buttons {
    justify-content: center !important;
  }
}

/* --- CAELORA HERO SECTION (custom) --- */
@media (max-width: 989px) {
  .caelora-hero,
  [class*="caelora-hero"] {
    min-height: 60vh !important;
  }

  .caelora-hero-content,
  .caelora-hero__content {
    text-align: center !important;
    padding: 40px 24px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 16px !important;
  }

  .caelora-hero h1,
  .caelora-hero__heading {
    font-size: 28px !important;
    line-height: 1.2 !important;
    margin-bottom: 8px !important;
  }

  .caelora-hero h2,
  .caelora-hero__subheading {
    font-size: 16px !important;
    line-height: 1.4 !important;
    margin-bottom: 12px !important;
    padding: 0 10px !important;
  }

  .caelora-hero p {
    font-size: 14px !important;
    line-height: 1.5 !important;
    padding: 0 10px !important;
    margin-bottom: 12px !important;
  }

  .caelora-hero .button,
  .caelora-hero a.button,
  .caelora-hero [class*="btn"],
  .caelora-hero .caelora-btn {
    margin: 8px auto 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }
}

/* --- GENERAL SECTION MOBILE SPACING --- */
@media (max-width: 989px) {
  /* Sections need breathing room */
  .section-template--* ,
  .shopify-section {
    overflow-x: hidden !important;
  }

  /* Prevent horizontal overflow */
  body {
    overflow-x: hidden !important;
  }

  /* Collection grid mobile */
  .collection-list__item {
    width: 100% !important;
  }

  /* Featured collection mobile */
  .featured-collection .grid {
    gap: 16px !important;
  }

  /* Product cards mobile */
  .product-card-wrapper {
    margin-bottom: 16px !important;
  }

  /* Footer mobile */
  .footer__content-top {
    flex-direction: column !important;
    gap: 24px !important;
    padding: 0 20px !important;
  }

  .footer-block {
    text-align: center !important;
    width: 100% !important;
  }

  .footer__content-bottom {
    flex-direction: column !important;
    text-align: center !important;
    gap: 12px !important;
    padding: 0 20px !important;
  }

  /* Newsletter form mobile */
  .newsletter-form {
    max-width: 100% !important;
    padding: 0 20px !important;
  }

  .newsletter-form__field-wrapper {
    flex-direction: column !important;
    gap: 8px !important;
  }

  /* About section mobile */
  .caelora-about,
  [class*="caelora-about"] {
    padding: 40px 20px !important;
  }

  .caelora-about h2 {
    font-size: 24px !important;
    text-align: center !important;
  }

  .caelora-about p {
    font-size: 14px !important;
    text-align: center !important;
    line-height: 1.6 !important;
  }
}

/* --- SMALL PHONE FIX (375px and below) --- */
@media (max-width: 375px) {
  .header.header--middle-center {
    padding: 0 12px !important;
  }

  .header__heading .h2 {
    font-size: 16px !important;
  }

  .banner__heading {
    font-size: 26px !important;
  }

  .caelora-hero h1,
  .caelora-hero__heading {
    font-size: 24px !important;
  }
}

/* --- TABLET FIX (750-989px) --- */
@media (min-width: 750px) and (max-width: 989px) {
  .header.header--middle-center {
    padding: 0 24px !important;
    height: 64px !important;
    min-height: 64px !important;
  }

  .header__heading .h2 {
    font-size: 20px !important;
  }

  .banner__heading {
    font-size: 38px !important;
  }

  .caelora-hero h1,
  .caelora-hero__heading {
    font-size: 34px !important;
  }
}


/* =====================================================
   TARGETED MOBILE FIXES - Hero & Header (actual classes)
   ===================================================== */

/* --- MOBILE HERO: Stack elements vertically instead of absolute positioning --- */
@media (max-width: 989px) {
  .caelora-hero-wrapper {
    position: relative !important;
    min-height: 70vh !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-end !important;
    align-items: center !important;
    padding-bottom: 30px !important;
    overflow: hidden !important;
  }

  .caelora-hero-wrapper .banner__media {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 0 !important;
  }

  /* Big heading - scale down dramatically for mobile */
  .desire-hero-text {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    font-size: 18vw !important;
    line-height: 1 !important;
    text-align: center !important;
    width: 100% !important;
    z-index: 1 !important;
    margin-bottom: 16px !important;
    padding: 0 10px !important;
  }

  /* Subtitle - left text */
  .desire-hero-subtitle {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    text-align: center !important;
    width: 100% !important;
    z-index: 1 !important;
    font-size: 14px !important;
    padding: 0 20px !important;
    margin-bottom: 16px !important;
  }

  /* Description - right text */
  .desire-hero-desc {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    text-align: center !important;
    width: 100% !important;
    z-index: 1 !important;
    font-size: 14px !important;
    padding: 0 20px !important;
    margin-bottom: 20px !important;
  }

  /* Button container - center it */
  .caelora-hero-wrapper .banner__content {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    width: auto !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    z-index: 1 !important;
    margin-bottom: 10px !important;
  }

  .caelora-hero-wrapper .banner__content .button {
    margin: 0 auto !important;
    text-align: center !important;
  }
}

/* --- SMALL PHONE HERO --- */
@media (max-width: 480px) {
  .desire-hero-text {
    font-size: 22vw !important;
  }

  .caelora-hero-wrapper {
    min-height: 60vh !important;
  }
}


/* =====================================================
   ADDITIONAL SECTION MOBILE FIXES
   ===================================================== */

/* --- VIDEO BANNER: Stack side text above/below video --- */
@media (max-width: 989px) {
  .desire-video-layout {
    flex-direction: column !important;
    padding: 20px !important;
    gap: 16px !important;
  }

  .desire-video-side-text {
    width: 100% !important;
    text-align: center !important;
    padding: 0 10px !important;
  }

  .desire-video-frame {
    width: 100% !important;
    max-width: 100% !important;
  }
}

/* --- COLLECTION GRID: 1 column on mobile, 2 on tablet --- */
@media (max-width: 749px) {
  .desire-collection-grid {
    grid-template-columns: 1fr !important;
    gap: 0 !important;
  }

  .desire-product-card {
    width: 100% !important;
  }

  .desire-collection-heading {
    font-size: 24px !important;
    text-align: center !important;
    padding: 20px !important;
  }
}

/* --- LIFESTYLE IMAGE: fit mobile --- */
@media (max-width: 989px) {
  .desire-lifestyle-image {
    width: 100% !important;
    height: auto !important;
  }

  .desire-lifestyle-image img {
    width: 100% !important;
    height: auto !important;
    object-fit: cover !important;
  }
}

/* --- REVIEWS: tighten padding on mobile --- */
@media (max-width: 989px) {
  .reviews-section {
    padding: 40px 20px !important;
  }
}

/* --- NEWSLETTER: full width on mobile --- */
@media (max-width: 989px) {
  .lifestyle-newsletter-wrapper {
    padding: 40px 20px !important;
    text-align: center !important;
  }
}

/* --- RICH TEXT / BRAND STATEMENT: center on mobile --- */
@media (max-width: 989px) {
  .rich-text__wrapper--center {
    padding: 40px 20px !important;
  }

  .rich-text__heading {
    font-size: 24px !important;
    text-align: center !important;
  }

  .rich-text__blocks.center {
    text-align: center !important;
    align-items: center !important;
  }

  .rich-text__buttons {
    display: flex !important;
    justify-content: center !important;
  }
}

/* --- ANNOUNCEMENT BAR: mobile fix --- */
@media (max-width: 989px) {
  .announcement-bar {
    font-size: 12px !important;
    padding: 8px 16px !important;
  }
}


/* =====================================================
   MOBILE BUTTON TEXT CENTERING - All buttons sitewide
   ===================================================== */
@media (max-width: 989px) {
  /* Dawn .button base class - force flex centering */
  .button,
  a.button,
  button.button,
  .button--primary,
  .button--secondary,
  .button--tertiary,
  .button--full-width,
  .shopify-payment-button button,
  .shopify-payment-button__button,
  input[type="submit"],
  input[type="button"] {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }

  /* Custom desire buttons (product hover, checkout) */
  .desire-hover-btn,
  .desire-add-btn,
  .desire-checkout-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }

  /* Newsletter / overlay buttons */
  .newsletter-overlay-btn,
  [class*="newsletter"] .button,
  [class*="newsletter"] button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }

  /* Rich text section buttons */
  .rich-text__buttons .button,
  .rich-text__buttons a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }

  /* Hero banner button */
  .banner__content .button,
  .banner__buttons .button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }

  /* Cart drawer buttons */
  .cart__checkout-button,
  .cart-notification__close,
  cart-notification .button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }

  /* Full-width buttons should remain full width but still center text */
  .button--full-width {
    display: flex !important;
    width: 100% !important;
  }

  /* Caelora custom buttons */
  .caelora-btn,
  [class*="caelora"] .button,
  [class*="caelora"] a.button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }

  /* Product form buttons (Add to cart, Buy now) */
  .product-form__submit,
  .product-form__cart-submit {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }
}


/* =====================================================
   PIN CTA BUTTONS TO BOTTOM OF THEIR SECTIONS
   Matches the DISCOVER NOW positioning pattern
   ===================================================== */

/* Rich text / Brand Statement section - pin "Learn More" to bottom */
.rich-text.content-container {
  position: relative !important;
}

.rich-text .rich-text__wrapper {
  padding-bottom: 80px !important;
}

.rich-text .rich-text__blocks {
  display: flex !important;
  flex-direction: column !important;
  min-height: 100% !important;
}

.rich-text .rich-text__buttons {
  position: absolute !important;
  bottom: 40px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
}

/* On mobile, keep buttons at bottom but adjust spacing */
@media (max-width: 989px) {
  .rich-text .rich-text__buttons {
    position: absolute !important;
    bottom: 30px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
  }

  .rich-text .rich-text__wrapper {
    padding-bottom: 80px !important;
  }
}


/* =====================================================
   FIX 1: DISCOVER NOW button below text on mobile hero
   Use CSS order to reorder flex children
   ===================================================== */
@media (max-width: 989px) {
  /* Hero wrapper is flex column on mobile - reorder children */
  .caelora-hero-wrapper .desire-hero-text {
    order: 1 !important;
  }
  .caelora-hero-wrapper .desire-hero-subtitle {
    order: 2 !important;
  }
  .caelora-hero-wrapper .desire-hero-desc {
    order: 3 !important;
  }
  .caelora-hero-wrapper .banner__content {
    order: 4 !important;
  }
  .caelora-hero-wrapper .banner__media {
    order: 0 !important;
  }
}

/* =====================================================
   FIX 2: Center burger menu in left section on mobile
   ===================================================== */
@media (max-width: 989px) {
  header-drawer {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    height: 100% !important;
    overflow: visible !important;
  }

  header-drawer .header__icon {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    height: 44px !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  header-drawer button,
  header-drawer .menu-drawer__open {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
  }

  /* Ensure the burger SVG icon is not clipped */
  header-drawer svg,
  header-drawer .icon-hamburger {
    overflow: visible !important;
    display: block !important;
  }
}

/* =====================================================
   FIX 3: Center cart icon in right section on mobile
   ===================================================== */
@media (max-width: 989px) {
  .header__icons {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    height: 100% !important;
    overflow: visible !important;
  }

  .header__icon--cart {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    height: 44px !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  .header__icon--cart svg,
  .header__icon--cart .icon-cart {
    overflow: visible !important;
    display: block !important;
  }

  /* Cart count badge - keep it visible */
  .cart-count-bubble {
    overflow: visible !important;
  }
}


/* =====================================================
   FIX 4: Scale up hero title "Be Desired" by 1.3x on mobile
   Current mobile size is 18vw, * 1.3 = ~23.4vw
   ===================================================== */
@media (max-width: 989px) {
  .desire-hero-text {
    font-size: 23.4vw !important;
  }
}

@media (max-width: 480px) {
  .desire-hero-text {
    font-size: 28.6vw !important;
  }
}


/* ============================================
   NEWSLETTER SECTION - MOBILE FIX
   ============================================ */
@media (max-width: 989px) {
  /* Newsletter overlay panel - clean padding */
  .newsletter-overlay-panel {
    width: 90% !important;
    max-width: 400px !important;
    padding: 32px 24px !important;
    margin: 0 auto !important;
    box-sizing: border-box !important;
  }

  /* Inner container - consistent spacing */
  .newsletter-overlay-inner {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 20px !important;
    padding: 0 !important;
    width: 100% !important;
  }

  /* Heading - proper sizing and spacing */
  .newsletter-overlay-heading.font--melodrama {
    font-size: 22px !important;
    line-height: 1.2 !important;
    text-align: center !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
  }

  /* Subtext - clean and centered */
  .newsletter-overlay-subtext.font--melodrama {
    font-size: 13px !important;
    line-height: 1.5 !important;
    text-align: center !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    opacity: 0.8;
  }

  /* Form container */
  .newsletter-overlay-form {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* Input row - stack vertically */
  .newsletter-overlay-input-row {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    width: 100% !important;
    align-items: stretch !important;
  }

  /* Email input - full width, clean styling */
  .newsletter-overlay-email.font--melodrama {
    width: 100% !important;
    min-width: 0 !important;
    padding: 14px 16px !important;
    font-size: 14px !important;
    box-sizing: border-box !important;
    margin: 0 !important;
  }

  /* Subscribe button - full width, centered */
  .newsletter-overlay-btn.font--melodrama {
    width: 100% !important;
    min-width: 0 !important;
    padding: 14px 16px !important;
    font-size: 14px !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }

  /* Lifestyle newsletter wrapper */
  .lifestyle-newsletter-wrapper {
    padding: 0 !important;
  }

  /* Scroll spacer - reduce on mobile */
  .scroll-spacer {
    min-height: 60vh !important;
  }
}


/* ============================================
   HEADER LOGO LINES - FIX FOR NON-HOMEPAGE
   On homepage: h1.header__heading wraps the link (existing rule works)
   On other pages: a.header__heading-link is direct child of header (needs this rule)
   ============================================ */
header.header > .header__heading-link {
  border-left: 1px solid rgba(255, 255, 255, 0.5) !important;
  border-right: 1px solid rgba(255, 255, 255, 0.5) !important;
  padding: 0px 47.5px !important;
  display: flex !important;
  align-items: center !important;
  align-self: stretch !important;
  height: 100% !important;
}


/* ============================================
   HEADER LOGO FONT - CONSISTENT ACROSS ALL PAGES
   Ensures OUD DESIRE text matches homepage styling
   ============================================ */
.header__heading-link {
  font-family: Melodrama, serif !important;
  font-size: 14px !important;
  letter-spacing: 3px !important;
  font-weight: 400 !important;
  text-transform: uppercase !important;
}


/* ============================================
   HEADER LOGO - MOBILE FIX FOR NON-HOMEPAGE
   Match the .header__heading mobile behavior
   ============================================ */
@media (max-width: 989px) {
  header.header > .header__heading-link {
    grid-area: heading !important;
    justify-self: center !important;
    text-align: center !important;
    padding: 7.5px !important;
    margin: 0 !important;
    align-self: stretch !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-left: 1px solid rgba(255, 255, 255, 0.5) !important;
    border-right: 1px solid rgba(255, 255, 255, 0.5) !important;
  }
}


/* ============================================
   COLLECTION GRID LAYOUT - CMS CONTROLLED
   columns controlled via --coll-columns / --coll-columns-mobile
   ============================================ */

/* Grid container */
.desire-collection-grid {
  display: grid !important;
  grid-template-columns: repeat(var(--coll-columns, 3), 1fr) !important;
  gap: var(--coll-gap, 0px) !important;
  width: 100% !important;
}

/* Cards fill their grid cell */
.desire-collection-grid .desire-product-card {
  aspect-ratio: 1 / 1 !important;
  min-height: 300px !important;
  width: auto !important;
  border-right: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
}

/* MOBILE */
@media (max-width: 749px) {
  .desire-collection-grid {
    grid-template-columns: repeat(var(--coll-columns-mobile, 1), 1fr) !important;
  }
  .desire-collection-grid .desire-product-card {
    aspect-ratio: auto !important;
    min-height: 280px !important;
    border-right: none !important;
  }
}

/* TABLET */
@media (min-width: 750px) and (max-width: 989px) {
  .desire-collection-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .desire-collection-grid .desire-product-card {
    min-height: 300px !important;
  }
}


/* ============================================
   COLLECTION PAGE STYLING
   Match to homepage product grid
   ============================================ */

/* Page background */
.collection {
  background: #000 !important;
}

/* Collection hero / title area */
.collection-hero {
  background: #000 !important;
  padding: 60px 0 40px !important;
}
.collection-hero__title {
  font-family: "Melodrama", serif !important;
  color: #fff !important;
  font-size: clamp(2.5rem, 5vw, 4rem) !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  text-align: center !important;
}
.collection-hero__description {
  color: rgba(255,255,255,0.6) !important;
  font-family: "Melodrama", serif !important;
  text-align: center !important;
}

/* Filter / Sort bar */
.facets__price,
.facet-filters,
.facet-filters__field,
.facet-filters__label,
.facet-filters__sort,
.facets-container {
  color: #fff !important;
  background: transparent !important;
  border-color: rgba(255,255,255,0.15) !important;
}
.facet-filters {
  padding: 20px 0 !important;
  border-bottom: 1px solid rgba(255,255,255,0.1) !important;
}
.facet-filters__label,
.product-count__text {
  color: rgba(255,255,255,0.5) !important;
  font-family: "Melodrama", serif !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  font-size: 0.8rem !important;
}
.facet-filters__sort,
.facet-filters__sort select,
.mobile-facets__sort select {
  color: #fff !important;
  background: transparent !important;
  border: 1px solid rgba(255,255,255,0.2) !important;
  font-family: "Melodrama", serif !important;
  letter-spacing: 0.05em !important;
}
.facet-filters__sort select option,
.mobile-facets__sort select option {
  background: #111 !important;
  color: #fff !important;
}
.disclosure__button {
  color: #fff !important;
}

/* Product grid container */
.product-grid-container {
  background: #000 !important;
  padding: 0 !important;
}
.template-collection .section-template--27579882864906__product-grid-padding {
  padding-top: 0 !important;
  padding-bottom: 80px !important;
}

/* Product grid - 3 columns like homepage */
.collection .product-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 2px !important;
  max-width: 1600px !important;
  margin: 0 auto !important;
}

/* Grid items - override Dawn's max-width constraints */
.collection .product-grid.grid--4-col-desktop .grid__item,
.collection .product-grid.grid--3-col-desktop .grid__item,
.collection .product-grid .grid__item {
  max-width: 100% !important;
  width: 100% !important;
  flex: none !important;
}
.collection .product-grid.grid--4-col-desktop,
.collection .product-grid.grid--3-col-desktop {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
}

/* Card fills its grid cell */
.collection .card-wrapper,
.collection .product-card-wrapper,
.collection .card,
.collection .card__inner {
  width: 100% !important;
}
.collection .card--standard .card__inner,
.collection .card--media .card__inner {
  width: 100% !important;
}


/* Card wrapper */
.collection .card-wrapper,
.collection .product-card-wrapper {
  margin: 0 !important;
}

/* Card styling - match homepage */
.collection .card {
  background: #0a0a0a !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 0 !important;
  overflow: hidden !important;
  position: relative !important;
}
.collection .card__inner {
  border: none !important;
  border-radius: 0 !important;
  background: #0a0a0a !important;
}
.collection .card__media {
  overflow: hidden !important;
  aspect-ratio: 1 / 1 !important;
}
.collection .card__media img,
.collection .media img {
  object-fit: cover !important;
  width: 100% !important;
  height: 100% !important;
  transition: transform 0.5s ease, filter 0.3s ease !important;
  filter: brightness(1.4) !important;
}
.collection .card-wrapper:hover .card__media img,
.collection .card-wrapper:hover .media img {
  transform: scale(1.05) !important;
}

/* Card content / info area */
.collection .card__content {
  padding: 20px 16px !important;
  background: #0a0a0a !important;
}
.collection .card-information {
  padding: 0 !important;
}
.collection .card__heading {
  font-family: "Melodrama", serif !important;
  font-size: 0.95rem !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  margin-bottom: 8px !important;
}
.collection .card__heading a {
  color: #fff !important;
  text-decoration: none !important;
}
.collection .card__heading a:hover {
  color: rgba(255,255,255,0.7) !important;
}

/* Price styling */
.collection .price {
  color: rgba(255,255,255,0.6) !important;
  font-family: "Melodrama", serif !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.08em !important;
}
.collection .price-item {
  color: rgba(255,255,255,0.6) !important;
}

/* Badge styling */
.collection .card__badge {
  position: absolute !important;
  top: 16px !important;
  left: 16px !important;
  z-index: 2 !important;
}
.collection .badge {
  background: #fff !important;
  color: #000 !important;
  font-family: "Melodrama", serif !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  font-size: 0.7rem !important;
  padding: 4px 12px !important;
  border-radius: 0 !important;
}

/* Quick add button */
.collection .quick-add {
  background: transparent !important;
}
.collection .quick-add__submit {
  background: #fff !important;
  color: #000 !important;
  border: none !important;
  border-radius: 0 !important;
  font-family: "Melodrama", serif !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  font-size: 0.75rem !important;
  padding: 12px 24px !important;
  transition: background 0.3s ease !important;
}
.collection .quick-add__submit:hover {
  background: rgba(255,255,255,0.85) !important;
}

/* View all button */
.collection .button--secondary {
  background: transparent !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,0.3) !important;
  border-radius: 0 !important;
  font-family: "Melodrama", serif !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  padding: 16px 40px !important;
  transition: all 0.3s ease !important;
}
.collection .button--secondary:hover {
  background: #fff !important;
  color: #000 !important;
}

/* Remove any default Dawn shadows/borders */
.collection .card--standard > .card__inner,
.collection .card--media > .card__inner {
  box-shadow: none !important;
}
.collection .card--standard:after,
.collection .card--media:after {
  display: none !important;
}

/* Pagination styling */
.collection .pagination-wrapper {
  background: #000 !important;
  padding: 40px 0 80px !important;
}
.collection .pagination__list {
  gap: 8px !important;
}
.collection .pagination__item a,
.collection .pagination__item span {
  color: #fff !important;
  background: transparent !important;
  border: 1px solid rgba(255,255,255,0.2) !important;
  font-family: "Melodrama", serif !important;
  min-width: 44px !important;
  height: 44px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.3s ease !important;
}
.collection .pagination__item a:hover {
  background: #fff !important;
  color: #000 !important;
}
.collection .pagination__item--current span {
  background: #fff !important;
  color: #000 !important;
}

/* ---- COLLECTION PAGE RESPONSIVE ---- */
@media (max-width: 989px) {
  .collection .product-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 2px !important;
  }
  .product-grid-container {
    padding: 0 !important;
  }
}
@media (max-width: 575px) {
  .collection .product-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 1px !important;
  }
  .product-grid-container {
    padding: 0 !important;
  }
  .collection .card__heading {
    font-size: 0.8rem !important;
    letter-spacing: 0.08em !important;
  }
  .collection .price {
    font-size: 0.75rem !important;
  }
  .collection-hero__title {
    font-size: 2rem !important;
  }
}


/* ============================================
   DESIRE VAULT - BLOG ARTICLE TEMPLATE
   Goyaso layout + Caelora dark theme
   ============================================ */

.desire-vault-article {
  background: #000;
  color: #fff;
  min-height: 100vh;
}

/* --- HERO SECTION --- */
.dv-hero {
  background: #000;
  padding: 80px 0 60px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.dv-hero__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 60px;
  align-items: center;
}
.dv-hero__title {
  font-family: "Melodrama", serif !important;
  font-size: clamp(2.5rem, 5vw, 4.5rem) !important;
  line-height: 1.1 !important;
  color: #fff !important;
  margin: 0 0 24px !important;
  font-weight: 400 !important;
  letter-spacing: 0.02em;
}
.dv-hero__excerpt {
  font-family: "Melodrama", serif !important;
  font-size: 1.15rem;
  line-height: 1.6;
  color: rgba(255,255,255,0.7);
  margin: 0 0 32px;
  font-weight: 400;
}
.dv-hero__details {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}
.dv-hero__date,
.dv-hero__read-time {
  font-family: "Manrope", sans-serif;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.5);
  letter-spacing: 0.05em;
}
.dv-hero__separator {
  color: rgba(255,255,255,0.3);
}
.dv-hero__tags {
  margin-bottom: 32px;
}
.dv-hero__tag {
  font-family: "Manrope", sans-serif;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.5);
  text-decoration: none;
  letter-spacing: 0.05em;
  transition: color 0.3s ease;
}
.dv-hero__tag:hover {
  color: #fff;
}
.dv-hero__tag-sep {
  color: rgba(255,255,255,0.3);
  margin: 0 4px;
}
.dv-hero__author {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 40px;
}
.dv-hero__author-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Melodrama", serif;
  font-size: 1.1rem;
  color: #fff;
}
.dv-hero__author-name {
  font-family: "Manrope", sans-serif;
  font-size: 0.9rem;
  color: rgba(255,255,255,0.7);
  letter-spacing: 0.03em;
}

/* Hero Image */
.dv-hero__image-col {
  position: relative;
  overflow: hidden;
  border-radius: 0;
}
.dv-hero__image {
  width: 100%;
  height: auto;
  min-height: 400px;
  object-fit: cover;
  display: block;
}
.dv-hero__image-placeholder {
  width: 100%;
  min-height: 400px;
  background: #111;
}

/* --- ARTICLE BODY --- */
.dv-body {
  background: #000;
  padding: 80px 0;
}
.dv-body__content {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 40px;
}
.dv-body__content h2 {
  font-family: "Melodrama", serif !important;
  font-size: clamp(1.6rem, 3vw, 2.2rem) !important;
  color: #fff !important;
  margin: 60px 0 24px !important;
  font-weight: 400 !important;
  letter-spacing: 0.02em;
  line-height: 1.2 !important;
}
.dv-body__content h3 {
  font-family: "Melodrama", serif !important;
  font-size: clamp(1.2rem, 2vw, 1.6rem) !important;
  color: #fff !important;
  margin: 48px 0 18px !important;
  font-weight: 400 !important;
  letter-spacing: 0.02em;
  line-height: 1.3 !important;
}
.dv-body__content h4 {
  font-family: "Melodrama", serif !important;
  font-size: 1.2rem !important;
  color: rgba(255,255,255,0.9) !important;
  margin: 40px 0 14px !important;
  font-weight: 400 !important;
}
.dv-body__content p {
  font-family: "Manrope", sans-serif !important;
  font-size: 1.05rem !important;
  line-height: 1.8 !important;
  color: rgba(255,255,255,0.7) !important;
  margin: 0 0 24px !important;
}
.dv-body__content a {
  color: #fff !important;
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: opacity 0.3s ease;
}
.dv-body__content a:hover {
  opacity: 0.7;
}
.dv-body__content img {
  max-width: 100%;
  height: auto;
  margin: 40px 0;
  display: block;
}
.dv-body__content ul,
.dv-body__content ol {
  font-family: "Manrope", sans-serif !important;
  font-size: 1.05rem !important;
  line-height: 1.8 !important;
  color: rgba(255,255,255,0.7) !important;
  margin: 0 0 24px 24px !important;
  padding: 0 !important;
}
.dv-body__content li {
  margin-bottom: 8px;
}
.dv-body__content blockquote {
  border-left: 2px solid rgba(255,255,255,0.2);
  margin: 40px 0;
  padding: 20px 32px;
  font-family: "Melodrama", serif !important;
  font-size: 1.3rem;
  font-style: italic;
  color: rgba(255,255,255,0.6);
  line-height: 1.6;
}

/* --- ARTICLE FOOTER --- */
.dv-footer {
  background: #000;
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 40px 0;
}
.dv-footer__inner {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 24px;
}
.dv-footer__share {
  display: flex;
  align-items: center;
  gap: 16px;
}
.dv-footer__share-label {
  font-family: "Manrope", sans-serif;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.4);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.dv-footer__share-link {
  font-family: "Manrope", sans-serif;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.6);
  text-decoration: none;
  letter-spacing: 0.05em;
  transition: color 0.3s ease;
}
.dv-footer__share-link:hover {
  color: #fff;
}
.dv-footer__nav {
  display: flex;
  gap: 24px;
  align-items: center;
}
.dv-footer__nav-link {
  font-family: "Manrope", sans-serif;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.5);
  text-decoration: none;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  transition: color 0.3s ease;
}
.dv-footer__nav-link:hover {
  color: #fff;
}

/* --- COMMENTS --- */
.dv-comments {
  background: #000;
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 60px 0 80px;
}
.dv-comments__inner {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 40px;
}
.dv-comments__heading {
  font-family: "Melodrama", serif !important;
  font-size: 1.8rem !important;
  color: #fff !important;
  margin: 0 0 40px !important;
  font-weight: 400 !important;
}
.dv-comment {
  border-bottom: 1px solid rgba(255,255,255,0.06);
  padding: 24px 0;
}
.dv-comment__author {
  font-family: "Melodrama", serif;
  font-size: 1rem;
  color: #fff;
  margin-bottom: 4px;
}
.dv-comment__date {
  font-family: "Manrope", sans-serif;
  font-size: 0.75rem;
  color: rgba(255,255,255,0.4);
}
.dv-comment__body {
  font-family: "Manrope", sans-serif;
  font-size: 0.95rem;
  line-height: 1.7;
  color: rgba(255,255,255,0.65);
  margin-top: 12px;
}
.dv-comments__form-heading {
  font-family: "Melodrama", serif !important;
  font-size: 1.3rem !important;
  color: #fff !important;
  margin: 40px 0 20px !important;
  font-weight: 400 !important;
}
.dv-comments__form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}
.dv-comments__input,
.dv-comments__textarea {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.15);
  color: #fff;
  font-family: "Manrope", sans-serif;
  font-size: 0.9rem;
  padding: 14px 18px;
  width: 100%;
  box-sizing: border-box;
  transition: border-color 0.3s ease;
}
.dv-comments__input:focus,
.dv-comments__textarea:focus {
  border-color: rgba(255,255,255,0.4);
  outline: none;
}
.dv-comments__textarea {
  min-height: 140px;
  resize: vertical;
  margin-bottom: 20px;
}
.dv-comments__submit {
  background: #fff;
  color: #000;
  border: none;
  font-family: "Melodrama", serif;
  font-size: 0.85rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 14px 40px;
  cursor: pointer;
  transition: opacity 0.3s ease;
}
.dv-comments__submit:hover {
  opacity: 0.85;
}

/* --- RESPONSIVE --- */
@media (max-width: 989px) {
  .dv-hero__inner {
    grid-template-columns: 1fr;
    gap: 40px;
    padding: 0 40px;
  }
  .dv-hero__meta-col {
    order: 1;
  }
  .dv-hero__image-col {
    order: 0;
  }
  .dv-hero {
    padding: 40px 0;
  }
}
@media (max-width: 575px) {
  .dv-hero__inner {
    padding: 0 20px;
    gap: 24px;
  }
  .dv-hero__title {
    font-size: 2rem !important;
  }
  .dv-body__content {
    padding: 0 20px;
  }
  .dv-footer__inner {
    padding: 0 20px;
    flex-direction: column;
    align-items: flex-start;
  }
  .dv-footer__nav {
    flex-direction: column;
    gap: 12px;
  }
  .dv-comments__inner {
    padding: 0 20px;
  }
  .dv-comments__form-row {
    grid-template-columns: 1fr;
  }
}


/* DESIRE VAULT - FONT SIZE FIX (Dawn root=10px, so rem values need adjustment) */
.dv-hero__excerpt { font-size: 18px !important; line-height: 1.6 !important; }
.dv-hero__date, .dv-hero__read-time { font-size: 13px !important; }
.dv-hero__tags a { font-size: 12px !important; }
.dv-hero__author-name { font-size: 14px !important; }
.dv-body__content p { font-size: 17px !important; line-height: 1.85 !important; }
.dv-body__content h2 { font-size: clamp(24px, 3vw, 32px) !important; }
.dv-body__content h3 { font-size: clamp(20px, 2.5vw, 26px) !important; }
.dv-body__content strong { font-size: inherit !important; }
.dv-body__content blockquote { font-size: 20px !important; }
.dv-body__content ul, .dv-body__content ol { font-size: 17px !important; }
.dv-body__content li { font-size: 17px !important; line-height: 1.8 !important; }
.dv-share__label { font-size: 13px !important; }
.dv-nav a { font-size: 15px !important; }
.dv-nav__title { font-size: 18px !important; }
.dv-comments__title { font-size: clamp(24px, 3vw, 32px) !important; }
.dv-comments__label { font-size: 14px !important; }
.dv-comments__input, .dv-comments__textarea { font-size: 15px !important; }
.dv-comments__submit { font-size: 14px !important; }
.dv-body__divider { margin: 60px auto !important; }


/* IMAGE VISIBILITY FIXES */
/* Product card images - subtle background to distinguish from page */
.card__media, .card__inner {
  background: #1a1a1a !important;
}
.card__media img, .card__inner img {
  opacity: 1 !important;
  visibility: visible !important;
}

/* Collection page product images */
.collection-product-card .card__media {
  background: #1a1a1a !important;
  border: 1px solid rgba(255,255,255,0.05);
}

/* Lifestyle image section - slight brightness boost for dark images */
.desire-lifestyle-image img {
  filter: brightness(1.15) !important;
}

/* Lifestyle newsletter image - ensure it displays */
.lifestyle-sticky-image img,
.lifestyle-img {
  opacity: 1 !important;
  visibility: visible !important;
  display: block !important;
}

/* Force images to render eagerly via CSS */
.caelora-lifestyle-section img,
.lifestyle-newsletter-wrapper img {
  content-visibility: visible !important;
}


/* COLLECTION CARD IMAGE FIX - overlay content was hiding product images */
.card--media > .card__inner > .card__content,
.card--standard.card--media > .card__inner > .card__content {
  background: transparent !important;
  background-color: transparent !important;
}
.card--media > .card__inner::after {
  background: transparent !important;
}
.card--media .card__content {
  background: transparent !important;
}


/* ==========================================================================
   PAGE TITLES — DESIRE VAULT + COLLECTION (match About hero title size)
   ========================================================================== */
.desire-vault-title,
.collection-title-override,
.collection-hero__title,
.main-blog .title--primary {
  font-family: "Melodrama", serif !important;
  font-size: clamp(60px, 10vw, 130px) !important;
  line-height: 1.05 !important;
  font-weight: 400 !important;
  letter-spacing: 0.01em !important;
  text-transform: uppercase !important;
  text-align: center !important;
  margin: 60px 0 40px 0 !important;
  color: #fff !important;
}

.main-blog {
  background: #000 !important;
  padding-top: 120px !important;
}
.main-blog .blog-articles__article .article-card__title,
.main-blog .blog-articles__article .article-card__excerpt,
.main-blog .blog-articles__article time {
  color: #fff !important;
}

.collection-hero {
  background: #000 !important;
  padding-top: 80px !important;
  padding-bottom: 40px !important;
}
.collection-hero__description {
  color: rgba(255,255,255,0.7) !important;
  text-align: center !important;
  max-width: 700px !important;
  margin: 0 auto !important;
}


/* === COLLECTION + BLOG HERO FIX === */
/* 1) Pure black background on collection hero inner (kill rgb(15,15,15)) */
.collection-hero,
.collection-hero.color-scheme-1,
.collection-hero.color-scheme-1.gradient,
.collection-hero__inner,
.collection-hero .collection-hero__inner {
  background: #000 !important;
  background-color: #000 !important;
  background-image: none !important;
}

/* 2) Left-align the COLLECTION title */
.collection-hero__inner,
.collection-hero__text-wrapper {
  text-align: left !important;
  align-items: flex-start !important;
}
.collection-hero__title,
.collection-hero__title.collection-title-override,
.collection-hero h1 {
  text-align: left !important;
  justify-content: flex-start !important;
  margin-left: 0 !important;
  width: 100% !important;
}
.collection-hero__description,
.collection-hero__description.rte {
  text-align: left !important;
}

/* 3) Desire Vault (blog) title area → match collection hero styling */
.main-blog.page-width {
  max-width: none !important;
  width: 100% !important;
  padding: 0 40px !important;
  margin: 0 !important;
  background: #000 !important;
}
.main-blog > .title-wrapper,
.main-blog > header,
.main-blog > h1,
.main-blog .title--primary,
.main-blog .desire-vault-title {
  /* will be wrapped visually via the hero-like container below */
}
/* Create a hero band at the top of the blog page that mirrors .collection-hero__inner */
.main-blog {
  position: relative;
}
.main-blog .title--primary.desire-vault-title,
h1.desire-vault-title {
  display: block !important;
  background: #000 !important;
  color: #fff !important;
  text-align: left !important;
  padding: 120px 5rem 80px !important;
  margin: 0 0 40px 0 !important;
  font-family: "Melodrama", serif !important;
  font-size: clamp(3rem, 8vw, 7rem) !important;
  line-height: 1 !important;
  letter-spacing: -0.02em !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
/* Push the article grid back inside a page-width container */
.main-blog .blog-articles,
.main-blog .article-card-wrapper,
.main-blog > *:not(.title--primary):not(.desire-vault-title) {
  max-width: var(--page-width, 1400px);
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  box-sizing: border-box;
}

/* Match the visual padding of the collection hero on mobile */
@media (max-width: 749px) {
  h1.desire-vault-title,
  .main-blog .title--primary.desire-vault-title {
    padding: 90px 1.5rem 60px !important;
    font-size: clamp(2.5rem, 12vw, 4rem) !important;
  }
}
/* === /COLLECTION + BLOG HERO FIX === */


/* Match Desire Vault title to Collection title */
.desire-vault-title,
h1.desire-vault-title,
.main-blog .title--primary,
.main-blog .title--primary.desire-vault-title {
  font-size: clamp(60px, 10vw, 130px) !important;
  line-height: 1.05 !important;
  letter-spacing: 0.01em !important;
}

/* ============================================
   MOBILE RESPONSIVENESS FIX v2 - May 2026
   ============================================ */

@media (max-width: 749px) {

  /* --- GLOBAL --- */
  body { overflow-x: hidden !important; }
  .page-width { padding-left: 20px !important; padding-right: 20px !important; }

  /* --- HEADER --- */
  .header__heading-link .h2 { font-size: 14px !important; }

  /* --- HERO SECTION --- */
  .caelora-hero-wrapper {
    min-height: 100svh !important;
    height: 100svh !important;
  }

  .desire-hero-text {
    font-size: 16vw !important;
    line-height: 1 !important;
    top: auto !important;
    bottom: 200px !important;
    left: 0 !important;
    right: 0 !important;
    text-align: center !important;
    padding: 0 15px !important;
  }

  .desire-hero-subtitle {
    font-size: 11px !important;
    letter-spacing: 1px !important;
    top: auto !important;
    bottom: 110px !important;
    left: 20px !important;
    right: auto !important;
    width: auto !important;
    text-align: left !important;
  }

  .desire-hero-desc {
    font-size: 11px !important;
    top: auto !important;
    bottom: 110px !important;
    left: auto !important;
    right: 20px !important;
    text-align: right !important;
  }

  .banner__content {
    top: auto !important;
    bottom: 40px !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    width: auto !important;
    align-items: center !important;
  }

  .banner__content .button,
  .banner__content .button--secondary {
    font-size: 10px !important;
    letter-spacing: 2px !important;
    padding: 14px 32px !important;
    min-width: unset !important;
  }

  /* --- LIFESTYLE IMAGE --- */
  .desire-lifestyle-image {
    padding: 40px 20px !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .desire-lifestyle-image img {
    max-width: 80% !important;
    margin: 0 auto !important;
    display: block !important;
  }

  /* --- BRAND / RICH TEXT --- */
  .rich-text .rich-text__wrapper,
  .rich-text__blocks { padding: 30px 20px !important; }

  .rich-text .rich-text__wrapper h2,
  .rich-text__blocks h2 {
    font-size: 26px !important;
    line-height: 1.3 !important;
  }

  .rich-text .rich-text__wrapper p,
  .rich-text__blocks p {
    font-size: 13px !important;
    line-height: 1.6 !important;
  }

  /* --- FEATURED COLLECTION --- */
  .desire-collection-heading {
    font-size: 36px !important;
    line-height: 1.15 !important;
    padding: 20px 15px !important;
    margin-bottom: 10px !important;
  }

  .desire-collection-grid {
    grid-template-columns: 1fr !important;
    gap: 2px !important;
  }

  .desire-product-cell {
    border-right: none !important;
    min-height: 300px !important;
  }

  .desire-product-overlay h3 {
    font-size: 22px !important;
  }

  .desire-product-overlay p {
    font-size: 12px !important;
  }

  .desire-see-all-cell {
    min-height: 120px !important;
    padding: 20px !important;
  }

  /* --- VIDEO BANNER --- */
  .desire-video-banner {
    width: 100% !important;
    margin: 0 auto !important;
    padding: 0 !important;
  }

  .desire-video-layout {
    flex-direction: column !important;
    gap: 0 !important;
  }

  .desire-video-frame {
    width: 100% !important;
    min-height: 220px !important;
  }

  .desire-video-side-text {
    width: 100% !important;
    padding: 25px 20px !important;
    text-align: center !important;
    font-size: 13px !important;
  }

  .desire-video-side-text h3 {
    font-size: 20px !important;
  }

  /* --- CUSTOMER REVIEWS --- */
  .reviews-section { padding: 40px 20px !important; overflow: hidden !important; }

  .reviews-section h2,
  .reviews-section .section-heading {
    font-size: 26px !important;
    line-height: 1.2 !important;
  }

  .reviews-grid,
  .reviews-track,
  .reviews-carousel {
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
  }

  .review-card {
    width: 100% !important;
    min-width: unset !important;
    max-width: 100% !important;
    flex-shrink: 0 !important;
  }

  /* --- NEWSLETTER --- */
  .lifestyle-sticky-image {
    min-height: 50vh !important;
    height: 50vh !important;
  }

  .scroll-spacer {
    height: 300px !important;
  }

  .newsletter-overlay-panel {
    flex-direction: column !important;
    padding: 20px !important;
    align-items: center !important;
  }

  .newsletter-overlay-inner {
    width: 100% !important;
    max-width: 100% !important;
    padding: 30px 20px !important;
    box-sizing: border-box !important;
  }

  .newsletter-overlay-inner h2 {
    font-size: 26px !important;
    line-height: 1.2 !important;
  }

  .newsletter-overlay-inner p {
    font-size: 13px !important;
  }

  .newsletter-overlay-inner input[type="email"] {
    width: 100% !important;
    box-sizing: border-box !important;
  }

  /* --- FOOTER --- */
  .caelora-footer {
    padding: 40px 20px 20px !important;
  }

  .caelora-footer-grid {
    grid-template-columns: 1fr !important;
    gap: 35px !important;
    padding: 0 !important;
  }

  .caelora-footer-col {
    text-align: center !important;
  }

  .caelora-footer-col h4 {
    font-size: 12px !important;
    margin-bottom: 15px !important;
  }

  .caelora-footer-col a,
  .caelora-footer-col p {
    font-size: 13px !important;
  }

  .caelora-footer-bottom {
    flex-direction: column !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 20px 0 !important;
    text-align: center !important;
  }

  .caelora-footer::after {
    font-size: 24px !important;
    letter-spacing: 2px !important;
  }

  /* --- PRODUCT PAGE --- */
  .product__info-wrapper {
    padding: 0 20px !important;
  }

  /* --- COLLECTION PAGE --- */
  .collection-hero__inner {
    padding: 20px !important;
  }

  .collection-hero__inner h1 {
    font-size: 32px !important;
  }
}

/* --- TABLET (750px - 989px) --- */
@media (min-width: 750px) and (max-width: 989px) {
  .desire-hero-text {
    font-size: 10vw !important;
  }

  .desire-collection-heading {
    font-size: 70px !important;
  }

  .caelora-footer-grid {
    grid-template-columns: 1fr 1fr !important;
  }

  .desire-collection-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .newsletter-overlay-inner {
    width: 80% !important;
  }
}
/* ============================================
   PRODUCT CARD CLICK-THROUGH FIX - May 2026
   Ensures the product link is always clickable
   on both desktop and mobile devices.
   The link sits above the overlay so it always
   captures clicks/taps. The overlay shows visually
   on hover but cannot block navigation.
   ============================================ */

/* Make the product link always sit above the overlay */
.desire-card-link {
  z-index: 20 !important;
  position: absolute !important;
  inset: 0 !important;
}

/* Ensure the overlay never captures pointer events - 
   it's purely visual. Remove the pointer-events:auto 
   from the hover state. */
.desire-card-hover-overlay,
.desire-product-card:hover .desire-card-hover-overlay {
  pointer-events: none !important;
}

/* The checkout and add-to-basket buttons inside the overlay
   need pointer-events restored so they remain clickable,
   and they need a z-index above the link */
.desire-hover-btn {
  pointer-events: auto !important;
  position: relative !important;
  z-index: 25 !important;
}

@media (max-width: 749px) {
  /* On mobile, hide the hover overlay entirely since
     touch devices don't have true hover */
  .desire-card-hover-overlay {
    display: none !important;
  }
}
