/** Shopify CDN: Minification failed

Line 676:8 Expected identifier but found whitespace
Line 676:13 Unexpected ";"

**/
/* 
 * IO Theme Stylesheet - Optimized for Performance
 * Maintains all sizing, padding, width, height, and core structural elements
 * Optimized for better rendering performance and reduced CSS specificity
 */

/* Universal MainContent Fix - Apply to all pages */
#MainContent {
  display: block !important;
  margin-top: 0 !important;
  padding-top: 0 !important;
  position: relative !important;
  top: 0 !important;
  transform: none !important;
  align-items: flex-start !important;
  z-index: 5 !important;
}

/* Ensure correct layout for all page templates */
body {
  display: block !important;
  min-height: 100vh !important;
}

/* Ensure consistent header and footer positioning */
.shopify-section-group-header-group {
  position: relative !important;

}

.shopify-section-group-footer-group {
  position: relative !important;
  z-index: 1 !important;
}

/* Cart Page Fix - Comprehensive solution to ensure content aligns from top */
body.template-cart {
  display: block !important;
  min-height: 100vh !important;
  height: auto !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  align-items: stretch !important;
}

body.template-cart #MainContent {
  display: block !important;
  margin-top: 0 !important;
  padding-top: 0 !important;
  flex: 0 0 auto !important;
  position: relative !important;
  top: 0 !important;
  transform: none !important;
  align-items: flex-start !important;
  height: auto !important;
  min-height: 0 !important;
}

body.template-cart main,
body.template-cart .page-width {
  display: block !important;
  margin-top: 2rem !important;
  height: auto !important;
  min-height: auto !important;
  justify-content: flex-start !important;
  align-items: flex-start !important;
}

body.template-cart cart-items {
  display: block !important;
  min-height: 0 !important;
  position: relative !important;
  top: 0 !important;
  margin-top: 0 !important;
}

body.template-cart .cart {
  margin-bottom: 2rem !important;
  margin-top: 0 !important;
}

/* Fix for any flex container that might be pushing content down */
body.template-cart .main-cart-footer,
body.template-cart .cart__footer {
  position: relative !important;
  bottom: auto !important;
  margin-top: 0 !important;
}

/* Ensure cart items are visible */
body.template-cart .cart__items {
  opacity: 1 !important;
  visibility: visible !important;
}

/* Base Variables & Reset */
:root {
  --primary-color: #d79c6e;
  --accent-color: #be5c41;
  --text-color: #996c60;
  --dark-text: #615046;
  --frame-border: #B9A389;
  --mobile-width: calc(100% - 30px);
  --tablet-width: calc(100% - 100px);
  --desktop-width: 1100px;
  --radius-sm: 2px;
  --radius-md: 4px;
  --radius-lg: 5px;
  --shadow: 0px 2px 2px rgba(0, 0, 0, 0.3);
  --gradient-bg: linear-gradient(to top, #ffffff, #ffe1a5, #ffffff);
  
  /* Animation durations for consistent timing */
  --transition-fast: 0.1s;
  --transition-medium: 0.2s;
  --transition-slow: 0.3s;
  
  /* Common layout properties */
  --container-margin: 0 auto;
  --pinstripe-height: 3px;
}

/* Global Reset */
html, body {
  margin: 0 !important;
  padding: 0 !important;
  background: white !important;
  position: relative;
  min-height: 100%;
}



/* =============== LAYOUT & BACKGROUND STRUCTURE =============== */
/* Frame and gradient background - desktop only */
@media (min-width: 765px) {
  #gradient {
    position: absolute !important;
    display: flex;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: var(--gradient-bg) !important;
    z-index: -11111 !important;
    pointer-events: none !important;
    will-change: transform; /* Optimize for GPU acceleration */
  }

  #frame {
    position: absolute !important;
    display: flex !important;
    top: 0 !important;
    margin-top: 50px !important;
    bottom: 0 !important;
    left: calc(50% - 600px) !important;
    width: 1200px !important;
    border: 1px solid var(--frame-border) !important;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1) !important;
    background: white !important;
    pointer-events: none !important;
    z-index: -9999 !important;
    box-sizing: border-box !important;
    will-change: transform; /* Optimize for GPU acceleration */
  }

  .color-background-1,
  .isolate {
    background: transparent !important;
  }
}

/* =============== RESPONSIVE CONTAINER SYSTEM =============== */
/* Container base styles */
.custom-banner-wrapper,
.custom-banner-container,
.collectionlabel,
.pinstripe,
.pinstripe-long,
.pinstripe-white,
.salegif,
.animated-banner,
.review-container,
.about-us-text {
  margin: var(--container-margin);
  box-sizing: border-box;
  width: 100%;
  max-width: var(--desktop-width);
}

