/** Shopify CDN: Minification failed

Line 1517:0 Unexpected "@media"

**/
/*
 * KOWS Kitchenware — Modern Theme Improvements
 * ──────────────────────────────────────────────
 * Load this file AFTER the original theme CSS.
 * Provides: modern typography · refined animations · mobile optimisation
 *           improved components · better accessibility · cleaner UI polish
 *
 * Breakpoints (matching original):
 *   mobile : < 700px
 *   tablet : 700px – 999px
 *   desktop: 1000px+
 *   wide   : 1150px+
 */

/* ═══════════════════════════════════════════════════════════════
   1. DESIGN TOKEN REFINEMENTS
   ═══════════════════════════════════════════════════════════════ */
:root {
  /* Sharper, more readable body line-height */
  --body-line-height: 1.65;

  /* Refined shadow system */
  --shadow-xs : 0 1px  2px rgb(0 0 0 / .04), 0 1px  3px rgb(0 0 0 / .06);
  --shadow-sm : 0 2px  4px rgb(0 0 0 / .06), 0 2px  6px rgb(0 0 0 / .08);
  --shadow-md : 0 4px 12px rgb(0 0 0 / .08), 0 2px  8px rgb(0 0 0 / .06);
  --shadow-lg : 0 8px 24px rgb(0 0 0 / .10), 0 4px 12px rgb(0 0 0 / .08);
  --shadow-xl : 0 16px 40px rgb(0 0 0 / .12), 0 8px 20px rgb(0 0 0 / .08);

  /* Transition presets */
  --transition-fast   : 150ms cubic-bezier(.4, 0, .2, 1);
  --transition-base   : 250ms cubic-bezier(.4, 0, .2, 1);
  --transition-slow   : 400ms cubic-bezier(.22, 1, .36, 1);
  --transition-spring : 500ms cubic-bezier(.34, 1.2, .64, 1);

  /* Focus ring */
  --focus-ring: 0 0 0 3px rgb(var(--accent, 220 140 60) / .4);
}

/* ═══════════════════════════════════════════════════════════════
   2. GLOBAL BASE IMPROVEMENTS
   ═══════════════════════════════════════════════════════════════ */
html {
  /* Smooth scroll everywhere */
  scroll-behavior: smooth;
  /* Slightly better letter-spacing for Indian-market sans-serif fonts */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  line-height: var(--body-line-height);
  /* Very subtle text rendering improvement */
  text-rendering: optimizeLegibility;
}

/* Better placeholder colour for accessibility */
input::placeholder,
textarea::placeholder {
  opacity: .55;
  color: inherit;
}

/* Remove tap flash on all interactive elements */
* {
  -webkit-tap-highlight-color: transparent;
}

img {
  /* Prevent layout shifts on load */
  content-visibility: auto;
}

/* ═══════════════════════════════════════════════════════════════
   3. FOCUS STYLES — accessible, modern ring
   ═══════════════════════════════════════════════════════════════ */
:focus-visible {
  outline: 2px solid rgb(var(--accent, 220 140 60));
  outline-offset: 3px;
  border-radius: 3px;
}

/* Remove outline when not keyboard navigating */
:focus:not(:focus-visible) {
  outline: none;
}

/* ═══════════════════════════════════════════════════════════════
   4. TYPOGRAPHY IMPROVEMENTS
   ═══════════════════════════════════════════════════════════════ */

/* Tighter, more balanced heading line-heights */
.h0 { line-height: 1.05; letter-spacing: -.03em; }
.h1 { line-height: 1.08; letter-spacing: -.025em; }
.h2 { line-height: 1.12; letter-spacing: -.02em; }
.h3 { line-height: 1.18; letter-spacing: -.015em; }
.h4 { line-height: 1.25; letter-spacing: -.01em; }
.h5 { line-height: 1.35; }
.h6 { line-height: 1.4; }

/* Prose readability */
.prose {
  font-size: 1rem;
  line-height: 1.75;
  max-width: 68ch;
}

.prose p + p {
  margin-block-start: 1.25em;
}

/* Section headings — subtle optical weight */
.section-header .h1,
.section-header .h2 {
  letter-spacing: -.022em;
}

/* ═══════════════════════════════════════════════════════════════
   5. BUTTONS — refined style & interactions
   ═══════════════════════════════════════════════════════════════ */
.button,
.btn {
  /* Slightly more padding for breathing room */
  padding-inline-start: var(--spacing-6);
  padding-inline-end:   var(--spacing-6);
  /* Refined transitions */
  transition:
    background-color var(--transition-fast),
    color            var(--transition-fast),
    box-shadow       var(--transition-fast),
    transform        var(--transition-fast),
    opacity          var(--transition-fast);
  /* Prevent layout shift on hover */
  will-change: transform;
  /* Sharper letter-spacing on button text */
  letter-spacing: .02em;
  /* Better font weight */
  font-weight: 600;
}

/* Press effect */
.button:active,
.btn:active {
  transform: translateY(1px);
}

/* Primary button hover — lift + glow */
@media screen and (pointer: fine) {
  .button:not(.button--secondary, .button--subdued, .button--outline, .circle-button):hover {
    box-shadow: var(--shadow-md), 0 0 0 1px rgb(var(--button-background-primary) / .2);
    transform: translateY(-1px);
  }
}

/* Outline button — cleaner border */
.button--outline {
  border-width: 1.5px;
  transition:
    background-color var(--transition-fast),
    color            var(--transition-fast),
    border-color     var(--transition-fast),
    box-shadow       var(--transition-fast),
    transform        var(--transition-fast);
}

@media screen and (pointer: fine) {
  .button--outline:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
  }
}

/* Subdued button */
.button--subdued {
  opacity: .8;
  transition: opacity var(--transition-fast), transform var(--transition-fast);
}

