/* =======================================================================
   Theme Meta Information 
========================================================================== */
/* 
Theme Name: Stack
Theme URI: --
Description: --
Author: --
Author URI: --
Template: hello-elementor
Version: 2.0.0
Text Domain: stack-child
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/


/* ================================================================================================================================================= 
   Root
==================================================================================================================================================== */
:root {

  /* Global Layout */
  --wp--style--global--wide-size: 1400px;
  --wp--style--global--content-size: 1140px;

 /* Global Custom Properties - Icons */
  --icon-size: 1em;
  --icon-gap: 0.4em;
  --icon-valign: middle;

}

/* ================================================================================================================================================= 
   Body colo variables
==================================================================================================================================================== */

body.elementor-kit-8 {
  --color-primary: var(--e-global-color-primary);
  --color-secondary: var(--e-global-color-secondary);
  --color-text: var(--e-global-color-text);
  --color-accent: var(--e-global-color-accent);

  --color-primary-dark: var(--e-global-color-ac6e05f);
  --color-primary-light: var(--e-global-color-38ae551);
  --color-secondary-dark: var(--e-global-color-a115843);
  --color-secondary-light: var(--e-global-color-c80e38c);
  --color-tertiary: var(--e-global-color-757a5a4);
  --color-tertiary-dark: var(--e-global-color-f629a96);
  --color-tertiary-light: var(--e-global-color-1062c31);

  --color-white: var(--e-global-color-4443d05);
  --color-black: var(--e-global-color-ac6e05f);

  --color-grey-100: var(--e-global-color-89d564c);
  --color-grey-200: var(--e-global-color-8a21a6b);
  --color-grey-300: var(--e-global-color-bdead0c);
  --color-grey-400: var(--e-global-color-c3491e5);
  --color-grey-500: var(--e-global-color-28c87ca);
  --color-grey-600: var(--e-global-color-98641cf);
  --color-grey-700: var(--e-global-color-03eee67);
  --color-grey-800: var(--e-global-color-4066ca7);
  --color-grey-900: var(--e-global-color-f0538ba);
}


/* ================================================================================================================================================= 
   Base Font Size & Responsive Typograph
==================================================================================================================================================== */

html {
  font-size: 16px; /* Base font size for small screens */
  scrollbar-gutter: stable;
}

/* Target Desktop Safari to fix issue with horizontal scrolling */
@supports(font: -apple-system-body) and (not (-webkit-touch-callout: default)) {
  /* Add your desktop Safari-specific styles here */
  .elementor.type-page>.e-parent {
    overflow-x: hidden;
  }

}

@media (min-width: 992px) {
  html {
    font-size: 16px; /* Increased font size for larger screens */
  }
}


/* ================================================================================================================================================= 
   Fonts
==================================================================================================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Courgette&display=swap');

/* Font Face */
@font-face {
  font-family: 'courgette';
  src:
    url('/wp-content/themes/breeze/assets/fonts/Courgette-Regular.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}



.elementor-kit-8 h1,
.elementor-kit-8 h2,
.elementor-kit-8 h3,
.elementor-kit-8 h4,
.elementor-kit-8 h5,
.elementor-kit-8 h6 {
 
}

h1,
h2,
h3,
h4,
h5,
h6 {
 margin: 1rem auto 1.5rem auto;
}

p + h1,
p + h2,
p + h3,
p + h4,
p + h5,
p + h6 {
  margin-top: 3rem;
}

h1 span,
h2 span,
h3 span,
h4 span,
h5 span,
h6 span {

}

h1 i, h1 em,
h2 i, h2 em,
h3 i, h3 em,
h4 i, h4 em,
h5 i, h5 em,
h6 i, h6 em {
  font-family: 'courgette';
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0;
  text-transform: none;
}


/* Block Headings Font Sizes */
.wp-block-heading.is-style-h1 {
  font-weight: var(--e-global-typography-c297f56-font-weight);
  font-style: normal;
  font-size: var(--e-global-typography-c297f56-font-size);
  line-height: var(--e-global-typography-c297f56-line-height);
  letter-spacing: var(--e-global-typography-c297f56-letter-spacing);
  text-transform: var(--e-global-typography-c297f56-text-transform);
}

.wp-block-heading.is-style-h2 {
  font-weight: var(--e-global-typography-21c5652-font-weight);
  font-style: normal;
  font-size: var(--e-global-typography-21c5652-font-size);
  line-height: var(--e-global-typography-21c5652-line-height);
  letter-spacing: var(--e-global-typography-21c5652-letter-spacing);
  text-transform: var(--e-global-typography-21c5652-text-transform);
}

.wp-block-heading.is-style-h3 {
  font-weight: var(--e-global-typography-9ddb4af-font-weight);
  font-style: normal;
  font-size: var(--e-global-typography-9ddb4af-font-size);
  line-height: var(--e-global-typography-9ddb4af-line-height);
  letter-spacing: var(--e-global-typography-9ddb4af-letter-spacing);
  text-transform: var(--e-global-typography-9ddb4af-text-transform);
}

.wp-block-heading.is-style-h4 {
  font-weight: var(--e-global-typography-2fe9092-font-weight);
  font-style: normal;
  font-size: var(--e-global-typography-2fe9092-font-size);
  line-height: var(--e-global-typography-2fe9092-line-height);
  letter-spacing: var(--e-global-typography-2fe9092-letter-spacing);
  text-transform: var(--e-global-typography-2fe9092-text-transform);
}

.wp-block-heading.is-style-h5 {
  font-weight: var(--e-global-typography-a73f9a2-font-weight);
  font-style: normal;
  font-size: var(--e-global-typography-a73f9a2-font-size);
  line-height: var(--e-global-typography-a73f9a2-line-height);
  letter-spacing: var(--e-global-typography-a73f9a2-letter-spacing);
  text-transform: var(--e-global-typography-a73f9a2-text-transform);
}

.wp-block-heading.is-style-h6 {
  font-weight: var(--e-global-typography-7b4f8fe-font-weight);
  font-style: normal;
  font-size: var(--e-global-typography-7b4f8fe-font-size);
  line-height: var(--e-global-typography-7b4f8fe-line-height);
  letter-spacing: var(--e-global-typography-7b4f8fe-letter-spacing);
  text-transform: var(--e-global-typography-7b4f8fe-text-transform);
}

.wp-block-heading.is-style-s1,
.date-range .elementor-shortcode {
  font-size: var(--e-global-typography-45735d1-font-size);
  line-height: var(--e-global-typography-45735d1-line-height);
  letter-spacing: var(--e-global-typography-45735d1-letter-spacing);
  font-weight: var(--e-global-typography-45735d1-font-weight);
  text-transform: var(--e-global-typography-45735d1-text-transform);
}

.elementor-kit-8 p.is-style-inline-link,
.elementor-kit-8 a {
    font-size: var(--e-global-typography-c5d0c2c-font-size);
    font-weight: var(--e-global-typography-c5d0c2c-font-weight);
    text-decoration: var(--e-global-typography-c5d0c2c-text-decoration);
    line-height: var(--e-global-typography-c5d0c2c-line-height);
    letter-spacing: var(--e-global-typography-c5d0c2c-letter-spacing);
}

.elementor-kit-8 p.is-style-inline-link:hover,
.elementor-kit-8 a:hover {
  color: var(--color-grey-500);
} 

.footer a {
    font-weight: 500;
}

/* ================================================================================================================================================= 
   Header & Headroom – Default + Transparent Styles
==================================================================================================================================================== */
header.headroom {
    /*transition: background-color 0.3s ease, transform 0.3s ease;*/
   transition: transform 0.7s ease, background-color 2s ease;
   position: sticky;
   top: 0;
   z-index: 1002;
}


/* DEFAULT STYLE */
.header-default header.headroom {
  background-color: var(--e-global-color-secondary); /* Solid fill */

}

/*** Prevent collapse when menu is active ***/
header.headroom:has(.e-n-menu-toggle[aria-expanded="true"]),
header.headroom:has(.e-n-menu-content.e-active) {
  transform: translateY(0%) !important;
}



/* TRANSPARENT STYLE - HOME ONLY */
.header-transparent header.headroom {
  background-color: transparent; /* Initial transparent */
  opacity: 1;
  animation-name: fadeInOpacity;
  animation-iteration-count: 1;
  animation-timing-function: ease-in;
  animation-duration: 1s;
  
}

/* Links on Transparent Header*/
.header-transparent header.headroom .e-n-menu-title-text {
  
}

/* Transparent header logic with scroll */
.header-transparent header.headroom--top {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.25), rgba(0, 0, 0, 0));
  background-color: transparent; /* At top: stays transparent */
transition: transform 0.7s ease, background 0s ease;
}