/* Mobile breakpoint: max-width 765px */
@media (max-width: 765px) {
  .custom-banner-container,
  .collectionlabel,
  .pinstripe,
  .salegif,
  .animated-banner,
  .review-container,
  .about-us-text {
    width: var(--mobile-width);
  }

  .svg-label {
    padding-bottom: 1rem !important;
    padding-left: 1rem !important;
    padding-top: 2rem !important;
    max-width: 70%;
  }
  
  .pinstripe-long,
  .pinstripe-white {
    width: 100vw;
  }
  
  .custom-banner-container {
    height: 35px;
  }
  
  .collectionlabel {
    height: 65px !important;
  }
  
  .collectionlabel.smaller {
    height: 40px !important;
  }
  
  .collectionlabel.smaller img {
    padding-top: 8px;
    padding-bottom: 4px;
  }
  
  .pinstripe, 
  .pinstripe-white {
    height: 2px;
    border-radius: 1px;
    display: flex;
    object-position: center;
  }
  
  .animated-banner {
    height: 80px;
  }
  
  .about-us-text {
    font-size: 16px;
  }
  
  .txt-lrg {
    font-size: 20x !important;
    -webkit-text-stroke: 0.5px #382710 !important;
  }

  
  .txt-med {
    font-size: 18px !important;
  }
  
  .svg-label {
    padding: 2rem 1rem 1.5rem;
  }
  
  .review-cards-wrapper {
    height: 360px;
  }
  
  .review-title-card {
    flex: 0 0 300px;
  }
  
  .review-iphone-card {
    flex: 0 0 200px;
  }
  
  .review-caption {
    font-size: 14px;
  }
  
  .review-star {
    width: 65%;
    margin: 0 0 12px 0;
  }
  
  .review-text {
    padding: 12px;
  }
}


  /* Product Description Font Sizes */
.product__description {
  font-size: 18px;
font-weight: 200;
}

@media screen and (min-width: 765px) {
  .product__description {
    font-size: 20px;
font-weight: 200;
  }
}

/* Tablet breakpoint: between 765px and 1199px */
@media (min-width: 765px) and (max-width: 1199px) {
  .custom-banner-container,
  .collectionlabel,
  .pinstripe,
  .salegif,
  .animated-banner,
  .review-container,
  .about-us-text {
    width: var(--tablet-width);
  }
  
  .pinstripe-long {
    width: 100%;
  }
  
  .custom-banner-container {
    height: 55px;
  }
}

/* Large screen styles */
@media (min-width: 768px) {
  .animated-banner {
    height: 160px !important;
  }
  
  .collectionlabel {
    height: 100px !important;
  }
  
  .review-cards-wrapper {
    height: 460px;
  }
  
  .review-title-card {
    flex: 0 0 500px;
  }
  
  .review-iphone-card {
    flex: 0 0 260px;
  }
}

@media (min-width: 1200px) {
  .custom-banner-container {
    height: 65px;
  }
  
  .salegif {
    height: 100px !important;
  }
}

/* =============== PINSTRIPES =============== */
.pinstripe-container {
  border-radius: var(--radius-lg);
  max-width: 100vw !important;
  margin: 0 auto;
  height: var(--pinstripe-height);
  overflow: visible;
  position: relative !important;
  z-index: 1 !important;
  transform: translateZ(0);
  contain: paint layout;
  pointer-events: none;
}

.pinstripe,
.pinstripe-long {
  height: var(--pinstripe-height);
  background-color: var(--primary-color);
  overflow: visible;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  contain: paint layout;
  pointer-events: none;
}

.pinstripe-white {
  margin: 0 auto;
  height: 2px;
  background-color: white;
  border-radius: 1px;
  display: flex;
  object-position: center;
  position: relative;
  z-index: 1;
  contain: paint layout;
  pointer-events: none;
}

/* Ensure pinstripes don't affect document flow */
header .pinstripe-container,
header .pinstripe,
header .pinstripe-long,
header .pinstripe-white {
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
}

/* Add spacing after pinstripes without affecting layout */
header .pinstripe-container::after,
header .pinstripe::after,
header .pinstripe-long::after,
header .pinstripe-white::after {
  content: '';
  display: block;
  height: var(--pinstripe-height);
  pointer-events: none;
}