@media screen and (pointer: fine) {
  .button--subdued:hover {
    opacity: 1;
  }
}

/* Circle/icon buttons — better sizing on mobile */
.circle-button {
  min-width: 44px;
  min-height: 44px;
  transition: background-color var(--transition-fast),
              box-shadow       var(--transition-fast),
              transform        var(--transition-fast);
}

@media screen and (pointer: fine) {
  .circle-button:not([disabled]):hover {
    transform: scale(1.05);
    box-shadow: var(--shadow-sm);
  }
}

/* Back button improvement */
.back-button {
  transition: color var(--transition-fast), transform var(--transition-fast);
}

@media screen and (pointer: fine) {
  .back-button:hover {
    transform: translateX(-3px);
  }
}

/* ═══════════════════════════════════════════════════════════════
   6. FORMS — modern floating labels & refined inputs
   ═══════════════════════════════════════════════════════════════ */
.input,
.textarea,
.select {
  transition:
    border-color var(--transition-fast),
    box-shadow   var(--transition-fast),
    background   var(--transition-fast);
  /* Slightly taller for better touch target */
  min-height: 48px;
}

.input:focus,
.textarea:focus,
.select:focus {
  outline: none;
  border-color: rgb(var(--accent, 220 140 60));
  box-shadow: 0 0 0 3px rgb(var(--accent, 220 140 60) / .15);
}

/* Floating label — smoother transition */
.floating-label {
  transition: transform  var(--transition-fast),
              font-size  var(--transition-fast),
              color      var(--transition-fast),
              opacity    var(--transition-fast);
  transform-origin: left top;
}

/* Checkbox & radio — better touch targets */
.checkbox-container {
  min-height: 44px;
}

.checkbox {
  min-width: 20px;
  min-height: 20px;
  transition: background-color var(--transition-fast),
              border-color     var(--transition-fast),
              box-shadow       var(--transition-fast);
}

.checkbox:focus-visible {
  box-shadow: var(--focus-ring);
}

/* Select chevron */
.select-chevron {
  transition: transform var(--transition-fast);
}

.select:focus ~ .select-chevron,
.select:focus-within ~ .select-chevron {
  transform: translateY(-50%) rotate(180deg);
}

/* Quantity selector — better touch affordance */
.quantity-selector {
  min-height: 48px;
  transition: border-color var(--transition-fast),
              box-shadow   var(--transition-fast);
}

.quantity-selector:focus-within {
  border-color: rgb(var(--accent, 220 140 60));
  box-shadow: 0 0 0 3px rgb(var(--accent, 220 140 60) / .15);
}

.quantity-selector__button {
  transition: background-color var(--transition-fast),
              color             var(--transition-fast);
  min-width: 44px;
}

@media screen and (pointer: fine) {
  .quantity-selector__button:hover {
    background: rgb(var(--text-color) / .06);
  }
}

/* ═══════════════════════════════════════════════════════════════
   7. PRODUCT CARDS — refined visuals & smooth interactions
   ═══════════════════════════════════════════════════════════════ */
.product-card {
  /* Smooth shadow on hover */
  transition: box-shadow var(--transition-base),
              transform  var(--transition-base);
  border-radius: var(--rounded-sm);
  overflow: hidden;
}

@media screen and (pointer: fine) {
  .product-card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-3px);
  }
}

/* Product image — scale on hover */
.product-card__figure {
  overflow: hidden;
}

.product-card__image--primary {
  transition: transform  var(--transition-slow),
              opacity    200ms ease-in-out,
              filter     var(--transition-slow);
  transform-origin: center center;
  will-change: transform;
}

@media screen and (pointer: fine) {
  .product-card:hover .product-card__image--primary {
    transform: scale(1.04);
  }

  .product-card--show-secondary-media .product-card__figure:hover .product-card__image--primary {
    transform: scale(1.02);
    opacity: 0;
  }
}

/* Secondary image — smoother cross-fade */
.product-card__image--secondary {
  transition: opacity var(--transition-base);
}

/* Quick-buy — smoother reveal */
.product-card__quick-buy {
  transition: opacity     var(--transition-fast),
              visibility  var(--transition-fast),
              transform   var(--transition-base);
}

@media screen and (pointer: fine) {
  .product-card:focus-within .product-card__quick-buy,
  .product-card:hover .product-card__quick-buy {
    transform: translateY(0);
  }
}

/* Product info area — slightly more breathing room */
.product-card__info {
  gap: var(--spacing-1-5);
}

