/*-----------------------------------*\
  #style.css
\*-----------------------------------*/

/**
 * copyright 2022 @codewithsadee 
 */





/*-----------------------------------*\
  #CUSTOM PROPERTY
\*-----------------------------------*/

:root {

  /**
   * colors
   */

  --spanish-gray: hsl(0, 0%, 60%);
  --sonic-silver: hsl(0, 0%, 47%);
  --eerie-black: hsl(0, 0%, 13%);
  --salmon-pink: hsl(353, 100%, 78%);
  --sandy-brown: hsl(29, 90%, 65%);
  --bittersweet: hsl(0, 100%, 70%);
  --ocean-green: hsl(152, 51%, 52%);
  --davys-gray: hsl(0, 0%, 33%);
  --cultured: hsl(0, 0%, 93%);
  --white: hsl(0, 100%, 100%);
  --onyx: hsl(0, 0%, 27%);

  /**
   * typography
   */

  --fs-1: 1.563rem;
  --fs-2: 1.375rem;
  --fs-3: 1.25rem;
  --fs-4: 1.125rem;
  --fs-5: 1rem;
  --fs-6: 0.938rem;
  --fs-7: 0.875rem;
  --fs-8: 0.813rem;
  --fs-9: 0.75rem;
  --fs-10: 0.688rem;
  --fs-11: 0.625rem;

  --weight-300: 300;
  --weight-400: 400;
  --weight-500: 500;
  --weight-600: 600;
  --weight-700: 700;

  /**
   * border-radius
   */

  --border-radius-md: 10px;
  --border-radius-sm: 5px;

  /**
   * transition 
   */

  --transition-timing: 0.2s ease;

}





/*-----------------------------------*\
  #RESET
\*-----------------------------------*/

*, *::before, *::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

a { text-decoration: none; }

li { list-style: none; }

button {
  background: none;
  font: inherit;
  border: none;
  cursor: pointer;
}

img, ion-icon, button, a { display: block; }

span { display: inline-block; }

html {
  font-family: "Poppins", sans-serif;
  overscroll-behavior: contain;
}

input {
  display: block;
  width: 100%;
  font: inherit;
}

input::placeholder { font: inherit; }

body { background: var(--white); }

/**
 * scrollbar style
 */

body::-webkit-scrollbar { width: 15px; }

body::-webkit-scrollbar-track {
  background: var(--white);
  border-left: 1px solid var(--cultured);
}

body::-webkit-scrollbar-thumb {
  background: hsl(0, 0%, 80%);
  border: 3px solid var(--white);
  border-radius: 10px;
}

body::-webkit-scrollbar-thumb:hover { background: hsl(0, 0%, 70%); }





/*-----------------------------------*\
  #REUSED STYLE
\*-----------------------------------*/

.container { padding: 0 15px; }

.has-scrollbar { padding-bottom: 5px; }

.has-scrollbar::-webkit-scrollbar {
  width: 12px; /* for vertical scroll */
  height: 12px; /* for horizontal scroll */
}

.has-scrollbar::-webkit-scrollbar-thumb {
  background: transparent;
  border: 3px solid var(--white);
  border-radius: 20px;
}

.has-scrollbar:hover::-webkit-scrollbar-thumb { background: hsl(0, 0%, 90%); }

.has-scrollbar::-webkit-scrollbar-thumb:hover { background: hsl(0, 0%, 80%); }

.title {
  color: var(--eerie-black);
  font-size: var(--fs-5);
  font-weight: var(--weight-600);
  letter-spacing: 0.4px;
  text-transform: capitalize;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--cultured);
  margin-bottom: 30px;
}
/*-----------------------------------*\
  #MAIN
\*-----------------------------------*/

/**
 * overlay 
 */

.overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: hsla(0, 0%, 0%, 0.5);
  opacity: 0;
  pointer-events: none;
  z-index: 15;
  transition: 0.5s ease;
}

.overlay.active {
  opacity: 1;
  pointer-events: all;
}

/*-----------------------------------*\
  #HEADER
\*-----------------------------------*/

.header-top,
.header-user-actions,
.desktop-navigation-menu { display: none; }

.header-main {
  padding: 20px 0;
  border-bottom: 1px solid var(--cultured);
}