/* =============== COLLECTION LABEL =============== */
.collectionlabel {
  display: flex !important;
  background-color: var(--accent-color) !important;
  filter: brightness(1.0) contrast(1.3);
  border-radius: var(--radius-lg) !important;
  overflow: hidden;
  box-shadow: var(--shadow) !important;
  margin-bottom: 6px !important;
  transition: filter var(--transition-fast) steps(2);
}

.collectionlabel img {
  width: 100% !important;
  height: 100% !important;
  border-radius: var(--radius-sm) !important;
  object-fit: contain !important;
  object-position: left !important;
}

.collectionlabel:hover {
  filter: brightness(1.05) contrast(1.3);
}



/* =============== SALE GIF =============== */
.salegif {
  display: flex !important;
  margin: 0 auto !important;
  background-color: #332a26 !important;
  transition: filter var(--transition-medium) ease;
  animation: brightness-pulse-slow 1s steps(2) infinite;
  border-radius: 4px !important;
  overflow: hidden;
  box-shadow: var(--shadow) !important;
}

.salegif img {
  width: 100% !important;
  height: 100% !important;
  border-radius: var(--radius-sm) !important;
  object-fit: contain !important;
  object-position: left !important;
}

.salegif:hover {
  animation: brightness-pulse 0.3s steps(2) infinite;
}

/* =============== ANIMATED BANNER =============== */
.animated-banner {
  border: 1.5px solid #be7373;

  overflow: hidden;
  background: #774242;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  display: flex;
  flex-direction: row;
  gap: 1px;
  cursor: default !important;
  will-change: transform; /* Optimize for GPU acceleration */
}

.banner-image {
  flex: 1;
  overflow: hidden;
    transition: filter var(--transition-medium) ease;
}

.banner-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;

      transform: scale(1.04);
  transition: filter var(--transition-medium) steps(3);
  will-change: transform, filter; /* Optimize for GPU acceleration */
  backface-visibility: hidden; /* Prevent flickering */
    transition: filter var(--transition-medium) ease;
}

.banner-image img:hover {
  filter: brightness(1.10);
        transform: scale(1.055);
    transition: filter var(--transition-medium) ease;
}

/* Banner image variations - consolidated for better performance */
.banner-image--one img { object-position: calc(50% + 0px) calc(50% - 15%); }
.banner-image--two img { object-position: calc(50% + 0px) calc(50% - 2%); }
.banner-image--three img { object-position: calc(50% + 0px) calc(50% - 22%); }
.animated-banner.about img { animation: scalePulse 9s steps(12) infinite; }
.bnr2 img { object-position: 0px 35% !important; }
.bnr3 img { object-position: 0px 31% !important; }
.bnr5 img { object-position: 0px 65% !important; }

/* =============== REVIEWS =============== */
.review-title-bar {
  width: 100%;
  overflow: hidden;
  white-space: nowrap;
  position: relative;
  display: inline-block;
  margin: 0;
  font-weight: 525;
  background: var(--dark-text);
  color: var(--dark-text) !important;
}

.review-title-bar h2 {
  display: inline-block;
  width: 100%;
  color: white !important;
  padding: 8px 0;
  white-space: nowrap;
  animation: marquee 16s linear infinite;
  margin: 0;
  font-size: 20px;
  font-weight: 625;
  font-family: 'Poppins', sans-serif;
  background: var(--dark-text);
}

.review-caption, .h3, .review-title {
  color: #926c63;
  width: 100%;
  text-align: left;
  margin: 0;
}

.review-title { font-size: 20px; }

.review-star {
  height: auto;
  width: 50%;
  margin: 8px 0 12px 0;
}

.review-cards-wrapper {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  gap: 8px !important;
  width: 100%;
  padding-bottom: 8px;
  background: transparent;
  flex-wrap: nowrap;
  overflow-x: auto;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
  scroll-snap-type: x mandatory;
  overscroll-behavior-x: contain; /* Prevent scroll chaining */
}

.review-cards-wrapper::-webkit-scrollbar { display: none; }

.review-card {
  width: 100%;
  height: 100%;
  margin: 0 auto;
  background: transparent !important;
  box-shadow: var(--shadow) !important;
  display: flex;
  flex-direction: row;
  position: relative;
}