/* Title — better wrapping */
.product-card__title {
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Mobile quick-buy button — larger tap target */
.product-card__mobile-quick-buy-button {
  width: 2.75rem;
  height: 2.75rem;
  transition: background-color var(--transition-fast),
              transform        var(--transition-fast),
              box-shadow       var(--transition-fast);
}

@media screen and (pointer: coarse) {
  .product-card__mobile-quick-buy-button:active {
    transform: scale(.94);
    box-shadow: var(--shadow-xs);
  }
}

/* ═══════════════════════════════════════════════════════════════
   8. BADGES & PRICE
   ═══════════════════════════════════════════════════════════════ */
.badge {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: 3px 7px;
  border-radius: var(--rounded-button);
  line-height: 1.4;
}

@media screen and (min-width: 700px) {
  .badge:not(.badge--lg) {
    font-size: 11px;
    padding: 4px 8px;
  }
}

/* On-sale badge — more visible */
.badge--on-sale {
  font-weight: 700;
  letter-spacing: .05em;
}

/* Sold-out badge — slightly muted */
.badge--sold-out {
  opacity: .9;
}

/* Price list — better alignment */
.price-list {
  align-items: baseline;
  gap: var(--spacing-1-5) var(--spacing-2-5);
}

/* ═══════════════════════════════════════════════════════════════
   9. ANNOUNCEMENT BAR — refined & readable
   ═══════════════════════════════════════════════════════════════ */
.announcement-bar {
  padding-block-start: var(--spacing-3);
  padding-block-end: var(--spacing-3);
  /* Better vertical rhythm */
  letter-spacing: .01em;
  font-size: var(--text-sm);
}

.announcement-bar__wrapper {
  max-width: 600px;
}

@media screen and (min-width: 700px) {
  .announcement-bar {
    padding-block-start: var(--spacing-3-5);
    padding-block-end: var(--spacing-3-5);
    font-size: var(--text-sm);
  }
}

/* ═══════════════════════════════════════════════════════════════
   10. HEADER — refined backdrop & transitions
   ═══════════════════════════════════════════════════════════════ */
.header {
  transition:
    background   var(--transition-base),
    box-shadow   var(--transition-base),
    color        var(--transition-base);
}

.header__wrapper {
  /* Stronger backdrop blur for frosted glass effect */
  -webkit-backdrop-filter: blur(20px) saturate(180%);
          backdrop-filter: blur(20px) saturate(180%);
  /* Subtle border-bottom when scrolled */
  box-shadow: 0 1px 0 rgb(var(--text-color) / .08);
  transition:
    background   var(--transition-base),
    box-shadow   var(--transition-base);
}

/* Transparent header — remove bottom line when at top */
.header[allow-transparency]:not(.is-filled) .header__wrapper {
  box-shadow: none;
}

/* Logo — smooth opacity transitions */
.header__logo-image {
  transition: opacity var(--transition-base);
}

/* Navigation links — refined hover */
.header__link-list a {
  position: relative;
  padding-block: var(--spacing-1);
  transition: color var(--transition-fast);
}

.header__link-list a::after {
  content: '';
  position: absolute;
  inset-inline: 0;
  bottom: -2px;
  height: 1.5px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform var(--transition-base);
  border-radius: 2px;
}

@media screen and (pointer: fine) {
  .header__link-list a:hover::after {
    transform: scaleX(1);
    transform-origin: left;
  }
}

/* Cart icon count bubble — refined */
.header__cart-count {
  transition: transform var(--transition-spring),
              opacity   var(--transition-fast);
}

/* Icon buttons in header — larger touch target */
.header__icon-list > * {
  min-width: 44px;
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ═══════════════════════════════════════════════════════════════
   11. DROPDOWN & MEGA MENU — refined
   ═══════════════════════════════════════════════════════════════ */
.dropdown-menu {
  border-radius: var(--rounded-sm);
  box-shadow: var(--shadow-xl), 0 0 0 1px rgb(var(--text-color) / .06);
  transition: opacity var(--transition-fast),
              transform var(--transition-fast);
  transform: translateY(6px);
}

/* Use animation: open state is applied via JS */
.dropdown-menu[style*="opacity: 1"],
.dropdown-menu.is-open {
  transform: translateY(0);
}

/* ═══════════════════════════════════════════════════════════════
   12. DRAWERS — modern slide & spring animations
   ═══════════════════════════════════════════════════════════════ */
.drawer::part(overlay) {
  /* Richer backdrop */
  background: rgb(0 0 0 / .35);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  transition: opacity var(--transition-base);
}

.drawer::part(content) {
  /* Slight shadow for depth */
  box-shadow: var(--shadow-xl);
  transition: transform var(--transition-slow);
}

/* ═══════════════════════════════════════════════════════════════
   13. CART DRAWER
   ═══════════════════════════════════════════════════════════════ */
.cart-drawer {
  --drawer-header-padding: var(--spacing-6);
}

/* Line items — better spacing & separator */
.cart-drawer__line-items > * + * {
  border-top-width: 1px;
  border-top-color: rgb(var(--text-color) / .08);
  padding-block-start: var(--spacing-4);
  margin-block-start: var(--spacing-4);
}

.line-item {
  display: grid;
  gap: var(--spacing-4);
  grid-template-columns: auto 1fr;
  align-items: start;
}

.line-item__media-wrapper {
  border-radius: var(--rounded-sm);
  overflow: hidden;
  box-shadow: var(--shadow-xs);
}

/* Cart total — more prominent */
.cart__total,
.cart-order__total {
  font-size: var(--text-lg, 1.125rem);
  font-weight: 700;
  letter-spacing: -.01em;
}

/* ═══════════════════════════════════════════════════════════════
   14. QUICK-ADD PANEL — refined mobile panel
   ═══════════════════════════════════════════════════════════════ */
.product-quick-add {
  padding: var(--spacing-5);
  border-radius: var(--rounded-sm) var(--rounded-sm) 0 0;
  box-shadow: var(--shadow-xl);
  transition:
    opacity    var(--transition-fast),
    visibility var(--transition-fast),
    transform  var(--transition-base);
}

@media screen and (min-width: 700px) {
  .product-quick-add {
    border-radius: var(--rounded-sm);
    box-shadow: var(--shadow-lg);
  }
}

/* ═══════════════════════════════════════════════════════════════
   15. ACCORDION — smoother expand/collapse
   ═══════════════════════════════════════════════════════════════ */
.accordion {
  --accordion-spacing: var(--spacing-5);
}

.accordion__toggle {
  transition: color var(--transition-fast);
  padding-block: var(--spacing-5);
}

@media screen and (pointer: fine) {
  .accordion__toggle:hover {
    color: rgb(var(--text-color) / .75);
  }
}

/* Chevron rotation for open state */
.accordion__toggle [class*="icon-chevron"] {
  transition: transform var(--transition-base);
  flex-shrink: 0;
}

[open] .accordion__toggle [class*="icon-chevron"],
[aria-expanded="true"] .accordion__toggle [class*="icon-chevron"] {
  transform: rotate(180deg);
}

.accordion__content {
  /* smoother reveal via transform is handled in JS / Motion One */
  will-change: transform, opacity;
}

/* ═══════════════════════════════════════════════════════════════
   16. POPOVER — polished dropdown
   ═══════════════════════════════════════════════════════════════ */
.popover {
  box-shadow: var(--shadow-lg), 0 0 0 1px rgb(var(--text-color) / .07);
  border-radius: var(--rounded-sm);
  transition: opacity var(--transition-fast),
              transform var(--transition-fast);
}

.popover-listbox__option {
  transition: background-color var(--transition-fast),
              color             var(--transition-fast);
  min-height: 40px;
  display: flex;
  align-items: center;
  border-radius: 6px;
}

@media screen and (pointer: fine) {
  .popover-listbox__option:not(.is-disabled):hover {
    background: rgb(var(--text-color) / .06);
  }
}

/* ═══════════════════════════════════════════════════════════════
   17. SECTION LAYOUT — refined spacing & headers
   ═══════════════════════════════════════════════════════════════ */
.section-header {
  gap: var(--spacing-3);
}

/* Section heading — subtle left accent line on desktop */
@media screen and (min-width: 1000px) {
  .section-header .h1,
  .section-header .h2 {
    max-width: 28ch;
  }
}

/* ═══════════════════════════════════════════════════════════════
   18. COLLECTION PAGE — filters & results
   ═══════════════════════════════════════════════════════════════ */
.collection__top-bar,
.collection__facets {
  gap: var(--spacing-3);
}

/* Active filter pill */
.active-filter {
  transition: background-color var(--transition-fast),
              transform        var(--transition-fast);
}

@media screen and (pointer: fine) {
  .active-filter:hover {
    transform: scale(.97);
  }
}

.collection-card {
  transition: box-shadow var(--transition-base),
              transform  var(--transition-base);
  overflow: hidden;
}

@media screen and (pointer: fine) {
  .collection-card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
  }
}

.collection-card img {
  transition: transform var(--transition-slow);
}

@media screen and (pointer: fine) {
  .collection-card:hover img {
    transform: scale(1.04);
  }
}

/* ═══════════════════════════════════════════════════════════════
   19. FOOTER — cleaner layout & spacing
   ═══════════════════════════════════════════════════════════════ */
.footer {
  --footer-padding-block: var(--spacing-14);
  --footer-block-gap: var(--spacing-5);
  --footer-block-list-gap: var(--spacing-10);
  /* Subtle top border */
  border-top: 1px solid rgb(var(--text-color) / .1);
}

.footer__block-list {
  row-gap: var(--spacing-10);
}

/* Footer nav links */
.footer__block a {
  transition: color var(--transition-fast),
              opacity var(--transition-fast);
  opacity: .8;
  line-height: 1.8;
  display: inline-block;
}

@media screen and (pointer: fine) {
  .footer__block a:hover {
    opacity: 1;
  }
}

/* Newsletter form — larger input */
.footer__newsletter-form .input {
  min-height: 48px;
}

/* Footer policy links — better spacing */
.footer__policy-links {
  gap: var(--spacing-1);
}

.footer__policy-links li + li::before {
  margin-inline: .4rem .2rem;
  opacity: .4;
}

@media screen and (min-width: 700px) {
  .footer {
    --footer-padding-block: var(--spacing-20);
    --footer-block-gap: var(--spacing-6);
  }
}

@media screen and (min-width: 1000px) {
  .footer {
    --footer-padding-block: var(--spacing-24);
  }
}

/* ═══════════════════════════════════════════════════════════════
   20. BANNER / HERO SECTIONS
   ═══════════════════════════════════════════════════════════════ */
.content-over-media {
  overflow: hidden;
}

.content-over-media > img,
.content-over-media > video-media {
  /* Prevent image from being clipped by border-radius */
  border-radius: inherit;
}

/* ═══════════════════════════════════════════════════════════════
   21. BLOG POST CARDS
   ═══════════════════════════════════════════════════════════════ */
.blog-post-card {
  transition: box-shadow var(--transition-base),
              transform  var(--transition-base);
}

@media screen and (pointer: fine) {
  .blog-post-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
  }
}