.header-logo {
  margin-bottom: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.header-logo img {
  display: block;
  height: 1204px;   /* increase/decrease: 48, 56, 72 */
  width: auto;
}
.header-search-container { position: relative; }

.header-search-container .search-field {
  font-size: var(--fs-7);
  color: var(--onyx);
  padding: 10px 15px;
  padding-right: 50px;
  border: 1px solid var(--cultured);
  border-radius: var(--border-radius-md);
}

.search-field::-webkit-search-cancel-button { display: none; }

.search-btn {
  background: var(--white);
  position: absolute;
  top: 50%;
  right: 2px;
  transform: translateY(-50%);
  color: var(--onyx);
  font-size: 18px;
  padding: 8px 15px;
  border-radius: var(--border-radius-md);
  transition: color var(--transition-timing);
}

.search-btn:hover { color: var(--salmon-pink); }

.mobile-bottom-navigation {
  background: var(--white);
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 500px;
  margin: auto;
  display: flex;
  justify-content: space-around;
  align-items: center;
  padding: 5px 0;
  box-shadow: 0 0 10px hsla(0, 0%, 0%, 0.25);
  z-index: 5;
}

.mobile-bottom-navigation .action-btn {
  position: relative;
  font-size: 26px;
  color: var(--eerie-black);
  padding: 10px;
}

.mobile-bottom-navigation .count {
  background: var(--bittersweet);
  color: var(--white);
  position: absolute;
  top: 0;
  right: 0;
  font-size: 12px;
  font-weight: var(--weight-500);
  line-height: 1;
  padding: 2px 4px;
  border-radius: 20px;
}

.mobile-navigation-menu {
  background: var(--white);
  position: fixed;
  top: 0;
  left: -100%;
  width: 100%;
  max-width: 320px;
  height: 100vh;
  padding: 20px;
  box-shadow: 0 0 10px hsla(0, 0%, 0%, 0.1);
  overflow-y: scroll;
  overscroll-behavior: contain;
  visibility: hidden;
  transition: 0.5s ease;
  z-index: 20;
}

.mobile-navigation-menu.active {
  left: 0;
  visibility: visible;
}

.menu-top {
  padding-bottom: 15px;
  margin-bottom: 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 2px solid var(--cultured);
}

.menu-top .menu-title {
  color: var(--salmon-pink);
  font-size: var(--fs-4);
  font-weight: var(--weight-600);
}

.menu-close-btn {
  color: var(--eerie-black);
  font-size: 22px;
}

.menu-close-btn ion-icon { --ionicon-stroke-width: 50px; }

.mobile-menu-category-list { margin-bottom: 30px; }

.menu-category .accordion-menu {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.mobile-menu-category-list .menu-category { border-bottom: 1px solid var(--cultured); }

.mobile-menu-category-list .menu-title {
  color: var(--onyx);
  font-size: var(--fs-6);
  font-weight: var(--weight-500);
  padding: 12px 0;
}

.accordion-menu > div { font-size: 14px; }

.accordion-menu ion-icon {
  color: var(--onyx);
  --ionicon-stroke-width: 90px;
}

.accordion-menu.active .add-icon,
.accordion-menu .remove-icon { display: none; }

.accordion-menu .add-icon,
.accordion-menu.active .remove-icon { display: block; }

.menu-category .submenu-category-list { margin-left: 10px; }

.submenu-title {
  padding: 6px 0;
  font-size: var(--fs-6);
  color: var(--sonic-silver);
  font-weight: var(--weight-300);
}

.submenu-title:hover { color: var(--davys-gray); }

.submenu-category-list {
  max-height: 0;
  overflow: hidden;
  visibility: hidden;
  transition: 0.5s ease-in-out;
}

.submenu-category-list.active {
  max-height: 148px;
  visibility: visible;
}

.menu-bottom .menu-category-list { margin-bottom: 20px; }

.menu-bottom .menu-category { border-bottom: none; }

.menu-bottom .menu-title {
  font-size: var(--fs-6);
  font-weight: var(--weight-500);
  color: var(--eerie-black);
  padding: 12px 0;
}

.accordion-menu.active .caret-back { transform: rotate(-0.25turn); }

.menu-bottom .submenu-category-list {
  border: 1px solid var(--cultured);
  border-radius: var(--border-radius-md);
  padding: 0 15px;
  margin-left: 0;
  box-shadow: 0 0 10px hsla(0, 0%, 0%, 0.05);
}

.menu-bottom .submenu-category:not(:last-child) { border-bottom: 1px solid var(--cultured); }

.menu-social-container {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}

.menu-social-container .social-link {
  background: var(--cultured);
  color: var(--eerie-black);
  font-size: 20px;
  padding: 10px;
  border-radius: var(--border-radius-md);
}
/*-----------------------------------*\
  #CATEGORY
\*-----------------------------------*/

.category { margin-bottom: 30px; }

.category-item-container {
  display: flex;
  align-items: center;
  gap: 10px;
  overflow: auto hidden;
  scroll-snap-type: inline mandatory;
  overscroll-behavior-inline: contain;
}

.category-item {
  min-width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 15px;
  border: 1px solid var(--cultured);
  border-radius: var(--border-radius-md);
  scroll-snap-align: start;
}

.category-img-box {
  background: var(--cultured);
  border: 1px solid hsl(0, 0%, 80%);
  padding: 10px;
  border-radius: var(--border-radius-sm);
}

.category-content-box { width: 100%; }

.category-content-flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.category-item-title {
  color: var(--eerie-black);
  font-size: var(--fs-9);
  font-weight: var(--weight-600);
  text-transform: uppercase;
}

.category-item-amount {
  color: var(--sonic-silver);
  font-size: var(--fs-11);
}

.category-btn {
  color: var(--salmon-pink);
  font-size: var(--fs-9);
  font-weight: var(--weight-500);
  text-transform: capitalize;
}





/*-----------------------------------*\
  #SIDEBAR
\*-----------------------------------*/

.sidebar {
  background: var(--white);
  position: fixed;
  top: 0;
  left: -100%;
  bottom: 0;
  width: 100%;
  max-width: 320px;
  padding: 30px;
  overflow-y: scroll;
  overscroll-behavior: contain;
  visibility: hidden;
  transition: 0.5s ease;
  z-index: 20;
}

.sidebar.active {
  left: 0;
  visibility: visible;
}

.sidebar-category {
  margin-bottom: 15px;
  padding-bottom: 15px;
  border-bottom: 1px solid var(--cultured);
}

.sidebar-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.sidebar-title {
  color: var(--onyx);
  font-size: var(--fs-5);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  font-weight: var(--weight-600);
}

.sidebar-close-btn {
  color: var(--eerie-black);
  font-size: 22px;
  font-weight: var(--weight-600);
}

.sidebar-close-btn ion-icon { --ionicon-stroke-width: 50px; }

.sidebar-accordion-menu {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 7px 0;
}

.sidebar .menu-title-flex {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sidebar .menu-title {
  font-size: var(--fs-5);
  color: var(--sonic-silver);
  font-weight: var(--weight-500);
}

.sidebar-accordion-menu ion-icon {
  color: var(--sonic-silver);
  font-size: 14px;
  --ionicon-stroke-width: 70px;
}

.sidebar-submenu-category-list {
  border-top: 1px solid var(--cultured);
  max-height: 0;
  overflow: hidden;
  visibility: hidden;
  transition: 0.5s ease-in-out;
}

.sidebar-submenu-category-list.active {
  padding: 13px 0 8px;
  max-height: 122px;
  visibility: visible;
}

.sidebar-submenu-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--sonic-silver);
  font-size: var(--fs-7);
  padding: 2px 0;
}

.sidebar-submenu-title:hover { color: var(--eerie-black); }

.sidebar .product-name { text-transform: capitalize; }

.sidebar-accordion-menu.active .add-icon,
.sidebar-accordion-menu .remove-icon { display: none; }

.sidebar-accordion-menu .add-icon,
.sidebar-accordion-menu.active .remove-icon { display: block; }

.sidebar .showcase-heading {
  font-size: var(--fs-5);
  font-weight: var(--weight-600);
  color: var(--onyx);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: 15px;
}

.sidebar .showcase {
  display: flex;
  align-items: center;
  gap: 15px;
}

.sidebar .showcase:not(:last-child) { margin-bottom: 15px; }

.sidebar .showcase-img { border-radius: var(--border-radius-sm); }

.sidebar .showcase-content { width: calc(100% - 90px); }

.sidebar .showcase-title {
  color: var(--onyx);
  font-size: var(--fs-7);
  font-weight: var(--weight-400);
  text-transform: capitalize;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  letter-spacing: 0.5px;
}

.sidebar .showcase-rating {
  display: flex;
  align-items: center;
  color: var(--sandy-brown);
  font-size: 13px;
  padding: 4px 0;
}

.sidebar .price-box {
  display: flex;
  align-items: center;
  gap: 15px;
}

.sidebar .price-box del {
  color: var(--sonic-silver);
  font-size: 13px;
}

.sidebar .price-box .price {
  font-size: var(--fs-7);
  font-weight: var(--weight-600);
  color: var(--davys-gray);
}

/*-----------------------------------*\
  #PRODUCT FEATURED (small fix)
\*-----------------------------------*/
/* =======================
   PRODUCT FEATURED
======================= */
.product-featured .showcase-banner{
  position:relative;
  width:100%;
  aspect-ratio:4/3;
  overflow:hidden;
  border-radius:var(--border-radius-md);
}
.product-featured .showcase-img{width:100%;height:100%;object-fit:cover;display:block}
.product-featured .showcase-title{
  white-space:normal;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/*-----------------------------------*\
  #PRODUCT GRID (fixed: constant image height + no gray + no zoom)
\*-----------------------------------*/
.product-main{margin-bottom:30px}
.product-grid{display:grid;grid-template-columns:1fr;gap:25px}

.product-grid .showcase{
  border:1px solid var(--cultured);
  border-radius:var(--border-radius-md);
  overflow:hidden;
  transition:var(--transition-timing);
  background:var(--white);
}
.product-grid .showcase:hover{box-shadow:0 0 10px hsla(0,0%,0%,.1)}

/* consistent media box (pick ONE ratio) */
.product-grid .showcase-banner{
  position:relative;
  width:100%;
  aspect-ratio:4/5;            /* change to 1/1 if you want square */
  overflow:hidden;
  background:transparent;       /* no gray frame */
}

/* make link fill the media box */
.product-grid .showcase-banner>a{
  display:block;
  width:100%;
  height:100%;
}

/* both images fill banner, same size, clean fade */
.product-grid .product-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  transform:none !important;    /* kills zoom from anywhere */
  transition:opacity .25s ease; /* clean crossfade */
}
.product-grid .product-img.default{opacity:1;z-index:1}
.product-grid .product-img.hover{opacity:0;z-index:2}
.product-grid .showcase:hover .product-img.hover{opacity:1}
.product-grid .showcase:hover .product-img.default{opacity:0}

/* badges / actions */
.product-grid .showcase-badge{
  position:absolute;
  top:15px;
  left:15px;
  background:var(--ocean-green);
  font-size:var(--fs-8);
  font-weight:var(--weight-500);
  color:var(--white);
  padding:0 8px;
  border-radius:var(--border-radius-sm);
  z-index:3;
}
.product-grid .showcase-badge.angle{
  top:8px;
  left:-29px;
  transform:rotate(-45deg);
  text-transform:uppercase;
  font-size:11px;
  padding:5px 40px;
}
.product-grid .showcase-badge.black{background:var(--eerie-black)}
.product-grid .showcase-badge.pink{background:var(--salmon-pink)}

.product-grid .showcase-actions{
  position:absolute;
  top:10px;
  right:10px;
  font-size:20px;
  transform:translateX(50px);
  transition:var(--transition-timing);
  z-index:3;
}
.product-grid .showcase:hover .showcase-actions{transform:translateX(0)}

.product-grid .btn-action{
  background:var(--white);
  color:var(--sonic-silver);
  margin-bottom:5px;
  border:1px solid var(--cultured);
  padding:5px;
  border-radius:var(--border-radius-sm);
  transition:var(--transition-timing);
}
.product-grid .btn-action:hover{
  background:var(--eerie-black);
  color:var(--white);
  border-color:var(--eerie-black);
}

/* content */
.product-grid .showcase-content{padding:14px 16px 12px}
.product-grid .showcase-category{
  color:var(--salmon-pink);
  font-size:var(--fs-9);
  font-weight:var(--weight-500);
  text-transform:uppercase;
  margin-bottom:8px;
}
.product-grid .showcase-title{
  color:var(--eerie-black);
  font-size:var(--fs-8);
  font-weight:var(--weight-500);
  text-transform:none;
  letter-spacing:.2px;
  margin-bottom:10px;
  transition:var(--transition-timing);
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  min-height:calc(var(--fs-8)*1.2*2);
}
.product-grid .showcase-title:hover{color:var(--salmon-pink)}

.product-grid .showcase-rating{display:flex;color:var(--sandy-brown);margin-bottom:10px}
.product-grid .price-box{
  display:flex;
  gap:10px;
  font-size:var(--fs-7);
  color:var(--eerie-black);
  margin-bottom:0;
  align-items:baseline;
}
.product-grid .price{font-weight:var(--weight-700)}
.product-grid del{color:var(--sonic-silver)}


/* TOP PROMO BAR */
.promo-bar{
  position: relative;
  top: 0;
  background: var(--eerie-black);
  color: var(--white);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.promo-bar__inner{
  max-width: 1100px;
  margin: 0 auto;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.promo-bar__text{
  font-size: 0.9rem;
  line-height: 1.2;
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.promo-bar__link{
  color: var(--white);
  font-weight: 600;
  text-decoration: underline;
  white-space: nowrap;
}

.promo-bar__close{
  border: 0;
  background: transparent;
  color: var(--white);
  font-size: 18px;
  line-height: 1;
  padding: 6px 8px;
  border-radius: 10px;
  cursor: pointer;
  white-space: nowrap;
}

.promo-bar__close:hover{
  background: rgba(255,255,255,.10);
}

/* mobile: allow 2 lines instead of ellipsis */
@media (max-width: 480px){
  .promo-bar__text{
    white-space: normal;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
}
/* ===== PRICE BOX (works for real + fake compare-at) ===== */
.price-box{display:flex;align-items:baseline;gap:10px;margin:0}
.price-box .price{margin:0;font-weight:900;letter-spacing:.2px}
.price-box del{opacity:.62;font-size:.92em}

/* optional: if you want the fake % badge not to overlap your existing angle badge */
.showcase-badge--home{top:38px} /* moves it below the first badge */

/* ===== BROWSE MORE BUTTON (eye-catching, mobile-first) ===== */
.browse-more{margin:18px 0 88px;display:flex;justify-content:center;padding:8px 0 22px}
.browse-more__btn{
  display:flex;align-items:center;gap:10px;
  padding:14px 16px;border-radius:18px;
  border:1px solid rgba(0,0,0,.12);
  background:var(--eerie-black);color:var(--white);
  text-decoration:none;font-weight:900;
  box-shadow:0 10px 26px rgba(0,0,0,.14);
  transform:translateZ(0);
  transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease;
  position:relative;overflow:hidden;
}
.browse-more__btn:before{
  content:"";position:absolute;inset:-40% -30%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);
  transform:translateX(-60%) rotate(10deg);
  animation:bm-sheen 3.6s ease-in-out infinite;
}
@keyframes bm-sheen{0%,55%{transform:translateX(-60%) rotate(10deg)}75%,100%{transform:translateX(60%) rotate(10deg)}}

.browse-more__pill{
  display:inline-flex;align-items:center;justify-content:center;
  padding:6px 10px;border-radius:999px;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.18);
  font-size:11px;letter-spacing:.6px
}
.browse-more__txt{font-size:15px;line-height:1;position:relative}
.browse-more__arrow{font-size:18px;line-height:1;position:relative}

@media (hover:hover){
  .browse-more__btn:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(0,0,0,.18);opacity:.98}
  .browse-more__btn:hover .browse-more__arrow{transform:translateX(2px);transition:transform .18s ease}
}
@media (max-width:480px){
  .browse-more__btn{width:100%;max-width:480px;justify-content:center}
}
@media (prefers-reduced-motion:reduce){
  .browse-more__btn:before{animation:none}
}

/* =========================
   Accessible hidden text
========================= */
.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;
}

/* =========================
   Header search
========================= */
.header-search-container {
  position: relative;
  display: flex;
  align-items: center;
  width: min(680px, 100%);
  min-height: 48px;
  margin-inline: auto;
  background: #fff;
  border: 1px solid rgba(17, 17, 17, 0.12);
  border-radius: 999px;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.header-search-container:hover {
  border-color: rgba(17, 17, 17, 0.22);
}

.header-search-container:focus-within {
  border-color: rgba(17, 17, 17, 0.32);
  box-shadow: 0 0 0 4px rgba(17, 17, 17, 0.06);
}

.search-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding-left: 16px;
  flex: 0 0 auto;
  font-size: 20px;
  color: #666;
}

.search-field {
  flex: 1 1 auto;
  width: 100%;
  min-width: 0;
  height: 46px;
  border: 0;
  outline: 0;
  background: transparent;
  padding: 0 10px;
  font: inherit;
  font-size: 15px;
  color: #111;
}

.search-field::placeholder {
  color: #8a8a8a;
}

.search-clear-btn,
.search-submit-btn {
  border: 0;
  background: transparent;
  font: inherit;
  cursor: pointer;
}

.search-clear-btn {
  width: 38px;
  height: 38px;
  margin-right: 4px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #666;
  transition: background 0.2s ease, color 0.2s ease;
}

.search-clear-btn:hover {
  background: rgba(17, 17, 17, 0.06);
  color: #111;
}

.search-submit-btn {
  flex: 0 0 auto;
  min-width: 92px;
  height: 40px;
  margin-right: 4px;
  padding: 0 16px;
  border-radius: 999px;
  background: #111;
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.search-submit-btn:hover {
  opacity: 0.92;
}

.search-submit-btn:active {
  transform: translateY(1px);
}

/* =========================
   Mobile search behavior
========================= */
@media (max-width: 767px) {
  .header-main .container {
    position: relative;
  }

  .header-search-container {
    display: none;
    width: 100%;
    margin-top: 12px;
  }

  .site-header.is-search-open .header-logo,
  .site-header.is-search-open .header-user-actions,
  .site-header.is-search-open .header-mobile-actions--right,
  .site-header.is-search-open .mobile-quick-links {
    display: none !important;
  }

  .site-header.is-search-open .header-search-container {
    display: flex;
  }

  .site-header.is-search-open .header-main .container {
    flex-wrap: wrap;
    row-gap: 10px;
  }

  .search-submit-btn {
    min-width: 78px;
    padding: 0 14px;
  }
}

/* =========================
   Desktop
========================= */
@media (min-width: 768px) {
  .header-search-container {
    display: flex;
  }
}
/*-----------------------------------*\
  #FOOTER
\*-----------------------------------*/

footer {
  background: var(--eerie-black);
  padding: 30px 0;
}

.footer-category {
  margin-bottom: 30px;
  padding-bottom: 15px;
  border-bottom: 1px solid var(--onyx);
}

.footer-category-title {
  color: var(--salmon-pink);
  font-size: var(--fs-6);
  font-weight: var(--weight-600);
  text-transform: uppercase;
  margin-bottom: 15px;
}

.footer-category-box {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  column-gap: 20px;
  row-gap: 3px;
  margin-bottom: 15px;
}

.category-box-title {
  color: var(--spanish-gray);
  font-size: var(--fs-8);
  font-weight: var(--weight-600);
  text-transform: uppercase;
}

.footer-category-link {
  position: relative;
  color: var(--sonic-silver);
  font-size: var(--fs-7);
  text-transform: capitalize;
  transition: var(--transition-timing);
}

.footer-category-link:hover { color: var(--spanish-gray); }

.footer-category-link:not(:last-child)::after {
  position: absolute;
  content: '';
  top: 3px;
  right: -10px;
  background: var(--sonic-silver);
  width: 1px;
  height: 15px;
}


/**
 * footer nav 
 */

.footer-nav {
  border-bottom: 1px solid var(--onyx);
  padding-bottom: 30px;
  margin-bottom: 30px;
}

.footer-nav-list:not(:last-child) { margin-bottom: 20px; }

.footer-nav .nav-title {
  position: relative;
  color: var(--white);
  font-size: var(--fs-7);
  text-transform: uppercase;
  margin-bottom: 15px;
  padding-bottom: 5px;
}

.footer-nav .nav-title::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  background: var(--salmon-pink);
  width: 60px;
  height: 1px;
}

.footer-nav-item { padding: 3px 0; }

.footer-nav-link,
.footer-nav-item .content {
  width: max-content;
  color: var(--sonic-silver);
  font-size: var(--fs-7);
  text-transform: capitalize;
  transition: var(--transition-timing);
}

.footer-nav-link:hover { color: var(--salmon-pink); }

.footer-nav-item.flex {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.footer-nav-item .content {
  font-style: normal;
  margin-bottom: 5px;
}

.footer-nav-item .icon-box {
  color: var(--sonic-silver);
  font-size: 25px;
}

.footer-nav-item .icon-box ion-icon { --ionicon-stroke-width: 30px; }

.footer-nav .social-link {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 10px;
}

.social-link .footer-nav-link { font-size: 25px; }

.footer-bottom {
  margin-bottom: 50px;
  text-align: center;
}

.payment-img {
  max-width: 335px;
  width: 100%;
  margin: auto;
  margin-bottom: 15px;
}

.copyright {
  color: var(--sonic-silver);
  font-size: var(--fs-8);
  font-weight: var(--weight-500);
  text-transform: capitalize;
  letter-spacing: 1.2px;
}

.copyright a {
  display: inline;
  color: inherit;
}
/* ============================
   SEE MORE CARD — SIMPLE BLACK
   ============================ */

.product-strip-card--see-more .see-more-media {
  /* Same structure as your image area, but styled like a CTA */
  display: grid;
  place-items: center;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

/* Subtle diagonal sheen (dark site friendly) */
.product-strip-card--see-more .see-more-media::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 35%, rgba(255,255,255,0.06) 50%, transparent 65%);
  transform: translateX(-120%);
  opacity: 0;
}

.see-more-pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(0,0,0,0.55);
  border: 1px solid rgba(255,255,255,0.14);
  color: rgba(255,255,255,0.92);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.2px;
  backdrop-filter: blur(6px);
  transition: transform 180ms ease, border-color 180ms ease;
}

