/** Shopify CDN: Minification failed

Line 707:0 Unexpected "}"

**/
/* ========================================
   Grid View Section
   ======================================== */

/* Base Section Styles */
.grid-view {
  background-color: var(--section-bg, #ffffff);
  padding-top: var(--spacing-top);
  padding-bottom: var(--spacing-bottom);
  overflow: hidden;
  width: 100%;
}

.grid-view__container {
  width: 100%;
  overflow: hidden;
}

.grid-view--full-width .grid-view__container {
  width: 100%;
  max-width: 100%;
}

/* Contained - with side padding */
.grid-view--contained {
  padding-left: 12px;
  padding-right: 12px;
}

@media screen and (min-width: 750px) {
  .grid-view--contained {
    padding-left: 16px;
    padding-right: 16px;
  }
}

.grid-view--contained .grid-view__container {
  width: 100%;
}

/* Full width: no gap, no border-radius on cards */
.grid-view--full-width .grid-view__grid {
  gap: 0;
}

.grid-view--full-width .grid-view__card {
  border-radius: 0;
}

/* ========================================
   Grid Layout
   ======================================== */
.grid-view__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  width: 100%;
}

@media screen and (min-width: 750px) {
  .grid-view__grid--1-items {
    grid-template-columns: 1fr;
  }
  
  .grid-view__grid--2-items {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .grid-view__grid--3-items {
    grid-template-columns: repeat(3, 1fr);
  }
  
  /* 4 items: 2x2 grid */
  .grid-view__grid--4-items {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, 1fr);
  }
}

/* ========================================
   Mobile Carousel
   ======================================== */
@media screen and (max-width: 749px) {
  .grid-view--mobile-carousel .grid-view__carousel {
    display: flex;
    flex-wrap: nowrap;
    gap: 12px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding-bottom: 4px;
  }
  
  .grid-view--mobile-carousel .grid-view__carousel::-webkit-scrollbar {
    display: none;
  }
  
  .grid-view--mobile-carousel .grid-view__carousel .grid-view__item {
    flex: 0 0 85%;
    scroll-snap-align: center;
    min-width: 0;
  }
  
  .grid-view--mobile-carousel .grid-view__carousel.is-grabbing {
    cursor: grabbing;
    scroll-snap-type: none;
  }

  /* Full width: no gap in mobile carousel */
  .grid-view--full-width.grid-view--mobile-carousel .grid-view__carousel {
    gap: 0;
  }
  
  .grid-view--mobile-carousel .grid-view__carousel:not(.is-grabbing) {
    cursor: grab;
  }
}

/* ========================================
   Grid Item
   ======================================== */
.grid-view__item {
  width: 100%;
}

/* ========================================
   Card Styles
   ======================================== */
.grid-view__card {
  position: relative;
  width: 100%;
  height: var(--card-height, auto);
  aspect-ratio: var(--card-aspect-ratio, auto);
  min-height: 300px;
  border-radius: 12px;
  overflow: hidden;
}

@media screen and (min-width: 750px) {
  .grid-view__card {
    border-radius: 16px;
    min-height: 350px;
  }
}

/* Card Media (Background Image/Video) */
.grid-view__card-media-link {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 3;
  display: block;
}

.grid-view__card-media {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

/* Desktop/Mobile media visibility */
.grid-view__card-media--desktop {
  display: none;
}

.grid-view__card-media--mobile {
  display: block;
}

@media screen and (min-width: 750px) {
  .grid-view__card-media--desktop {
    display: block;
  }
  
  .grid-view__card-media--mobile {
    display: none;
  }
}

.grid-view__card-image,
.grid-view__card-video {
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform;
}

.grid-view__card:hover .grid-view__card-image,
.grid-view__card:hover .grid-view__card-video {
  transform: scale(1.04);
}

.grid-view__card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Card Video */
.grid-view__card-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.grid-view__card-video--iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  transform: translate(-50%, -50%);
}

/* Scale iframe to cover container (videos have 16:9 aspect ratio by default) */
@supports (aspect-ratio: 16/9) {
  .grid-view__card-video--iframe {
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto;
    aspect-ratio: 16/9;
  }
}

/* Fallback for browsers without aspect-ratio support */
@supports not (aspect-ratio: 16/9) {
  .grid-view__card-video--iframe {
    min-width: 177.78vh; /* 16:9 ratio */
    min-height: 56.25vw;
  }
}

.grid-view__card-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #f5f5f5;
}

.grid-view__card-placeholder .placeholder-svg {
  width: 60%;
  height: 60%;
  fill: #cccccc;
}

/* Card Overlay */
.grid-view__card-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--card-overlay, #000000);
  opacity: var(--card-overlay-opacity, 0.2);
  z-index: 2;
  pointer-events: none;
}

/* ========================================
   Card Content
   ======================================== */
.grid-view__card-content {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 3;
  display: flex;
  padding: 24px;
  box-sizing: border-box;
  pointer-events: none;
}

@media screen and (min-width: 750px) {
  .grid-view__card-content {
    padding: 32px;
  }
}