/* After scroll: solid */
.header-transparent header.headroom:has(.e-n-menu-toggle[aria-expanded="true"]),
.header-transparent header.headroom:has(.e-n-menu-content.e-active),
.header-transparent header.headroom--not-top {
  background-image: none;
  background-color: var(--e-global-color-secondary) !important; /* Solid fill */
  transition: background-color 0.0s ease;
}


/* ensures solid fill background doesn't appear at end of fold-up */
.header-transparent header.headroom--not-top {
  transition: transform 0.7s ease, background-color 2.5s ease;
}



/* After scroll: change text color */
.header-transparent header.headroom--not-top .e-n-menu-title-text {

}



/* COMMON HEADROOM BEHAVIOR */
header.headroom--pinned {
  transform: translateY(0%); /* Visible when pinned */
}
header.headroom--unpinned {
  transform: translateY(-100%); /* Hidden when unpinned */
}
/* Smoother transitions */
header {
  /*transition: background-color 0.3s ease, transform 0.3s ease;*/
  transition: transform 0.3s ease;
}



/* ================================================================================================================================================= 
  Nav 
==================================================================================================================================================== */
/* Nav menu links */
.elementor-widget-n-menu .e-n-menu-title,
.elementor-widget-n-menu .e-n-menu-title span {
  cursor: pointer!important;
}

/* Menu panel scroll */
.elementor-widget-n-menu .e-n-menu-heading {
  max-height: calc(100vh - 70px);
  overflow-y: auto;
}

/* Top-level title row: text left / icon right */
.elementor-widget-n-menu .e-n-menu-title {
  display: flex;
  align-items: center;
  justify-content: space-between!important;
  width: 100%;
  gap: 1rem;
}

/* Keep title text flexible */
.elementor-widget-n-menu .e-n-menu-title-text,
.elementor-widget-n-menu .e-n-menu-title > span:first-child {
  flex: 1 1 auto;
  min-width: 0;
}

/* Keep dropdown icon on the far right */
.elementor-widget-n-menu .e-n-menu-dropdown-icon {
  flex: 0 0 auto;
  display: none;
  margin-left: auto;
}

/* List Text Hover transition */
.nav-list .elementor-icon-list-text {
  transition: font-weight 0.2s ease;
}

/* List Text Hover state */
.nav-list .elementor-icon-list-item a:hover .elementor-icon-list-text {
  font-weight:600; /* or 700 depending on your type scale */
}

/* Hide arrow on desktop */
.e-n-menu-dropdown-icon {
  display: none!important;
}


/* menu toggle */
.e-n-menu-toggle {
    display: flex;
    background: transparent!important;
}

.elementor-widget-n-menu .e-n-menu[data-layout=dropdown] .e-n-menu-content>.e-con {
  margin-top: 0;
}
/* after arrow icon */
.elementor-widget-n-menu .e-n-menu-title .e-n-menu-dropdown-icon[aria-expanded=false] .e-n-menu-dropdown-icon-closed {
    display: none;
}

@media (max-width: 991px) {
  /* Show on mobile only */
   .e-n-menu-dropdown-icon {
    display: flex!important;
  
  }
  .elementor-widget-n-menu .e-n-menu-title .e-n-menu-dropdown-icon {
    height: auto;
  }
  
  .elementor-widget-n-menu .e-n-menu-heading {
    background-color: var(--color-grey-200);
    padding: 0 2rem;
  }

  .elementor-widget-n-menu .e-n-menu[data-layout="dropdown"] .e-n-menu-wrapper {
    box-shadow: 0 8px 16px -4px rgba(0, 0, 0, 0.12);
    clip-path: inset(0px -16px -16px -16px);
  }

 /* Add the 1px solid grey border to each menu item */
  .elementor-widget-n-menu .e-n-menu-item {
    border-bottom: 1px solid #949699; /* Tailwind grey-500 equivalent */
  }

  /* Remove border from the last item so it looks clean */
  .elementor-widget-n-menu .e-n-menu-item:last-child {
    border-bottom: none;
  }

  .elementor-widget-n-menu .e-n-menu-title {
    padding:0;
  }

  .elementor-widget-n-menu .e-n-menu-item {
    padding: 1rem 0;
  }

  /* Remove the grey border from the last item so the button is clean */
  .elementor-widget-n-menu .e-n-menu-item:last-child {
    border-bottom: none !important;
    padding: 1rem 0; /* Give it some breathing room from the previous item */
  }

  /*Style the last nav title as a button */
  .elementor-widget-n-menu .e-n-menu-item:last-child .e-n-menu-title {
    background-color: transparent;
    font-family: var(--e-global-typography-595342a-font-family), Sans-serif;
    font-size: var(--e-global-typography-595342a-font-size);
    font-weight: var(--e-global-typography-595342a-font-weight);
    text-transform: var(--e-global-typography-595342a-text-transform);
    line-height: var(--e-global-typography-595342a-line-height);
    letter-spacing: var(--e-global-typography-595342a-letter-spacing);
    color: var(--color-text); 
    border: 1px solid var(--color-text);
    border-radius: 20rem!important;
    padding: 0.75rem 1.5rem;
    width: fit-content ; /* Prevents button from stretching full width */
    justify-content: center ; /* Centers text and icon if present */
    transition: background-color 0.3s ease, color 0.3s ease;
    margin-bottom: 1rem;
    margin-top: 1rem;
  }

    /*Style the last nav title as a button */
  .elementor-widget-n-menu .e-n-menu-item:last-child .e-n-menu-title:hover {
    background-color: var(--color-primary)!important;
    color: var(--color-grey-200)!important; 
    border: 1px solid var(--color-grey-200);
  }

  .elementor-widget-n-menu .e-n-menu-item:last-child .e-n-menu-title .e-n-menu-title-text {
    color: var(--color-text); 
  }
  .elementor-widget-n-menu .e-n-menu-item:last-child .e-n-menu-title .e-n-menu-title-text:hover {
    color: var(--color-grey-200)!important; 
  }
}