.review-text {
  width: 55%;
  height: 100%;
  max-height: 100%;
  padding: 16px;
  background: white;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.review-title-card, .review-iphone-card {
  overflow: hidden;
  display: flex;
  flex-direction: column;
  scroll-snap-align: start;
  height: 100%;
}

.review-title-card {
  background: linear-gradient(to top, #fcc38a, #fff0e1, #fff);
  border: 1.5px solid #af8d81;
  border-radius: var(--radius-md);
  box-shadow: 0px 2px 6px rgba(0, 0, 0, 0.25);
}

.review-iphone-card {
  background: white;
  border-radius: var(--radius-md);
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.6);
}

.review-right {
  display: flex;
  max-height: 100%;
  width: 45%;
  margin: 8px;
  overflow: hidden;
  border: 1.5px solid #844e40;
  border-radius: 12px;
  box-shadow: var(--shadow) !important;
}

.review-right img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-medium) steps(4);
  overflow: hidden;
  transform-origin: center;
  border-radius: 8px;
  transform: scale(1.02);
  will-change: transform; /* Optimize for GPU acceleration */
}

.review-right img:hover { transform: scale(1.15); }

.review-confirm {
  width: 100%;
  height: auto;
  display: flex;
  margin-top: auto;
}

.review-confirm img {
  width: 100%;
  height: 100%;
  display: flex;
  margin-top: auto;
}

.slider-buttons {
  display: flex;
  gap: 8px;
  justify-content: center;
  align-items: center;
  margin: 1rem auto;
}

.slider-button {
background: linear-gradient(to top, #433225, #836147) !important;
  box-shadow: var(--shadow) !important;
}
  color: #fff;
  padding: 8px 14px;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  font-size: 14px;
  transition: background-color var(--transition-fast) ease;
}



.review-iphone-title-bar {
  background: var(--dark-text);
  color: white;
  padding: 12px 16px;
  font-family: 'Poppins', sans-serif;
  font-weight: 625;
}

.review-iphone-media {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.review-iphone-media img, .review-iphone-media video {
  width: 101%;
  height: 101%;
  object-fit: cover;
  transition: transform var(--transition-medium) ease-in-out;
  pointer-events: none;
  will-change: transform; /* Optimize for GPU acceleration */
}

.review-iphone-media img:hover, .review-iphone-media video:hover {
  transform: scale(1.05);
}

.instagram-logo {
  position: absolute;
  bottom: 12px;
  right: 12px;
  width: 20px !important;
  height: 20px !important;
  max-width: 40px;
  max-height: 40px;
  z-index: 10;
}

/* =============== SLIDER =============== */
.slider-component-desktop {
  position: relative !important;
  isolation: isolate !important;
  box-sizing: content-box !important;
  overflow: visible !important;
  width: 100% !important;
  z-index: 10050 !important;
  min-height: 0 !important;
  contain: layout; /* Improve performance */
}

.slider-component-desktop::after, .slider-component-desktop::before {
  content: '' !important;
  position: fixed !important;
  top: 0 !important;
  bottom: 0 !important;
  height: auto !important;
  width: 100vw !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  pointer-events: none !important;
  z-index: 10050 !important;
  box-sizing: border-box !important;
  will-change: opacity; /* Optimize for GPU acceleration */
}

.slider-component-desktop::after {
  left: calc(50% + 550px) !important;
  background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 10%, white 100%) !important;
}

.slider-component-desktop::before {
  right: calc(50% + 550px) !important;
  background: linear-gradient(-90deg, transparent 0%, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 10%, white 100%) !important;
}

@media (max-width: 1100px) {
  .slider-component-desktop::after, .slider-component-desktop::before {
    display: none !important;
  }
}

.slider-component-desktop .slider-track, .slider-component-desktop .slider-container {
  overflow: visible !important;
  box-sizing: border-box !important;
  margin: 0 !important;
  contain: content; /* Improve performance */
}

/* =============== ABOUT US TEXT =============== */
.about-us-text {
  font-size: 26px;
  color: var(--text-color);
  padding: 0;
  line-height: 1.8;
  cursor: default !important;
}

p {
  padding-bottom: 12px;
  height: 100%;
  margin: 0;
}

/* =============== TEXT STYLES =============== */
.txt-lrg {
  font-size: 40px;
  background-color: #995844;
  padding: 6px 12px;
  border-radius: var(--radius-md);
  color: #382710;
  box-shadow: var(--shadow) !important;
  font-weight: 300;
  animation: textColorAnimation 1.5s infinite alternate;
  -webkit-text-stroke: 1px #382710;
  cursor: default !important;
  transition: filter var(--transition-fast) ease;
}

.txt-lrg:hover { filter: brightness(1.1); }

.txt-med {
  font-size: 30px !important;
  color: #49453b;
  -webkit-text-stroke: 1px #49453b !important;
  box-shadow: -1px 1px 1px rgba(0, 0, 0, 0.5) !important;
  padding: 6px 6px 4px 6px;
  background-color: #fffca0;
  letter-spacing: 1.25px;
  border-radius: 0;
  transition: filter var(--transition-fast) ease;
}