.see-more-pill__arrow {
  display: inline-block;
  transition: transform 180ms ease;
  opacity: 0.9;
}

/* Hover only on devices that actually hover */
@media (hover: hover) and (pointer: fine) {
  .product-strip-card--see-more .see-more-media:hover {
    transform: translateY(-2px);
    border-color: rgba(255,255,255,0.16);
    background: rgba(255,255,255,0.04);
  }

  .product-strip-card--see-more .see-more-media:hover::before {
    opacity: 1;
    animation: seeMoreSheenSimple 800ms ease forwards;
  }

  .product-strip-card--see-more .see-more-media:hover .see-more-pill {
    transform: scale(1.02);
    border-color: rgba(255,255,255,0.20);
  }

  .product-strip-card--see-more .see-more-media:hover .see-more-pill__arrow {
    transform: translateX(3px);
  }
}

/* Tap feedback on mobile */
.product-strip-card--see-more .see-more-media:active {
  transform: scale(0.99);
}

.product-strip-card--see-more .see-more-media:focus-visible {
  outline: 2px solid rgba(255,255,255,0.35);
  outline-offset: 3px;
}

@keyframes seeMoreSheenSimple {
  0%   { transform: translateX(-120%); }
  100% { transform: translateX(120%); }
}

@media (prefers-reduced-motion: reduce) {
  .product-strip-card--see-more .see-more-media,
  .product-strip-card--see-more .see-more-media::before,
  .see-more-pill,
  .see-more-pill__arrow {
    transition: none !important;
    animation: none !important;
  }
}