@media (max-width: 575px) {
 .elementor-widget-n-menu .e-n-menu-heading {
    background-color: var(--color-grey-200);
    padding: 0 1.5rem;
  }
  .elementor-widget-n-menu .e-n-menu-item {
    width: 100%!important;
  }
}


/* Tablet / tablet-extra */
@media (min-width: 576px) and (max-width: 991px) {
  .elementor-widget-n-menu .e-n-menu[data-layout="dropdown"] .e-n-menu-wrapper {
    --stretch-width: 400px;
    width: 400px !important;
    max-width: 400px !important;
    margin-right: 0;
    --stretch-left: -345px !important;
  }

  .elementor-widget-n-menu .e-n-menu[data-layout="dropdown"] .e-n-menu-item {
    width: 400px !important;
    max-width: 400px !important;
  }

  .elementor-widget-n-menu .e-n-menu[data-layout="dropdown"] .e-n-menu-content {
    width: 100%;
    max-width: 100%;
  }
}


/* Hover effect on nav item on desktop */
@media (min-width: 992px) {


/* Prevent the dropdown from inheriting the full-width 'stretch' behavior */
  .elementor-widget-n-menu .e-n-menu-content {
    right: auto !important;
    margin: 0 !important;
    transform: none !important;
  }

  /* Style the inner container to look like your mockup */
  .elementor-widget-n-menu .e-n-menu-content > .e-con {
    width: 100% !important;
  }
  
}

:where(.elementor-widget-n-menu .e-n-menu-content>.e-con) {
  background-color: transparent!important;

}

.e-n-menu-item .e-n-menu-title {
  cursor: pointer!important;
}



/* ================================================================================================================================================= 
  Button Toggle Menu 
==================================================================================================================================================== */
button.e-n-menu-toggle {
  margin: 0; /* Cancels out default button styling */
  border: 0 !important;
}

button.e-n-menu-toggle:hover,
button.e-n-menu-toggle:active {
  border: 0 !important;
}


/* ================================================================================================================================================= 
  Page Heros 
==================================================================================================================================================== */

/* Default Page Hero */
.page-hero {
  width: 100%;
  height: auto;
  min-height: 400px;
  max-height: 500px;
  position: relative;
  overflow: hidden;
}

.page-hero.collection-hero {
  height: auto;
  min-height: 650px;
  max-height: 1080px;
}

/* Tablet */
@media (max-width: 1199px) {
  .page-hero {
    height: auto;
    min-height: 400px;
    max-height: 500px;
  }
  .page-hero.collection-hero {
    height: auto;
    min-height: 650px;
    max-height: 850px;
  }
}

/* Mobile */
@media (max-width: 767px) {
  .page-hero {
    height: auto;
    min-height: 400px;
    max-height: 500px;
  }
  .page-hero.collection-hero {
    height: auto;
    min-height: 650px;
    max-height: 1080px;
  }
}

/* page content p width */
.elementor-widget-container p {
  max-width: 1140px;
}

.home-heading h1 {
    word-break: break-word!important;
}


/* ================================================================================================================================================= 
  Buttons 
==================================================================================================================================================== */
/* Default + Primary Button */
.wp-block-button .wp-block-button__link,
.wp-block-button.is-style-btn-default .wp-block-button__link,
.wp-block-button.is-style-btn-primary .wp-block-button__link {
    background-color: var(--e-global-color-primary);
    font-family: var(--e-global-typography-595342a-font-family), Sans-serif;
    font-size: var(--e-global-typography-595342a-font-size);
    font-weight: var(--e-global-typography-595342a-font-weight);
    text-transform: var(--e-global-typography-595342a-text-transform);
    line-height: var(--e-global-typography-595342a-line-height);
    letter-spacing: var(--e-global-typography-595342a-letter-spacing);
    text-decoration: none;
    color: var(--color-white);
    border-style: solid;
    border-width: 1px 1px 1px 1px;
    border-color: var(--color-white);
    border-radius: 0.25rem;
    padding: 0.75rem 1.5rem;
    margin: 1rem auto;
    transition: background-color 0.3s ease, color 0.3s ease;
}

/* Default + Primary Button Hover */
.wp-block-button .wp-block-button__link:hover,
.wp-block-button.is-style-btn-default .wp-block-button__link:hover,
.wp-block-button.is-style-btn-primary .wp-block-button__link:hover {
  background-color: var(--color-secondary-dark);
  color: var(--color-white);
  border-color: var(--color-white);
}

/* Secondary Button */
.wp-block-button.is-style-btn-secondary .wp-block-button__link {
  background-color: var(--color-primary-dark);
  color: var(--color-white);
  border-color: var(--color-white);
}

/* Secondary Button Hover */
.wp-block-button.is-style-btn-secondary .wp-block-button__link:hover {
  background-color: var(--color-secondary-dark);
  color: var(--color-white);
  border-color: var(--color-white);
}

/* Outline Button */
.wp-block-button.is-style-btn-outline .wp-block-button__link {
  background-color: transparent;
  color: var(--color-text);
  border-color: var(--color-primary-dark);
}

/* Outline Button Hover */
.wp-block-button.is-style-btn-outline .wp-block-button__link:hover {
  background-color: var(--color-primary-dark);
  color: var(--color-white);
  border-color: var(--color-primary-dark);
}


/* Next Arrow Button */
.wp-block-button.is-style-btn-next .wp-block-button__link {
  padding: 0;
  background-color: transparent;
  color: var(--color-text);
  border:none;
}

/* Next Arrow Button Icon*/
.wp-block-button.is-style-btn-next .wp-block-button__link::after {
  content: "\e904"; 
  font-family: 'arty-icons';
  font-size: 0.7em;
  margin-left: 0.5rem;
  vertical-align: middle;
  color: var(--color-text);
}

/* Next Arrow Button Hover */
.wp-block-button.is-style-btn-next .wp-block-button__link:hover {
  color: var(--color-primary);
}

/* Next Arrow Button Icon Hover */
.wp-block-button.is-style-btn-next .wp-block-button__link:hover::after {
  color: var(--color-primary); 
}


/* Prev Arrow Button */
.wp-block-button.is-style-btn-prev .wp-block-button__link {
  padding: 0;
  background-color: transparent;
  color: var(--color-text);
  border:none;
}

