/** Shopify CDN: Minification failed

Line 1973:0 Unexpected "}"

**/
/* Optimized Non-Critical CSS - Deferred Load */
/* Navigation */
.main-nav {
  display: none;
  gap: 2rem;
  font-size: .875rem
}

@media (min-width:768px) {
  .main-nav {
    display: flex
  }
}

.nav-link {
  color: #fff;
  text-decoration: none;
  transition: color .3s
}

.nav-link:hover {
  color: #fff
}

.cart-link:hover {
  background: #8b5cf6;
  transform: translateY(-1px);
  color: #fff
}

.explore-mobile-app-btn:hover {
  background: rgba(255, 255, 255, .3);
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgba(0, 0, 0, .2);
  border-color: rgba(255, 255, 255, .5);
  color: #fff
}

/* Animations moved from critical CSS */
.floating-cards .card {
  position: relative;
  padding: 0;
  background: 0 0;
  backdrop-filter: none;
  border-radius: 15px;
  border: none;
  cursor: pointer;
  transition: transform .3s ease;
  animation: abstractFloat 6s ease-in-out infinite;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center
}

.floating-cards .card img {
  transition: all .3s ease
}

.floating-cards .card:hover {
  box-shadow: 0 0 30px rgba(255, 255, 255, .7);
  transform: scale(1.05)
}

.floating-cards .card:hover img {
  transform: scale(1.1);
  filter: drop-shadow(0 20px 40px rgba(0, 0, 0, .3))
}

.floating-cards .card:nth-child(1) {
  animation-delay: 0s
}

.floating-cards .card:nth-child(2) {
  animation-delay: -1s
}

.floating-cards .card:nth-child(3) {
  animation-delay: -2s
}

.floating-cards .card:nth-child(4) {
  animation-delay: -3s
}

.floating-cards .card:nth-child(5) {
  animation-delay: -4s
}

.floating-cards .card:nth-child(6) {
  animation-delay: -5s
}

@keyframes abstractFloat {

  0%,
  100% {
    transform: translateY(0) rotate(0) scale(1)
  }

  25% {
    transform: translateY(-15px) rotate(3deg) scale(1.02)
  }

  50% {
    transform: translateY(-30px) rotate(0) scale(1.05)
  }

  75% {
    transform: translateY(-15px) rotate(-3deg) scale(1.02)
  }
}

.hero::before {
  content: "";
  position: absolute;
  width: 50px;
  height: 50px;
  background: rgba(255, 255, 255, .3);
  border-radius: 50%;
  top: 10%;
  left: 20%;
  animation: floatElement1 10s ease-in-out infinite;
  pointer-events: none;
  z-index: 1
}

@keyframes floatElement1 {

  0%,
  100% {
    transform: translate(0, 0) rotate(0)
  }

  25% {
    transform: translate(10px, -20px) rotate(45deg)
  }

  50% {
    transform: translate(0, -40px) rotate(90deg)
  }

  75% {
    transform: translate(-10px, -20px) rotate(135deg)
  }
}

@keyframes gradientShift {
  0% {
    background-position: 0 50%
  }

  50% {
    background-position: 100% 50%
  }

  100% {
    background-position: 0 50%
  }
}

/* Product Section Base */
.product-section {
  padding: 4rem 0 6rem;
  background: #e6e0f0;
  color: #333
}

.product-category-title,
.collection-title,
.category-title,
.collection-banner-title {
  font-size: clamp(2.5rem, 5vw, 4rem);
  text-align: left;
  color: #18181b;
  margin-bottom: 2rem;
  position: relative;
  display: inline-block;
  font-family: Poppins, sans-serif;
  font-weight: 800;
  letter-spacing: -.02em;
  transform: rotate(-1deg);
  z-index: 0
}

.you-may-like-title {
  font-family: Poppins, sans-serif;
  font-weight: 800;
  font-size: 2rem;
  letter-spacing: -.01em;
  transform: rotate(-0.5deg)
}

.sketch-underline {
  font-family: Poppins, sans-serif;
  position: relative;
  display: inline-block;
  z-index: 0;
  font-weight: 800
}

.sketch-underline::after {
  content: "";
  position: absolute;
  bottom: 2px;
  left: -10px;
  right: -10px;
  height: 15px;
  z-index: -1;
  background-image: url('data:image/svg+xml,%3csvg width="200" height="12" viewBox="0 0 200 12" fill="none" xmlns="http://www.w3.org/2000/svg"%3e%3cpath d="M2 5.89249C31.5513 3.66524 63.8583 3.19361 94.6133 4.67385C125.368 6.15409 157.828 8.0538 198 9.5" stroke="%23A78BFA" stroke-width="4" stroke-linecap="round"/%3e%3cpath d="M2 8.89249C31.5513 6.66524 63.8583 6.19361 94.6133 7.67385C125.368 9.15409 157.828 11.0538 198 12.5" stroke="%23A78BFA" stroke-width="4" stroke-linecap="round"/%3e%3c/svg%3e');
  background-repeat: no-repeat;
  background-size: 100% 100%;
  transform: rotate(-.5deg);
  pointer-events: none
}

/* Product Grid */
.product-grid-container {
  position: relative;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 1rem;
  overflow: visible
}

@media (min-width:640px) {
  .product-grid-container {
    padding: 0 1.5rem
  }
}

@media (min-width:1024px) {
  .product-grid-container {
    padding: 0 2rem
  }
}

@media (max-width:767px) {
  .product-grid-container {
    padding: 0 1rem;
    overflow: visible;
    position: relative;
    max-width: none;
    margin: 0 auto
  }

  .product-section {
    overflow: visible;
    position: relative
  }
}

.horizontal-scroll {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 400px));
  justify-content: center;
  gap: 2rem;
  padding: 1.875rem 0 2rem
}

@media (max-width:767px) {
  .horizontal-scroll {
    grid-template-columns: 1fr;
    gap: 1rem;
    padding: 1rem;
    overflow: visible;
    scroll-snap-type: none;
    -webkit-overflow-scrolling: auto;
    touch-action: auto;
    margin: 0;
    width: 100%
  }

  .horizontal-scroll::-webkit-scrollbar {
    display: auto
  }

  .horizontal-scroll>.product-card {
    scroll-snap-align: none;
    flex-shrink: 1;
    width: 100%;
    pointer-events: auto;
    will-change: auto;
    transform: none
  }
}

