/* ============================================================
   SHIESHOP SUPPLIES — Design System v3.0
   Visual Engineering Standard — Mobile-First Implementation
   Brand: Everything for Her Home, Family & Everyday Living
   Primary Rose #D96C8A | Plum #7A4E6D | Gold #D4A017
   Breakpoints: 0→639 | 640→767 | 768→1023 | 1024→1279 | 1280+
   ============================================================ */

/* ── 1. DESIGN TOKENS ────────────────────────────────────── */
:root {
  --shie-primary:        #D96C8A;
  --shie-primary-dark:   #C05578;
  --shie-primary-light:  #F0A0B8;
  --shie-primary-soft:   #FFF0F3;
  --shie-secondary:      #7A4E6D;
  --shie-secondary-dark: #5E3A54;
  --shie-secondary-light:#9B6A8F;
  --shie-secondary-soft: #F3EFF5;
  --shie-gold:           #D4A017;
  --shie-gold-dark:      #B88A12;
  --shie-gold-soft:      #FFFBF0;
  --shie-success:        #16A34A;
  --shie-warning:        #F59E0B;
  --shie-error:          #DC2626;
  --shie-info:           #0284C7;
  --shie-white:          #FFFFFF;
  --shie-soft-bg:        #FFF8FA;
  --shie-section-bg:     #F9F5F7;
  --shie-border-light:   #E7E0E3;
  --shie-border-med:     #D4CBD0;
  --shie-text-primary:   #2C1F26;
  --shie-text-sec:       #5E4B54;
  --shie-text-muted:     #7A6B72;
  --shie-font: 'Inter', system-ui, -apple-system, BlinkMacSystemFont,
               'Segoe UI', Roboto, sans-serif;
  --shie-r-sm:   8px;
  --shie-r-md:   12px;
  --shie-r-lg:   16px;
  --shie-r-xl:   20px;
  --shie-r-pill: 999px;
  --shie-shadow-xs:   0 1px 3px rgba(44,31,38,.06);
  --shie-shadow-sm:   0 2px 8px rgba(217,108,138,.10);
  --shie-shadow-md:   0 4px 20px rgba(217,108,138,.14);
  --shie-shadow-lg:   0 8px 40px rgba(122,78,109,.14);
  --shie-shadow-card: 0 2px 12px rgba(217,108,138,.08);
  --shie-ease:      0.22s cubic-bezier(0.4,0,0.2,1);
  --shie-ease-fast: 0.15s ease;
  --shie-z-topbar:  1040;
  --shie-z-navbar:  1030;
  --shie-z-drawer:  1060;
  --shie-z-overlay: 1055;
  --shie-z-float:   1050;
  /* Legacy aliases */
  --ss-navy:        var(--shie-secondary);
  --ss-orange:      var(--shie-primary);
  --ss-green:       var(--shie-success);
  --ss-gray-50:     var(--shie-soft-bg);
  --ss-gray-100:    var(--shie-section-bg);
  --ss-gray-200:    var(--shie-border-light);
  --ss-gray-300:    var(--shie-border-med);
  --ss-gray-400:    #a48f98;
  --ss-gray-500:    var(--shie-text-muted);
  --ss-gray-600:    var(--shie-text-sec);
  --ss-gray-700:    #4a3840;
  --ss-gray-800:    var(--shie-text-primary);
  --ss-gray-900:    #1a0f14;
  --ss-error:       var(--shie-error);
  --ss-success:     var(--shie-success);
  --ss-warning:     var(--shie-warning);
  --ss-radius-sm:   var(--shie-r-sm);
  --ss-radius-md:   var(--shie-r-md);
  --ss-radius-lg:   var(--shie-r-lg);
  --ss-radius-xl:   var(--shie-r-xl);
  --ss-radius-pill: var(--shie-r-pill);
  --ss-shadow-sm:   var(--shie-shadow-sm);
  --ss-shadow-md:   var(--shie-shadow-md);
  --ss-shadow-lg:   var(--shie-shadow-lg);
  --ss-shadow-card: var(--shie-shadow-card);
  --ss-ease:        var(--shie-ease);
  --ss-ease-fast:   var(--shie-ease-fast);
  --ss-font:        var(--shie-font);
}

/* ── 2. RESET & BASE (Mobile-First) ─────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family:            var(--shie-font);
  font-size:              1rem;
  line-height:            1.7;
  color:                  var(--shie-text-primary);
  background:             var(--shie-soft-bg);
  -webkit-font-smoothing: antialiased;
  overflow-x:             hidden;
  padding-bottom:         72px; /* Space for mobile sticky bar */
}

@media (min-width: 768px) { body { padding-bottom: 0; } }

a { color: var(--shie-secondary); text-decoration: none; transition: color var(--shie-ease-fast); }
a:hover { color: var(--shie-primary); }
img { max-width: 100%; height: auto; display: block; }
button { font-family: var(--shie-font); }

/* ── 3. TYPOGRAPHY (VES Type Scale) ─────────────────────── */
h1 { font-size: 2rem;   font-weight: 800; line-height: 1.1; }
h2 { font-size: 1.5rem; font-weight: 700; line-height: 1.15; }
h3 { font-size: 1.25rem;font-weight: 700; line-height: 1.2; }
h4 { font-size: 1.1rem; font-weight: 600; line-height: 1.25; }

@media (min-width: 1024px) {
  h1 { font-size: 3.5rem; }
  h2 { font-size: 2.75rem; }
  h3 { font-size: 2rem; }
  h4 { font-size: 1.5rem; }
}