.blog-post-card__figure img {
  transition: transform var(--transition-slow);
}

@media screen and (pointer: fine) {
  .blog-post-card:hover .blog-post-card__figure img {
    transform: scale(1.04);
  }
}

/* ═══════════════════════════════════════════════════════════════
   22. RATING STARS
   ═══════════════════════════════════════════════════════════════ */
.rating__star {
  transition: color var(--transition-fast);
}

/* ═══════════════════════════════════════════════════════════════
   23. SCROLLBAR COMPONENT — thinner, refined
   ═══════════════════════════════════════════════════════════════ */
.scrollbar__progress {
  height: 2px;
  background: rgb(var(--text-color) / .12);
  border-radius: 2px;
}

.scrollbar__progress::before {
  border-radius: 2px;
}

/* ═══════════════════════════════════════════════════════════════
   24. PROGRESS BAR — refined
   ═══════════════════════════════════════════════════════════════ */
.progress-bar {
  height: 3px;
  background: rgb(var(--text-color) / .12);
  border-radius: 3px;
}

.progress-bar::before {
  transition: transform .6s cubic-bezier(.22, 1, .36, 1);
  border-radius: 3px;
}

/* ═══════════════════════════════════════════════════════════════
   25. PAGE DOTS & CAROUSEL INDICATORS
   ═══════════════════════════════════════════════════════════════ */
.page-dots > * {
  transition: transform var(--transition-base),
              opacity   var(--transition-base),
              background-color var(--transition-base);
  border-radius: 99px;
}

.page-dots > *[aria-current="true"] {
  transform: scale(1.25);
}

.stretching-dots > * {
  transition: width var(--transition-base),
              background-color var(--transition-base);
}

/* ═══════════════════════════════════════════════════════════════
   26. TABLE — refined borders & hover
   ═══════════════════════════════════════════════════════════════ */