/* Content Positioning */
.grid-view__card-content--top-left {
  justify-content: flex-start;
  align-items: flex-start;
}

.grid-view__card-content--top-center {
  justify-content: center;
  align-items: flex-start;
}

.grid-view__card-content--top-right {
  justify-content: flex-end;
  align-items: flex-start;
}

.grid-view__card-content--center-left {
  justify-content: flex-start;
  align-items: center;
}

.grid-view__card-content--center-center {
  justify-content: center;
  align-items: center;
}

.grid-view__card-content--center-right {
  justify-content: flex-end;
  align-items: center;
}

.grid-view__card-content--bottom-left {
  justify-content: flex-start;
  align-items: flex-end;
}

.grid-view__card-content--bottom-center {
  justify-content: center;
  align-items: flex-end;
}

.grid-view__card-content--bottom-right {
  justify-content: flex-end;
  align-items: flex-end;
}

/* Text Container */
.grid-view__card-text {
  display: flex;
  flex-direction: column;
  align-items: inherit;
  gap: 12px;
  max-width: 100%;
}

.grid-view__card-content--top-center .grid-view__card-text,
.grid-view__card-content--center-center .grid-view__card-text,
.grid-view__card-content--bottom-center .grid-view__card-text {
  align-items: center;
  text-align: center;
}

.grid-view__card-content--top-right .grid-view__card-text,
.grid-view__card-content--center-right .grid-view__card-text,
.grid-view__card-content--bottom-right .grid-view__card-text {
  align-items: flex-end;
  text-align: right;
}

/* Title */
.grid-view__card-title {
  font-family: var(--heading-font);
  font-size: var(--font-size-3xl);
  font-weight: var(--heading-weight);
  font-style: italic;
  line-height: var(--line-height-snug);
  letter-spacing: var(--heading-letter-spacing);
  margin: 0;
  color: var(--title-color, #ffffff);
}

@media screen and (min-width: 750px) {
  .grid-view__card-title {
    font-size: var(--font-size-4xl);
  }
}

/* Description */
.grid-view__card-description {
  font-family: var(--body-font);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-normal);
  margin: 0;
  color: var(--description-color, #ffffff);
  max-width: 300px;
}

@media screen and (min-width: 750px) {
  .grid-view__card-description {
    font-size: var(--font-size-base);
  }
}

/* ========================================
   Button Styles
   ======================================== */
.grid-view__card-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 24px;
  min-height: var(--button-min-height, 44px);
  font-family: var(--ui-font);
  font-size: var(--button-font-size);
  font-weight: var(--ui-weight);
  letter-spacing: var(--ui-letter-spacing);
  text-transform: uppercase;
  text-decoration: none;
  border-radius: var(--button-border-radius, 0);
  cursor: pointer;
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
  margin-top: 4px;
  width: auto;
  position: relative;
  z-index: 4;
  pointer-events: auto;
}