/* Product Card - Optimized for Conversion */
.product-card {
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  transition: all .3s cubic-bezier(.4, 0, .2, 1);
  cursor: pointer;
  color: #333;
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06)
}

.product-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, .15), 0 4px 8px rgba(0, 0, 0, .1)
}

.product-image-container {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: #fff
}

.product-image {
  width: 100%;
  height: auto;
  display: block;
  transition: transform .5s cubic-bezier(.4, 0, .2, 1)
}

.product-card:hover .product-image {
  transform: scale(1.08)
}

.product-glow {
  display: none
}

.product-info {
  padding: 1.25rem;
  position: relative;
  z-index: 2;
  background: #fff;
  display: flex;
  flex-direction: column;
  gap: .75rem
}

.product-title {
  font-size: 1rem;
  font-weight: 600;
  color: #1f2937;
  font-family: Poppins, sans-serif;
  margin: 0;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.8em
}

.product-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  margin-top: auto
}

.product-price {
  font-family: Arial, sans-serif;
  display: flex;
  align-items: baseline;
  gap: .5rem;
  flex-wrap: wrap
}

.product-price-current {
  font-size: 1.25rem;
  font-weight: 700;
  color: #18181b;
  font-family: Arial, sans-serif
}

.product-price-old {
  font-size: .875rem;
  color: #9ca3af;
  text-decoration: line-through;
  font-family: Arial, sans-serif
}

/* Product Buttons - High Conversion Design */
.product-cart-controls {
  display: flex;
  width: 100%;
  gap: .5rem
}

.product-add-to-cart-btn,
.product-remove-from-cart-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .375rem;
  padding: .625rem 1rem;
  border: none;
  border-radius: 8px;
  font-size: .8125rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .2s cubic-bezier(.4, 0, .2, 1);
  flex: 1;
  min-height: 40px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .1)
}

.product-add-to-cart-btn {
  background: linear-gradient(135deg, #10b981 0%, #059669 100%);
  color: #fff
}

.product-add-to-cart-btn:hover {
  background: linear-gradient(135deg, #059669 0%, #047857 100%);
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(16, 185, 129, .3)
}

.product-add-to-cart-btn:active {
  transform: translateY(0)
}

.product-remove-from-cart-btn {
  background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
  color: #fff
}

.product-remove-from-cart-btn:hover {
  background: linear-gradient(135deg, #d97706 0%, #b45309 100%);
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(245, 158, 11, .3)
}

.product-remove-from-cart-btn:active {
  transform: translateY(0)
}

.product-add-to-cart-btn.loading,
.product-remove-from-cart-btn.loading {
  opacity: .7;
  cursor: not-allowed;
  transform: none
}

.product-add-to-cart-btn.added {
  background: linear-gradient(135deg, #059669 0%, #047857 100%)
}

.product-add-to-cart-btn.sold-out {
  background: #e5e7eb;
  color: #9ca3af;
  cursor: not-allowed
}

.product-add-to-cart-btn svg,
.product-remove-from-cart-btn svg {
  width: 14px;
  height: 14px
}

.product-add-to-cart-btn .btn-text,
.product-remove-from-cart-btn .btn-text {
  font-size: .8125rem;
  font-weight: 600
}

.product-add-to-cart-btn.hidden,
.product-remove-from-cart-btn.hidden {
  display: none
}

/* Product Details */
.product-details-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 3rem 1.5rem;
  margin-top: 4rem;
  overflow: visible
}

@media (max-width:767px) {
  .product-details-container {
    padding: 2rem 1rem;
    margin-top: 3rem;
    max-width: 100vw;
    overflow-x: visible;
    box-sizing: border-box
  }
}

.product-details-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem
}

@media (min-width:768px) {
  .product-details-grid {
    grid-template-columns: 1fr 1fr
  }
}

.product-gallery {
  display: flex;
  flex-direction: column
}

.main-image-container {
  aspect-ratio: 1;
  width: 100%;
  overflow: hidden;
  border-radius: 1rem;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  justify-content: center
}

.main-image {
  height: 100%;
  width: 100%;
  object-fit: contain;
  object-position: center
}

.thumbnail-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem
}

.thumbnail-button {
  aspect-ratio: 1;
  width: 100%;
  overflow: hidden;
  border-radius: .5rem;
  border: 2px solid transparent;
  cursor: pointer;
  transition: border-color .3s;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  background: 0 0
}

.thumbnail-button.active {
  border-color: var(--brand)
}

.thumbnail-image {
  height: 100%;
  width: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: .25rem
}

@media (max-width: 767px) {
  .thumbnail-grid {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 0.5rem;
    gap: 0.75rem;
    -webkit-overflow-scrolling: touch;
  }

  .thumbnail-button {
    flex: 0 0 80px;
    scroll-snap-align: start;
    width: 80px;
  }
}

.product-info-section {
  display: flex;
  flex-direction: column
}

.product-details-title {
  font-size: 2.5rem;
  font-weight: 700;
  color: #18181b;
  margin-bottom: 1rem;
  line-height: 1.2;
  letter-spacing: -.02em
}

@media (max-width:767px) {
  .product-details-title {
    font-size: 1.75rem
  }
}

.product-details-price {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-bottom: 1rem
}

.product-details-price-current {
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--brand);
  font-family: Arial, sans-serif
}

@media (max-width:767px) {
  .product-details-price-current {
    font-size: 2rem
  }
}

.product-details-price-old {
  font-size: 1.5rem;
  color: #71717a;
  text-decoration: line-through;
  font-family: Arial, sans-serif
}

@media (max-width:767px) {
  .product-details-price-old {
    font-size: 1.25rem
  }
}

.delivery-info {
  font-size: 1rem;
  font-weight: 600;
  color: #059669;
  margin-bottom: 1.5rem;
  padding: .75rem 1rem;
  background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
  border-radius: 8px;
  border: 1px solid #10b981;
  display: inline-block
}