table {
  border-collapse: separate;
  border-spacing: 0;
}

thead th {
  border-bottom-color: rgb(var(--text-color) / .15);
  font-weight: 600;
  letter-spacing: .02em;
  font-size: var(--text-sm);
  text-transform: uppercase;
}

tbody tr + tr > *,
thead + tbody tr > * {
  border-top-color: rgb(var(--text-color) / .08);
}

.table-row-hover {
  transition: background-color var(--transition-fast);
}

/* ═══════════════════════════════════════════════════════════════
   27. SKELETON LOADERS — softer pulse
   ═══════════════════════════════════════════════════════════════ */
@keyframes skeleton-pulse {
  0%, 100% { opacity: 1;   }
  50%       { opacity: .45; }
}

.skeleton {
  animation: skeleton-pulse 2s ease-in-out infinite;
  background: rgb(var(--text-color) / .1);
  border-radius: 6px;
}

/* ═══════════════════════════════════════════════════════════════
   28. PRIVACY BAR (Cookie consent)
   ═══════════════════════════════════════════════════════════════ */
.privacy-bar__inner {
  border-radius: var(--rounded-sm);
  box-shadow: var(--shadow-xl);
  border-width: 1px;
  border-color: rgb(var(--text-color) / .1);
}

/* ═══════════════════════════════════════════════════════════════
   29. LINKS — refined underline animation
   ═══════════════════════════════════════════════════════════════ */
.link,
.prose a:not(.button) {
  transition: color var(--transition-fast),
              background-size var(--transition-base);
}

@media screen and (pointer: fine) {
  :is(.link, .prose a:not(.button)):hover {
    color: rgb(var(--text-color));
  }
}

/* ═══════════════════════════════════════════════════════════════
   30. SWITCH TOGGLE — refined
   ═══════════════════════════════════════════════════════════════ */
.switch {
  transition: background-color var(--transition-base);
}

.switch::before {
  transition: transform var(--transition-base),
              box-shadow var(--transition-base);
}

/* ═══════════════════════════════════════════════════════════════
   31. ANIMATED ARROW — refine timing
   ═══════════════════════════════════════════════════════════════ */
.animated-arrow {
  transition: transform var(--transition-fast);
}

@media screen and (pointer: fine) {
  .group:hover .animated-arrow,
  .animated-arrow:hover {
    transform: translateX(4px);
  }
}

/* ═══════════════════════════════════════════════════════════════
   32. HORIZONTAL PRODUCT — cart item refinements
   ═══════════════════════════════════════════════════════════════ */
.horizontal-product {
  transition: background-color var(--transition-fast);
  border-radius: var(--rounded-sm);
  padding: var(--spacing-3);
}

.horizontal-product__image {
  border-radius: 6px;
  overflow: hidden;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════════
   33. COUNT BUBBLE — spring animation on change
   ═══════════════════════════════════════════════════════════════ */
.count-bubble {
  transition: transform  var(--transition-spring),
              opacity    var(--transition-fast),
              background var(--transition-fast);
}

/* ═══════════════════════════════════════════════════════════════
   34. MOBILE OPTIMISATION
   ═══════════════════════════════════════════════════════════════ */
@media screen and (max-width: 699px) {
  /* Larger base font for readability */
  html {
    font-size: 16px;
  }

  /* Generous tap targets for all interactive elements */
  a, button, [role="button"], label, summary {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
  }

  /* Override for span-level inline elements */
  .badge, .count-bubble, .shape-circle, .shape-square {
    min-height: unset;
    display: unset;
  }

  /* Product grid — 2 columns always */
  .product-list {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: var(--spacing-3) !important;
  }

  /* Bigger product card info */
  .product-card__info {
    padding: var(--spacing-3) !important;
    gap: var(--spacing-1) !important;
  }

  /* Ensure cart items are readable */
  .cart-drawer__line-items > * + * {
    padding-block-start: var(--spacing-5);
    margin-block-start: var(--spacing-5);
  }

  /* Footer — single column */
  .footer__block-list {
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-8) var(--spacing-6);
  }

  .footer__block--text,
  .footer__block--newsletter,
  .footer__block--app {
    grid-column: 1 / -1;
  }

  /* Section headers — less padding */
  .section-header {
    margin-block-end: var(--spacing-6);
  }

  /* Announcement bar — shorter & readable */
  .announcement-bar {
    font-size: 12px;
    padding-block: var(--spacing-2);
  }

  /* Input minimum height for touch */
  .input, .textarea, .select {
    min-height: 52px;
    font-size: 16px; /* Prevents iOS zoom */
  }

  /* Quantity selector on mobile */
  .quantity-selector {
    min-height: 52px;
  }

  .quantity-selector__button {
    padding-inline: var(--spacing-5);
  }

  /* Button sizing for mobile */
  .button, .btn {
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  /* Buy button — full width on mobile */
  .buy-buttons {
    gap: var(--spacing-3);
  }

  /* Product quick-add panel — full-width slide-up */
  .product-quick-add {
    border-radius: var(--rounded-sm) var(--rounded-sm) 0 0;
    padding-bottom: env(safe-area-inset-bottom, var(--spacing-5));
  }

  /* Drawer full-height on mobile */
  .drawer::part(content) {
    max-height: 90dvh;
  }

  /* Smoother scroll on mobile */
  .scroll-area {
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
  }

  /* Table — horizontal scroll instead of squish */
  .table-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Better header spacing */
  .header__wrapper {
    padding-inline: var(--spacing-4);
  }

  /* Bigger icon buttons in header */
  .header__icon-list > * {
    width: 44px;
    height: 44px;
  }
}

/* Tablet specific */
@media screen and (min-width: 700px) and (max-width: 999px) {
  /* Input font size — prevents iOS auto-zoom */
  .input, .textarea, .select {
    font-size: 16px;
  }

  /* 3-column grid */
  .product-list {
    gap: var(--spacing-4);
  }
}

/* ═══════════════════════════════════════════════════════════════
   35. SAFE AREA INSETS — for iOS notch & home bar
   ═══════════════════════════════════════════════════════════════ */
.drawer::part(content) {
  padding-bottom: env(safe-area-inset-bottom, 0px);
}

.product-quick-add {
  padding-bottom: calc(env(safe-area-inset-bottom, 0px) + var(--spacing-5));
}

/* ═══════════════════════════════════════════════════════════════
   36. PRINT — hide non-essential elements
   ═══════════════════════════════════════════════════════════════ */
@media print {
  .header,
  .footer,
  .announcement-bar,
  .drawer,
  .product-quick-add,
  .cart-drawer,
  .privacy-bar {
    display: none !important;
  }

  body {
    font-size: 12pt;
    color: #000;
    background: #fff;
  }
}

/* ═══════════════════════════════════════════════════════════════
   37. REDUCED MOTION — respect user preference
   ═══════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }

  .product-card:hover,
  .blog-post-card:hover,
  .collection-card:hover {
    transform: none !important;
  }

  .product-card__image--primary,
  .blog-post-card__figure img,
  .collection-card img {
    transform: none !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   38. SEARCH — refined search UI
   ═══════════════════════════════════════════════════════════════ */
/* Search input — prominent */
[type="search"] {
  border-radius: var(--rounded-button);
  transition: border-color var(--transition-fast),
              box-shadow   var(--transition-fast);
}

[type="search"]:focus {
  outline: none;
  border-color: rgb(var(--accent, 220 140 60));
  box-shadow: 0 0 0 3px rgb(var(--accent, 220 140 60) / .15);
}

/* Search results — card-like items */
.predictive-search__result-item {
  transition: background-color var(--transition-fast);
  border-radius: 8px;
}

@media screen and (pointer: fine) {
  .predictive-search__result-item:hover {
    background: rgb(var(--text-color) / .05);
  }
}

/* ═══════════════════════════════════════════════════════════════
   39. SWATCHES — refined
   ═══════════════════════════════════════════════════════════════ */
.color-swatch {
  transition: transform  var(--transition-fast),
              box-shadow var(--transition-fast);
  border-radius: 50%;
}

.color-swatch:hover,
.color-swatch[aria-checked="true"] {
  transform: scale(1.12);
  box-shadow: 0 0 0 2px rgb(var(--text-color)),
              0 0 0 4px rgb(var(--background-primary));
}

.block-swatch {
  transition: background-color var(--transition-fast),
              color            var(--transition-fast),
              box-shadow       var(--transition-fast),
              transform        var(--transition-fast);
  border-width: 1px;
}

.block-swatch:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-xs);
}