.txt-med:hover { filter: brightness(0.82) contrast(1.5) !important; }
.tm2 { background-color: #ffa0a2 !important; }

/* =============== SVG & IMAGE ELEMENTS =============== */
.svg-label {
  fill: white !important;
  filter: brightness(0) invert(1);
  padding-bottom: 1.5rem;
  padding-left: 1.5rem;
  padding-top: 2.5rem;
  display: flex;
}

.img-large img { transform: scale(140%) !important; }

/* =============== MISCELLANEOUS =============== */
.link { color: white !important; }

.pagination__item.link {
  background-color: white;
  color: #7d421a !important;
}

.pagination__item.pagination__item--current.light {
  color: #bd4c00 !important;
}

.swiper-slide.xo-grid-item.no-effect.swiper-slide-active, .imagebox {
  border-radius: 6px !important;
  box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.4);
}

.swiper-container { padding-bottom: 8px !important; }

/* =============== ANIMATIONS =============== */
@keyframes marquee {
  from { transform: translateX(40%); }
  to { transform: translateX(-100%); }
}

@keyframes scalePulse {
  0%, 100% { transform: scale(1.04); }
  50% { transform: scale(1.09); }
}

@keyframes brightness-pulse {
  0% { filter: brightness(1.0); }
  50% { filter: brightness(1.25); }
  100% { filter: brightness(1.0); }
}

@keyframes brightness-pulse-slow {
  0% { filter: brightness(1.00); }
  50% { filter: brightness(1.35); }
  100% { filter: brightness(1.00); }
}

@keyframes textColorAnimation {
  0% { color: #382710; }
  100% { color: #583010; }
}

/* Print styles - hide animations and reduce colors for better printing */
@media print {
  * {
    animation: none !important;
    transition: none !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }
  
  body, html {
    background: white !important;
    color: black !important;
  }
  
  .animated-banner, .salegif, .review-cards-wrapper {
    break-inside: avoid;
  }
}

/* Remove all previous fixes */
section.section.pinstripe {
  display: block;
  height: auto;
  min-height: 0;
  max-height: none;
  padding: 0;
  line-height: 0;
  font-size: 0;
  overflow: visible;
}

/* Specific fix for footer sections */
footer section.section {
  display: block;
  padding: 0;
  line-height: 0;
  font-size: 0;
  overflow: visible;
}

/* Reset for non-pinstripe sections */
section.section:not(.pinstripe) {

  font-size: initial;
}

.full-unstyled-link {

  color: #6B1616 !important;
}




.label-text {
    font-size: 56px;
    color: #fff;

    padding: 0px 0px 8px 12px;
    letter-spacing: 0.1rem;
    transition: filter var(--transition-fast)ease;
      -webkit-text-stroke: 1px white !important;
  font-weight: 500;
}

.kern-fix {
    letter-spacing: 0.4rem !important;
}



@media (max-width: 768px) {
  .label-text {
    font-size: 36px !important;
        letter-spacing: 0.03rem;
  }
  .kern-fix {
    letter-spacing: 0.2rem !important;
}


}


  





/* Ensure GIFs in banners always display properly */
.banner img[src*=".gif"],
.custom-banner img[src*=".gif"],
.swiper-slide img[src*=".gif"],
img.banner-image[src*=".gif"] {
  object-fit: cover;
  width: 100%;
  height: 100%;
  max-width: 100%;
  display: block;
  opacity: 1 !important;
}

/* Force images to display even if there's a loading issue */
.banner img,
.custom-banner img,
.swiper-slide img,
img.banner-image {
  min-height: 30px;
  min-width: 30px;
  background-color: rgba(240, 240, 240, 0.2);
}

.quickadd {
padding: 0 !important;
  border: 0 !important;
  float: right;
  box-shadow: 0 0 0 .1rem #9d7979 !important;
  bottom: 0 !important;
  position: absolute;
  right: 0;
  margin-right: 1rem;
  margin: 0 1rem 1rem 0;
z-index: 8000;
  cursor: pointer;
}

.quickadd::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url('/cdn/shop/files/leak-overlay-small.gif?v=1740949901');
  background-size: cover;
  background-position: center;
  opacity: 1;
  pointer-events: none;
  mix-blend-mode: soft-light;
  transition: opacity 0.3s ease;
  border-radius: 0px !important;
  transition: animation 1s ease;
}

.quickadd:hover {
transform: scale(1.05);
  transition: transform 0.5s ease;
  
}

.formspacer {
margin-top: 2rem;

}