.rating-section {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: 1.5rem;
  padding: .5rem 0
}

.star {
  width: 1.5rem;
  height: 1.5rem;
  fill: #facc15;
  color: #facc15
}

.rating-count {
  margin-left: .25rem;
  font-size: 1rem;
  color: #374151;
  font-weight: 500
}

.feature-list {
  list-style: none;
  margin: 2rem 0;
  padding: 0;
  background: #f9fafb;
  border-radius: 12px;
  padding: 1.5rem
}

.feature-item {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-bottom: 1rem;
  font-size: 1rem;
  color: #18181b;
  font-weight: 500
}

.feature-item:last-child {
  margin-bottom: 0
}

.check-icon {
  width: 1.5rem;
  height: 1.5rem;
  color: var(--brand);
  flex-shrink: 0
}

.video-container {
  margin: 1.5rem 0;
  aspect-ratio: 16/9;
  width: 100%;
  overflow: hidden;
  border-radius: .75rem
}

.video-iframe {
  height: 100%;
  width: 100%;
  border: none
}

.purchase-section {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-top: 2rem
}

@media (max-width:480px) {
  .purchase-section {
    gap: .75rem
  }
}

@media (max-width:390px) {
  .purchase-section {
    gap: .5rem
  }

  .quantity-selector {
    min-width: auto
  }
}

.quantity-selector {
  display: flex;
  align-items: center;
  border-radius: 9999px;
  border: 1px solid #cbd5e1;
  padding: .25rem;
  background-color: var(--site-bg);
  flex-shrink: 0;
  width: auto
}

.quantity__button {
  border-radius: 50%;
  padding: .5rem;
  background: 0 0;
  border: none;
  cursor: pointer;
  transition: background-color .3s;
  display: flex;
  align-items: center;
  justify-content: center
}

.quantity__button:hover {
  background-color: #cbd5e1
}

.quantity__input {
  width: 2.5rem;
  text-align: center;
  font-weight: 500;
  background: 0 0;
  border: none;
  font-family: inherit
}

.buy-now-button {
  flex: 1;
  border-radius: 12px;
  padding: 1rem 1.5rem;
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  box-shadow: 0 10px 25px -5px rgba(0, 0, 0, .2);
  transition: all .3s;
  border: none;
  cursor: pointer;
  position: relative;
  background: var(--buy-now-green);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-height: 56px
}

@media (max-width:767px) {
  .buy-now-button {
    padding: .875rem 1.25rem;
    font-size: .9375rem;
    min-height: 52px
  }
}

.buy-now-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 15px 30px -5px rgba(0, 0, 0, .25)
}

.buy-now-button:disabled {
  opacity: .6;
  cursor: not-allowed;
  transform: none
}

.add-to-cart-btn {
  background: var(--add-to-cart-green) !important;
  flex: 1;
  white-space: nowrap;
  min-height: 56px
}

@media (max-width:767px) {
  .add-to-cart-btn {
    min-height: 52px
  }
}

.add-to-cart-btn:hover {
  background: var(--add-to-cart-hover) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 15px 30px -5px rgba(0, 0, 0, .25) !important
}

.btn-buy-now {
  background: var(--buy-now-green) !important;
  flex: 1;
  white-space: nowrap;
  min-height: 56px
}

@media (max-width:767px) {
  .btn-buy-now {
    min-height: 52px
  }
}

.btn-buy-now:hover {
  background: #036644 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 15px 30px -5px rgba(0, 0, 0, .25) !important
}

/* Loading Animation */
.loading-overlay__spinner {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%)
}

.spinner {
  width: 20px;
  height: 20px;
  animation: spin 1s linear infinite
}

@keyframes spin {
  0% {
    transform: rotate(0)
  }

  100% {
    transform: rotate(360deg)
  }
}

.spinner .path {
  stroke: currentColor;
  stroke-linecap: round;
  animation: dash 1.5s ease-in-out infinite
}

@keyframes dash {
  0% {
    stroke-dasharray: 1, 150;
    stroke-dashoffset: 0
  }

  50% {
    stroke-dasharray: 90, 150;
    stroke-dashoffset: -35
  }

  100% {
    stroke-dasharray: 90, 150;
    stroke-dashoffset: -124
  }
}

/* Related Products */
.related-products {
  margin-top: 4rem;
  width: 100%;
  padding: 0;
  overflow: visible
}

.related-products-title {
  font-size: clamp(2.5rem, 5vw, 4rem);
  text-align: left;
  color: #18181b;
  margin-bottom: 2rem;
  position: relative;
  display: inline-block;
  font-family: Poppins, sans-serif;
  font-weight: 800;
  letter-spacing: -.02em;
  transform: rotate(-0.75deg);
  z-index: 0;
  padding: 0 1rem
}

.related-products-title .sketch-underline {
  font-family: Poppins, sans-serif;
  position: relative;
  display: inline-block;
  z-index: 0;
  font-weight: 800
}

.related-products-title .sketch-underline::after {
  content: "";
  position: absolute;
  bottom: 2px;
  left: -10px;
  right: -10px;
  height: 15px;
  z-index: -1;
  background-image: url('data:image/svg+xml,%3csvg width="200" height="12" viewBox="0 0 200 12" fill="none" xmlns="http://www.w3.org/2000/svg"%3e%3cpath d="M2 5.89249C31.5513 3.66524 63.8583 3.19361 94.6133 4.67385C125.368 6.15409 157.828 8.0538 198 9.5" stroke="%23A78BFA" stroke-width="4" stroke-linecap="round"/%3e%3cpath d="M2 8.89249C31.5513 6.66524 63.8583 6.19361 94.6133 7.67385C125.368 9.15409 157.828 11.0538 198 12.5" stroke="%23A78BFA" stroke-width="4" stroke-linecap="round"/%3e%3c/svg%3e');
  background-repeat: no-repeat;
  background-size: 100% 100%;
  transform: rotate(-.5deg);
  pointer-events: none
}

.related-products-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 400px));
  justify-content: center;
  gap: 2rem;
  padding: 1.875rem 0 2rem
}