.block-swatch[aria-checked="true"] {
  font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════════
   40. VARIANT PICKER — cleaner layout
   ═══════════════════════════════════════════════════════════════ */
.variant-picker {
  gap: var(--spacing-5);
}

.variant-picker__option-info {
  font-weight: 600;
  font-size: var(--text-sm);
  letter-spacing: .01em;
  margin-block-end: var(--spacing-3);
}

/* ═══════════════════════════════════════════════════════════════
   41. FREE SHIPPING BAR — progress bar style
   ═══════════════════════════════════════════════════════════════ */
.free-shipping-bar {
  border-radius: var(--rounded-full);
}

/* ═══════════════════════════════════════════════════════════════
   42. PHOTOSWIPE — keep original styles but refine close button
   ═══════════════════════════════════════════════════════════════ */
.pswp__button--close {
  transition: transform var(--transition-base),
              opacity   var(--transition-fast);
  opacity: .85;
}

@media screen and (pointer: fine) {
  .pswp__button--close:hover {
    opacity: 1;
    transform: rotate(90deg);
  }
}

/* ═══════════════════════════════════════════════════════════════
   43. SCROLL SHADOW — refined indicator
   ═══════════════════════════════════════════════════════════════ */
scroll-shadow {
  --scroll-shadow-size: 32px;
}

/* ═══════════════════════════════════════════════════════════════
   44. PILL LOADER — refined dots
   ═══════════════════════════════════════════════════════════════ */
.pill-loader {
  border-radius: var(--rounded-full);
}

.loader-dots > * {
  border-radius: 50%;
  animation-timing-function: cubic-bezier(.45, 0, .55, 1);
}

/* ═══════════════════════════════════════════════════════════════
   45. UTILITY OVERRIDES
   ═══════════════════════════════════════════════════════════════ */

/* Better truncate: adds ellipsis with max-width guard */
.truncate-text {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 100%;
}

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

/* Smooth image loading — prevent content layout shift */
img[loading="lazy"] {
  background: rgb(var(--text-color) / .06);
}

/* ═══════════════════════════════════════════════════════════════
   46. GIFT CARD — polished layout
   ═══════════════════════════════════════════════════════════════ */
.gift-card {
  gap: var(--spacing-8);
}

/* ═══════════════════════════════════════════════════════════════
   47. ACCOUNT PAGES
   ═══════════════════════════════════════════════════════════════ */
.account-nav__item a {
  transition: color var(--transition-fast),
              background-color var(--transition-fast);
  border-radius: 8px;
  padding: var(--spacing-2) var(--spacing-3);
  min-height: 44px;
  display: flex;
  align-items: center;
}

@media screen and (pointer: fine) {
  .account-nav__item a:hover {
    background: rgb(var(--text-color) / .06);
  }
}

.account-nav__item[aria-current="page"] a {
  font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════════
   48. SHOP-THE-LOOK & FEATURE CHART
   ═══════════════════════════════════════════════════════════════ */
/* Shop-the-look dots — spring animation */
.shop-the-look__dot {
  transition: transform var(--transition-spring),
              box-shadow var(--transition-base);
}

@media screen and (pointer: fine) {
  .shop-the-look__dot:hover {
    transform: scale(1.15);
    box-shadow: var(--shadow-md);
  }
}

/* ═══════════════════════════════════════════════════════════════
   49. SECTION-BOXED — stronger card look
   ═══════════════════════════════════════════════════════════════ */
.section-boxed {
  border-radius: var(--rounded-lg);
  box-shadow: var(--shadow-lg);
}

/* ═══════════════════════════════════════════════════════════════
   50. FINAL POLISH — micro-interactions & details
   ═══════════════════════════════════════════════════════════════ */

/* Smooth hr */
hr {
  border-top-color: rgb(var(--text-color) / .1);
}

/* Blockquote — refined leading quote */
.blockquote {
  font-style: italic;
}

/* Image banner — text is always legible */
.image-banner .content-over-media > :not(img, video, picture) {
  text-shadow: 0 1px 3px rgb(0 0 0 / .2);
}

/* Better banner CTA positioning on mobile */
@media screen and (max-width: 699px) {
  .image-banner .button,
  .image-banner .btn {
    min-height: 52px;
    width: 100%;
    justify-content: center;
  }
}

/* Slideshow dots — refined */
.slideshow .page-dots {
  gap: var(--spacing-2);
}

/* Media carousel — smooth drag cursor */
media-carousel {
  cursor: grab;
}

media-carousel:active {
  cursor: grabbing;
}

/* Impact text — strong visual weight */
.impact-text {
  line-height: .95;
  letter-spacing: -.04em;
}

/* Newsletter section — focused CTA */
.newsletter-popup .button {
  min-height: 52px;
  font-size: var(--text-base);
}

/* Collection list cards */
.collection-list {
  gap: var(--spacing-4);
}

@media screen and (min-width: 700px) {
  .collection-list {
    gap: var(--spacing-6);
  }
}

/* Press carousel — refined quote style */
.press-carousel .blockquote {
  font-size: var(--text-xl, 1.25rem);
  line-height: 1.4;
}

/* Recently viewed — subtle section divider */
.recently-viewed-products {
  border-top: 1px solid rgb(var(--text-color) / .08);
  padding-block-start: var(--spacing-8);
}

/* ═══════════════════════════════════════════════════════════════
   51. MEGA CATEGORY NAV  (boAt-style full-width panel)
   ═══════════════════════════════════════════════════════════════ */

/* ── Trigger button (sits in header nav list) ─────────────── */
.mega-cat-nav {
  position: static;        /* panel is positioned relative to viewport */
  list-style: none;
}

.mega-cat-nav__trigger {
  /* Looks exactly like the other header nav links */
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 0;
  background: transparent;
  border: none;
  color: inherit;
  font: inherit;
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: .01em;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  white-space: nowrap;
  line-height: inherit;
  /* Match link hover underline from global nav improvements */
  position: relative;
  padding-block: var(--spacing-1);
  transition: color var(--transition-fast);
}

.mega-cat-nav__trigger::after {
  content: '';
  position: absolute;
  inset-inline: 0;
  bottom: -2px;
  height: 1.5px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform var(--transition-base);
  border-radius: 2px;
}

.mega-cat-nav--open .mega-cat-nav__trigger::after,
@media screen and (pointer: fine) {
  .mega-cat-nav__trigger:hover::after {
    transform: scaleX(1);
    transform-origin: left;
  }
}

.mega-cat-nav--open .mega-cat-nav__trigger {
  color: rgb(var(--text-color));
}

/* Chevron rotates when open */
.mega-cat-nav__chevron {
  flex-shrink: 0;
  transition: transform var(--transition-base);
  position: relative;
  top: 1px;
}

.mega-cat-nav--open .mega-cat-nav__chevron {
  transform: rotate(180deg);
}

/* ── Panel shell (full viewport width, anchored to header) ─── */
.mega-cat-panel {
  /* Positioned relative to the viewport, sits flush below header */
  position: fixed;
  top: var(--sticky-area-height, 60px);
  left: 0;
  right: 0;
  z-index: 200;
  /* Hidden by default */
  pointer-events: none;
}

.mega-cat-panel[hidden] {
  display: block !important; /* override HTML hidden so we can animate out */
  visibility: hidden;
  pointer-events: none;
}

/* ── Backdrop (page-dim layer) ────────────────────────────── */
.mega-cat-panel__backdrop {
  position: fixed;
  inset: 0;
  top: var(--sticky-area-height, 60px);
  background: rgb(0 0 0 / 0);
  transition: background var(--transition-base);
  pointer-events: none;
  z-index: -1;
}

.mega-cat-panel--open .mega-cat-panel__backdrop {
  background: rgb(0 0 0 / .25);
  pointer-events: auto;
  backdrop-filter: blur(1px);
  -webkit-backdrop-filter: blur(1px);
}

/* ── Panel box (the white card) ───────────────────────────── */
.mega-cat-panel__box {
  background: rgb(var(--background-primary, 255 255 255));
  color: rgb(var(--text-primary, 30 30 30));
  border-top: 1px solid rgb(var(--text-color, 30 30 30) / .08);
  box-shadow: 0 12px 32px rgb(0 0 0 / .12), 0 4px 12px rgb(0 0 0 / .08);
  /* Animate in from slightly above */
  transform: translateY(-10px);
  opacity: 0;
  transition:
    transform var(--transition-slow),
    opacity   250ms cubic-bezier(.4, 0, .2, 1);
  pointer-events: none;
  will-change: transform, opacity;
  max-height: 80vh;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}

.mega-cat-panel--open .mega-cat-panel__box {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

/* ── Inner content (max-width container) ─────────────────── */
.mega-cat-panel__inner {
  max-width: var(--container-max-width, 1400px);
  margin-inline: auto;
  padding: var(--spacing-6) max(var(--container-gutter, 1.5rem), 50% - var(--container-max-width, 1400px) / 2);
}

/* ── Category grid ────────────────────────────────────────── */
.mega-cat-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: var(--spacing-2);
}

@media screen and (max-width: 1149px) {
  .mega-cat-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media screen and (max-width: 999px) {
  .mega-cat-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media screen and (max-width: 699px) {
  .mega-cat-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* ── Individual category card ─────────────────────────────── */
.mega-cat-grid__item {
  display: block;
}

/* Empty state hint (theme editor only) */
.mega-cat-grid__item--empty {
  grid-column: 1 / -1;
  padding: var(--spacing-8);
  text-align: center;
  font-size: var(--text-sm);
  opacity: .6;
  border: 1px dashed rgb(var(--text-color) / .3);
  border-radius: 8px;
}

/* ── Category link (image + label, side by side) ────────── */
.mega-cat-grid__link {
  display: flex;
  align-items: center;
  gap: var(--spacing-3);
  padding: var(--spacing-3) var(--spacing-3);
  border-radius: 10px;
  text-decoration: none;
  color: rgb(var(--text-primary, 30 30 30));
  transition:
    background-color var(--transition-fast),
    transform        var(--transition-fast),
    box-shadow       var(--transition-fast);
  -webkit-tap-highlight-color: transparent;
  position: relative;
}

@media screen and (pointer: fine) {
  .mega-cat-grid__link:hover {
    background: rgb(var(--text-color) / .06);
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgb(0 0 0 / .06);
  }

  .mega-cat-grid__link:hover .mega-cat-grid__img,
  .mega-cat-grid__link:hover .mega-cat-grid__img-svg {
    transform: scale(1.08);
  }
}

.mega-cat-grid__link:active {
  transform: scale(.97);
  background: rgb(var(--text-color) / .1);
}

/* Active collection */
.mega-cat-grid__link--active {
  background: rgb(var(--button-background-primary, 30 30 30) / .07);
}

.mega-cat-grid__link--active .mega-cat-grid__name {
  font-weight: 700;
}

/* ── Thumbnail image wrapper ─────────────────────────────── */
.mega-cat-grid__img-wrap {
  width: 60px;
  height: 60px;
  flex-shrink: 0;
  border-radius: 10px;
  overflow: hidden;
  background: rgb(var(--text-color) / .05);
  display: flex;
  align-items: center;
  justify-content: center;
  /* Subtle inner shadow for depth */
  box-shadow: inset 0 0 0 1px rgb(var(--text-color) / .08);
  transition: box-shadow var(--transition-fast);
}

@media screen and (pointer: fine) {
  .mega-cat-grid__link:hover .mega-cat-grid__img-wrap {
    box-shadow: inset 0 0 0 1px rgb(var(--text-color) / .12),
                0 2px 8px rgb(0 0 0 / .1);
  }
}

.mega-cat-grid__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform var(--transition-slow);
}

/* SVG / icon placeholder */
.mega-cat-grid__img-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgb(var(--text-color) / .35);
}

.mega-cat-grid__img-svg {
  width: 28px;
  height: 28px;
  transition: transform var(--transition-slow);
}

/* ── Category name ─────────────────────────────────────────── */
.mega-cat-grid__name {
  font-size: var(--text-sm);
  font-weight: 500;
  line-height: 1.3;
  color: rgb(var(--text-primary, 30 30 30));
  letter-spacing: .005em;
  /* Allow up to 2 lines */
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── Panel footer ("View all categories" link) ────────────── */
.mega-cat-panel__footer {
  margin-block-start: var(--spacing-4);
  padding-block-start: var(--spacing-4);
  border-top: 1px solid rgb(var(--text-color) / .08);
  display: flex;
  justify-content: flex-end;
}

.mega-cat-panel__view-all {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-1-5);
  font-size: var(--text-sm);
  font-weight: 500;
  color: rgb(var(--text-color) / .65);
  text-decoration: none;
  transition: color var(--transition-fast), gap var(--transition-fast);
  padding: var(--spacing-2) 0;
}

@media screen and (pointer: fine) {
  .mega-cat-panel__view-all:hover {
    color: rgb(var(--text-color));
    gap: var(--spacing-2-5);
  }
}

/* ══ Mobile: full-screen slide-down panel ══════════════════ */
@media screen and (max-width: 699px) {
  .mega-cat-panel {
    top: var(--sticky-area-height, 56px);
  }

  .mega-cat-panel__box {
    max-height: calc(100dvh - var(--sticky-area-height, 56px));
    border-radius: 0 0 16px 16px;
  }

  .mega-cat-panel__inner {
    padding: var(--spacing-4) var(--spacing-4) var(--spacing-6);
  }

  .mega-cat-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--spacing-2);
  }

  .mega-cat-grid__link {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-2);
    padding: var(--spacing-3);
  }

  .mega-cat-grid__img-wrap {
    width: 56px;
    height: 56px;
  }

  .mega-cat-grid__name {
    font-size: 12px;
  }

  /* Full-width "view all" on mobile */
  .mega-cat-panel__footer {
    justify-content: center;
  }

  .mega-cat-panel__view-all {
    font-size: var(--text-base);
    padding: var(--spacing-3) var(--spacing-5);
    background: rgb(var(--text-color) / .05);
    border-radius: 8px;
  }
}

/* ══ Reduce motion override ════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  .mega-cat-panel__box {
    transition: opacity 100ms ease;
    transform: none !important;
  }
  .mega-cat-nav__chevron {
    transition: none;
  }
}

/* ═══════════════════════════════════════════════════════════════
   END OF KOWS KITCHENWARE THEME IMPROVEMENTS
   ═══════════════════════════════════════════════════════════════ */