/*-----------------------------------*\
  #RESPONSIVE
\*-----------------------------------*/
/* ====== CORE RESPONSIVE / OVERRIDES (DEDUPED) ====== */

/* Container + base typography */
.container{margin:auto;padding-inline:15px}
html{font-size:16px}

/* Header (mobile-first) */
.site-header .header-main{padding:14px 0;border-bottom:1px solid var(--cultured)}
.site-header .header-logo{display:flex;align-items:center;justify-content:center;margin:8px 0 14px}
.site-header .header-logo img{display:block;height:56px;width:auto;max-width:92vw;object-fit:contain}

/* Mobile top actions + quick links */
.header-mobile-actions{display:flex;align-items:center;gap:6px}
.header-mobile-actions .action-btn{position:relative;font-size:24px;color:var(--eerie-black);padding:10px;background:transparent;border:0;display:inline-flex;align-items:center;justify-content:center}
.header-mobile-actions .action-btn ion-icon{--ionicon-stroke-width:50px}
.header-mobile-actions .count{background:var(--bittersweet);color:var(--white);position:absolute;top:0;right:0;font-size:12px;font-weight:var(--weight-500);line-height:1;padding:2px 4px;border-radius:20px}

.mobile-quick-links{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:10px 0 0;margin-top:6px}
.mobile-quick-links::-webkit-scrollbar{display:none}
.mobile-quick-links a{flex:0 0 auto;padding:8px 12px;border:1px solid var(--cultured);border-radius:999px;font-size:var(--fs-7);color:var(--onyx);background:var(--white);white-space:nowrap}

/* ===== CATEGORY STRIP (fix: not 1-per-row; mobile shows 2.5; desktop shows all) ===== */
.category{margin:12px 0 10px}
.category .category-item-container{
  display:flex;
  gap:10px;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  padding:6px 0 10px;
  scroll-snap-type:x mandatory;
  overscroll-behavior-x:contain;
}
.category .category-item-container::-webkit-scrollbar{height:6px}
.category .category-item-container::-webkit-scrollbar-thumb{background:rgba(0,0,0,.18);border-radius:999px}
.category .category-item-container::-webkit-scrollbar-track{background:rgba(0,0,0,.06);border-radius:999px}

/* mobile: 2.5 visible */
.category .category-item{
  flex:0 0 44%;
  max-width:280px;
  scroll-snap-align:start;
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  background:#fff;
  min-width:0;
}
@media (max-width:359px){.category .category-item{flex-basis:48%}}
@media (min-width:360px){.category .category-item{flex-basis:42%}}
@media (min-width:480px){.category .category-item{flex-basis:34%}}
@media (min-width:640px){.category .category-item{flex-basis:28%}}