@media (max-width:767px) {
  .related-products {
    margin-top: 3rem;
    padding: 0;
    overflow: visible
  }

  .related-products-title {
    padding: 0 1rem;
    margin-bottom: 1.5rem
  }

  .related-products-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
    padding: 0 1rem;
    margin: 0;
    width: 100%;
    max-width: 100vw;
    overflow: visible;
    box-sizing: border-box;
    scroll-snap-type: none;
    -webkit-overflow-scrolling: auto;
    touch-action: auto
  }

  .related-products-grid::-webkit-scrollbar {
    display: auto
  }

  .related-products-grid>.product-card {
    scroll-snap-align: none;
    flex-shrink: 1;
    width: 100%;
    pointer-events: auto;
    will-change: auto;
    transform: none;
    margin: 0;
    box-sizing: border-box
  }
}

/* Accordion */
.accordion-item {
  border-bottom: 1px solid rgba(91, 33, 182, .5)
}

.accordion-button {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 0;
  text-align: left;
  background: 0 0;
  border: none;
  cursor: pointer;
  font-weight: 500;
  color: #18181b;
  font-family: inherit
}

.accordion-icon {
  height: 1.25rem;
  width: 1.25rem;
  transition: transform .3s
}

.accordion-icon.rotated {
  transform: rotate(180deg)
}

.accordion-content {
  overflow: hidden;
  transition: max-height .3s
}

.accordion-content.open {
  max-height: 200px
}

.accordion-content.closed {
  max-height: 0
}

.accordion-content-inner {
  padding-bottom: 1rem;
  color: #374151
}

/* Cart Notification */
.cart-notification {
  position: fixed;
  top: 100px;
  right: 20px;
  z-index: 1000;
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, .1);
  padding: 1.5rem;
  max-width: 400px;
  width: 90vw;
  transform: translateX(100%);
  transition: transform .3s
}

.cart-notification.active {
  transform: translateX(0)
}

.cart-notification__wrapper {
  display: flex;
  flex-direction: column;
  gap: 1rem
}

.cart-notification__header {
  display: flex;
  justify-content: space-between;
  align-items: center
}

.cart-notification__heading {
  font-size: 1.125rem;
  font-weight: 600;
  color: #18181b
}

.cart-notification__close {
  background: 0 0;
  border: none;
  cursor: pointer;
  padding: .25rem;
  color: #6b7280
}

.cart-notification__product {
  display: flex;
  gap: 1rem;
  align-items: center
}

.cart-notification__product-image img {
  width: 60px;
  height: 60px;
  object-fit: contain;
  border-radius: 4px
}

.cart-notification__links {
  display: flex;
  gap: .5rem;
  flex-direction: column
}

/* Testimonials */
.testimonials-section {
  border-top: 1px solid rgba(91, 33, 182, .5);
  padding: 4rem 0 6rem
}

.testimonials-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 1.5rem
}

.testimonials-header {
  margin-bottom: 2.5rem
}

.eyebrow {
  font-size: .6875rem;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: #71717a;
  margin-bottom: .5rem
}

.testimonials-title {
  margin-top: .5rem;
  font-size: 1.5rem;
  font-weight: 600;
  letter-spacing: -.025em;
  color: #18181b
}

@media (min-width:768px) {
  .testimonials-title {
    font-size: 1.875rem
  }
}

.testimonials-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem
}

@media (min-width:640px) {
  .testimonials-grid {
    grid-template-columns: repeat(3, 1fr)
  }
}

.testimonial-card {
  border-radius: 1rem;
  padding: 1.5rem;
  background-color: var(--card-bg)
}

.testimonial-text {
  font-size: .875rem;
  color: #1f2937;
  margin-bottom: .75rem
}

.testimonial-footer {
  margin-top: .75rem;
  font-size: .75rem;
  color: #52525b
}

/* Page Content */
.page-container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 4rem 1rem;
  margin-top: 4rem
}

.page-hero {
  padding: 4rem 0;
  text-align: center
}

.page-hero-container {
  max-width: 1024px;
  margin: 0 auto;
  padding: 0 1rem
}

.page-title {
  font-size: 2.25rem;
  font-weight: 700;
  letter-spacing: -.025em;
  color: var(--brand)
}

@media (min-width:640px) {
  .page-title {
    font-size: 3rem
  }
}

.page-content {
  max-width: 1280px;
  margin: 0 auto;
  padding: 4rem 1rem
}

.content-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem
}

@media (min-width:1024px) {
  .content-grid {
    grid-template-columns: 1fr 1fr;
    gap: 4rem
  }
}

.content-section {
  display: flex;
  flex-direction: column;
  gap: 1.5rem
}

.section-title {
  font-size: 1.875rem;
  font-weight: 700;
  color: #18181b
}

.section-text {
  color: #374151;
  line-height: 1.75
}

.section-image {
  border-radius: .5rem;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);
  max-width: 300px;
  height: auto
}

/* Contact */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem
}

@media (min-width:768px) {
  .contact-grid {
    grid-template-columns: repeat(2, 1fr)
  }
}

@media (min-width:640px) {
  .contact-grid {
    gap: 2rem
  }
}

.contact-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  border-radius: .75rem;
  border: 1px solid #e5e7eb;
  padding: 1.5rem;
  text-align: center;
  transition: all .3s;
  background: #fff;
  text-decoration: none;
  color: inherit
}

.contact-card:hover {
  border-color: #c4b5fd;
  background-color: #faf5ff
}

.contact-icon-container {
  border-radius: 50%;
  background: #ede9fe;
  padding: 1rem;
  transition: background-color .3s
}

.contact-card:hover .contact-icon-container {
  background: #ddd6fe
}

.contact-icon {
  height: 2rem;
  width: 2rem;
  color: var(--brand)
}

.contact-text {
  font-weight: 600;
  color: #1f2937;
  word-break: break-words
}

/* Cart Page */
.cart-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 4rem 1rem;
  margin-top: 4rem
}

.cart-title {
  font-size: 2rem;
  font-weight: 700;
  color: #18181b;
  margin-bottom: 2rem
}

.cart-content {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem
}