/* Prev Arrow Button Icon*/
.wp-block-button.is-style-btn-prev .wp-block-button__link::before {
  content: "\e904"; 
  font-family: 'arty-icons';
  font-size: 0.7em;
  margin-left: 0.5rem;
  vertical-align: middle;
  color: var(--color-text);
}

/* Prev Arrow Button Hover */
.wp-block-button.is-style-btn-prev .wp-block-button__link:hover {
  color: var(--color-primary);
}

/* Prev Arrow Button Icon Hover */
.wp-block-button.is-style-btn-prev .wp-block-button__link:hover::before {
  color: var(--color-primary); 
}



/* Default + Primary Button - Paddings tablet and mobile */
@media (max-width:767px) {
  .wp-block-button .wp-block-button__link,
  .wp-block-button.is-style-btn-default .wp-block-button__link,
  .wp-block-button.is-style-btn-primary .wp-block-button__link,
    .wp-block-button.is-style-btn-outline .wp-block-button__link {
    padding: 0.625rem 0.938rem;
  }
}




/* ================================================================================================================================================= 
   Icons
==================================================================================================================================================== */
/* Font Face */
@font-face {
  font-family: 'arty-icons';
  src:
    url('/wp-content/themes/breeze/assets/icons/fonts/arty-icons.eot') format('eot'),
    url('/wp-content/themes/breeze/assets/icons/fonts/arty-icons.woff') format('woff'),
    url('/wp-content/themes/breeze/assets/icons/fonts/arty-icons.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}

/* Base Icon Rendering - Before */
:is(
  [class^="icon-"],
  [class*=" icon-"],
  .has-icons a,
  .has-icons li,
  .has-icons button,
  .has-icons span,
  .has-icons .wp-block-button__link,
  .wp-block-button.is-style-link .wp-block-button__link,
  .site-nav a,
  .feature-list li,
  .sidebar-widget a
)::before {
  font-family: 'arty-icons';
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  display: inline-block;
  font-size: var(--icon-size, 1em);
  color: currentColor;
  vertical-align: var(--icon-valign, middle);
  margin-right: var(--icon-gap, 0.4em);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Base Icon Rendering - After */
:is(
  [class^="icon-after-"],
  [class*=" icon-after-"],
  .has-icons-after a,
  .has-icons-after li,
  .has-icons-after button,
  .has-icons-after span,
  .has-icons-after .wp-block-button__link,
  .wp-block-button.is-style-link .wp-block-button__link
)::after {
  font-family: 'arty-icons';
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  display: inline-block;
  font-size: var(--icon-size, 1em);
  color: currentColor;
  vertical-align: var(--icon-valign, middle);
  margin-left: var(--icon-gap, 0.4em);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Direct Icon Classes - Before */
.icon-minus:before {
  content: "\e900";
  color: #463a00;
}
.icon-plus:before {
  content: "\e901";
  color: #463a00;
}
.icon-chevron_down:before {
  content: "\e902";
}
.icon-chevron_up:before {
  content: "\e903";
}
.icon-double_arrow:before {
  content: "\e904";
  color: #7a776e;
}
.icon-fb:before {
  content: "\e905";
  color: #463a00;
}
.icon-ig:before {
  content: "\e906";
  color: #463a00;
}
.icon-menu_close:before {
  content: "\e907";
  color: #463a00;
}
.icon-menu_toggle:before {
  content: "\e908";
  color: #463a00;
}
.icon-pin:before {
  content: "\e909";
  color: #463a00;
}
.icon-share:before {
  content: "\e90a";
  color: #625d4e;
}
.icon-trip:before {
  content: "\e90b";
  color: #463a00;
}
.icon-twt:before {
  content: "\e90c";
  color: #463a00;
}
.icon-zoom:before {
  content: "\e90d";
  color: #f7f6f4;
}


/* Direct Icon Classes - After */
.icon-after-minus:after {
  content: "\e900";
  color: #463a00;
}
.icon-after-plus:after {
  content: "\e901";
  color: #463a00;
}
.icon-after-chevron_down:after {
  content: "\e902";
}
.icon-after-chevron_up:after {
  content: "\e903";
}
.icon-after-double_arrow:after {
  content: "\e904";
  color: #7a776e;
}
.icon-after-fb:after {
  content: "\e905";
  color: #463a00;
}
.icon-after-ig:after {
  content: "\e906";
  color: #463a00;
}
.icon-after-menu_close:after {
  content: "\e907";
  color: #463a00;
}
.icon-after-menu_toggle:after {
  content: "\e908";
  color: #463a00;
}
.icon-after-pin:after {
  content: "\e909";
  color: #463a00;
}
.icon-after-share:after {
  content: "\e90a";
  color: #625d4e;
}
.icon-after-trip:after {
  content: "\e90b";
  color: #463a00;
}
.icon-after-twt:after {
  content: "\e90c";
  color: #463a00;
}
.icon-after-zoom:after {
  content: "\e90d";
  color: #f7f6f4;
}

/* ================================================================================================================================================= 
   Blockquotes
==================================================================================================================================================== */
/* Grouped Selectors */
.wp-block-quote,
blockquote {
  display: flex;
  flex-direction: column;
  gap: 0.75em;
  margin: 1.5em 0; /* Ensures proper spacing when not using Gutenberg */
  width: 75%;
  color: var(--color-text);
  font-weight: 400;
}

/* to support 2 colours on svg - need to use bg img */
.wp-block-quote::before,
blockquote::before {
  content: '';
  display: block;
  margin-top: .25rem;
  width: 3em;
  height: 3em;
  flex-shrink: 0;
  background-image: url('/wp-content/themes/breeze/assets/icons/quotes.svg');
  background-repeat: no-repeat;
  background-size: contain;
}

/* Grouped Media Query */
@media (min-width: 768px) {
  .wp-block-quote,
  blockquote {
    flex-direction: row;
    align-items: flex-start;
    gap: 0; /* Added gap for the row layout to separate icon from text */
  }

  .wp-block-quote::before,
  blockquote::before {
    flex-shrink: 0;
  }
}

blockquote {
  border-left: none;
  margin-block-start: 0;
  padding-left: 0;
  font-weight: 500;
  font-size: var(--e-global-typography-6d86073-font-size);
  line-height: var(--e-global-typography-6d86073-line-height);
  letter-spacing: var(--e-global-typography-6d86073-letter-spacing);
  color: var(--e-global-color-primary);
  font-style: var(--e-global-typography-6d86073-font-style);
  margin: 2rem 0;
}

/* ================================================================================================================================================= 
   Boxes
==================================================================================================================================================== */
/* stretched link */
.box {
  position: relative;
  overflow: hidden !important; 
  /* This is the magic rule! It strictly chops off the invisible giant link so it doesn't cover other grid items */
  clip-path: inset(0);
}



/* Stretch the link to cover the entire .box */
.box .heading-box .box-title h3 a::before {
  content: "";
  position: absolute;
width: 200vw; 
  height: 200vh;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 10; /* Ensures the clickable area sits on top of the image */
}


/* Icon box title */
.box .heading-box .box-title h3::after {
  /* This ensures the icon targets the text span specifically */
  content: "\e904"; 
  font-family: 'arty-icons';
  font-size: 0.7em;
  margin-left: 0.5rem;
  vertical-align: middle;
  color: var(--color-grey-700);
}


/* Image Zoom */
.box-img .elementor-widget-container {
  overflow: hidden;
}

/* Set up the image for a smooth transition */
.box-img .elementor-widget-container img {
  transition: transform 0.3s ease;
  display: block;
  width: 100%;
  height: auto;
}

/* Apply the scale effect on hover */
.box:hover .box-img .elementor-widget-container img {
  transform: scale(1.05); /* Increase or decrease this value to adjust zoom intensity */
}


/* ================================================================================================================================================= 
   Breadcrumbs
==================================================================================================================================================== */

/* Styling the breadcrumb icon specifically */
.breadcrumb .elementor-icon-list-text::after,
.breadcrumb .jet-listing-dynamic-field__content a::after,
.breadcrumb .jet-listing-dynamic-terms a::after {
  /* This ensures the icon targets the text span specifically */
  content: "\e904"; 
  font-family: 'arty-icons';
  font-size: 0.8em;
  margin-left: 0.5rem;
  vertical-align: middle;
}

/* Optional: If you want to remove the default icon list bullet/icon */
.breadcrumb .elementor-icon-list-icon {
  display: none !important;
}

.breadcrumb .jet-listing-dynamic-field__content {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center!important;
}

.breadcrumb .jet-listing-dynamic-field__content a {
  margin-top: 0.35rem !important;
}

/* breadcrumbs text */
.breadcrumb .elementor-icon-list-text,
.breadcrumb .jet-listing-dynamic-field__content,
.breadcrumb .jet-listing-dynamic-field__content a,
.breadcrumb .jet-listing-dynamic-terms a {
    font-family: var(--e-global-typography-595342a-font-family), Sans-serif;
    font-size: var(--e-global-typography-595342a-font-size)!important;
    font-weight: var(--e-global-typography-595342a-font-weight);
    text-transform: var(--e-global-typography-595342a-text-transform);
    line-height: var(--e-global-typography-595342a-line-height)!important;
    letter-spacing: var(--e-global-typography-595342a-letter-spacing);
    color:var(--color-grey-700);
}

/* breadcrumbs hover */
.breadcrumb .jet-listing-dynamic-field__content a:hover,
.breadcrumb .jet-listing-dynamic-terms a:hover {
  color:var(--color-primary);
}


/* ================================================================================================================================================= 
   Media + Text
==================================================================================================================================================== */
/* Base layout */
.elementor-widget-container .wp-block-media-text {
  position: relative;
  direction: ltr;
  display: grid;
  gap: 5rem;
  margin: 3rem 0;
  padding: 0;
  overflow: hidden;
  color: var(--e-global-color-text);
}

.elementor-widget-container > .wp-block-media-text.has-media-on-the-right {
    grid-template-columns: 1fr 45%;
}
.elementor-widget-container > .wp-block-media-text {
    grid-template-columns: 45% 1fr;
}

/*** Media & Text -- (top level / non-canvas) ***/
.elementor-widget-container > .wp-block-media-text .wp-block-media-text__content {
  padding: 0;
  color: var(--e-global-color-text);
}

/* Media wrapper */
.elementor-widget-container > .wp-block-media-text__media {
  position: relative;
  overflow: hidden;
}

/* Image */
.elementor-widget-container > .wp-block-media-text img {
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: center;
  display: block;
  border-radius: 0;
  max-height: 650px;
}

@media (max-width: 575px) {
/* Stack all Media & Text blocks */
  .elementor-widget-container > .wp-block-media-text {
    display: flex !important;
    flex-direction: column;
    gap: 1rem;
  }

  /* Image */
  .elementor-widget-container > .wp-block-media-text__media img {
    width: 100%;
    height: auto;
    max-height: 450px;
  }

  /* Default mobile order: image first */
  .elementor-widget-container > .wp-block-media-text__media,
  .elementor-widget-container > .wp-block-media-text.has-media-on-the-right .wp-block-media-text__media {
    order: -1;
    width: 100%;
  }
  .elementor-widget-container > .wp-block-media-text__content,
  .elementor-widget-container > .wp-block-media-text.has-media-on-the-right .wp-block-media-text_content {
    order: 2;
  }

  /* 🔁 Reversed mobile style */
  .elementor-widget-container > .wp-block-media-text.is-style-reversed-mobile .wp-block-media-text__media {
    order: 2;
  }

  .elementor-widget-container > .wp-block-media-text.is-style-reversed-mobile .wp-block-media-text__content {
    order: -1;
  }
}


/* ===================================================================================================================================================
   Cards
==================================================================================================================================================== */

/* Base Card Styles */
.card {
  word-break: break-word;
  /*aspect-ratio: 1 / 1;*/
  width: 100%;
  max-width: 300px;
  gap: 1rem;
  position: relative;
  cursor: pointer;
}

/* Card Heading Line Clamp */
.card.card-type-default h3 {
  -webkit-line-clamp: 3;
  line-clamp: 3;
  text-overflow: ellipsis;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}

/* Card Heading >> Icon */
.card.card-listing .card-title h3::after,
.card.card-collection .card-title h3::after,
.card.card-blog .card-title h3::after {
  content: "\e904";
  font-family: 'arty-icons';
  font-size: 0.5em;
  margin-left: 0.5rem;
  vertical-align: middle;
  font-weight: 400;
  color: var(--color-grey-700);
}

/* Card Img */
.card .featured img {
  aspect-ratio: 1 / 1;
  object-fit: cover;
  object-position: center;
  border-radius: 2px;
  transition: filter 0.3s ease;
}


/* Card Img — listing variant shows original proportions */
/* Img Container */
.card.card-listing .img-container {
  aspect-ratio: 1 / 1;
  width: 100%;
  max-width: 300px;
  height: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

/* Mobile — let img container size naturally */
@media (max-width: 576px) {
  .card.card-listing {
    aspect-ratio: auto;
    height: auto;
  }

  .card.card-listing .img-container {
    aspect-ratio: auto;
    max-width: 100%;
  }

  .card.card-listing .featured img {
    aspect-ratio: auto;
    width: 100%;
    height: auto;
    object-fit: contain;
  }
}

/* Img inside — natural size, centered, no crop */
.card.card-listing .img-container img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center;
}

/* Card Img Hover */
.card:hover .featured img {
  filter: brightness(0.6);
}

/* Cards inside Grids specifically */
.jet-listing-grid__items .card {
}

/* Cards inside Carousels specifically */
.carousel .jet-listing-grid__items .card {

}


/* blog/exhibition card date range */
.blog-hero .date-range .elementor-shortcode {
  color: var(--color-grey-700);
}
.card-blog .date-range .elementor-shortcode {
  color: var(--color-grey-600);
  font-size: 1rem;
}


/* ================================================================================================================================================= 
   Carousels
==================================================================================================================================================== */
.jet-listing-grid__loader {
	display:none;
}

.carousel {
	position: relative;
  overflow: visible;
}
    
.carousel .jet-listing-grid {
	margin-right: -1rem;	
	margin-left: 0rem;
  overflow: hidden;
}

.carousel .jet-listing-grid__item:nth-of-type(1) {
	margin-left: 3rem;
}


/* Hide Prev Arrow on first slide and Next Arrow on last slide */
.carousel .prev-arrow.slick-disabled,
.carousel .next-arrow.slick-disabled {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
}


@media (min-width: 992px) {
  .carousel .jet-listing-grid { 
    margin-right: calc((50% - 50vw) + 0.5rem);
    margin-left: 0rem;
  } 
  
  .carousel .jet-listing-grid__item:nth-of-type(1) {
    margin-left: 3rem;
  }
  
  .carousel .jet-listing-grid .jet-listing-grid__items {
    width: calc(100% + 1rem) !important;
  } 

  /* Fade Out Effect applied strictly to the slider track so arrows bypass it */
  .carousel .slick-list {
    -webkit-mask-image: linear-gradient(to right, black 90%, transparent 100%);
    mask-image: linear-gradient(to right, black 90%, transparent 100%);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
  }

  /* Navigation Arrows Logic */
  .carousel .prev-arrow,
  .carousel .next-arrow {
    opacity: 0.85;
    display: flex; /* Flex used for easy icon centering */
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 50%;
    padding: -1rem;
    transform: translateY(-50%); /* Exact centering */
    z-index: 100;
    cursor: pointer !important;
    color: var(--color-primary-dark);
    background: radial-gradient(circle, var(--color-white) 0%, var(--color-white) 35%, transparent 80%);
    border-radius: 100%;
    transition: all 0.3s ease;
    font-size: 0;
  }

  .carousel .prev-arrow {
    left: 20px;
    background-image: url('/wp-content/themes/breeze/assets/icons/chevron-left-regular-full.svg');
  }

  .carousel .next-arrow {
    right: calc((50% - 50vw) + 0.5rem);
    background-image: url('/wp-content/themes/breeze/assets/icons/chevron-right-regular-full.svg');
  }

  .carousel .prev-arrow:hover,
  .carousel .next-arrow:hover {
    opacity: 1;
    color: var(--color-grey-800);
  }
}

/* Mobile/Tablet Styles (Hide Arrows and Remove Gradient) */
@media (max-width: 991px) {
  .carousel .prev-arrow,
  .carousel .next-arrow {
    display: none;
  }
  
  /* Ensure mask is disabled on the slick-list for mobile */
  .carousel .slick-list {
    -webkit-mask-image: none;
    mask-image: none;
  }

  /* Eliminate space from the main grid container */
  .carousel .jet-listing-grid,
  .carousel .jet-listing-grid__items {
    padding-top: 0 !important;
    margin-top: 0 !important;
    gap: 0 !important;
  }
}

/**** Carousel Item/Cards *****/
.carousel .jet-listing-grid__item {
    flex: none !important; 
    max-width: 350px !important;  
}

@media (min-width: 768px) {
  .carousel .jet-listing-grid__item {
    flex: 0 0 calc(var(--content-width) / 3) !important; 
    max-width: calc(var(--content-width) / 3) !important; 
  }
}

@media (min-width: 1440px) {
  .carousel .jet-listing-grid__item {
    flex: 0 0 calc(var(--content-width) / 4) !important; 
    max-width: calc(var(--content-width) / 4) !important; 
  }
} 





/* ================================================================================================================================================= 
   Grid
==================================================================================================================================================== */
/* JetEngine Listing Grid: 4 cols on XL screens */
@media (min-width: 1440px) {
   .grid.grid-listing .jet-listing-grid .jet-listing-grid__items.grid-col-desk-3,
   .grid.grid-blog .jet-listing-grid .jet-listing-grid__items.grid-col-desk-3 {
      --columns: 4!important;
  }
}

/* JetEngine Listing Grid: 1 column for screens 635px and narrower */
@media (max-width: 635px) {
  .jet-listing-grid .jet-listing-grid__items {
    --columns: 1;
  }
}

/* JetEngine Listing Grid: 2 columns for screens starting at 636px up to 767px */
@media (min-width: 636px) and (max-width: 767px) {
  .jet-listing-grid .jet-listing-grid__items {
    --columns: 2;
  }
}




/* ================================================================================================================================================= 
   Listing Grid + Carousel
==================================================================================================================================================== */
.carousel .jet-listing-grid .jet-listing-grid__items,
.grid.grid-listing .jet-listing-grid__items {
  display: flex;
  align-items: stretch;
  width: 100%; /* Ensures the track fills the container */
}

.carousel .jet-listing-grid .jet-listing-grid__items {
  flex-wrap: nowrap;
}

.carousel .jet-listing-grid .jet-listing-grid__item {
  min-width: 350px;
  min-height: 350px;
  flex: 0 0 350px; 
  height: auto;
  width: 350px;
  display: flex;
  flex-direction: column;
}


.carousel .jet-listing-grid .card-wrapper,
.grid.grid-listing .card-wrapper,
/* Front and Back Shared */
.jet-listing-grid .card-wrapper .card-front {
  width: 100%;
  flex: 1;
  aspect-ratio: 1 / 1 !important;
  position: relative;
  flex: 1;
}

.grid .grid.grid-listing .jet-listing-grid__item {
  min-width: 350px;
}

/* Ensure faces fill the square */
.carousel .jet-listing-grid .card-wrapper .card.inner,
.grid.grid-listing .card-wrapper .card-inner,
.carousel .card-wrapper .card-inner,
.carousel .card-wrapper .card-front,
.carousel .card-wrapper .card-back,
.jet-listing-grid .card-wrapper .card-back  {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.carousel .jet-slick-dots {
  width: 100% !important;
  display: block;
  margin-top: 30px;
}
  






/* ================================================================================================================================================= 
   Image Block
==================================================================================================================================================== */

.wp-block-image.alignwide {
  margin-inline: unset;
}


/* =================================================================================
   Gallery - Lightbox
================================================================================= */
.scrim {
  background-color: var(--color-grey-500);
}

.wp-lightbox-container button:focus,
.wp-lightbox-container button:hover,
.wp-lightbox-container button:not(:hover):not(:active):not(.has-background) {
  background-color: var(--color-grey-500);
  border: none;
  display: none;
}

.wp-lightbox-overlay .close-button {
  color: var(--color-primary) !important;
}

.wp-lightbox-overlay .close-button svg {
  fill: currentColor !important;
}

.wp-lightbox-overlay .close-button svg path,
.wp-lightbox-overlay .close-button svg line,
.wp-lightbox-overlay .close-button svg rect {
  fill: currentColor !important;
  stroke: currentColor !important;
}

.wp-lightbox-overlay .close-button[style*="fill"] {
  fill: var(--color-primary) !important;
}

.wp-lightbox-overlay .wp-block-image img {
  border-radius: 4px;
}

/* Lightbox injected caption */
.wp-lightbox-overlay .custom-lightbox-caption {
  text-align: center;
  color: #333;
  font-size: 14px;
  margin-top: 0.75rem;
  padding: 0 1rem;
  font-style: italic;
}


/* =================================================================================
   Gallery - Grid
================================================================================= */
.wp-block-gallery {
  gap: 1rem !important;
  margin: 3rem auto;
}

.wp-block-gallery figure {
  margin: 0;
  overflow: hidden;
  border-radius: 2px;
}

.wp-block-gallery img {
  display: block;
  width: 100%;
  height: auto;
}

/* Hide captions on grid thumbnails — shown in lightbox only */
.wp-block-gallery.has-nested-images figure.wp-block-image figcaption {
  display: none !important;
}


/* =================================================================================
   Gallery - Masonry
================================================================================= */
.wp-block-gallery.is-style-masonry {
  display: block !important;
  column-gap: 1rem;
  column-count: var(--masonry-cols, 3);
}

.wp-block-gallery.is-style-masonry.columns-1 { --masonry-cols: 1; }
.wp-block-gallery.is-style-masonry.columns-2 { --masonry-cols: 2; }
.wp-block-gallery.is-style-masonry.columns-3 { --masonry-cols: 3; }
.wp-block-gallery.is-style-masonry.columns-4 { --masonry-cols: 4; }
.wp-block-gallery.is-style-masonry.columns-default { --masonry-cols: 3; }

.wp-block-gallery.is-style-masonry > figure {
  display: inline-block !important;
  width: 100% !important;
  padding-bottom: 1rem;
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
}

.wp-block-gallery.is-style-masonry > figure:last-child {
  padding-bottom: 0;
}

.wp-block-gallery.is-style-masonry > figure > img,
.wp-block-gallery.is-style-masonry > figure img,
.wp-block-gallery.is-style-masonry > figure > a,
.wp-block-gallery.is-style-masonry > figure > a > img,
.wp-block-gallery.is-style-masonry > figure > div,
.wp-block-gallery.is-style-masonry > figure > div > img {
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  display: block !important;
}


@media (max-width: 767px) {
  .wp-block-gallery.is-style-masonry {
    --masonry-cols: 2 !important;
  }
}


/* ================================================================================================================================================= 
   Accordions - Fixed & Consolidated
==================================================================================================================================================== */

/* Accordion Main Container */ 
.wp-block-accordion { 
  /* layout */ 
  --accordion-margin: 3rem; 
  --accordion-gap: 0.5rem; 
  --accordion-width: 900px; 
  /* border */ 
  --accordion-border: 1px solid var(--color-tertiary-dark); 
  /* typography */ 
  --accordion-title-color: var(--color-text); 
  --accordion-content-color: var(--color-text); 
  /* icon */ 
  --accordion-icon-size: 1.5rem; 
  margin: var(--accordion-margin) 0; 
  max-width: var(--accordion-width); 
} 

/* Accordion Item */ 
.wp-block-accordion .wp-block-accordion-item { 
  border-bottom: var(--accordion-border); 
  margin-bottom: 0; 
}

/* Accordion Button & Header */ 
.wp-block-accordion .wp-block-accordion-heading button { 
  display: flex; 
  justify-content: space-between; 
  align-items: center; 
  width: 100%; 
  padding: 0; 
  border-radius: 0; 
  border: none;
  background: transparent; 
  cursor: pointer; 
}

h3.wp-block-accordion-heading {
  margin: 0 auto;
}

/* Accordion Title Text */ 
.wp-block-accordion-heading__toggle-title { 
  color: var(--accordion-title-color); 
  text-align: left; 
  margin: 2rem auto;
  flex: 1 1 auto;
  min-width: 0;
  white-space: normal;
  overflow-wrap: break-word;
  font-size: var(--e-global-typography-45735d1-font-size);
  line-height: var(--e-global-typography-45735d1-line-height);
  letter-spacing: var(--e-global-typography-45735d1-letter-spacing);
  font-weight: var(--e-global-typography-45735d1-font-weight);
  text-transform: var(--e-global-typography-45735d1-text-transform);
  text-decoration: none !important;
}

.wp-block-accordion-heading__toggle-icon {
    align-items: center;
    display: flex;
    height: 2rem;
    justify-content: center;
    width: 2rem;
    font-size: 2rem;
    color: var(--color-primary);
}

/* Panel & Animations */
.wp-block-accordion .wp-block-accordion-item.is-open .wp-block-accordion-panel {
  padding-bottom: 2rem;
  animation: accordionFadeIn 0.35s ease;
}

@keyframes accordionFadeIn {
  from {
    opacity: 0;
    transform: translateY(-0.5rem);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* 7. Mobile Adjustments */
@media (max-width: 640px) {
  .wp-block-accordion-heading__toggle-title {
    margin: 1rem auto;
  }
  .wp-block-accordion .wp-block-accordion-heading button {
    align-items: flex-start;
    gap: 1.5rem;
  }
  .wp-block-accordion-heading__toggle-icon {
    margin-top: 0.2em;
  }
}


/* ================================================================================================================================================= 
   Image Carousel - Editor
==================================================================================================================================================== */

/* Base slider / swiper */
.wp-block-cb-carousel-v2.cb-carousel-block,
.wp-block-cb-carousel-v2.cb-carousel-block .swiper {
  width: 100%;
}

/* Use aspect ratio to define slider height */
.wp-block-cb-carousel-v2.cb-carousel-block .swiper {
  aspect-ratio: 16 / 9; /* adjust if needed */
  height: auto;
  position: relative;
  margin: 3rem auto !important;
}
@media (max-width: 575px) {
  .wp-block-cb-carousel-v2.cb-carousel-block .swiper {
    margin: 1rem auto !important;
  }
}
/* Slides should fill the swiper box */
.wp-block-cb-carousel-v2.cb-carousel-block .swiper-slide {
  position: relative;
  overflow: hidden;
  border-radius: 0; /* desktop radius */
  height: 100% !important; /* Force height to match the parent's aspect ratio */
  display: flex; /* Flexbox helps center the inner wrappers */
  align-items: center;
  justify-content: center;
}

/* Figure / image wrapper */
.wp-block-cb-carousel-v2.cb-carousel-block .swiper-slide figure,
.wp-block-cb-carousel-v2.cb-carousel-block .swiper-slide .wp-block-image {
  margin: 0 !important;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Image fills the slide */
.wp-block-cb-carousel-v2.cb-carousel-block .swiper-slide img {
  display: block;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain;
  object-position: center;
  border-radius: inherit; /* ensure image follows slide radius */
}

/* Pagination – overlay on image, centered bottom */
.wp-block-cb-carousel-v2.cb-carousel-block .swiper-pagination {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 1.25rem !important;
  z-index: 10 !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 0;
  pointer-events: auto;
}

/* Pagination bullets – desktop */
.wp-block-cb-carousel-v2.cb-carousel-block .swiper-pagination-bullet {
  width: 18px !important;
  height: 18px !important;
  border-radius: 999px;
  opacity: 0.55;
  margin: .75rem !important;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.45);
}

/* Active bullet */
.wp-block-cb-carousel-v2.cb-carousel-block
.swiper-pagination-bullet-active {
  background-color: var(--color-white)!important;
  opacity: 1;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.6);
}

/* Inactive bullets */
.wp-block-cb-carousel-v2.cb-carousel-block
.swiper-pagination-bullet {
  background-color: rgba(255, 255, 255, 0.75);
}

/* Mobile adjustments */
@media (max-width: 767px) {
  /* Slightly taller ratio on mobile */
  .wp-block-cb-carousel-v2.cb-carousel-block .swiper {
    aspect-ratio: 4 / 3;
  }
  /* Smaller radius on mobile */
  .wp-block-cb-carousel-v2.cb-carousel-block .swiper-slide {
    border-radius: 0;
  }
  /* Pagination tweaks */
  .wp-block-cb-carousel-v2.cb-carousel-block .swiper-pagination {
    bottom: 1rem !important;
    gap: 0;
  }
  .wp-block-cb-carousel-v2.cb-carousel-block .swiper-pagination-bullet {
    width: 20px !important;
    height: 20px !important;
  }
}


/* ================================================================================================================================================= 
   Image Carousel - Elementor
==================================================================================================================================================== */
/* Ensure each slide can define height */
.elementor-widget-image-carousel .swiper-slide {
  display: flex;
  align-items: stretch;
}

/* Force the inner wrapper to fill the slide */
.elementor-widget-image-carousel .swiper-slide-inner {
  width: 100%;
  height: 100%;
  margin: 0;
  display: block;
}

/* Pagination bullets position*/
.elementor-widget-n-carousel .swiper-pagination-bullets {
    bottom: 10px;
    top: unset;
}

/* Pagination bullets */
.swiper-pagination-bullet {
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.45);
}

/* Active bullet */
.swiper-pagination-bullet .swiper-pagination-bullet-active {
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.6);
}

/* Make the image behave like a background cover */
.elementor-widget-image-carousel .swiper-slide-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
@media (max-width: 767px) {
  /* Pagination bullets position*/
  .elementor-widget-n-carousel .swiper-pagination-bullets {
      bottom: 5px;
      top: unset;
  }
}
.elementor-widget-image-carousel .swiper {
  overflow: hidden;
} 


/* =============================================================
   Image Carousel — Listing Slider
============================================================= */

/* Slider wrapper */
.listing-slider {
  position: relative;
  width: 100%;
  max-width: 100%;
  margin: 0;
  left: auto;
  transform: none;
}

/* Prevent horizontal overflow only in the Elementor chain
   that contains this slider */
.elementor-element:has(> .elementor-widget-container > .listing-slider),
.elementor-element:has(.listing-slider) {
  max-width: 100%;
  overflow-x: clip;
}

/* Elementor widget structure */
.listing-slider > .elementor-widget-container,
.listing-slider .elementor-image-carousel-wrapper {
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
}

/* Swiper root */
.listing-slider .swiper,
.listing-slider .swiper-container {
  --slider-pagination-offset: 1rem;
  position: relative;
  width: 100%;
  max-width: 100%;
  overflow: visible;
}

/* Swiper track */
.listing-slider .swiper-wrapper {
  display: flex;
  align-items: stretch;
  box-sizing: border-box;
}

/* Slides */
.listing-slider .swiper-slide {
  flex-shrink: 0;
  box-sizing: border-box;
  opacity: 0.45;
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.listing-slider .swiper-slide-active {
  opacity: 1;
  z-index: 2;
}

.listing-slider .swiper-slide-prev,
.listing-slider .swiper-slide-next {
  opacity: 0.65;
}

/* Slide image */
.listing-slider .swiper-slide img {
  display: block;
  width: 100%;
  height: auto;
}

/* =============================================================
   Pagination - Keep dots positioned over the image
============================================================= */

/* Main pagination positioning */
.listing-slider .swiper-pagination,
.listing-slider .swiper-horizontal > .swiper-pagination-bullets,
.listing-slider .swiper-pagination-bullets.swiper-pagination-horizontal {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 3;
  width: 100%;
  margin: 0;
  line-height: 1;
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  transform: translateY(calc(-1 * var(--slider-pagination-offset)));
}

/* Bullet layout */
.listing-slider .swiper-pagination-bullets {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
}

.listing-slider .swiper-pagination-bullet {
  margin: 0;
}

/* Mobile adjustment */
@media (max-width: 767px) {
  .listing-slider .swiper,
  .listing-slider .swiper-container {
    --slider-pagination-offset: 0.75rem;
  }
}





/* ================================================================================================================================================= 
  Separator 
==================================================================================================================================================== */

.elementor hr,
hr,
.wp-block-separator {
  margin: 3rem auto;
  border-top: 1px solid var(--color-grey-500);
}


/* ================================================================================================================================================= 
   Sign Up Form Footer
==================================================================================================================================================== */
.signup-form .elementor-form-fields-wrapper {
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
}

.signup-form .elementor-field-type-email {
  flex: 1 1 auto;
  width: 0 !important;
}

.signup-form .elementor-field-type-submit {
  flex: 0 0 auto;
  width: auto !important;
}

input[type="submit"] {
  border-style: solid;
  border-width: 1px 1px 1px 1px;
  border-color: var(--e-global-color-primary);
  border-radius: 20rem 20rem 20rem 20rem;
  padding: 0.75rem 1.5rem 0.75rem 1.5rem;
}

@media (max-width: 767px) {
  .signup-form .elementor-form-fields-wrapper {
    flex-direction: column;
  }

  .signup-form .elementor-field-type-email,
  .signup-form .elementor-field-type-submit {
    width: 100% !important;
  }
}



/* ================================================================================================================================================= 
   Zoom Lightbox Artwork
==================================================================================================================================================== */
.elementor-lightbox {
  background-color: var(--color-grey-500);
}

/* Target the anchor tag wrapping the image — this is the right hook */
.zoom-hover-img .elementor-widget-container a {
  position: relative;
  display: block;
  overflow: hidden;
}

/* Zoom SVG icon — bottom right */
.zoom-hover-img .elementor-widget-container a::after {
  content: "";
  background-image: url('/wp-content/themes/breeze/assets/icons/zoom.svg');
  background-repeat: no-repeat;
  background-size: contain;
  width: 32px;
  height: 32px;
  position: absolute;
  bottom: 12px;
  right: 12px;
  transform: scale(0);
  opacity: 0;
  transition: all 0.3s ease;
  pointer-events: none;
  z-index: 10;
}

/* Show on hover */
.zoom-hover-img .elementor-widget-container a:hover::after {
  transform: scale(1);
  opacity: 1;
}

/* Optional: subtle image zoom */
.zoom-hover-img .elementor-widget-container a img {
  transition: transform 0.3s ease;
  display: block;
  width: 100%;
}
.zoom-hover-img .elementor-widget-container a:hover img {
  transform: scale(1.05);
}