/* Button Styles - Primary (uses theme settings) */
.grid-view__button--primary {
  background-color: var(--color-button-primary-bg, #1a1a1a);
  color: var(--color-button-primary-text, #ffffff);
  border: 1px solid var(--color-button-primary-border, #1a1a1a);
}

.grid-view__button--primary:hover {
  background-color: var(--color-button-primary-bg-hover, #333333);
  color: var(--color-button-primary-text-hover, #ffffff);
}

/* Button Styles - Secondary (uses theme settings) */
.grid-view__button--secondary {
  background-color: var(--color-button-secondary-bg, transparent);
  color: var(--color-button-secondary-text, #1a1a1a);
  border: 1px solid var(--color-button-secondary-border, #1a1a1a);
}

.grid-view__button--secondary:hover {
  background-color: var(--color-button-secondary-bg-hover, #1a1a1a);
  color: var(--color-button-secondary-text-hover, #ffffff);
}

/* Button Styles - Tertiary (uses theme settings) */
.grid-view__button--tertiary {
  background-color: transparent;
  color: var(--color-button-tertiary-text, #1a1a1a);
  border: none;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.grid-view__button--tertiary:hover {
  color: var(--color-button-tertiary-text-hover, #666666);
}

/* Button Styles - Link (uses theme settings) */
.grid-view__button--link {
  background-color: transparent;
  color: var(--color-button-link-text, #1a1a1a);
  border: none;
  padding: 8px 0;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--color-button-link-underline, #1a1a1a);
}

.grid-view__button--link:hover {
  color: var(--color-button-link-text-hover, #666666);
  text-decoration-color: var(--color-button-link-text-hover, #666666);
}

/* ========================================
   Empty State
   ======================================== */
.grid-view__empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 300px;
  background-color: #f5f5f5;
  border-radius: 12px;
}

.grid-view__empty p {
  color: #666666;
  font-family: var(--body-font);
  font-size: var(--font-size-base);
  margin: 0;
}

/* ========================================
   Content Layout: Overlay vs Below
   ======================================== */

/* Default: Content Below is hidden */
.grid-view__content-below {
  display: none;
}

/* Default: Overlay content is shown */
.grid-view__card-content--overlay {
  display: flex;
}

/* --- MOBILE LAYOUT --- */
@media screen and (max-width: 749px) {
  /* Mobile: Below layout */
  .grid-view__item--mobile-below .grid-view__card-content--overlay {
    display: none;
  }
  
  .grid-view__item--mobile-below .grid-view__content-below {
    display: block;
  }
  
  .grid-view__item--mobile-below .grid-view__card-overlay {
    display: none;
  }
  
  /* Mobile: Overlay layout (default) */
  .grid-view__item--mobile-overlay .grid-view__card-content--overlay {
    display: flex;
  }
  
  .grid-view__item--mobile-overlay .grid-view__content-below {
    display: none;
  }
}

/* --- DESKTOP LAYOUT --- */
@media screen and (min-width: 750px) {
  /* Desktop: Below layout */
  .grid-view__item--desktop-below .grid-view__card-content--overlay {
    display: none;
  }
  
  .grid-view__item--desktop-below .grid-view__content-below {
    display: block;
  }
  
  .grid-view__item--desktop-below .grid-view__card-overlay {
    display: none;
  }
  
  /* Desktop: Overlay layout (default) */
  .grid-view__item--desktop-overlay .grid-view__card-content--overlay {
    display: flex;
  }
  
  .grid-view__item--desktop-overlay .grid-view__content-below {
    display: none;
  }
}

/* ========================================
   Content Below Styles
   ======================================== */
.grid-view__content-below {
  padding: 16px 0 0;
}

.grid-view__content-below-inner {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Title Below */
.grid-view__title-below {
  font-family: var(--heading-font);
  font-size: var(--font-size-xl);
  font-weight: var(--heading-weight);
  font-style: italic;
  line-height: var(--line-height-snug);
  letter-spacing: var(--heading-letter-spacing);
  margin: 0;
  color: var(--title-color-below, #1a1a1a);
}

@media screen and (min-width: 750px) {
  .grid-view__title-below {
    font-size: var(--font-size-2xl);
  }
}

/* Description Below */
.grid-view__description-below {
  font-family: var(--body-font);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-normal);
  margin: 0;
  color: var(--description-color-below, #666666);
}

@media screen and (min-width: 750px) {
  .grid-view__description-below {
    font-size: var(--font-size-base);
  }
}

/* Button Below */
.grid-view__button-below {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  padding: 8px 24px;
  min-height: var(--button-min-height, 44px);
  font-family: var(--ui-font);
  font-size: var(--button-font-size);
  font-weight: var(--ui-weight);
  letter-spacing: var(--ui-letter-spacing);
  text-transform: uppercase;
  text-decoration: none;
  border-radius: var(--button-border-radius, 0);
  cursor: pointer;
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
  margin-top: 8px;
  width: auto;
}

/* Button Below inherits the same button styles */
.grid-view__button-below.grid-view__button--primary {
  background-color: var(--color-button-primary-bg, #1a1a1a);
  color: var(--color-button-primary-text, #ffffff);
  border: 1px solid var(--color-button-primary-border, #1a1a1a);
}

.grid-view__button-below.grid-view__button--primary:hover {
  background-color: var(--color-button-primary-bg-hover, #333333);
  color: var(--color-button-primary-text-hover, #ffffff);
}

.grid-view__button-below.grid-view__button--secondary {
  background-color: var(--color-button-secondary-bg, transparent);
  color: var(--color-button-secondary-text, #1a1a1a);
  border: 1px solid var(--color-button-secondary-border, #1a1a1a);
}

.grid-view__button-below.grid-view__button--secondary:hover {
  background-color: var(--color-button-secondary-bg-hover, #1a1a1a);
  color: var(--color-button-secondary-text-hover, #ffffff);
}

.grid-view__button-below.grid-view__button--tertiary {
  background-color: transparent;
  color: var(--color-button-tertiary-text, #1a1a1a);
  border: none;
  text-decoration: underline;
  text-underline-offset: 3px;
  padding: 8px 0;
}

.grid-view__button-below.grid-view__button--tertiary:hover {
  color: var(--color-button-tertiary-text-hover, #666666);
}

.grid-view__button-below.grid-view__button--link {
  background-color: transparent;
  color: var(--color-button-link-text, #1a1a1a);
  border: none;
  padding: 8px 0;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--color-button-link-underline, #1a1a1a);
}

.grid-view__button-below.grid-view__button--link:hover {
  color: var(--color-button-link-text-hover, #666666);
  text-decoration-color: var(--color-button-link-text-hover, #666666);
}

/* ========================================
   Carousel Counter
   ======================================== */
.grid-view__counter {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  font-family: var(--heading-font);
  font-size: var(--font-size-3xl);
  font-weight: var(--heading-weight);
  color: #1a1a1a;
  margin-top: 24px;
}

/* Hide counter on desktop */
@media screen and (min-width: 750px) {
  .grid-view__counter {
    display: none;
  }
}

.grid-view__counter-current,
.grid-view__counter-total {
  min-width: 1.5ch;
  text-align: center;
}

.grid-view__counter-separator {
  opacity: 0.6;
}
}