@media (min-width:1024px) {
  .cart-content {
    grid-template-columns: 2fr 1fr
  }
}

.cart-items {
  background: #fff;
  border-radius: 1rem;
  padding: 1.5rem;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1)
}

.cart-item {
  display: grid;
  grid-template-columns: 100px 1fr auto auto;
  gap: 1.5rem;
  align-items: center;
  padding: 1.5rem;
  border-bottom: 1px solid #f3f4f6;
  background: #f9fafb;
  border-radius: .5rem;
  margin-bottom: 1rem;
  transition: all .3s
}

.cart-item:last-child {
  margin-bottom: 0;
  border-bottom: none
}

.cart-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, .1)
}

.cart-item-image {
  width: 100px;
  height: 100px;
  object-fit: cover;
  border-radius: .5rem;
  transition: transform .3s
}

.cart-item:hover .cart-item-image {
  transform: scale(1.05)
}

.cart-item-details h3 {
  font-size: 1rem;
  font-weight: 600;
  color: #18181b;
  margin-bottom: .25rem
}

.cart-item-details p {
  font-size: .875rem;
  color: #6b7280;
  margin: 0
}

.cart-item-price {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--brand);
  font-family: Arial, sans-serif
}

.cart-item-quantity {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .75rem
}

.modern-quantity-selector {
  display: flex;
  align-items: center;
  border-radius: 8px;
  border: 1px solid #e5e7eb;
  background: #fff;
  overflow: hidden
}

.modern-quantity-btn {
  background: 0 0;
  border: none;
  cursor: pointer;
  padding: .5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color .2s;
  color: #6b7280
}

.modern-quantity-btn:hover {
  background: #f3f4f6;
  color: #374151
}

.modern-quantity-btn:active {
  background: #e5e7eb
}

.modern-quantity-input {
  width: 3rem;
  text-align: center;
  font-weight: 500;
  border: none;
  background: 0 0;
  padding: .5rem 0;
  font-family: inherit;
  color: #374151
}

.modern-quantity-input:focus {
  outline: none
}

.remove-item-btn {
  background: #ef4444;
  color: #fff;
  border: none;
  padding: .5rem 1rem;
  border-radius: 6px;
  cursor: pointer;
  font-size: .875rem;
  font-weight: 500;
  transition: background-color .2s
}

.remove-item-btn:hover {
  background: #dc2626
}

.cart-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 3rem;
  text-align: center
}

.cart-empty h3 {
  font-size: 1.5rem;
  margin-bottom: .5rem;
  color: #374151
}

.cart-empty p {
  margin-bottom: 1.5rem;
  color: #6b7280
}

.cart-summary {
  background: #fff;
  border-radius: 1rem;
  padding: 1.5rem;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1);
  height: fit-content
}

.cart-summary h3 {
  font-size: 1.25rem;
  font-weight: 700;
  color: #18181b;
  margin-bottom: 1.5rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid #f3f4f6
}

.cart-summary-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .75rem 0;
  color: #4b5563
}

.cart-summary-row.total-row {
  border-top: 1px solid #f3f4f6;
  margin-top: .5rem;
  padding-top: 1rem;
  font-weight: 700;
  font-size: 1.125rem;
  color: #18181b
}

.checkout-button {
  width: 100%;
  background: var(--checkout-green);
  color: #fff;
  padding: 1rem;
  border-radius: .5rem;
  border: none;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  margin-top: 1.5rem;
  transition: all .3s;
  box-shadow: 0 4px 6px rgba(0, 0, 0, .1)
}

.checkout-button:hover {
  background: #047857;
  transform: translateY(-2px);
  box-shadow: 0 6px 10px rgba(0, 0, 0, .15)
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .75rem 1.5rem;
  border-radius: .5rem;
  font-weight: 600;
  text-decoration: none;
  text-align: center;
  border: none;
  cursor: pointer;
  transition: all .3s;
  font-family: inherit;
  font-size: .875rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis
}

.btn--primary {
  background: var(--brand);
  color: #fff
}

.btn--primary:hover {
  background: var(--brand-700);
  color: #fff
}

.btn--secondary {
  background: 0 0;
  color: var(--brand);
  border: 1px solid var(--brand)
}

.btn--secondary:hover {
  background: var(--brand);
  color: #fff
}

/* Footer */
.site-footer {
  border-top: 1px solid rgba(91, 33, 182, .5)
}

.footer-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 2.5rem 1.5rem 4rem
}

.footer-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.5rem
}

@media (min-width:768px) {
  .footer-content {
    flex-direction: row;
    align-items: center
  }
}

.footer-logo {
  height: 1.5rem;
  width: auto
}

.footer-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  font-size: .75rem;
  color: #52525b
}

.footer-link {
  color: #52525b;
  text-decoration: none;
  transition: color .3s
}

.footer-link:hover {
  color: #000
}

.footer-copyright {
  margin-top: 2rem;
  font-size: .6875rem;
  color: #52525b
}