.category .category-img-box{
  flex:0 0 42px;
  width:42px;
  height:42px;
  border-radius:12px;
  background:rgba(0,0,0,.04);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.category .category-img-box img{width:26px;height:26px;object-fit:cover;display:block}

.category .category-content-box{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  width:100%;
  min-width:0;
}
.category .category-content-flex{min-width:0}
.category .category-item-title{
  margin:0;
  font-weight:900;
  font-size:12px;
  line-height:1.1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.category .category-item-amount{margin:3px 0 0;font-size:10px;opacity:.65;white-space:nowrap}
.category .category-btn{
  flex:0 0 auto;
  text-decoration:none;
  font-weight:900;
  font-size:11px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.12);
  background:var(--eerie-black);
  color:var(--white);
  line-height:1;
}
/* ===== CATEGORY STRIP: clean + responsive 350px -> 1700px+ ===== */
/* ===== CATEGORY STRIP: ALWAYS 1 ROW + HORIZONTAL SCROLL (ALL SIZES) ===== */

.category .category-item-container{
  display:flex;
  flex-wrap:nowrap;                 /* <-- never wrap to 2 rows */
  gap:12px;
  overflow-x:auto;                  /* <-- always scroll */
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  scroll-snap-type:x mandatory;
  overscroll-behavior-x:contain;
  padding:8px 0 12px;
}

.category .category-item-container::-webkit-scrollbar{height:6px}
.category .category-item-container::-webkit-scrollbar-thumb{background:rgba(0,0,0,.15);border-radius:999px}
.category .category-item-container::-webkit-scrollbar-track{background:rgba(0,0,0,.06);border-radius:999px}

/* card sizing: show ~2.3 cards on small, scale up smoothly on big */
.category .category-item{
  flex:0 0 clamp(170px, 44vw, 320px); /* wider than before, still responsive */
  scroll-snap-align:start;
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 12px;               /* compact height */
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  background:#fff;
  text-decoration:none;
  color:inherit;
}

/* round image fully fills */
.category .category-img-box{
  width:60px;
  height:60px;
  flex:0 0 60px;
  border-radius:999px;
  overflow:hidden;
  background:transparent;
}
.category .category-img-box img{
  width:100% !important;
  height:100% !important;
  object-fit:cover;
  display:block;
  border-radius:inherit;
}

/* layout inside */
.category .category-content-box{
  flex:1;
  min-width:0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.category .category-content-flex{min-width:0}

/* title */
.category .category-item-title{
  margin:0;
  font-size:14px;
  line-height:1.15;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* keep mobile clean: hide secondary + button */
.category .category-item-amount{display:none}
.category .category-btn{display:none}

/* mid screens: slightly bigger */
@media (min-width:480px){
  .category .category-item{flex-basis:clamp(190px, 34vw, 340px)}
  .category .category-img-box{width:64px;height:64px;flex-basis:64px}
  .category .category-item-title{font-size:15px}
}

/* desktop: still 1 row + scroll, but show extra info + button */
@media (min-width:900px){
  .category .category-item{flex-basis:clamp(220px, 22vw, 360px)}
  .category .category-item-amount{display:block;font-size:12px;margin:3px 0 0;opacity:.7}
  .category .category-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:7px 12px;
    border-radius:999px;
    border:1px solid rgba(0,0,0,.12);
    font-size:12px;
    font-weight:700;
    background:#fff;
    white-space:nowrap;
  }
}

/* desktop/tablet: show ALL (no scroll) + smaller tiles */
@media (min-width:768px){
  .category .category-item-container{
    overflow:visible;
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:10px;
    padding:0;
  }
  .category .category-item{flex:unset;max-width:none;padding:10px}
}
@media (min-width:1024px){
  .category .category-item-container{grid-template-columns:repeat(6,minmax(0,1fr));gap:10px}
  .category .category-item{padding:9px;gap:8px}
  .category .category-img-box{width:40px;height:40px;flex-basis:40px}
}
@media (min-width:1200px){
  .category .category-item-container{grid-template-columns:repeat(8,minmax(0,1fr));gap:10px}
  .category .category-item{flex-direction:column;align-items:center;text-align:center;padding:10px 8px;gap:8px}
  .category .category-content-box{flex-direction:column;align-items:center;gap:8px}
  .category .category-btn{width:100%;padding:7px 10px}
  .category .category-item-title{font-size:11px}
}

/* ===== FIX: Make <500px look like the 500px layout ===== */
@media (max-width:499px){
  .header-main .container{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:nowrap}
  .site-header .header-logo{margin:0;flex:1;justify-content:center;min-width:0}
  .site-header .header-logo img{height:64px;max-width:240px;width:auto}
  .header-search-container{display:none}
}

/* Product grid (single source of truth) */
.product-grid,#product-grid{display:grid;grid-template-columns:1fr;gap:12px}
@media (min-width:360px){.product-grid,#product-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}}
@media (min-width:768px){.product-grid,#product-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}}
@media (min-width:1024px){.product-grid,#product-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}}

.product-grid .showcase-banner{position:relative;width:100%;aspect-ratio:4/5;overflow:hidden;background:rgba(0,0,0,.04)}
.product-grid .product-img{width:100%;height:100%;object-fit:cover;display:block}
.product-grid .showcase-content{padding:10px}
.product-grid .showcase-title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:13px;line-height:1.2;min-height:calc(13px*1.2*2)}
.product-grid .showcase-category{font-size:11px;margin-bottom:6px}
.product-grid .price-box{font-size:13px;margin-bottom:0}

/* Promo bar */
.promo-bar{width:100%;border-bottom:1px solid rgba(196,195,195,.08);background:#000}
.promo-bar__inner{max-width:1100px;margin:0 auto;padding:6px 12px;display:flex;align-items:center;gap:8px}
.promo-bar__text{font-size:12px;color:rgba(255,255,255,.78);line-height:1.15;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.promo-bar__link{font-size:12px;font-weight:700;text-decoration:none;color:inherit;border-bottom:1px solid rgba(255,255,255,.25);padding-bottom:1px;white-space:nowrap}
.promo-bar__close{border:0;background:transparent;cursor:pointer;font-size:14px;line-height:1;padding:4px 6px;border-radius:10px}
@media (max-width:380px){.promo-bar__inner{padding:6px 10px;gap:6px}.promo-bar__text,.promo-bar__link{font-size:11px}}

/* Product strip */
.product-strip{margin:12px 0 16px}
.product-strip__header{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:8px}
.product-strip__link{text-decoration:none;font-weight:700;font-size:12px;color:inherit;opacity:.75;white-space:nowrap}
.product-strip__link:hover{opacity:1}
.product-strip__scroller{display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;padding:2px 14px 8px 0;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;overscroll-behavior-x:contain}
.product-strip__scroller::-webkit-scrollbar{height:6px}
.product-strip__scroller::-webkit-scrollbar-thumb{background:rgba(0,0,0,.18);border-radius:999px}
.product-strip__scroller::-webkit-scrollbar-track{background:rgba(0,0,0,.06);border-radius:999px}
.product-strip-card{flex:0 0 auto;scroll-snap-align:start;border:1px solid rgba(0,0,0,.08);border-radius:12px;overflow:hidden;background:#fff;width:56%;max-width:320px}
@media (min-width:480px){.product-strip-card{width:40%}}
@media (min-width:768px){.product-strip-card{width:240px}.product-strip__scroller{padding-right:0}}
.product-strip-card__media{display:block;width:100%;aspect-ratio:3/2;background:rgba(0,0,0,.04);overflow:hidden}
.product-strip-card__media img{width:100%;height:100%;object-fit:cover;display:block}
.product-strip-card__body{padding:8px 8px 9px}
.product-strip-card__top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}
.product-strip-card__cat{font-size:10px;text-transform:uppercase;letter-spacing:.4px;opacity:.7}
.product-strip-card__badge{font-size:10px;font-weight:800;padding:2px 6px;border-radius:999px;border:1px solid rgba(0,0,0,.10)}
.product-strip-card__title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-decoration:none;color:inherit;font-size:12px;font-weight:800;line-height:1.15;margin:0 0 6px;min-height:calc(12px*1.15*2)}
.product-strip-card__price{display:flex;gap:8px;align-items:baseline}
.product-strip-card__price .price{font-weight:900;font-size:12px}
.product-strip-card__price del{opacity:.6;font-size:11px}

/* Browse more */
.browse-more{margin:18px 0 88px;display:flex;justify-content:center;padding:8px 0 22px;text-align:center}
.browse-more .btn,.browse-more__btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border-radius:12px;border:1px solid rgba(0,0,0,.12);background:var(--eerie-black);color:var(--white);font-weight:700;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease;box-shadow:0 8px 18px rgba(0,0,0,.10)}
.browse-more .btn:hover,.browse-more__btn:hover{opacity:.92;transform:translateY(-1px);box-shadow:0 10px 22px rgba(0,0,0,.14)}
@media (max-width:480px){.browse-more{padding:10px 0 26px}.browse-more .btn,.browse-more__btn{width:100%;max-width:420px;padding:13px 16px;border-radius:16px}}

/* Catalog toolbar */
.catalog-header{padding:14px 0 8px}
.catalog-title{font-size:var(--fs-3);margin:0 0 10px;color:var(--eerie-black)}
.catalog-toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:space-between;padding:10px;border:1px solid rgba(0,0,0,.08);border-radius:14px;background:#fff}
.catalog-toolbar__left{flex:1;min-width:220px}
.catalog-search{width:100%;border:1px solid rgba(0,0,0,.12);border-radius:12px;padding:10px 12px;font-size:14px}
.catalog-toolbar__right{display:flex;gap:10px;align-items:center}
.catalog-sort{border:1px solid rgba(0,0,0,.12);border-radius:12px;padding:10px 12px;font-size:14px;background:#fff}
.catalog-apply{border:1px solid rgba(0,0,0,.12);border-radius:12px;padding:10px 14px;font-weight:700;background:var(--eerie-black);color:var(--white)}
.catalog-pagination{margin:18px 0 88px;display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:center}
.catalog-page-btn{padding:10px 12px;border-radius:12px;border:1px solid rgba(0,0,0,.12);text-decoration:none;color:inherit;font-weight:700;background:#fff}
.catalog-page-meta{padding:10px 12px;border-radius:12px;border:1px solid rgba(0,0,0,.10);background:rgba(0,0,0,.03)}

/* Product detail (pd-*) */
.pd{padding:16px 0 88px}
.pd-grid{display:grid;gap:16px}
@media (min-width:900px){.pd-grid{grid-template-columns:1.05fr .95fr;gap:26px;align-items:start}}
.pd-card{border:1px solid var(--cultured);border-radius:var(--border-radius-md);background:var(--white);overflow:hidden}
.pd-media{padding:12px}
.pd-main{display:block;width:100%;border-radius:14px;background:var(--cultured);overflow:hidden;aspect-ratio:1/1}
.pd-main img{width:100%;height:100%;object-fit:contain;display:block}
.pd-thumbs{margin-top:10px;display:flex;gap:10px;overflow-x:auto;padding-bottom:6px}
.pd-thumb{flex:0 0 auto;width:92px;aspect-ratio:1/1;border:1px solid rgba(0,0,0,.10);border-radius:12px;background:var(--cultured);padding:0;overflow:hidden}
.pd-thumb img{width:100%;height:100%;object-fit:cover;display:block}
@media (min-width:900px){.pd-thumb{width:105px}}
.pd-info{padding:16px}
.pd-title{margin:0 0 10px;font-size:1.25rem;line-height:1.2;color:var(--eerie-black)}
@media (min-width:900px){.pd-title{font-size:1.5rem}}
.pd-price{display:flex;flex-wrap:wrap;gap:8px 10px;align-items:center}
.pd-price-old{text-decoration:line-through;opacity:.6}
.pd-price-now{font-weight:800;font-size:1.15rem}
.pd-label{display:block;margin-bottom:6px;font-weight:700;font-size:13px;color:var(--eerie-black)}
.pd-select,.pd-qty{width:100%;padding:12px;border-radius:12px;border:1px solid rgba(0,0,0,.14);background:#fff;font-size:16px}
.pd-chips{margin-top:8px;display:flex;flex-wrap:wrap;gap:8px}
.pd-chip{border:1px solid rgba(0,0,0,.14);background:#fff;border-radius:999px;padding:10px 12px;font-size:13px;font-weight:700;min-height:40px}
.pd-chip.is-active{background:var(--eerie-black);border-color:var(--eerie-black);color:var(--white)}
.pd-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.pd-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 14px;border-radius:12px;border:1px solid rgba(0,0,0,.14);text-decoration:none;font-weight:800;cursor:pointer}
.pd-btn--primary{background:var(--eerie-black);border-color:var(--eerie-black);color:var(--white)}
.pd-btn--primary:disabled{opacity:.55;cursor:not-allowed}
.pd-btn--ghost{background:#fff;color:var(--eerie-black)}
.pd-hint{margin-top:10px;font-size:13px;opacity:.7}
.pd-desc{margin-top:18px;padding-top:14px;border-top:1px solid var(--cultured)}
.pd-subtitle{margin:0 0 8px;font-size:1rem}
.pd-desc p{margin:0;opacity:.85;line-height:1.5}

/* Cart mobile boost */
@media (max-width:420px){
  .cart{padding:10px 0 120px}
  .cart-left{gap:10px}
  .cart-item{grid-template-columns:62px 1fr;gap:10px;padding:10px}
  .cart-item__media{width:62px;height:62px;border-radius:10px}
  .cart-item__name{font-size:14px;-webkit-line-clamp:2}
  .cart-pill{font-size:11px;padding:3px 8px}
  .cart-item__bottom{grid-template-columns:1fr 1fr;gap:10px;align-items:end}
  .cart-qty__label,.cart-price__label{font-size:11px;margin-bottom:4px}
  .cart-qty__box{min-width:46px;height:38px;border-radius:10px;font-size:14px}
  .c-btn--icon{width:38px;height:38px;border-radius:10px;font-size:18px}
  .cart-price__value{font-size:.98rem;text-align:right}
  .cart-price__unit{font-size:11px;text-align:right}
  .cart-debug{display:none}
  .cart-right{position:fixed;left:0;right:0;bottom:0;z-index:50}
  .cart-summary{border-radius:16px 16px 0 0;border-left:0;border-right:0;border-bottom:0;padding:12px;box-shadow:0 -10px 30px rgba(0,0,0,.12)}
  .cart-form{display:none}
  .cart-summary__rows{gap:6px}
  .cart-row{font-size:14px}
  .cart-mobile-cta{display:grid;grid-template-columns:1fr;gap:8px;margin-top:10px}
  .cart-mobile-cta .c-btn{height:46px;border-radius:12px;font-size:15px}
}
@media (min-width:421px){.cart-mobile-cta{display:none}.cart-form{display:block}}

/* Checkout */
.checkout-wrap{padding:18px 0 70px}
.checkout-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.checkout-title{margin:0;font-size:1.25rem;font-weight:700}
.checkout-muted{color:rgba(0,0,0,.65);font-size:.95rem}
.checkout-card{background:#fff;border:1px solid rgba(0,0,0,.10);border-radius:16px;padding:14px}
.checkout-card+.checkout-card{margin-top:12px}
.checkout-kv{display:flex;flex-wrap:wrap;gap:10px 14px;margin-top:8px}
.checkout-kv .kv{font-size:14px;color:rgba(0,0,0,.72)}
.checkout-kv .kv strong{color:rgba(0,0,0,.92);font-weight:700}
.checkout-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:800;padding:4px 10px;border-radius:999px;border:1px solid rgba(0,0,0,.12)}
.checkout-badge--paid{background:rgba(25,135,84,.10);color:#198754;border-color:rgba(25,135,84,.25)}
.checkout-badge--unpaid{background:rgba(220,53,69,.10);color:#dc3545;border-color:rgba(220,53,69,.25)}
.checkout-ship{margin:8px 0 0;padding:0;list-style:none}
.checkout-ship li{padding:2px 0;color:rgba(0,0,0,.78);font-size:14px}
.checkout-table-wrap{overflow:auto;border-radius:12px;border:1px solid rgba(0,0,0,.08)}
.checkout-table{width:100%;border-collapse:collapse;min-width:720px;background:#fff}
.checkout-table th,.checkout-table td{padding:12px;border-bottom:1px solid rgba(0,0,0,.08);vertical-align:top;font-size:14px}
.checkout-table th{font-size:12px;text-transform:uppercase;letter-spacing:.6px;opacity:.75}
.checkout-items-cards{display:none;gap:10px}
.checkout-item-card{border:1px solid rgba(0,0,0,.10);border-radius:14px;padding:12px;background:#fff}
.checkout-total{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px}
.checkout-total .total{font-size:1.05rem;font-weight:900}
.checkout-cta{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}
@media (max-width:476px){
  .checkout-wrap{padding-bottom:100px}
  .checkout-title{font-size:1.1rem}
  .checkout-card{padding:12px;border-radius:14px}
  .checkout-table-wrap{display:none}
  .checkout-items-cards{display:grid}
  .checkout-total{flex-direction:column;align-items:stretch}
  .checkout-cta .btn{width:100%;padding:12px 14px;font-weight:800}
}

/* Toolbar helpers */
.shop-toolbar{position:static;z-index:50;background:#fff;padding:8px 0 10px;border-bottom:1px solid rgba(0,0,0,.06);margin-bottom:12px}
@media (min-width:768px){.shop-toolbar{position:sticky;top:0;padding:10px 0}}
.toolbar-inner{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:space-between}
.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid rgba(0,0,0,.12);border-radius:999px;font-size:12px;line-height:1;white-space:nowrap;background:#fff}

/* Category hero */
.category-hero{margin:10px 0 14px;border-radius:16px;overflow:hidden;border:1px solid rgba(0,0,0,.06);background:#111}
.category-hero .hero-inner{min-height:190px;display:flex;flex-direction:column;justify-content:center;gap:8px;padding:18px 14px;color:#fff;background-size:cover;background-position:center;background-repeat:no-repeat;background-image:linear-gradient(90deg,rgba(0,0,0,.78),rgba(0,0,0,.18))}
@media (max-width:360px){.category-hero .hero-inner{min-height:175px;padding:16px 12px}}
@media (min-width:768px){.category-hero .hero-inner{min-height:240px;padding:26px 18px}}
@media (min-width:1100px){.category-hero .hero-inner{min-height:280px;padding:30px 22px}}
.category-hero h1{margin:0;line-height:1.15;font-size:clamp(20px,4.8vw,34px);letter-spacing:-.2px}
.category-hero p{margin:0;opacity:.92;line-height:1.35;font-size:clamp(13px,3.2vw,16px);max-width:40ch}

/* Desktop breakpoints: layout + header/nav */
@media (min-width:370px){
  .header-top .container,.header-main .container{display:flex;justify-content:space-between;align-items:center;gap:10px}
  .site-header .header-logo{margin:0}
  .site-header .header-logo img{height:64px;max-width:240px}
  .header-search-container{min-width:240px}
}
@media (min-width:480px){
  .header-top{display:block;padding:10px 0;border-bottom:1px solid var(--cultured)}
  .site-header .header-main{padding:18px 0}
}
@media (min-width:768px){
  html{font-size:17px}
  :root{--fs-1:2.375rem}
  .container{max-width:750px}
  .site-header .header-main .container{gap:28px}
  .site-header .header-logo img{height:72px;max-width:280px}
  .header-search-container{flex-grow:1}
  .slider-item{aspect-ratio:auto;height:350px}
  .banner-content{max-width:380px;background:none}
  .product-minimal{display:flex;flex-wrap:wrap;justify-content:center;gap:20px}
  .product-minimal .product-showcase{min-width:calc(50% - 10px);width:calc(50% - 10px)}
  .product-minimal .showcase-container{min-width:100%}
}
@media (min-width:1024px){
  :root{--fs-1:2.625rem;--fs-2:1.125rem}
  .container{max-width:980px}
  .header-mobile-actions,.mobile-quick-links{display:none}
  .header-social-container{display:flex;align-items:center;gap:5px}
  .header-user-actions{display:flex;align-items:center;gap:15px}
  .desktop-navigation-menu{display:block}
  .mobile-bottom-navigation{display:none}
  .site-header .header-logo img{height:78px;max-width:320px}
  .desktop-menu-category-list{position:relative;display:flex;justify-content:center;align-items:center;gap:30px}
  .desktop-menu-category-list .menu-category:not(:nth-child(2)){position:relative}
  .desktop-menu-category-list .menu-category>.menu-title{position:relative;color:var(--onyx);font-size:var(--fs-7);font-weight:var(--weight-600);text-transform:uppercase;padding:15px 0;transition:var(--transition-timing)}
  .desktop-menu-category-list .menu-category>.menu-title:hover{color:var(--salmon-pink)}
  .desktop-menu-category-list .menu-category>.menu-title:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:2px;background:var(--salmon-pink);transform:scaleX(0);transform-origin:left;transition:var(--transition-timing)}
  .desktop-menu-category-list .menu-category>.menu-title:hover:after{transform:scaleX(1)}
  .dropdown-panel{position:absolute;top:100%;left:0;background:var(--white);width:100%;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;padding:30px;border:1px solid var(--cultured);box-shadow:0 3px 5px hsla(0,0%,0%,.1);border-radius:var(--border-radius-md);transform:translateY(50px);opacity:0;visibility:hidden;pointer-events:none;transition:var(--transition-timing);z-index:999}
  .desktop-menu-category-list .menu-category:hover>.dropdown-panel{transform:translateY(0);opacity:1;visibility:visible;pointer-events:auto}
  .dropdown-panel-list .menu-title a{color:var(--onyx);font-size:var(--fs-7);font-weight:var(--weight-600);padding-bottom:10px;border-bottom:1px solid var(--cultured);margin-bottom:10px}
  .panel-list-item a{color:var(--sonic-silver);font-size:var(--fs-7);text-transform:capitalize;transition:var(--transition-timing)}
  .panel-list-item a:hover{color:var(--salmon-pink)}
  .panel-list-item:not(:last-child) a{padding:4px 0}
  .panel-list-item:last-child{margin-top:20px}
  .panel-list-item img{width:100%;height:auto;border-radius:var(--border-radius-sm)}
}
@media (min-width:1200px){
  .container{max-width:1200px}
  .desktop-menu-category-list{gap:45px}
  .site-header .header-logo img{height:84px;max-width:360px}
}
@media (min-width:1400px){
  html{font-size:18px}
  .container{max-width:1350px}
  .slider-item{height:450px}
  .banner-content{left:110px;max-width:460px}
}

/* ===== MOBILE SEARCH TOGGLE (keep at bottom) ===== */
@media (max-width:499px){
  .header-main .container{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:nowrap}
  .site-header .header-search-container{display:none}
  .site-header.is-search-open .header-logo{display:none}
  .site-header.is-search-open .header-user-actions{display:none}
  .site-header.is-search-open .header-search-container{display:flex;align-items:center;flex:1;min-width:0}
  .site-header.is-search-open .search-field{width:100%;min-width:0;font-size:16px}
  .header-mobile-actions .icon-close{display:none}
  .site-header.is-search-open .header-mobile-actions .icon-search{display:none}
  .site-header.is-search-open .header-mobile-actions .icon-close{display:block}
}


/* big desktop: allow bigger cards (still scrolls) */
@media (min-width:1200px){
  .category .category-item{flex-basis:clamp(240px, 18vw, 380px)}
}
@media (min-width:1600px){
  .category .category-item{flex-basis:clamp(260px, 14vw, 420px)}
}
/* ===== SCROLL HINT ANIMATION (safe, subtle, runs once) ===== */
@media (hover:none){
  .category .category-item-container{
    animation:cat-nudge 1.1s ease-out .6s 1;
    will-change:transform;
  }
}

@keyframes cat-nudge{
  0%{transform:translateX(0)}
  35%{transform:translateX(-18px)}
  70%{transform:translateX(0)}
  100%{transform:translateX(0)}
}

/* respect users who disable motion */
@media (prefers-reduced-motion:reduce){
  .category .category-item-container{animation:none}
}
@media (hover:none){
  .category .category-item:nth-child(3){
    animation:cat-pulse 1.1s ease-out .9s 1;
  }
}
@keyframes cat-pulse{
  0%{transform:scale(1)}
  50%{transform:scale(1.03)}
  100%{transform:scale(1)}
}
@media (prefers-reduced-motion:reduce){
  .category .category-item:nth-child(3){animation:none}
}
@media (max-width:900px){
  .category .category-item-container{
    cursor:grab;
  }
  .category .category-item-container:active{
    cursor:grabbing;
  }
}
/* HERO BANNER (single, mobile-first) */
.hero-banners{margin:10px 0 8px}
.hero-banners__grid{display:block} /* single banner */
.hero-banner{position:relative;display:block;overflow:hidden;border-radius:18px;text-decoration:none;color:#fff;min-height:160px;border:1px solid rgba(0,0,0,.08);box-shadow:0 10px 24px rgba(0,0,0,.12);transform:translateZ(0)}
.hero-banner__media{position:absolute;inset:0}
.hero-banner__media img{width:100%;height:100%;object-fit:cover;display:block}
.hero-banner__bg{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.78),rgba(0,0,0,.25))}

/* fallback bg (if image missing) */
.hero-banner--sale .hero-banner__bg{background:linear-gradient(90deg,#0a0a0a,rgba(0,0,0,.25)),radial-gradient(900px 200px at 20% 20%,rgba(255,255,255,.18),transparent)}

.hero-banner__content{position:relative;z-index:1;padding:16px;display:flex;flex-direction:column;gap:6px;max-width:30ch}
.hero-banner__pill{display:inline-flex;align-items:center;gap:6px;width:max-content;font-size:12px;font-weight:800;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(6px)}
.hero-banner__title{margin:0;font-size:24px;line-height:1.05;letter-spacing:-.3px}
.hero-banner__subtitle{margin:0;opacity:.92;font-size:14px;line-height:1.25}
.hero-banner__cta{margin-top:6px;display:inline-flex;width:max-content;gap:8px;align-items:center;font-weight:900;font-size:13px;padding:9px 12px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22)}

/* subtle attention animation (runs once, mobile only) */
@media (hover:none){
  .hero-banner{animation:hero-pop .9s ease-out .25s 1}
  @keyframes hero-pop{0%{transform:scale(.985)}55%{transform:scale(1.01)}100%{transform:scale(1)}}
}
@media (prefers-reduced-motion:reduce){.hero-banner{animation:none}}

/* desktop: a bit taller + bigger type */
@media (min-width:900px){
  .hero-banner{min-height:210px}
  .hero-banner__content{padding:20px;max-width:40ch}
  .hero-banner__title{font-size:32px}
  .hero-banner__subtitle{font-size:15px}
}
/* ===== PRODUCT STRIP OVERRIDE (PUT LAST) ===== */
.product-strip__scroller{display:flex;gap:10px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;overscroll-behavior-x:contain;padding:2px 0 10px}
.product-strip__scroller::-webkit-scrollbar{height:6px}
.product-strip__scroller::-webkit-scrollbar-thumb{background:rgba(0,0,0,.15);border-radius:999px}
.product-strip__scroller::-webkit-scrollbar-track{background:rgba(0,0,0,.06);border-radius:999px}

/* IMPORTANT: kill old width rules */
.product-strip-card{flex:0 0 35%!important;width:auto!important;max-width:240px!important;min-width:150px!important;scroll-snap-align:start;border-radius:14px;overflow:hidden;position:relative;transition:transform .15s ease,box-shadow .15s ease}
@media (min-width:480px){.product-strip-card{flex-basis:clamp(170px,28vw,250px)!important;max-width:none!important;min-width:unset!important}}
@media (min-width:768px){.product-strip-card{flex-basis:240px!important}}
@media (min-width:1200px){.product-strip-card{flex-basis:260px!important}}

.product-strip-card__body{padding:8px}
.product-strip-card__title{font-size:12px;line-height:1.15}
.product-strip-card__cat{font-size:10px}

@media (hover:hover){.product-strip-card:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(0,0,0,.12)}}
@media (hover:none){.product-strip-card:active{transform:scale(.985)}.product-strip__scroller{cursor:grab}.product-strip__scroller:active{cursor:grabbing}}

/* ===== UNIQUE “SOMETIMES” LOOP HINT (touch only) ===== */
@media (hover:none){
  .product-strip__scroller{animation:ps-loop 9.8s cubic-bezier(.2,.9,.2,1) 1.2s infinite;will-change:transform}
  .product-strip-card:nth-of-type(2){animation:ps-pop 9.8s ease-out 1.2s infinite;will-change:transform}
  .product-strip-card:nth-of-type(2)::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.6) 45%,transparent 65%);transform:translateX(-140%) skewX(-12deg);opacity:0;animation:ps-sheen 9.8s ease-out 1.2s infinite}
}
@keyframes ps-loop{0%,72%,100%{transform:translateX(0)}6%{transform:translateX(-26px)}10%{transform:translateX(-12px)}14%{transform:translateX(-18px)}18%{transform:translateX(0)}}
@keyframes ps-pop{0%,72%,100%{transform:scale(1)}8%{transform:scale(1.03)}18%{transform:scale(1)}}
@keyframes ps-sheen{0%,72%,100%{opacity:0;transform:translateX(-140%) skewX(-12deg)}7%{opacity:.35}20%{opacity:0;transform:translateX(140%) skewX(-12deg)}}
@media (prefers-reduced-motion:reduce){.product-strip__scroller,.product-strip-card:nth-of-type(2),.product-strip-card:nth-of-type(2)::after{animation:none}}

.action-btn--stacked {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
}

.action-btn--stacked ion-icon {
  font-size: 22px;
  line-height: 1;
}

.action-label {
  font-size: 11px;
  line-height: 1;
  font-weight: 600;
}

.action-badge {
  position: absolute;
  top: 2px;
  right: 0;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  border-radius: 999px;
  background: #111;
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.skip-link {
      position: absolute;
      left: -9999px;
      top: auto;
      width: 1px;
      height: 1px;
      overflow: hidden;
    }
    .skip-link:focus {
      left: 16px;
      top: 16px;
      width: auto;
      height: auto;
      padding: 10px 12px;
      background: #111;
      color: #fff;
      z-index: 9999;
      border-radius: 10px;
    }

    .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;
    }

    .messages { margin: 12px 0; }
    .msg {
      padding: 10px 12px;
      border-radius: 12px;
      margin: 8px 0;
      border: 1px solid rgba(0, 0, 0, .12);
    }
    .msg-success { background: rgba(16, 185, 129, .12); }
    .msg-error, .msg-danger { background: rgba(239, 68, 68, .12); }
    .msg-warning { background: rgba(245, 158, 11, .14); }
    .msg-info { background: rgba(59, 130, 246, .12); }

    .header-logo img {
      height: 28px;
      width: auto;
      display: block;
    }

    img {
      max-width: 100%;
      height: auto;
    }

    @media (min-width: 768px) {
      .header-logo img { height: 34px; }
    }