/* ── 4. TOPBAR ───────────────────────────────────────────── */
.ss-topbar {
  background: var(--shie-secondary);
  color:      rgba(255,255,255,.9);
  font-size:  .78rem;
  padding:    6px 0;
  z-index:    var(--shie-z-topbar);
}
.ss-topbar a { color: rgba(255,255,255,.85); transition: color var(--shie-ease-fast); }
.ss-topbar a:hover { color: #fff; }
.ss-topbar .highlight { color: #f8d7e3; font-weight: 600; }

/* Topbar inner — stacked on mobile, row on desktop */
.ss-topbar-inner {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  flex-wrap:       wrap;
  gap:             4px;
}
.ss-topbar-left {
  display:     flex;
  align-items: center;
  gap:         8px;
  font-size:   .76rem;
}
.ss-topbar-phone {
  display:     flex;
  align-items: center;
  gap:         4px;
  font-weight: 600;
  color:       rgba(255,255,255,.95);
}
.ss-topbar-right {
  display:     flex;
  align-items: center;
  gap:         10px;
}

/* ── 5. MAIN NAVBAR ──────────────────────────────────────── */
.ss-navbar {
  background:    var(--shie-white);
  border-bottom: 1px solid var(--shie-border-light);
  box-shadow:    var(--shie-shadow-sm);
  position:      sticky;
  top:           0;
  z-index:       var(--shie-z-navbar);
}

.ss-navbar-inner {
  display:     flex;
  align-items: center;
  gap:         8px;
  padding:     10px 0;
}

/* Logo */
.ss-logo {
  display:         flex;
  align-items:     center;
  gap:             8px;
  font-weight:     800;
  font-size:       1.2rem;
  color:           var(--shie-secondary);
  text-decoration: none;
  flex-shrink:     0;
}
.ss-logo:hover { color: var(--shie-secondary); }
.ss-logo-icon {
  width:           36px;
  height:          36px;
  background:      linear-gradient(135deg, var(--shie-primary) 0%, var(--shie-secondary) 100%);
  border-radius:   var(--shie-r-md);
  display:         flex;
  align-items:     center;
  justify-content: center;
  color:           #fff;
  font-size:       1.1rem;
  flex-shrink:     0;
}
.ss-logo-sub {
  font-size:   .6rem;
  font-weight: 400;
  color:       var(--shie-text-muted);
  display:     block;
  line-height: 1;
}

@media (min-width: 768px) {
  .ss-logo { font-size: 1.35rem; }
  .ss-logo-icon { width: 40px; height: 40px; font-size: 1.2rem; }
  .ss-navbar-inner { padding: 14px 0; }
}

/* Search Bar */
.ss-search-wrap { flex: 1; max-width: 600px; margin: 0 auto; }

.ss-search-form {
  display:       flex;
  border:        2px solid var(--shie-border-light);
  border-radius: var(--shie-r-pill);
  overflow:      hidden;
  background:    #fff;
  transition:    border-color var(--shie-ease-fast), box-shadow var(--shie-ease-fast);
}
.ss-search-form:focus-within {
  border-color: var(--shie-primary);
  box-shadow:   0 0 0 3px rgba(217,108,138,.12);
}
.ss-search-input {
  flex:        1;
  border:      none;
  outline:     none;
  padding:     10px 14px;
  font-family: var(--shie-font);
  font-size:   .9rem;
  color:       var(--shie-text-primary);
  background:  transparent;
  min-width:   0;
}
.ss-search-btn {
  background:  var(--shie-primary);
  border:      none;
  color:       #fff;
  padding:     0 18px;
  cursor:      pointer;
  font-size:   1rem;
  transition:  background var(--shie-ease-fast);
  display:     flex;
  align-items: center;
  flex-shrink: 0;
}
.ss-search-btn:hover { background: var(--shie-primary-dark); }

/* Nav Actions */
.ss-nav-actions { display: flex; align-items: center; gap: 2px; flex-shrink: 0; }

.ss-nav-action-btn {
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  gap:             2px;
  padding:         5px 8px;
  border-radius:   var(--shie-r-md);
  border:          none;
  background:      none;
  color:           var(--shie-text-sec);
  cursor:          pointer;
  font-size:       .68rem;
  font-weight:     600;
  font-family:     var(--shie-font);
  text-decoration: none;
  transition:      all var(--shie-ease-fast);
  position:        relative;
  white-space:     nowrap;
}
.ss-nav-action-btn:hover { background: var(--shie-section-bg); color: var(--shie-secondary); }
.ss-nav-action-btn i { font-size: 1.2rem; }
.ss-nav-action-btn.cart-btn { background: var(--shie-primary); color: #fff; }
.ss-nav-action-btn.cart-btn:hover { background: var(--shie-primary-dark); color: #fff; }

.ss-cart-badge {
  position:        absolute;
  top:             1px;
  right:           4px;
  background:      var(--shie-secondary);
  color:           #fff;
  font-size:       .6rem;
  font-weight:     700;
  min-width:       16px;
  height:          16px;
  border-radius:   8px;
  display:         flex;
  align-items:     center;
  justify-content: center;
  border:          1.5px solid #fff;
  line-height:     1;
}

/* Mobile Search Bar (full-width dropdown) */
.ss-mobile-search-bar {
  padding: 8px 0 10px;
  border-top: 1px solid var(--shie-border-light);
}

/* ── 6. CATEGORY NAV BAR ─────────────────────────────────── */
.ss-cat-nav { background: var(--shie-secondary); }
.ss-cat-nav-inner {
  display:          flex;
  align-items:      center;
  overflow-x:       auto;
  scrollbar-width:  none;
  -ms-overflow-style: none;
  gap:              0;
}
.ss-cat-nav-inner::-webkit-scrollbar { display: none; }

.ss-cat-link {
  display:         flex;
  align-items:     center;
  gap:             5px;
  color:           rgba(255,255,255,.8);
  padding:         10px 14px;
  font-size:       .82rem;
  font-weight:     500;
  white-space:     nowrap;
  text-decoration: none;
  border-bottom:   2px solid transparent;
  transition:      all var(--shie-ease-fast);
  flex-shrink:     0;
}
.ss-cat-link:hover, .ss-cat-link.active {
  color:             #fff;
  background:        rgba(255,255,255,.1);
  border-bottom-color: var(--shie-gold);
}
.ss-cat-link i { font-size: .9rem; opacity: .85; }

@media (min-width: 768px) {
  .ss-cat-link { padding: 11px 16px; font-size: .85rem; }
}

/* ── 7. TRUST BAND ───────────────────────────────────────── */
.ss-trust-band {
  background:    var(--shie-white);
  border-bottom: 1px solid var(--shie-border-light);
  padding:       12px 0;
  overflow-x:    auto;
  scrollbar-width: none;
}
.ss-trust-band::-webkit-scrollbar { display: none; }

.ss-trust-row {
  display:   flex;
  flex-wrap: nowrap;
  gap:       0;
  min-width: max-content;
}

@media (min-width: 640px) {
  .ss-trust-row { flex-wrap: wrap; min-width: auto; }
}

.ss-trust-item {
  display:     flex;
  align-items: center;
  gap:         10px;
  padding:     6px 16px;
  min-width:   160px;
}

@media (min-width: 768px) {
  .ss-trust-item { padding: 8px 12px; min-width: auto; }
}

.ss-trust-icon {
  width:           40px;
  height:          40px;
  border-radius:   var(--shie-r-md);
  display:         flex;
  align-items:     center;
  justify-content: center;
  font-size:       1.15rem;
  flex-shrink:     0;
}
.ss-trust-icon.rose   { background: var(--shie-primary-soft);   color: var(--shie-primary); }
.ss-trust-icon.plum   { background: var(--shie-secondary-soft); color: var(--shie-secondary); }
.ss-trust-icon.green  { background: rgba(22,163,74,.10);        color: var(--shie-success); }
.ss-trust-icon.gold   { background: var(--shie-gold-soft);      color: var(--shie-gold); }
/* Legacy */
.ss-trust-icon.navy   { background: var(--shie-secondary-soft); color: var(--shie-secondary); }
.ss-trust-icon.orange { background: var(--shie-primary-soft);   color: var(--shie-primary); }

.ss-trust-title { font-size: .82rem; font-weight: 700; color: var(--shie-text-primary); line-height: 1.3; }
.ss-trust-sub   { font-size: .72rem; color: var(--shie-text-muted); line-height: 1.3; }

/* ── 8. HERO SECTION (Mobile-First) ─────────────────────── */
.ss-hero {
  background: linear-gradient(160deg, var(--shie-secondary) 0%, var(--shie-primary) 55%, #e8a0b8 100%);
  padding:    32px 0 28px;
  position:   relative;
  overflow:   hidden;
}

.ss-hero::before {
  content:  '';
  position: absolute;
  inset:    0;
  background: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='20' cy='20' r='2' fill='%23ffffff' fill-opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
}

.ss-hero-content {
  position:   relative;
  z-index:    1;
  text-align: center;
}

.ss-hero-eyebrow {
  display:       inline-flex;
  align-items:   center;
  gap:           6px;
  background:    rgba(255,255,255,.15);
  border:        1px solid rgba(255,255,255,.28);
  color:         rgba(255,255,255,.95);
  font-size:     .75rem;
  font-weight:   600;
  padding:       4px 12px;
  border-radius: var(--shie-r-pill);
  margin-bottom: 12px;
}

.ss-hero h1,
.ss-hero-title {
  font-size:     clamp(1.85rem, 6vw, 3.5rem);
  font-weight:   800;
  color:         #fff !important;
  line-height:   1.15;
  margin-bottom: 12px;
}

.ss-hero h1 span,
.ss-hero-title span { color: #ffeef5; }

.ss-hero-sub {
  font-size:     clamp(.9rem, 1.6vw, 1.05rem);
  color:         rgba(255,255,255,.85);
  margin:        0 auto 20px;
  line-height:   1.6;
  max-width:     560px;
}

@media (min-width: 640px) {
  .ss-hero { padding: 44px 0 36px; }
}

@media (min-width: 1024px) {
  .ss-hero { padding: 60px 0 52px; }
  .ss-hero-sub { margin-bottom: 28px; }
}

/* Hero Search */
.ss-hero-search {
  display:       flex;
  background:    #fff;
  border-radius: var(--shie-r-xl);
  overflow:      hidden;
  box-shadow:    var(--shie-shadow-lg);
  margin:        0 auto 16px;
  max-width:     600px;
}

.ss-hero-search select {
  border:      none;
  outline:     none;
  padding:     0 8px;
  border-right:1px solid var(--shie-border-light);
  background:  var(--shie-soft-bg);
  color:       var(--shie-text-sec);
  font-size:   .78rem;
  font-family: var(--shie-font);
  cursor:      pointer;
  min-width:   90px;
  max-width:   110px;
}

.ss-hero-search input {
  flex:        1;
  border:      none;
  outline:     none;
  padding:     12px 12px;
  font-size:   .88rem;
  font-family: var(--shie-font);
  color:       var(--shie-text-primary);
  min-width:   0;
}

.ss-hero-search-btn {
  background:  var(--shie-primary);
  border:      none;
  color:       #fff;
  padding:     0 16px;
  cursor:      pointer;
  font-size:   1rem;
  transition:  background var(--shie-ease-fast);
  display:     flex;
  align-items: center;
  gap:         6px;
  font-weight: 600;
  font-family: var(--shie-font);
  flex-shrink: 0;
}
.ss-hero-search-btn:hover { background: var(--shie-primary-dark); }

@media (min-width: 640px) {
  .ss-hero-search select { min-width: 110px; max-width: 140px; font-size: .85rem; }
  .ss-hero-search input  { padding: 14px 16px; font-size: .95rem; }
  .ss-hero-search-btn    { padding: 0 20px; }
}

.ss-hero-tags {
  display:         flex;
  flex-wrap:       wrap;
  gap:             6px;
  justify-content: center;
}

.ss-hero-tag {
  background:    rgba(255,255,255,.15);
  color:         rgba(255,255,255,.92);
  padding:       4px 11px;
  border-radius: var(--shie-r-pill);
  font-size:     .75rem;
  cursor:        pointer;
  border:        1px solid rgba(255,255,255,.25);
  transition:    all var(--shie-ease-fast);
  text-decoration: none;
}
.ss-hero-tag:hover { background: rgba(255,255,255,.28); color: #fff; }

/* Hero Stats (desktop only) — constrained so it doesn't stretch thin on ultra-wide */
.ss-hero-stats { display: none; }
@media (min-width: 1024px) {
  .ss-hero-stats { display: block; max-width: 420px; margin: 0 auto; }
}

/* ── 9. SECTION HEADERS ──────────────────────────────────── */
.ss-section    { padding: 36px 0; }
.ss-section-sm { padding: 24px 0; }

@media (min-width: 768px) {
  .ss-section    { padding: 48px 0; }
  .ss-section-sm { padding: 32px 0; }
}
@media (min-width: 1024px) {
  .ss-section    { padding: 56px 0; }
}

.ss-section-title  { font-size: 1.2rem; font-weight: 800; color: var(--shie-text-primary); margin-bottom: 4px; }
.ss-section-sub    { font-size: .85rem; color: var(--shie-text-muted); margin-bottom: 0; }
.ss-section-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 20px; }

@media (min-width: 768px) {
  .ss-section-title  { font-size: 1.4rem; }
  .ss-section-header { margin-bottom: 24px; }
}

.ss-view-all {
  font-size:       .82rem;
  font-weight:     600;
  color:           var(--shie-secondary);
  text-decoration: none;
  display:         flex;
  align-items:     center;
  gap:             4px;
  white-space:     nowrap;
  flex-shrink:     0;
}
.ss-view-all:hover { color: var(--shie-primary); }

.ss-section-divider {
  width:         40px;
  height:        3px;
  background:    linear-gradient(90deg, var(--shie-primary) 0%, var(--shie-primary-light) 100%);
  border-radius: 2px;
  margin-bottom: 16px;
}

/* ── 10. CATEGORY CARDS ──────────────────────────────────── */
.ss-cat-card {
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  justify-content: center;
  gap:             8px;
  padding:         16px 10px;
  background:      #fff;
  border-radius:   var(--shie-r-lg);
  border:          1.5px solid var(--shie-border-light);
  text-decoration: none;
  transition:      all var(--shie-ease);
  text-align:      center;
  min-height:      100px;
}
.ss-cat-card:hover {
  border-color: var(--shie-primary);
  box-shadow:   var(--shie-shadow-md);
  transform:    translateY(-2px);
}
.ss-cat-card-icon {
  width:           44px;
  height:          44px;
  border-radius:   var(--shie-r-md);
  display:         flex;
  align-items:     center;
  justify-content: center;
  font-size:       1.25rem;
  transition:      transform var(--shie-ease);
}
.ss-cat-card:hover .ss-cat-card-icon { transform: scale(1.08); }
.ss-cat-card-name  { font-size: .78rem; font-weight: 700; color: var(--shie-text-primary); line-height: 1.3; }
.ss-cat-card-count { font-size: .68rem; color: var(--shie-text-muted); }

@media (min-width: 768px) {
  .ss-cat-card-icon { width: 52px; height: 52px; font-size: 1.4rem; }
  .ss-cat-card-name { font-size: .83rem; }
  .ss-cat-card-count{ font-size: .72rem; }
}

.ss-cat-icon-1 { background: var(--shie-primary-soft);   color: var(--shie-primary); }
.ss-cat-icon-2 { background: var(--shie-secondary-soft); color: var(--shie-secondary); }
.ss-cat-icon-3 { background: rgba(22,163,74,.08);        color: var(--shie-success); }
.ss-cat-icon-4 { background: var(--shie-gold-soft);      color: var(--shie-gold); }
.ss-cat-icon-5 { background: rgba(2,132,199,.08);        color: #0284c7; }
.ss-cat-icon-6 { background: rgba(124,58,237,.08);       color: #7c3aed; }

/* ── 11. PRODUCT CARDS ───────────────────────────────────── */
.ss-product-card {
  background:    #fff;
  border-radius: var(--shie-r-lg);
  border:        1.5px solid var(--shie-border-light);
  overflow:      hidden;
  transition:    all var(--shie-ease);
  position:      relative;
  display:       flex;
  flex-direction:column;
  height:        100%;
}
.ss-product-card:hover {
  border-color: var(--shie-primary);
  box-shadow:   var(--shie-shadow-md);
  transform:    translateY(-2px);
}

.ss-product-img-wrap {
  position:       relative;
  padding-bottom: 80%;
  overflow:       hidden;
  background:     var(--shie-section-bg);
}
.ss-product-img-wrap img {
  position:   absolute;
  inset:      0;
  width:      100%;
  height:     100%;
  object-fit: cover;
  transition: transform .4s ease;
}
.ss-product-card:hover .ss-product-img-wrap img { transform: scale(1.04); }

.ss-product-img-placeholder {
  position:        absolute;
  inset:           0;
  display:         flex;
  align-items:     center;
  justify-content: center;
  color:           var(--shie-border-med);
  font-size:       2.5rem;
}

.ss-product-badges {
  position:       absolute;
  top:            8px;
  left:           8px;
  display:        flex;
  flex-direction: column;
  gap:            4px;
  z-index:        2;
}

.ss-badge {
  display:       inline-flex;
  align-items:   center;
  gap:           3px;
  font-size:     .68rem;
  font-weight:   700;
  padding:       2px 7px;
  border-radius: var(--shie-r-pill);
  line-height:   1.4;
}
.ss-badge-discount   { background: var(--shie-error);     color: #fff; }
.ss-badge-verified   { background: var(--shie-success);   color: #fff; }
.ss-badge-bestseller { background: var(--shie-primary);   color: #fff; }
.ss-badge-new        { background: var(--shie-secondary); color: #fff; }
.ss-badge-offer      { background: var(--shie-gold);      color: #fff; }

.ss-product-wish {
  position:        absolute;
  top:             8px;
  right:           8px;
  width:           30px;
  height:          30px;
  border-radius:   50%;
  background:      rgba(255,255,255,.9);
  border:          1px solid var(--shie-border-light);
  display:         flex;
  align-items:     center;
  justify-content: center;
  cursor:          pointer;
  font-size:       .9rem;
  transition:      all var(--shie-ease-fast);
  z-index:         2;
  color:           var(--shie-text-muted);
}
.ss-product-wish:hover { color: var(--shie-primary); border-color: var(--shie-primary); }

.ss-product-body {
  padding:        12px 12px 10px;
  flex:           1;
  display:        flex;
  flex-direction: column;
}
.ss-product-brand { font-size: .68rem; color: var(--shie-text-muted); font-weight: 600; text-transform: uppercase; margin-bottom: 3px; }
.ss-product-name  {
  font-size:   .82rem;
  font-weight: 600;
  color:       var(--shie-text-primary);
  line-height: 1.4;
  margin-bottom: 6px;
  display:     -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow:    hidden;
}
.ss-product-name a { color: inherit; text-decoration: none; }
.ss-product-name a:hover { color: var(--shie-primary); }

.ss-rating       { display: flex; align-items: center; gap: 3px; margin-bottom: 8px; }
.ss-stars        { color: #F59E0B; font-size: .7rem; }
.ss-rating-count { font-size: .68rem; color: var(--shie-text-muted); }

.ss-price-row   { display: flex; align-items: baseline; gap: 6px; margin-bottom: 10px; flex-wrap: wrap; }
.ss-price       { font-size: 1rem; font-weight: 800; color: var(--shie-text-primary); }
.ss-price-original { font-size: .76rem; color: var(--shie-text-muted); text-decoration: line-through; }
.ss-price-save  { font-size: .68rem; color: var(--shie-success); font-weight: 700; }
.ss-price-prefix{ font-size: .75rem; font-weight: 600; color: var(--shie-text-muted); margin-right: 1px; }

.ss-product-footer { margin-top: auto; }

.ss-btn-add-cart {
  width:           100%;
  display:         flex;
  align-items:     center;
  justify-content: center;
  gap:             5px;
  padding:         9px 12px;
  background:      var(--shie-primary);
  color:           #fff;
  border:          none;
  border-radius:   var(--shie-r-md);
  font-size:       .8rem;
  font-weight:     600;
  font-family:     var(--shie-font);
  cursor:          pointer;
  transition:      all var(--shie-ease-fast);
  min-height:      40px; /* Thumb-friendly */
}
.ss-btn-add-cart:hover  { background: var(--shie-primary-dark); }
.ss-btn-add-cart:active { transform: scale(.98); }
.ss-product-card.out-of-stock .ss-btn-add-cart { background: var(--shie-border-med); cursor: not-allowed; }

/* ── 12. BUTTONS (Thumb-Friendly Min 44px) ───────────────── */
.ss-btn {
  display:         inline-flex;
  align-items:     center;
  gap:             8px;
  padding:         12px 20px;
  border-radius:   var(--shie-r-md);
  font-size:       .9rem;
  font-weight:     600;
  font-family:     var(--shie-font);
  border:          2px solid transparent;
  cursor:          pointer;
  text-decoration: none;
  transition:      all var(--shie-ease-fast);
  line-height:     1.4;
  min-height:      44px;
}
.ss-btn:active { transform: scale(.98); }

.ss-btn-primary { background: var(--shie-primary);   color: #fff; border-color: var(--shie-primary); }
.ss-btn-primary:hover { background: var(--shie-primary-dark); border-color: var(--shie-primary-dark); color: #fff; }

.ss-btn-orange  { background: var(--shie-primary);   color: #fff; border-color: var(--shie-primary); }
.ss-btn-orange:hover { background: var(--shie-primary-dark); color: #fff; }

.ss-btn-outline { background: transparent; color: var(--shie-secondary); border-color: var(--shie-secondary); }
.ss-btn-outline:hover { background: var(--shie-secondary); color: #fff; }

.ss-btn-white   { background: #fff; color: var(--shie-secondary); border-color: #fff; }
.ss-btn-white:hover { background: var(--shie-soft-bg); color: var(--shie-secondary); }

.ss-btn-green   { background: var(--shie-success); color: #fff; border-color: var(--shie-success); }
.ss-btn-green:hover { background: #15803d; color: #fff; }

.ss-btn-gold    { background: var(--shie-gold); color: #fff; border-color: var(--shie-gold); }
.ss-btn-gold:hover { background: var(--shie-gold-dark); color: #fff; }

.ss-btn-whatsapp { background: #25D366; color: #fff; border-color: #25D366; font-size: .85rem; }
.ss-btn-whatsapp:hover { background: #1da851; color: #fff; }

.ss-btn-lg    { padding: 14px 28px; font-size: .95rem; border-radius: var(--shie-r-lg); }
.ss-btn-sm    { padding: 8px 16px;  font-size: .8rem;  min-height: 36px; }
.ss-btn-xs    { padding: 5px 10px;  font-size: .75rem; min-height: 30px; border-radius: var(--shie-r-sm); }
.ss-btn-block { width: 100%; justify-content: center; }

/* ── 13. FORMS (VES: Full Width, Rose Focus) ─────────────── */
.ss-form-label   { font-size: .85rem; font-weight: 600; color: var(--shie-text-sec); margin-bottom: 6px; display: block; }

.ss-form-control {
  width:       100%;
  padding:     12px 14px;
  border:      1.5px solid var(--shie-border-med);
  border-radius: var(--shie-r-md);
  font-size:   1rem;
  font-family: var(--shie-font);
  color:       var(--shie-text-primary);
  background:  #fff;
  transition:  border-color var(--shie-ease-fast), box-shadow var(--shie-ease-fast);
  outline:     none;
  min-height:  44px;
  -webkit-appearance: none;
}
.ss-form-control:focus {
  border-color: var(--shie-primary);
  box-shadow:   0 0 0 3px rgba(217,108,138,.12);
}
.ss-form-control::placeholder { color: var(--shie-text-muted); }

/* ── 14. PROMO BANNERS ───────────────────────────────────── */
.ss-promo-banner {
  background:    linear-gradient(135deg, var(--shie-primary) 0%, var(--shie-primary-dark) 100%);
  border-radius: var(--shie-r-xl);
  padding:       28px 24px;
  color:         #fff;
  position:      relative;
  overflow:      hidden;
}
.ss-promo-banner::after {
  content:  '';
  position: absolute; right: -30px; top: -30px;
  width:    150px; height: 150px;
  background: rgba(255,255,255,.07); border-radius: 50%;
}
.ss-promo-banner-title { font-size: 1.2rem; font-weight: 800; margin-bottom: 8px; }
.ss-promo-banner-sub   { font-size: .88rem; opacity: .85; margin-bottom: 16px; }

@media (min-width: 768px) {
  .ss-promo-banner { padding: 40px; }
  .ss-promo-banner-title { font-size: 1.5rem; }
  .ss-promo-banner-sub   { font-size: .95rem; margin-bottom: 20px; }
}

.ss-navy-banner {
  background:    linear-gradient(135deg, var(--shie-secondary) 0%, var(--shie-secondary-dark) 100%);
  border-radius: var(--shie-r-xl);
  padding:       28px 24px;
  color:         #fff;
}
@media (min-width: 768px) { .ss-navy-banner { padding: 40px; } }

/* ── 15. ALERTS ──────────────────────────────────────────── */
.ss-alert {
  display:     flex; align-items: flex-start; gap: 10px;
  padding:     12px 14px; border-radius: var(--shie-r-md);
  font-size:   .875rem; margin-bottom: 12px;
}
.ss-alert-success { background: #f0fdf4; border: 1px solid #bbf7d0; color: #166534; }
.ss-alert-error   { background: #fef2f2; border: 1px solid #fecaca; color: #991b1b; }
.ss-alert-warning { background: #fffbeb; border: 1px solid #fde68a; color: #92400e; }
.ss-alert-info    { background: var(--shie-primary-soft); border: 1px solid var(--shie-border-light); color: var(--shie-secondary); }

/* ── 16. CART ────────────────────────────────────────────── */
.ss-cart-item {
  display:       flex; gap: 12px; padding: 14px 0;
  border-bottom: 1px solid var(--shie-border-light);
  align-items:   flex-start;
}
.ss-cart-item-img {
  width: 72px; height: 72px; flex-shrink: 0;
  border-radius: var(--shie-r-md); overflow: hidden;
  background: var(--shie-section-bg); border: 1px solid var(--shie-border-light);
}
.ss-cart-item-img img { width: 100%; height: 100%; object-fit: cover; }
.ss-cart-item-name { font-size: .88rem; font-weight: 600; color: var(--shie-text-primary); }

.ss-cart-qty-ctrl {
  display:      flex; align-items: center;
  border:       1.5px solid var(--shie-border-light);
  border-radius:var(--shie-r-md); overflow: hidden;
}
.ss-cart-qty-btn {
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  background: var(--shie-section-bg); border: none;
  cursor: pointer; font-size: 1rem; color: var(--shie-text-sec);
  transition: background var(--shie-ease-fast);
}
.ss-cart-qty-btn:hover { background: var(--shie-border-light); }
.ss-cart-qty-val {
  width: 44px; text-align: center; font-size: .9rem; font-weight: 600;
  border: none; padding: 0 4px;
  border-left:  1.5px solid var(--shie-border-light);
  border-right: 1.5px solid var(--shie-border-light);
}

.ss-order-summary {
  background:    var(--shie-section-bg);
  border-radius: var(--shie-r-lg);
  border:        1.5px solid var(--shie-border-light);
  padding:       18px;
}
.ss-summary-row {
  display:         flex; justify-content: space-between;
  align-items:     center; padding: 8px 0; font-size: .875rem;
}
.ss-summary-row.total {
  border-top:  2px solid var(--shie-border-light);
  margin-top:  4px; padding-top: 12px;
  font-weight: 800; font-size: 1rem;
}
.ss-summary-free { color: var(--shie-success); font-weight: 700; }
.ss-delivery-progress { height: 6px; background: var(--shie-border-light); border-radius: 3px; overflow: hidden; margin: 8px 0 4px; }
.ss-delivery-progress-fill { height: 100%; background: linear-gradient(90deg, var(--shie-success) 0%, #22c55e 100%); border-radius: 3px; transition: width .4s ease; }

/* ── 17. CHECKOUT ────────────────────────────────────────── */
.ss-checkout-step {
  background: #fff; border-radius: var(--shie-r-lg);
  border: 1.5px solid var(--shie-border-light); padding: 20px; margin-bottom: 16px;
}
.ss-step-header { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.ss-step-num {
  width: 32px; height: 32px; min-width: 32px;
  background: var(--shie-primary); color: #fff;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: .85rem; font-weight: 700;
}
.ss-step-title { font-size: .95rem; font-weight: 700; color: var(--shie-text-primary); }

.ss-payment-option {
  display: flex; align-items: center; gap: 12px;
  border: 2px solid var(--shie-border-light);
  border-radius: var(--shie-r-md); padding: 12px 14px;
  cursor: pointer; transition: all var(--shie-ease-fast); margin-bottom: 10px;
}
.ss-payment-option:hover  { border-color: var(--shie-primary); }
.ss-payment-option.selected { border-color: var(--shie-primary); background: var(--shie-primary-soft); }
.ss-payment-option input[type="radio"] { accent-color: var(--shie-primary); }
.ss-payment-icon { width: 40px; height: 40px; border-radius: var(--shie-r-md); display: flex; align-items: center; justify-content: center; font-size: 1.25rem; }
.ss-payment-label { font-size: .875rem; font-weight: 600; color: var(--shie-text-primary); }
.ss-payment-sub   { font-size: .76rem;  color: var(--shie-text-muted); }

/* ── 18. TESTIMONIALS ────────────────────────────────────── */
.ss-testimonial {
  background: #fff; border-radius: var(--shie-r-lg);
  border: 1.5px solid var(--shie-border-light); padding: 20px; height: 100%;
}
.ss-testimonial-stars  { color: #F59E0B; font-size: .85rem; margin-bottom: 10px; }
.ss-testimonial-text   { font-size: .875rem; color: var(--shie-text-sec); line-height: 1.7; margin-bottom: 14px; font-style: italic; }
.ss-testimonial-author { display: flex; align-items: center; gap: 10px; }
.ss-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--shie-primary); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: .85rem; flex-shrink: 0;
}
.ss-reviewer-name  { font-size: .82rem; font-weight: 700; color: var(--shie-text-primary); }
.ss-reviewer-badge { font-size: .68rem; color: var(--shie-success); font-weight: 600; }

/* ── 19. NEWSLETTER ──────────────────────────────────────── */
.ss-newsletter {
  background: linear-gradient(135deg, var(--shie-secondary) 0%, var(--shie-primary) 100%);
  padding: 44px 0; color: #fff; text-align: center;
}
.ss-newsletter h2 { font-size: 1.4rem; font-weight: 800; margin-bottom: 8px; }
.ss-newsletter p  { color: rgba(255,255,255,.78); margin-bottom: 24px; font-size: .9rem; }

@media (min-width: 768px) {
  .ss-newsletter { padding: 56px 0; }
  .ss-newsletter h2 { font-size: 1.75rem; }
}

.ss-newsletter-form {
  display: flex; max-width: 420px; margin: 0 auto;
  background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.25);
  border-radius: var(--shie-r-pill); overflow: hidden; padding: 4px;
}
.ss-newsletter-input {
  flex: 1; border: none; background: transparent;
  color: #fff; padding: 10px 14px; font-family: var(--shie-font); font-size: .875rem; outline: none; min-width: 0;
}
.ss-newsletter-input::placeholder { color: rgba(255,255,255,.5); }
.ss-newsletter-btn {
  background: var(--shie-white); border: none; color: var(--shie-primary);
  padding: 10px 18px; border-radius: var(--shie-r-pill); font-weight: 700; font-size: .82rem;
  cursor: pointer; font-family: var(--shie-font); transition: all var(--shie-ease-fast); white-space: nowrap;
}
.ss-newsletter-btn:hover { background: var(--shie-soft-bg); }

/* ── 20. FOOTER ──────────────────────────────────────────── */
.ss-footer { background: var(--shie-text-primary); color: rgba(255,255,255,.7); padding: 44px 0 0; }

@media (min-width: 768px) { .ss-footer { padding: 56px 0 0; } }

.ss-footer-logo-text    { font-size: 1.2rem; font-weight: 800; color: #fff; margin-bottom: 10px; }
.ss-footer-desc         { font-size: .83rem; line-height: 1.7; margin-bottom: 18px; }
.ss-footer-social       { display: flex; gap: 8px; flex-wrap: wrap; }
.ss-social-link {
  width: 34px; height: 34px;
  background: rgba(255,255,255,.1); border-radius: var(--shie-r-sm);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.7); font-size: .95rem;
  text-decoration: none; transition: all var(--shie-ease-fast);
}
.ss-social-link:hover { background: var(--shie-primary); color: #fff; }
.ss-footer-heading {
  font-size: .82rem; font-weight: 700; color: #fff;
  text-transform: uppercase; letter-spacing: .05em; margin-bottom: 14px;
}
.ss-footer-links       { list-style: none; padding: 0; margin: 0; }
.ss-footer-links li    { margin-bottom: 8px; }
.ss-footer-links a     { font-size: .83rem; color: rgba(255,255,255,.6); text-decoration: none; transition: color var(--shie-ease-fast); }
.ss-footer-links a:hover { color: #fff; }
.ss-footer-contact-item {
  display: flex; gap: 10px; align-items: flex-start;
  font-size: .83rem; color: rgba(255,255,255,.65); margin-bottom: 10px;
}
.ss-footer-contact-item i { color: var(--shie-primary); font-size: .95rem; flex-shrink: 0; margin-top: 2px; }
.ss-footer-bottom {
  border-top: 1px solid rgba(255,255,255,.08); padding: 14px 0; margin-top: 36px;
  font-size: .78rem; color: rgba(255,255,255,.35);
}

/* ── 21. VERIFIED & UTILITY BADGES ──────────────────────── */
.ss-verified-tag {
  display: inline-flex; align-items: center; gap: 4px;
  background: rgba(22,163,74,.1); color: var(--shie-success);
  font-size: .72rem; font-weight: 700;
  padding: 2px 8px; border-radius: var(--shie-r-pill);
  border: 1px solid rgba(22,163,74,.2);
}

.ss-page-header {
  background: linear-gradient(135deg, var(--shie-secondary) 0%, var(--shie-primary) 100%);
  padding: 24px 0; color: #fff;
}
.ss-page-header h1  { font-size: 1.25rem; font-weight: 800; margin-bottom: 4px; }
.ss-breadcrumb      { font-size: .75rem; color: rgba(255,255,255,.6); }
.ss-breadcrumb a    { color: rgba(255,255,255,.75); text-decoration: none; }
.ss-breadcrumb a:hover { color: #fff; }

@media (min-width: 768px) {
  .ss-page-header { padding: 32px 0; }
  .ss-page-header h1 { font-size: 1.5rem; }
}

/* ── 22. PRODUCT DETAIL ──────────────────────────────────── */
.ss-product-detail-img { border-radius: var(--shie-r-lg); overflow: hidden; background: var(--shie-section-bg); }
.ss-product-detail-img img { width: 100%; aspect-ratio: 1; object-fit: cover; }
.ss-thumb-strip { display: flex; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
.ss-thumb {
  width: 60px; height: 60px; border-radius: var(--shie-r-sm); overflow: hidden;
  cursor: pointer; border: 2px solid var(--shie-border-light); transition: border-color var(--shie-ease-fast);
}
.ss-thumb.active, .ss-thumb:hover { border-color: var(--shie-primary); }
.ss-thumb img { width: 100%; height: 100%; object-fit: cover; }
.ss-product-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.ss-spec-table { width: 100%; }
.ss-spec-table tr:nth-child(even) td { background: var(--shie-section-bg); }
.ss-spec-table td { padding: 8px 10px; font-size: .85rem; border-bottom: 1px solid var(--shie-border-light); }
.ss-spec-key { font-weight: 600; color: var(--shie-text-sec); width: 40%; }
.ss-spec-val { color: var(--shie-text-muted); }

/* ── 23. SIDEBAR FILTER ──────────────────────────────────── */
.ss-filter-card {
  background: #fff; border-radius: var(--shie-r-lg);
  border: 1.5px solid var(--shie-border-light); padding: 18px; margin-bottom: 16px;
}
.ss-filter-title { font-size: .85rem; font-weight: 700; color: var(--shie-text-primary); margin-bottom: 10px; }

/* ── 24. EMPTY STATES ────────────────────────────────────── */
.ss-empty-state  { text-align: center; padding: 48px 24px; }
.ss-empty-icon   { font-size: 3.5rem; color: var(--shie-border-med); margin-bottom: 14px; }
.ss-empty-title  { font-size: 1.1rem; font-weight: 700; color: var(--shie-text-sec); margin-bottom: 8px; }
.ss-empty-sub    { color: var(--shie-text-muted); font-size: .875rem; margin-bottom: 20px; }

/* ── 25. UTILITY CLASSES ─────────────────────────────────── */
.ss-card {
  background: #fff; border-radius: var(--shie-r-lg);
  border: 1.5px solid var(--shie-border-light); padding: 18px;
}
@media (min-width: 768px) { .ss-card { padding: 20px; } }

.ss-divider  { border-top: 1px solid var(--shie-border-light); margin: 14px 0; }

.ss-spinner {
  width: 28px; height: 28px;
  border: 3px solid var(--shie-border-light);
  border-top-color: var(--shie-primary);
  border-radius: 50%; animation: ss-spin .7s linear infinite;
}
@keyframes ss-spin { to { transform: rotate(360deg); } }

@keyframes ss-fade-up { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
.ss-fade-up { animation: ss-fade-up .35s ease forwards; }

/* ── 26. FLOATING CONTACT STACK (Desktop) ────────────────── */
.shie-float-stack {
  position:       fixed;
  right:          0;
  top:            50%;
  transform:      translateY(-50%);
  z-index:        var(--shie-z-float);
  display:        none;
  flex-direction: column;
  gap:            6px;
  padding:        6px 0;
}

@media (min-width: 768px) { .shie-float-stack { display: flex; } }

.shie-float-btn {
  display:         flex;
  align-items:     center;
  gap:             8px;
  padding:         10px 14px 10px 12px;
  border-radius:   var(--shie-r-lg) 0 0 var(--shie-r-lg);
  color:           #fff;
  text-decoration: none;
  font-family:     var(--shie-font);
  font-size:       .76rem;
  font-weight:     700;
  cursor:          pointer;
  border:          none;
  outline:         none;
  box-shadow:      var(--shie-shadow-md);
  transition:      all var(--shie-ease);
  min-width:       140px;
  white-space:     nowrap;
}
.shie-float-btn:hover { transform: translateX(-4px); box-shadow: var(--shie-shadow-lg); color: #fff; }
.shie-float-btn i { font-size: 1.05rem; flex-shrink: 0; }

.shie-float-btn-label { display: flex; flex-direction: column; line-height: 1.25; }
.shie-float-btn-title { font-size: .74rem; font-weight: 700; }
.shie-float-btn-sub   { font-size: .65rem; font-weight: 500; opacity: .85; }

.shie-float-wa    { background: #25D366; }
.shie-float-wa:hover { background: #1da851; }
.shie-float-phone { background: var(--shie-secondary); }
.shie-float-phone:hover { background: var(--shie-secondary-dark); }
.shie-float-till  { background: var(--shie-gold); }
.shie-float-till:hover { background: var(--shie-gold-dark); }

/* ── 27. MOBILE STICKY BAR ───────────────────────────────── */
.shie-mobile-bar {
  position:   fixed;
  bottom:     0;
  left:       0;
  right:      0;
  z-index:    var(--shie-z-float);
  background: #fff;
  border-top: 2px solid var(--shie-border-light);
  box-shadow: 0 -4px 20px rgba(122,78,109,.10);
  display:    flex;
  gap:        8px;
  padding:    8px 12px;
  padding-bottom: max(8px, env(safe-area-inset-bottom));
}

@media (min-width: 768px) { .shie-mobile-bar { display: none; } }

.shie-mobile-bar-btn {
  flex:            1;
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  justify-content: center;
  gap:             3px;
  padding:         8px 4px;
  border-radius:   var(--shie-r-md);
  color:           #fff;
  text-decoration: none;
  font-family:     var(--shie-font);
  font-size:       .68rem;
  font-weight:     700;
  border:          none;
  cursor:          pointer;
  transition:      all var(--shie-ease-fast);
  outline:         none;
  min-height:      52px;
}
.shie-mobile-bar-btn:active { transform: scale(.96); }
.shie-mobile-bar-btn i   { font-size: 1.15rem; }
.shie-mobile-bar-btn.wa  { background: #25D366; }
.shie-mobile-bar-btn.phone { background: var(--shie-secondary); }
.shie-mobile-bar-btn.till  { background: var(--shie-gold); }

/* Till copy tooltip */
.shie-till-copied {
  position:    absolute; bottom: 100%; left: 50%; transform: translateX(-50%);
  background:  var(--shie-text-primary); color: #fff;
  font-size:   .7rem; padding: 4px 10px; border-radius: var(--shie-r-sm);
  white-space: nowrap; pointer-events: none; margin-bottom: 6px;
  animation:   ss-fade-up .2s ease;
}