/* Mobile Optimizations */
@media (max-width:768px) {
  .hero {
    padding: 2.25rem 0 8rem;
    min-height: auto
  }

  .hero-content {
    display: flex;
    flex-direction: column;
    gap: 1.1rem;
    text-align: left;
    margin-top: 1vh
  }

  .hero-left {
    display: contents
  }

  .hero-main-text {
    order: 1;
    padding-top: 1.6rem;
    text-align: left
  }

  .hero-visual {
    order: 2;
    margin-bottom: 2rem
  }

  .hero-main-text h2 {
    font-size: 1.2rem
  }

  .hero-main-text p {
    font-size: .8rem
  }

  .explore-mobile-app-btn {
    font-size: .9rem;
    padding: .6rem 1.2rem
  }

  .mobile-only.explore-mobile-app-btn {
    order: 4;
    margin: 1.25rem auto 2.5rem !important;
    padding-bottom: 1.1rem
  }

  .floating-cards {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    height: auto;
    width: 100%;
    gap: 12px;
    padding: 0 10px
  }

  .floating-cards .card {
    position: static;
    width: 120px;
    margin: 0;
    animation: none
  }

  .floating-cards .card img {
    height: auto
  }

  .cart-item {
    grid-template-columns: 60px 1fr;
    gap: .75rem
  }

  .cart-item-details {
    grid-column: 1/-1
  }

  .hero-stats {
    justify-content: space-between;
    gap: 1rem;
    width: 100%;
    margin-top: 0;
    order: 3
  }

  .stat {
    min-width: 0;
    padding: 1rem 1.25rem
  }

  .stat .number {
    font-size: 2.2rem;
    font-weight: 700
  }

  .stat .label {
    font-size: .75rem
  }

  .buy-now-button,
  .add-to-cart-btn,
  .btn-buy-now {
    height: auto !important;
    min-height: 44px;
    padding: .75rem 1.5rem !important;
    font-size: .875rem !important;
    line-height: 1.2 !important
  }

  .product-add-to-cart-btn,
  .product-remove-from-cart-btn {
    height: 36px !important;
    min-height: 36px !important;
    padding: .5rem .75rem !important;
    font-size: .7rem !important;
    line-height: 1.1 !important
  }

  .cart-item {
    grid-template-columns: 80px 1fr;
    gap: 1rem
  }

  .cart-item-price,
  .cart-item-quantity {
    grid-column: 1/-1;
    margin-top: .5rem
  }

  .cart-item-quantity {
    flex-direction: row;
    justify-content: space-between;
    align-items: center
  }
}

@media (max-width:480px) {
  .hero {
    padding: calc(3rem + env(safe-area-inset-top, 0px)) .75rem 2rem
  }

  .hero-content {
    gap: 1.5rem
  }

  .floating-cards .card {
    max-width: 90px !important
  }

  .floating-cards {
    gap: .5rem !important
  }

  .mobile-only.explore-mobile-app-btn {
    order: 4;
    font-size: .85rem;
    padding: .8rem 1.6rem 1rem;
    min-height: 44px;
    margin: 1rem auto 2rem !important
  }

  .add-to-cart-btn,
  .btn-buy-now {
    font-size: .8rem !important;
    padding: .65rem 1rem !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0
  }

  .purchase-section {
    gap: .75rem
  }
}

@media (max-width:390px) {
  .hero {
    padding: calc(2.5rem + env(safe-area-inset-top, 0px)) .5rem 2rem
  }

  .hero-content {
    gap: 1.25rem
  }

  .floating-cards {
    gap: .4rem !important
  }

  .floating-cards .card {
    max-width: 80px !important
  }

  .mobile-only.explore-mobile-app-btn {
    order: 4;
    font-size: .8rem;
    padding: .7rem 1.4rem .95rem;
    min-height: 40px;
    margin: 1rem auto 1.75rem !important
  }

  .purchase-section {
    gap: .5rem
  }

  .quantity-selector {
    min-width: auto
  }
}

/* Mobile Product Cards */
@media (max-width:767px) {
  .product-card {
    border-radius: 12px;
    margin-bottom: .5rem
  }

  .product-card:hover {
    transform: translateY(-2px)
  }

  .product-image-container {
    background: #fff
  }

  .product-info {
    padding: 1rem;
    gap: .5rem
  }

  .product-title {
    font-size: .9375rem;
    line-height: 1.4;
    min-height: 2.8em
  }

  .product-meta {
    flex-direction: column;
    align-items: stretch;
    gap: .75rem
  }

  .product-price {
    justify-content: flex-start;
    width: 100%
  }

  .product-price-current {
    font-size: 1.125rem
  }

  .product-price-old {
    font-size: .8125rem
  }

  .product-cart-controls {
    width: 100%;
    flex-direction: row
  }

  .product-add-to-cart-btn,
  .product-remove-from-cart-btn {
    min-height: 44px;
    font-size: .875rem;
    padding: .75rem 1rem
  }

  .related-products-grid .product-card {
    border-radius: 16px;
    margin-bottom: 0;
    box-shadow: 0 4px 12px rgba(0, 0, 0, .12);
    width: 100%;
    margin-left: 0;
    margin-right: 0
  }

  .related-products-grid .product-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 30px rgba(0, 0, 0, .2)
  }

  .related-products-grid .product-card .product-info {
    padding: 1rem
  }

  .related-products-grid .product-card .product-title {
    font-size: 1.1rem;
    line-height: 1.3;
    margin-bottom: .75rem;
    display: block;
    overflow: visible;
    white-space: normal;
    word-wrap: break-word;
    hyphens: auto;
    font-weight: 700
  }

  .related-products-grid .product-card .product-meta {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: .75rem;
    margin-top: auto
  }

  .related-products-grid .product-card .product-price {
    margin-bottom: 0;
    text-align: left;
    width: 100%
  }

  .related-products-grid .product-card .product-price-current {
    font-size: 1.2rem;
    font-weight: 800
  }

  .related-products-grid .product-card .product-cart-controls {
    width: 100%;
    display: flex
  }

  .related-products-grid .product-card .product-add-to-cart-btn,
  .related-products-grid .product-card .product-remove-from-cart-btn {
    width: 100%;
    justify-content: center;
    font-size: .85rem;
    padding: .75rem 1rem;
    min-height: 44px;
    font-weight: 600;
    white-space: normal;
    text-align: center
  }
}
}

/* Additional Optimizations */
.product-add-to-cart-btn .btn-text {
  margin-left: .125rem
}

.product-remove-from-cart-btn .btn-text {
  margin-left: .125rem
}

.quantity-selector {
  display: flex;
  align-items: center;
  border: 1px solid #cbd5e1;
  border-radius: 9999px;
  padding: .25rem;
  background: var(--site-bg)
}

.quantity-selector button {
  background: 0 0;
  border: none;
  cursor: pointer;
  padding: .5rem
}

.quantity-selector input {
  width: 2.5rem;
  text-align: center;
  border: none;
  background: 0 0
}

.quantity-selector.hidden {
  display: none
}

.cart-update-success {
  background: #d1fae5;
  border: 1px solid #10b981;
  color: #065f46;
  padding: .5rem;
  border-radius: .5rem;
  margin-bottom: 1rem;
  text-align: center
}

.cart-update-error {
  background: #fee2e2;
  border: 1px solid #ef4444;
  color: #991b1b;
  padding: .5rem;
  border-radius: .5rem;
  margin-bottom: 1rem;
  text-align: center
}

@media (min-width:768px) {
  .hero-stats {
    justify-content: flex-start;
    gap: 2rem
  }

  .stat {
    padding: 1rem 2rem;
    min-width: 140px
  }

  .stat .number {
    font-size: 2.5rem
  }

  .stat .label {
    font-size: .9rem
  }

  .product-section {
    text-align: center
  }
}

/* Collection Pages */
.collection-container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 4rem 1rem;
  margin-top: 4rem;
  background: var(--site-bg)
}

@media (max-width:767px) {
  .collection-container {
    padding: 2rem 1rem;
    margin-top: 3rem
  }
}

.collection-header {
  text-align: center;
  margin-bottom: 3rem
}

.collection-title {
  font-size: clamp(2.5rem, 5vw, 4rem);
  text-align: center;
  color: #18181b;
  margin-bottom: 1rem;
  font-family: Poppins, sans-serif;
  font-weight: 800;
  letter-spacing: -.02em
}

.collection-description {
  color: #374151;
  line-height: 1.75;
  max-width: 800px;
  margin: 0 auto;
  font-size: 1.125rem
}

.collection-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 2rem;
  padding: 1rem;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .08)
}

@media (max-width:767px) {
  .collection-toolbar {
    flex-direction: column;
    gap: 1rem;
    align-items: flex-start
  }
}

.collection-product-count {
  font-weight: 600;
  color: #18181b;
  font-size: 1rem
}

.collection-sorting {
  display: flex;
  align-items: center;
  gap: .75rem
}

@media (max-width:767px) {
  .collection-sorting {
    width: 100%
  }
}

.collection-sorting label {
  font-weight: 500;
  color: #374151;
  font-size: .875rem
}

.collection-sorting select {
  padding: .5rem 2.5rem .5rem .75rem;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  background: #fff;
  font-family: Poppins, sans-serif;
  font-size: .875rem;
  cursor: pointer;
  transition: border-color .3s;
  appearance: none;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
  background-position: right .5rem center;
  background-repeat: no-repeat;
  background-size: 1.5em 1.5em
}

@media (max-width:767px) {
  .collection-sorting select {
    width: 100%
  }
}

.collection-sorting select:hover {
  border-color: var(--brand)
}

.collection-sorting select:focus {
  outline: none;
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(124, 58, 237, .1)
}

.collection-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 2rem;
  padding: 1rem 0
}

@media (min-width:1024px) {
  .collection-grid {
    grid-template-columns: repeat(4, 1fr)
  }
}

@media (min-width:768px) and (max-width:1023px) {
  .collection-grid {
    grid-template-columns: repeat(3, 1fr)
  }
}

@media (min-width:640px) and (max-width:767px) {
  .collection-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem
  }
}

@media (max-width:639px) {
  .collection-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem
  }
}

.collection-product-card {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  transition: all .3s cubic-bezier(.175, .885, .32, 1.275);
  cursor: pointer;
  color: #333;
  position: relative;
  border: 2px solid transparent;
  background-clip: padding-box;
  display: flex;
  flex-direction: column;
  height: auto;
  box-shadow: 0 4px 12px rgba(0, 0, 0, .12)
}

.collection-product-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, .2)
}

.product-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  padding: .375rem .625rem;
  border-radius: 6px;
  font-size: .6875rem;
  font-weight: 700;
  z-index: 10;
  text-transform: uppercase;
  letter-spacing: .05em;
  backdrop-filter: blur(8px)
}

.sale-badge {
  background: rgba(239, 68, 68, .95);
  color: #fff;
  box-shadow: 0 2px 8px rgba(239, 68, 68, .4)
}

.sold-out-badge {
  background: rgba(107, 114, 128, .95);
  color: #fff;
  box-shadow: 0 2px 8px rgba(107, 114, 128, .3)
}

.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: .5rem;
  margin-top: 3rem;
  padding: 1rem
}

.pagination-item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: .5rem .75rem;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  font-weight: 500;
  color: #374151;
  text-decoration: none;
  transition: all .3s;
  background: #fff
}

.pagination-item:hover {
  border-color: var(--brand);
  color: var(--brand);
  background: #faf5ff
}

.pagination-current {
  background: var(--brand);
  color: #fff;
  border-color: var(--brand)
}

.pagination-current:hover {
  background: var(--brand-700)
}

.pagination-prev,
.pagination-next {
  padding: .5rem 1rem;
  gap: .5rem
}

.pagination-prev svg,
.pagination-next svg {
  width: 16px;
  height: 16px
}

.collection-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
  text-align: center
}

.collection-empty h2 {
  font-size: 1.875rem;
  font-weight: 700;
  color: #18181b;
  margin-bottom: 1rem
}

.collection-empty p {
  font-size: 1.125rem;
  color: #6b7280;
  margin-bottom: 2rem
}

/* Final UX Optimizations */
html {
  scroll-behavior: smooth
}

*:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
  border-radius: 4px
}

button:focus-visible,
a:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px
}

.product-link {
  text-decoration: none;
  color: inherit;
  display: block
}

.product-link:focus {
  outline: none
}

.product-link:focus-visible .product-title {
  color: var(--brand);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 4px
}

/* Review Section Styles */
.reviews-section {
  margin-top: 4rem;
  width: 100%
}

.reviews-grid,
.reviews-grid-extended {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  margin-top: 2rem
}

@media (max-width:767px) {

  .reviews-grid,
  .reviews-grid-extended {
    grid-template-columns: 1fr
  }
}

.review-card {
  background: #fff;
  border-radius: 16px;
  padding: 1.5rem;
  box-shadow: 0 4px 12px rgba(0, 0, 0, .08);
  transition: all .3s;
  border: 1px solid #f3f4f6
}

.review-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, .12);
  border-color: #e0d4fc
}

.review-card.featured-review {
  border: 2px solid var(--brand);
  background: linear-gradient(135deg, #faf5ff 0%, #fff 100%)
}

.review-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 1rem
}

.reviewer-info {
  display: flex;
  gap: 1rem;
  align-items: center
}

.reviewer-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--brand);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1.25rem;
  flex-shrink: 0
}

.reviewer-name {
  font-size: 1rem;
  font-weight: 600;
  color: #18181b;
  margin-bottom: .25rem
}

.verified-tag {
  font-size: .75rem;
  color: var(--brand);
  font-weight: 500;
  margin-left: .5rem
}

.review-rating {
  display: flex;
  gap: .25rem;
  margin-top: .25rem
}

.review-star {
  width: 16px;
  height: 16px;
  fill: #facc15;
  color: #facc15
}

.review-date {
  font-size: .75rem;
  color: #9ca3af;
  white-space: nowrap
}

.review-text {
  color: #374151;
  line-height: 1.6;
  font-size: .9375rem
}

.show-more-reviews {
  background: var(--brand);
  color: #fff;
  border: none;
  padding: .75rem 2rem;
  border-radius: 25px;
  font-weight: 600;
  cursor: pointer;
  transition: all .3s;
  box-shadow: 0 4px 12px rgba(124, 58, 237, .2)
}

.show-more-reviews:hover {
  background: var(--brand-700);
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(124, 58, 237, .3)
}

.show-more-reviews:active {
  transform: translateY(0);
  box-shadow: 0 2px 8px rgba(124, 58, 237, .2)
}

/* Micro-interactions */
@keyframes buttonPulse {

  0%,
  100% {
    transform: scale(1)
  }

  50% {
    transform: scale(1.05)
  }
}

.product-add-to-cart-btn.added {
  animation: buttonPulse .3s ease
}

.cart-notification {
  animation: slideInRight .3s ease
}

@keyframes slideInRight {
  from {
    transform: translateX(100%);
    opacity: 0
  }

  to {
    transform: translateX(0);
    opacity: 1
  }
}

.product-badge {
  animation: badgeBounce .5s ease;
  transform-origin: top right
}

@keyframes badgeBounce {

  0%,
  100% {
    transform: scale(1)
  }

  50% {
    transform: scale(1.1)
  }
}

/* Link hover states */
a:not(.btn):not(.product-link):not(.nav-link) {
  transition: color .2s, text-decoration-color .2s
}

a:not(.btn):not(.product-link):not(.nav-link):hover {
  text-decoration-thickness: 2px
}

/* Touch device optimizations */
@media (hover:none) {
  .product-card:hover {
    transform: none;
    box-shadow: 0 4px 12px rgba(0, 0, 0, .12)
  }

  .product-card:active {
    transform: scale(.98);
    box-shadow: 0 2px 8px rgba(0, 0, 0, .15)
  }

  button:hover {
    transform: none
  }

  button:active {
    transform: scale(.95)
  }
}

/* Loading states */
.loading {
  position: relative;
  pointer-events: none;
  opacity: .7
}

.loading::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 20px;
  border: 2px solid rgba(255, 255, 255, .3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin 1s linear infinite;
  transform: translate(-50%, -50%)
}

/* Accessibility improvements */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0
}

.skip-to-content {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--brand);
  color: #fff;
  padding: .5rem 1rem;
  z-index: 9999;
  transition: top .3s
}

.skip-to-content:focus {
  top: 0
}

/* High contrast mode support */
@media (prefers-contrast:high) {
  .product-card {
    border: 2px solid #000
  }

  .product-badge {
    border: 1px solid #000
  }

  button {
    border: 2px solid currentColor
  }
}

/* Reduced motion support */
@media (prefers-reduced-motion:reduce) {

  *,
  *::before,
  *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important
  }
}

/* Category Filter Animations & Optimizations */
.products-wrapper {
  position: relative;
  min-height: 400px
}

.category-section {
  transition: opacity .4s cubic-bezier(.4, 0, .2, 1), transform .4s cubic-bezier(.4, 0, .2, 1);
  will-change: opacity, transform;
  contain: layout style paint
}

.category-section[style*="display: none"] {
  pointer-events: none;
  visibility: hidden
}

@media (prefers-reduced-motion:no-preference) {
  .category-section {
    animation: categoryFadeIn .5s ease
  }
}

@keyframes categoryFadeIn {
  from {
    opacity: 0;
    transform: translateY(20px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

.category-filter-wrapper.is-stuck {
  box-shadow: 0 4px 12px rgba(124, 58, 237, .08);
  background: var(--site-bg)
}

/* Optimize for GPU acceleration */
.category-filter-tab,
.category-section,
.product-card {
  transform: translateZ(0);
  backface-visibility: hidden
}

/* Loading state for category transitions */
.products-wrapper.filtering .category-section {
  pointer-events: none
}

.products-wrapper.filtering::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 40px;
  height: 40px;
  border: 3px solid rgba(124, 58, 237, .3);
  border-top-color: var(--brand);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  transform: translate(-50%, -50%);
  z-index: 100
}
/* Precision Mobile Fix for Related Products (Override) */
@media (max-width: 767px) {
  .related-products-grid .product-card .product-meta {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    flex-wrap: nowrap !important;
    gap: 0.75rem !important;
    margin-top: auto !important;
  }
  .related-products-grid .product-card .product-cart-controls {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
  }
  .related-products-grid .product-card .product-add-to-cart-btn,
  .related-products-grid .product-card .product-remove-from-cart-btn {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    white-space: normal !important;
    box-sizing: border-box !important;
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
    text-align: center !important;
  }
  .related-products-grid .product-card .product-price {
    width: 100% !important;
    margin-bottom: 0.25rem !important;
  }
}

/* Header nav — compact size for many collection links */
.header-nav-link {
  font-size: .8125rem !important;
  padding: .25rem .45rem !important;
  font-weight: 500 !important;
  line-height: 1.2 !important;
}

@media (min-width: 1440px) {
  .header-nav-link {
    font-size: .875rem !important;
    padding: .25rem .5rem !important;
  }
}

.header-pill {
  padding: .5rem 1rem !important;
  gap: .75rem !important;
}

.logo-image {
  height: 2.5rem !important;
}
