/* ================================================================
   PRIME NUTRITION – Main Stylesheet v3.0
   Fixes: cursor, cat cards, reviews, footer colors, mobile nav,
          mega menu, mobile bottom nav stacking
================================================================ */

/* ── Variables ────────────────────────────────────────────────── */
:root {
  --bg:       #f5f4f1;
  --white:    #ffffff;
  --ink:      #0e0e0e;
  --ink2:     #181818;
  --mid:      #6b6b6b;
  --light:    #d8d5ce;
  --lighter:  #e8e5df;
  --blue:     #1a3a8f;
  --blue-l:   #e8edf8;
  --blue-m:   #c5d0f0;
  --silver:   #8a9ab8;
  --accent:   #c41c1c;
  --radius:   10px;
  --shadow:   0 4px 24px rgba(0,0,0,.07);
  --shadow-lg:0 8px 40px rgba(0,0,0,.11);
  --trans:    0.2s ease;
}

/* ── Reset ────────────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: 'Outfit', sans-serif;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  /* NORMAL cursor always */
  cursor: auto !important;
}
/* FIX: remove custom cursor override — use normal pointer */
*, *::before, *::after { cursor: inherit; }
a, button, [role="button"], label, select, .cat-card, .product-card, .brand-chip, .cat-tab { cursor: pointer; }
img { max-width:100%; height:auto; display:block; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
button { font-family:inherit; border:none; background:none; }
input, textarea, select { font-family:inherit; }
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--light); border-radius:3px; }

/* ── Hide the JS custom cursor element entirely ──────────────── */
#cursor, .custom-cursor { display: none !important; }

/* ── Layout ───────────────────────────────────────────────────── */
.container { max-width:1200px; margin:0 auto; padding:0 24px; }
.text-blue   { color: var(--blue); }
.text-accent { color: var(--accent); }

/* ── Animations ───────────────────────────────────────────────── */
@keyframes fade-up { from { opacity:0; transform:translateY(22px); } to { opacity:1; transform:translateY(0); } }
@keyframes logo-flip { 0%{transform:rotateY(0deg)} 30%{transform:rotateY(360deg)} 100%{transform:rotateY(360deg)} }
@keyframes btn-pop { 0%{transform:scale(1)} 40%{transform:scale(.9)} 70%{transform:scale(1.1)} 100%{transform:scale(1)} }

.animate-fade-up { opacity:0; }
.animate-fade-up.visible { animation: fade-up .55s ease forwards; }
.delay-1.visible { animation-delay:.12s; }
.delay-2.visible { animation-delay:.22s; }

/* ── Toast ────────────────────────────────────────────────────── */
.toast {
  position:fixed; bottom:96px; left:50%;
  transform:translateX(-50%) translateY(16px);
  background:var(--ink2); color:#fff;
  padding:11px 22px; border-radius:100px;
  font-size:13px; font-weight:500;
  opacity:0; transition:all .28s; z-index:500;
  white-space:nowrap; pointer-events:none;
  box-shadow:0 4px 20px rgba(0,0,0,.2);
}
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* ================================================================
   ANNOUNCE BAR
================================================================ */
.announce-bar {
  background:var(--ink2); color:#9aafcc;
  text-align:center; padding:9px 16px;
  font-size:13px; letter-spacing:.02em;
}
.announce-bar strong { color:#fff; font-weight:600; }

/* ================================================================
   HEADER
================================================================ */
.site-header {
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--lighter);
  position:sticky; top:0; z-index:200;
  transition:box-shadow var(--trans);
}
.site-header.scrolled { box-shadow:0 2px 28px rgba(0,0,0,.07); }

.header-inner {
  display:flex; align-items:center;
  justify-content:space-between;
  gap:20px; padding:15px 24px;
  max-width:1200px; margin:0 auto;
}

/* Logo */
.site-logo { display:flex; align-items:center; flex-shrink:0; }
.logo-3d { perspective:500px; display:inline-block; }
.logo-text {
  display:inline-block; font-family:'Outfit',sans-serif;
  font-weight:900; font-size:22px; letter-spacing:-.04em;
  color:var(--ink); line-height:1; transform-style:preserve-3d;
}
.logo-text sup { font-size:10px; font-weight:700; color:var(--blue); letter-spacing:.05em; vertical-align:super; margin-left:3px; }
.logo-text.flipping { animation:logo-flip 1.3s cubic-bezier(.4,0,.2,1) forwards; }

/* ── MEGA MENU (desktop) ────────────────────────────────────────*/
.desktop-nav { display:flex; align-items:center; flex:1; justify-content:center; position:relative; }
.desktop-nav-list { display:flex; gap:2px; align-items:center; }
.desktop-nav-list > li { position:relative; }
.desktop-nav-list > li > a {
  display:block; font-size:14px; font-weight:500; color:var(--mid);
  padding:8px 14px; border-radius:7px; transition:all var(--trans);
  white-space:nowrap;
}
.desktop-nav-list > li > a:hover,
.desktop-nav-list > li.current-menu-item > a { color:var(--ink); background:var(--bg); }
.desktop-nav-list > li.current-menu-item > a { color:var(--blue); background:var(--blue-l); font-weight:600; }

/* Mega menu dropdown — hover bridge prevents gap disappear */
.mega-menu {
  display:none; position:absolute; top:100%; left:50%;
  transform:translateX(-50%);
  background:var(--white); border:1px solid var(--lighter);
  border-radius:14px; box-shadow:0 16px 48px rgba(0,0,0,.12);
  padding:24px 24px 20px; min-width:640px; z-index:300;
  grid-template-columns:repeat(4,1fr); gap:8px;
  /* top padding bridges the gap so mouse can reach dropdown */
  margin-top:0;
}
/* Invisible bridge between nav item and dropdown */
.desktop-nav-list > li > a.mega-trigger::before {
  content:''; position:absolute; bottom:-16px; left:0; right:0; height:16px;
}
.desktop-nav-list > li:hover .mega-menu,
.mega-menu:hover { display:grid; }

.mega-menu-item {
  display:flex; flex-direction:column; align-items:flex-start;
  gap:6px; padding:14px; border-radius:10px;
  transition:background var(--trans);
}
.mega-menu-item:hover { background:var(--blue-l); }
.mega-menu-icon { font-size:24px; }
.mega-menu-name { font-weight:700; font-size:14px; color:var(--ink); }
.mega-menu-count { font-size:11px; color:var(--mid); }

/* Mega trigger arrow */
.mega-trigger::after { content:'  ▾'; font-size:10px; opacity:.5; }

/* Search */
.header-search { position:relative; }
.search-form {
  display:flex; align-items:center;
  background:var(--bg); border:1.5px solid var(--lighter);
  border-radius:8px; padding:0 12px; gap:8px;
  height:38px; width:190px;
  transition:border-color var(--trans), box-shadow var(--trans), width .3s;
}
.search-form:focus-within { border-color:var(--blue-m); box-shadow:0 0 0 3px rgba(26,58,143,.07); width:240px; }
.search-icon { stroke:var(--mid); flex-shrink:0; }
.search-input { border:none; background:transparent; font-size:13.5px; color:var(--ink); outline:none; width:100%; }
.search-input::placeholder { color:var(--mid); }

/* Header actions */
.header-actions { display:flex; align-items:center; gap:4px; flex-shrink:0; }
.icon-btn {
  width:38px; height:38px; border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  color:var(--ink); transition:background var(--trans); position:relative;
}
.icon-btn:hover { background:var(--bg); }

.cart-icon-btn { position:relative; }
.cart-count {
  position:absolute; top:5px; right:5px;
  background:var(--blue); color:#fff;
  width:16px; height:16px; border-radius:50%;
  font-size:9px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  border:2px solid #fff;
}

/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; padding:5px; }
.hamburger span { display:block; width:22px; height:2px; background:var(--ink); border-radius:2px; transition:all .3s; }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Category tabs strip */
.cat-tabs-strip { border-top:1px solid var(--lighter); overflow-x:auto; scrollbar-width:none; }
.cat-tabs-strip::-webkit-scrollbar { display:none; }
.cat-tabs-inner { display:flex; white-space:nowrap; padding:0; max-width:1200px; margin:0 auto; }
.cat-tab {
  padding:11px 16px; font-size:13px; font-weight:500; color:var(--mid);
  border-bottom:2.5px solid transparent; transition:all var(--trans);
  white-space:nowrap; display:block; cursor:pointer;
}
.cat-tab:hover { color:var(--ink); }
.cat-tab.on { color:var(--blue); border-bottom-color:var(--blue); font-weight:600; }

/* ================================================================
   MOBILE MENU (slide-out drawer)
================================================================ */
.mobile-menu { display:block; position:fixed; inset:0; z-index:300; pointer-events:none; }
.mobile-menu.open { pointer-events:all; }
.mobile-backdrop { position:absolute; inset:0; background:rgba(0,0,0,.45); opacity:0; transition:opacity .3s; }
.mobile-menu.open .mobile-backdrop { opacity:1; }
.mobile-drawer {
  position:absolute; top:0; left:0; bottom:0; width:300px;
  background:var(--white); transform:translateX(-100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1); overflow-y:auto;
}
.mobile-menu.open .mobile-drawer { transform:translateX(0); }
.mobile-drawer-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 20px 16px; border-bottom:1px solid var(--lighter);
}
.mobile-drawer-logo a { font-family:'Outfit',sans-serif; font-weight:900; font-size:21px; letter-spacing:-.04em; color:var(--ink); }
.mobile-drawer-logo sup { font-size:10px; color:var(--blue); vertical-align:super; margin-left:2px; }
.mobile-close {
  width:32px; height:32px; border-radius:6px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  color:var(--mid); transition:background var(--trans);
}
.mobile-close:hover { background:var(--bg); color:var(--ink); }
.mobile-nav-list { padding:8px 0; }
.mobile-nav-item {
  display:flex; align-items:center; gap:12px;
  padding:13px 20px; font-size:15px; font-weight:500; color:var(--ink);
  border-bottom:1px solid var(--bg); transition:background var(--trans); cursor:pointer;
}
.mobile-nav-item:hover { background:var(--bg); }
.mi-icon { font-size:18px; flex-shrink:0; }
.mi-label { flex:1; }
.mi-count { font-size:11px; color:var(--mid); }

/* ================================================================
   BUTTONS
================================================================ */
.btn {
  display:inline-flex; align-items:center; justify-content:center;
  gap:8px; padding:13px 24px; border-radius:8px;
  font-size:14px; font-weight:600; font-family:'Outfit',sans-serif;
  letter-spacing:-.01em; transition:all var(--trans);
  white-space:nowrap; border:none; cursor:pointer;
}
.btn-blue {
  background:var(--blue); color:#fff;
  box-shadow:0 4px 18px rgba(26,58,143,.25);
}
.btn-blue:hover { background:#152f75; box-shadow:0 6px 26px rgba(26,58,143,.35); transform:translateY(-1px); }
.btn-outline { background:transparent; color:var(--ink); border:1.5px solid var(--light); }
.btn-outline:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-l); }
.btn-white { background:#fff; color:var(--ink); }
.btn-white:hover { background:var(--blue-l); color:var(--blue); }

/* ================================================================
   SECTION HEADERS
================================================================ */
.section-head {
  display:flex; align-items:baseline; justify-content:space-between; margin-bottom:20px;
}
.section-title { font-family:'Outfit',sans-serif; font-weight:800; font-size:clamp(20px,2.5vw,26px); letter-spacing:-.03em; color:var(--ink); }
.section-link { font-size:13px; font-weight:600; color:var(--silver); transition:color var(--trans); border-bottom:1px solid transparent; padding-bottom:1px; cursor:pointer; }
.section-link:hover { color:var(--blue); border-color:var(--blue); }

/* ================================================================
   HERO SECTION
================================================================ */
.hero-section { background:var(--white); position:relative; overflow:hidden; }
.hero-bg-lines {
  position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(160deg,#f0f3fa 0%,#e8eef8 60%,#f5f4f1 100%);
}
.hero-bg-lines::before {
  content:''; position:absolute; inset:0;
  background-image:repeating-linear-gradient(-52deg,transparent,transparent 32px,rgba(26,58,143,.025) 32px,rgba(26,58,143,.025) 33px);
}
.hero-glow1 { position:absolute; top:-100px; right:-80px; width:500px; height:500px; pointer-events:none; background:radial-gradient(circle,rgba(26,58,143,.1) 0%,transparent 65%); }
.hero-glow2 { position:absolute; bottom:-80px; left:10%; width:320px; height:320px; pointer-events:none; background:radial-gradient(circle,rgba(196,28,28,.04) 0%,transparent 65%); }

.hero-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; padding:72px 0 60px; position:relative; z-index:1; }

.hero-kicker {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--blue); color:#fff; padding:5px 12px; border-radius:4px;
  font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; margin-bottom:18px;
}
.hero-title { font-family:'Outfit',sans-serif; font-weight:900; font-size:clamp(48px,5.5vw,78px); line-height:.92; letter-spacing:-.04em; color:var(--ink); margin-bottom:18px; }
.serif-italic { font-family:'Fraunces',serif; font-weight:300; font-style:italic; color:var(--blue); display:block; }
.hero-body { font-size:16px; font-weight:300; color:var(--mid); max-width:400px; line-height:1.7; margin-bottom:30px; }
.hero-ctas { display:flex; gap:12px; flex-wrap:wrap; }

.hero-right { display:grid; grid-template-columns:1fr 1fr; grid-template-rows:auto auto; gap:14px; }
.hero-card {
  background:var(--white); border:1px solid var(--lighter); border-radius:12px; padding:20px;
  display:flex; flex-direction:column; gap:8px; transition:box-shadow var(--trans), transform var(--trans); cursor:pointer;
}
.hero-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-3px); }
.hero-card:first-child { grid-column:1; grid-row:1/3; justify-content:center; align-items:center; text-align:center; min-height:260px; }
.hero-card-emoji { font-size:40px; }
.hero-card-name { font-weight:700; font-size:14px; color:var(--ink); }
.hero-card-price { font-weight:800; font-size:18px; color:var(--blue); letter-spacing:-.02em; }
.hero-card-thumb { width:100%; border-radius:8px; overflow:hidden; }
.hero-card-thumb img, .hero-card-thumb-img { width:100%; height:auto; object-fit:contain; border-radius:8px; max-height:160px; }
.card-badge { display:inline-block; font-size:10px; font-weight:700; padding:2px 8px; border-radius:3px; text-transform:uppercase; letter-spacing:.06em; align-self:flex-start; }
.badge-sale { background:var(--accent); color:#fff; }
.badge-new  { background:var(--blue); color:#fff; }
.badge-best { background:var(--ink); color:#fff; }
.hero-card:first-child .card-badge { align-self:center; }

/* Stats bar */
.hero-stats-bar { background:var(--ink2); position:relative; z-index:1; }
.hero-stats-row { display:flex; max-width:1200px; margin:0 auto; padding:0 24px; }
.stat-item { flex:1; padding:20px 0; text-align:center; border-right:1px solid rgba(255,255,255,.06); }
.stat-item:last-child { border-right:none; }
.stat-num { display:block; font-weight:800; font-size:26px; color:#fff; letter-spacing:-.03em; line-height:1; }
.stat-label { display:block; font-size:11px; color:#4a5a6a; text-transform:uppercase; letter-spacing:.06em; margin-top:4px; }

/* ================================================================
   BRANDS
================================================================ */
.brands-section { background:var(--bg); border-bottom:1px solid var(--lighter); padding:18px 0; }
.brands-inner { display:flex; align-items:center; gap:16px; overflow:hidden; }
.brands-label { font-size:10px; font-weight:700; color:var(--mid); text-transform:uppercase; letter-spacing:.1em; white-space:nowrap; flex-shrink:0; }
.brands-chips { display:flex; flex-direction:row; gap:8px; overflow-x:auto; scrollbar-width:none; flex-wrap:nowrap; }
.brands-chips::-webkit-scrollbar { display:none; }
.brand-chip {
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--white); border:1.5px solid var(--lighter);
  border-radius:100px; padding:6px 15px; font-size:13px; font-weight:600; color:var(--mid);
  white-space:nowrap; flex-shrink:0; cursor:pointer; transition:all var(--trans);
}
.brand-chip:hover, .brand-chip.on { background:var(--blue-l); border-color:var(--blue-m); color:var(--blue); }

/* ================================================================
   PRODUCTS
================================================================ */
.products-section { padding:40px 0 48px; }
.products-scroll-track { overflow-x:auto; overflow-y:visible; scrollbar-width:none; padding-bottom:4px; }
.products-scroll-track::-webkit-scrollbar { display:none; }
.products-flex { display:flex; flex-direction:row; flex-wrap:nowrap; gap:16px; width:max-content; }

/* Product Card */
.product-card {
  width:220px; flex-shrink:0;
  background:var(--white); border:1px solid var(--lighter); border-radius:var(--radius); overflow:hidden;
  transition:box-shadow var(--trans), transform var(--trans), border-color var(--trans);
  position:relative;
}
.product-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-3px); border-color:var(--blue-m); }
.product-badge {
  position:absolute; top:10px; left:10px;
  font-size:10px; font-weight:700; letter-spacing:.07em; text-transform:uppercase;
  padding:3px 9px; border-radius:4px; z-index:2;
}
.product-card-img-wrap {
  display:flex; height:170px; overflow:hidden;
  background:linear-gradient(140deg,#f0f3fa 0%,#e4ebf7 100%);
  align-items:center; justify-content:center;
}
.product-card-img-wrap img { width:100%; height:100%; object-fit:contain; transition:transform .3s; padding:8px; }
.product-card:hover .product-card-img-wrap img { transform:scale(1.05); }
.pc-img-placeholder { display:flex; align-items:center; justify-content:center; width:100%; height:100%; color:var(--silver); }

.product-card-body { padding:14px; }
.product-card-brand { font-size:10px; font-weight:700; color:var(--silver); text-transform:uppercase; letter-spacing:.08em; margin-bottom:5px; }
.product-card-name { display:block; font-weight:700; font-size:15px; line-height:1.25; color:var(--ink); margin-bottom:12px; transition:color var(--trans); }
.product-card-name:hover { color:var(--blue); }
.product-card-foot { display:flex; align-items:center; justify-content:space-between; gap:8px; }

/* WooCommerce price inside card */
.product-card-price { flex:1; }
.product-card-price .woocommerce-Price-amount { font-size:18px; font-weight:800; color:var(--ink); letter-spacing:-.02em; }
.product-card-price del { display:block; }
.product-card-price del .woocommerce-Price-amount { font-size:12px; color:var(--mid); font-weight:400; }
.product-card-price ins { text-decoration:none; display:block; }

.add-to-cart-btn {
  width:34px; height:34px; border-radius:7px; background:var(--blue); color:#fff;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  transition:all var(--trans); cursor:pointer;
}
.add-to-cart-btn:hover { background:#152f75; transform:scale(1.08); }
.add-to-cart-btn.added { background:#22863a; animation:btn-pop .3s ease; }
.add-to-cart-btn.loading { opacity:.6; pointer-events:none; }
.btn-out-of-stock { background:var(--lighter); color:var(--mid); }
.btn-out-of-stock:hover { background:var(--light); transform:none; }

/* ================================================================
   CATEGORIES GRID — fixed, styled properly
================================================================ */
.categories-section { padding:0 0 48px; }
.cat-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.cat-card {
  display:flex; flex-direction:column;
  background:var(--white); border:1px solid var(--lighter); border-radius:var(--radius);
  padding:22px 16px; cursor:pointer; transition:all var(--trans);
  position:relative; overflow:hidden; text-decoration:none; color:inherit;
}
.cat-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:3px;
  background:var(--blue); transform:scaleX(0); transition:transform var(--trans); transform-origin:left;
}
.cat-card:hover { border-color:var(--blue-m); background:var(--blue-l); }
.cat-card:hover::after { transform:scaleX(1); }
.cat-card-icon { font-size:28px; margin-bottom:10px; display:block; }
.cat-card-img { width:48px; height:48px; margin-bottom:10px; border-radius:8px; overflow:hidden; }
.cat-card-img img { width:100%; height:100%; object-fit:cover; }
.cat-card-name { font-weight:700; font-size:14px; color:var(--ink); margin-bottom:3px; }
.cat-card-count { font-size:12px; color:var(--mid); }

/* ================================================================
   PROMO BANNER
================================================================ */
.promo-section { padding:0 0 48px; }
.promo-banner {
  background:var(--ink2); border-radius:14px; overflow:hidden;
  display:grid; grid-template-columns:1fr auto; gap:0; position:relative;
}
.promo-banner::before {
  content:''; position:absolute; top:-80px; left:28%; width:400px; height:400px;
  background:radial-gradient(circle,rgba(26,58,143,.35) 0%,transparent 65%); pointer-events:none;
}
.promo-left { padding:40px 44px; position:relative; z-index:1; }
.promo-right { padding:40px 40px 40px 20px; display:flex; flex-direction:column; gap:16px; align-items:flex-start; position:relative; z-index:1; min-width:240px; }
.promo-eyebrow { font-size:11px; font-weight:700; color:var(--silver); letter-spacing:.12em; text-transform:uppercase; margin-bottom:12px; display:flex; align-items:center; gap:10px; }
.promo-eyebrow::before { content:''; display:inline-block; width:24px; height:1px; background:var(--silver); flex-shrink:0; }
.promo-title { font-family:'Outfit',sans-serif; font-weight:900; font-size:clamp(34px,3.5vw,52px); line-height:.92; letter-spacing:-.04em; color:#fff; margin-bottom:14px; }
.promo-title em { font-family:'Fraunces',serif; font-style:italic; font-weight:300; color:#7a9add; }
.promo-desc { font-size:14px; color:#5a6e90; line-height:1.65; max-width:400px; }
.countdown { display:flex; gap:10px; }
.cd-item { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:8px; padding:12px 18px; min-width:64px; text-align:center; }
.cd-num { display:block; font-weight:800; font-size:28px; color:#fff; line-height:1; letter-spacing:-.02em; }
.cd-label { font-size:9px; color:#4a5e7a; text-transform:uppercase; letter-spacing:.1em; }

/* ================================================================
   REVIEWS — properly styled
================================================================ */
.reviews-section { padding:0 0 48px; }
.reviews-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; }
.rc {
  background:var(--white); border:1px solid var(--lighter);
  border-radius:var(--radius); padding:22px; transition:box-shadow var(--trans);
}
.rc:hover { box-shadow:var(--shadow); }
.rc-top { display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.ravatar {
  width:44px; height:44px; border-radius:50%; flex-shrink:0;
  background:linear-gradient(135deg,var(--blue) 0%,#3a63c8 100%);
  display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:17px; color:#fff;
}
.ravatar-img { width:44px; height:44px; border-radius:50%; object-fit:cover; flex-shrink:0; }
.rname { font-weight:700; font-size:15px; color:var(--ink); }
.rstars { color:#d4920a; font-size:14px; letter-spacing:2px; margin-top:3px; }
.rtext { font-size:14px; color:var(--mid); line-height:1.65; font-style:italic; }

/* ================================================================
   TRUST BAND
================================================================ */
.trust-band { background:var(--white); border-top:1px solid var(--lighter); border-bottom:1px solid var(--lighter); }
.trust-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; padding:30px 0; }
.trust-item { display:flex; align-items:flex-start; gap:14px; }
.trust-icon { width:44px; height:44px; flex-shrink:0; background:var(--blue-l); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:20px; }
.trust-name { font-weight:700; font-size:14px; color:var(--ink); margin-bottom:3px; }
.trust-desc { font-size:12px; color:var(--mid); line-height:1.45; }

/* ================================================================
   CUSTOM BANNER
================================================================ */
.custom-banner { padding:0 0 48px; }
.custom-banner-inner { border-radius:14px; overflow:hidden; min-height:320px; position:relative; display:flex; align-items:center; background:#111; }
.custom-banner-overlay { position:absolute; inset:0; background:linear-gradient(90deg,rgba(0,0,0,.65) 0%,rgba(0,0,0,.2) 100%); }
.custom-banner-content { position:relative; z-index:1; padding:48px; }
.custom-banner-title { font-family:'Outfit',sans-serif; font-weight:900; font-size:clamp(28px,4vw,48px); letter-spacing:-.03em; color:#fff; margin-bottom:10px; }
.custom-banner-sub { font-size:16px; color:rgba(255,255,255,.7); margin-bottom:24px; }

/* ================================================================
   NEWSLETTER
================================================================ */
.newsletter-section { background:linear-gradient(135deg,var(--blue) 0%,#0f2560 100%); padding:56px 24px; text-align:center; position:relative; overflow:hidden; }
.newsletter-section::before { content:''; position:absolute; inset:0; background-image:repeating-linear-gradient(-45deg,transparent,transparent 28px,rgba(255,255,255,.015) 28px,rgba(255,255,255,.015) 29px); }
.newsletter-inner { max-width:540px; margin:0 auto; position:relative; z-index:1; }
.nl-title { font-family:'Outfit',sans-serif; font-weight:900; font-size:30px; letter-spacing:-.03em; color:#fff; margin-bottom:8px; }
.nl-desc { font-size:15px; color:rgba(255,255,255,.5); margin-bottom:24px; font-weight:300; }
.nl-form { display:flex; gap:10px; max-width:420px; margin:0 auto; }
.nl-input { flex:1; background:rgba(255,255,255,.1); border:1.5px solid rgba(255,255,255,.18); border-radius:8px; padding:13px 16px; font-family:'Outfit',sans-serif; font-size:14px; color:#fff; outline:none; transition:border-color var(--trans); }
.nl-input::placeholder { color:rgba(255,255,255,.35); }
.nl-input:focus { border-color:rgba(255,255,255,.45); }
.nl-btn { background:#fff; color:var(--blue); border:none; border-radius:8px; padding:13px 22px; font-size:13px; font-weight:700; font-family:'Outfit',sans-serif; cursor:pointer; white-space:nowrap; transition:all var(--trans); }
.nl-btn:hover { background:var(--blue-l); }

/* ================================================================
   FOOTER — all text visible on dark bg
================================================================ */
.site-footer { background:var(--ink2); padding:52px 0 0; }
.footer-top {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px; padding-bottom:40px; margin-bottom:0;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-logo-text { font-family:'Outfit',sans-serif; font-weight:900; font-size:22px; letter-spacing:-.04em; color:#fff; margin-bottom:10px; }
.footer-logo-text sup { font-size:10px; color:var(--silver); vertical-align:super; margin-left:2px; }
.footer-tagline { font-size:13px; color:#7a8fa8; line-height:1.65; margin-bottom:18px; }
.social-row { display:flex; gap:8px; }
.social-btn {
  width:36px; height:36px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
  border-radius:8px; display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.5); transition:all var(--trans); cursor:pointer;
}
.social-btn:hover { background:rgba(26,58,143,.5); border-color:rgba(26,58,143,.6); color:#fff; }

/* Footer column headings */
.footer-col-title { font-size:11px; font-weight:700; color:#6a7e98; text-transform:uppercase; letter-spacing:.1em; margin-bottom:14px; }
.footer-widget-title { font-size:11px; font-weight:700; color:#6a7e98; text-transform:uppercase; letter-spacing:.1em; margin-bottom:14px; }

/* Footer links — clearly visible */
.footer-col ul li a,
.footer-widget a,
.site-footer a {
  display:block; font-size:14px; color:#8aa0bc; padding:5px 0;
  transition:color var(--trans); text-decoration:none;
}
.footer-col ul li a:hover,
.footer-widget a:hover,
.site-footer a:hover { color:#c5d5f0; }

/* Footer bottom */
.footer-bottom { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; padding:20px 0; }
.footer-copy { font-size:12px; color:#3a4e66; }
.footer-payment { display:flex; gap:7px; flex-wrap:wrap; }
.pay-badge { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:4px; padding:5px 10px; font-size:10px; font-weight:700; color:#5a7090; letter-spacing:.04em; }

/* ================================================================
   SHOP LAYOUT (archive)
================================================================ */
.shop-page-wrap { padding:32px 0 48px; }
.shop-layout { display:grid; grid-template-columns:260px 1fr; gap:32px; align-items:start; }
.shop-sidebar { position:sticky; top:100px; }
.sidebar-widget { margin-bottom:24px; }
.widget-title { font-weight:700; font-size:14px; text-transform:uppercase; letter-spacing:.06em; color:var(--ink); padding-bottom:10px; margin-bottom:14px; border-bottom:2px solid var(--lighter); }
.shop-top-bar { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:24px; flex-wrap:wrap; }
.shop-archive-title { font-family:'Outfit',sans-serif; font-weight:800; font-size:28px; letter-spacing:-.03em; color:var(--ink); }
.shop-archive-desc { font-size:14px; color:var(--mid); margin-top:6px; }
.shop-controls { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.filter-toggle-btn { display:none; align-items:center; gap:7px; background:var(--white); border:1.5px solid var(--lighter); border-radius:7px; padding:8px 14px; font-size:13px; font-weight:600; color:var(--ink); transition:all var(--trans); cursor:pointer; }
.filter-toggle-btn:hover { border-color:var(--blue-m); background:var(--blue-l); color:var(--blue); }
.woocommerce-ordering select { background:var(--white); border:1.5px solid var(--lighter); border-radius:7px; padding:8px 12px; font-family:'Outfit',sans-serif; font-size:13px; color:var(--ink); outline:none; transition:border-color var(--trans); cursor:pointer; }
.woocommerce-result-count { font-size:13px; color:var(--mid); }
ul.products { display:grid !important; grid-template-columns:repeat(3,1fr) !important; gap:16px !important; list-style:none !important; margin:0 !important; }
ul.products li.product { width:auto !important; float:none !important; margin:0 !important; }
.woocommerce-pagination { margin-top:32px; }
.woocommerce-pagination ul { display:flex; gap:6px; justify-content:center; list-style:none; }
.woocommerce-pagination ul li { display:flex; }
.woocommerce-pagination ul li a, .woocommerce-pagination ul li span { display:flex; align-items:center; justify-content:center; width:38px; height:38px; border-radius:8px; font-size:13px; font-weight:600; color:var(--mid); border:1.5px solid var(--lighter); background:var(--white); transition:all var(--trans); }
.woocommerce-pagination ul li a:hover { border-color:var(--blue-m); color:var(--blue); background:var(--blue-l); }
.woocommerce-pagination ul li span.current { background:var(--blue); color:#fff; border-color:var(--blue); }
.woocommerce-breadcrumb { font-size:13px; color:var(--mid); margin-bottom:20px; }
.woocommerce-breadcrumb a { color:var(--mid); transition:color var(--trans); }
.woocommerce-breadcrumb a:hover { color:var(--blue); }

/* ================================================================
   SINGLE PRODUCT
================================================================ */
.single-product-wrap { padding:32px 0 56px; }
div.product { display:grid; grid-template-columns:1fr 1fr; gap:48px; }
div.product .woocommerce-product-gallery { grid-column:1; }
div.product .summary { grid-column:2; }
.product_title { font-family:'Outfit',sans-serif; font-weight:800; font-size:clamp(24px,3vw,36px); letter-spacing:-.03em; color:var(--ink); margin-bottom:12px; }
.woocommerce-product-rating { margin-bottom:16px; }
.price { font-size:28px; font-weight:800; color:var(--ink); letter-spacing:-.02em; margin-bottom:20px; }
.price del { font-size:18px; color:var(--mid); font-weight:400; margin-right:8px; }
.price ins { text-decoration:none; color:var(--ink); }
.woocommerce-product-details__short-description { font-size:15px; color:var(--mid); line-height:1.7; margin-bottom:24px; }
.quantity input { height:44px; width:64px; border:1.5px solid var(--lighter); border-radius:7px; text-align:center; font-family:'Outfit',sans-serif; font-size:16px; font-weight:600; outline:none; }
button.single_add_to_cart_button { height:44px; padding:0 28px; background:var(--blue); color:#fff; border:none; border-radius:8px; font-family:'Outfit',sans-serif; font-size:14px; font-weight:700; transition:all var(--trans); box-shadow:0 4px 18px rgba(26,58,143,.25); cursor:pointer; }
button.single_add_to_cart_button:hover { background:#152f75; transform:translateY(-1px); }
.woocommerce-tabs ul.tabs { display:flex; gap:0; border-bottom:2px solid var(--lighter); margin-bottom:24px; }
.woocommerce-tabs ul.tabs li { list-style:none; border:none !important; background:none !important; }
.woocommerce-tabs ul.tabs li a { display:block; padding:10px 20px; font-size:14px; font-weight:600; color:var(--mid); border-bottom:2px solid transparent; margin-bottom:-2px; transition:all var(--trans); }
.woocommerce-tabs ul.tabs li.active a { color:var(--blue); border-bottom-color:var(--blue); }
.related h2, .upsells h2 { font-family:'Outfit',sans-serif; font-weight:800; font-size:22px; letter-spacing:-.03em; margin-bottom:20px; }
.related ul.products { grid-template-columns:repeat(4,1fr) !important; }

/* Cart & Checkout */
button[name="update_cart"], .checkout-button, #place_order { background:var(--blue); color:#fff; border:none; border-radius:8px; padding:13px 26px; font-size:14px; font-weight:700; font-family:'Outfit',sans-serif; transition:all var(--trans); box-shadow:0 4px 18px rgba(26,58,143,.22); cursor:pointer; }
button[name="update_cart"]:hover, .checkout-button:hover, #place_order:hover { background:#152f75; transform:translateY(-1px); }
.woocommerce-checkout input[type="text"], .woocommerce-checkout input[type="email"], .woocommerce-checkout input[type="tel"], .woocommerce-checkout select, .woocommerce-checkout textarea { width:100%; border:1.5px solid var(--lighter); border-radius:7px; padding:10px 14px; font-family:'Outfit',sans-serif; font-size:14px; color:var(--ink); outline:none; margin-top:5px; transition:border-color var(--trans); }
.woocommerce-checkout input:focus, .woocommerce-checkout select:focus, .woocommerce-checkout textarea:focus { border-color:var(--blue-m); }

/* Woo messages */
.woocommerce-message, .woocommerce-info, .woocommerce-error { background:var(--white); border-top:3px solid var(--blue); border-radius:0 0 var(--radius) var(--radius); padding:14px 20px; margin-bottom:20px; font-size:14px; list-style:none; }
.woocommerce-error { border-top-color:var(--accent); }
.star-rating { color:#d4920a; }

/* ================================================================
   MOBILE BOTTOM NAV — FIX: stacked icons issue
================================================================ */
.mobile-bottom-nav { display:none; } /* hidden desktop */
.mobile-pad { display:none; }

/* ================================================================
   TABLET breakpoint
================================================================ */
@media (max-width:960px) {
  .hero-grid { grid-template-columns:1fr; gap:32px; padding:48px 0 40px; }
  .hero-right { display:none; }
  .hero-title { font-size:clamp(44px,9vw,64px); }
  .cat-grid { grid-template-columns:repeat(3,1fr); }
  .promo-banner { grid-template-columns:1fr; }
  .promo-right { padding:0 44px 40px; min-width:0; }
  .trust-grid { grid-template-columns:1fr 1fr; gap:20px; }
  .footer-top { grid-template-columns:1fr 1fr; gap:28px; }
  .shop-layout { grid-template-columns:220px 1fr; gap:24px; }
  ul.products { grid-template-columns:repeat(2,1fr) !important; }
  div.product { grid-template-columns:1fr; }
  div.product .summary { grid-column:1; }
  .desktop-nav { display:none; }
  .search-form { width:160px; }
  .mega-menu { display:none !important; }
}

/* ================================================================
   MOBILE breakpoint
================================================================ */
@media (max-width:640px) {
  .desktop-nav, .search-form { display:none; }
  .hamburger { display:flex; }

  /* ── Mobile bottom nav FIX: proper row layout ── */
  .mobile-bottom-nav {
    display:block;
    position:fixed; bottom:0; left:0; right:0;
    background:rgba(255,255,255,.97);
    backdrop-filter:blur(16px);
    border-top:1px solid var(--lighter);
    z-index:199;
    padding:0;
  }
  .mbn-inner {
    display:flex;
    flex-direction:row !important;
    align-items:center;
    justify-content:space-around;
    padding:10px 0 max(14px, env(safe-area-inset-bottom));
    width:100%;
  }
  .mbn-item {
    flex:1;
    display:flex;
    flex-direction:column !important;
    align-items:center;
    justify-content:center;
    gap:3px;
    text-decoration:none;
    color:#bbb;
    min-width:0;
    padding:0 4px;
    position:relative;
  }
  .mbn-item svg {
    width:22px; height:22px;
    stroke:#bbb; fill:none; stroke-width:1.7;
    transition:stroke var(--trans);
    flex-shrink:0;
    display:block;
  }
  .mbn-item span {
    font-size:10px; font-weight:500;
    text-transform:uppercase; letter-spacing:.05em;
    color:#bbb; display:block;
    white-space:nowrap;
    line-height:1;
  }
  .mbn-item.on svg { stroke:var(--blue); }
  .mbn-item.on span { color:var(--blue); }

  .mobile-pad { display:block; height:72px; }

  /* Layout fixes */
  .header-inner { padding:13px 16px; }
  .container { padding:0 16px; }
  .hero-grid { padding:28px 0 24px; }
  .hero-title { font-size:clamp(42px,12vw,56px); }
  .hero-stats-row { flex-wrap:wrap; }
  .stat-item { min-width:50%; border-right:none !important; border-bottom:1px solid rgba(255,255,255,.06); }
  .cat-grid { grid-template-columns:1fr 1fr; gap:10px; }
  .promo-left { padding:24px 20px; }
  .promo-right { padding:0 20px 28px; }
  .promo-title { font-size:34px; }
  .trust-grid { grid-template-columns:1fr 1fr; gap:16px; padding:24px 0; }
  .nl-form { flex-direction:column; }
  .footer-top { grid-template-columns:1fr; gap:20px; }
  .footer-bottom { flex-direction:column; align-items:flex-start; padding-bottom:20px; }
  .shop-layout { grid-template-columns:1fr; }
  .shop-sidebar { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:var(--white); z-index:250; overflow-y:auto; padding:20px; transform:translateX(-100%); transition:transform .35s; }
  .shop-sidebar.open { display:block; transform:translateX(0); }
  .filter-toggle-btn { display:flex; }
  ul.products { grid-template-columns:1fr 1fr !important; }
  .section-head { flex-wrap:wrap; gap:8px; }
  .toast { bottom:80px; }
  .reviews-grid { grid-template-columns:1fr; }
}

/* ================================================================
   SINGLE PRODUCT PAGE
================================================================ */
.single-product-page { padding:32px 0 56px; }
.single-product-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:52px; align-items:start; margin-bottom:48px;
}
/* Gallery */
.single-gallery-col { position:sticky; top:100px; }
.single-main-img { width:100%; border-radius:12px; background:#f0f3fa; object-fit:contain; max-height:480px; }
.single-no-img { width:100%; aspect-ratio:1; background:#f0f3fa; border-radius:12px; display:flex; align-items:center; justify-content:center; color:#aaa; }
.single-thumbs { display:flex; gap:8px; margin-top:12px; flex-wrap:wrap; }
.single-thumb { width:72px; height:72px; border-radius:8px; overflow:hidden; border:2px solid var(--lighter); cursor:pointer; transition:border-color .2s; }
.single-thumb img { width:100%; height:100%; object-fit:cover; }
.single-thumb.active, .single-thumb:hover { border-color:var(--blue); }

/* Summary */
.single-cat-badge { display:inline-block; background:var(--blue-l); color:var(--blue); border:1px solid var(--blue-m); border-radius:4px; padding:3px 10px; font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; margin-bottom:14px; }
.single-title { font-family:'Outfit',sans-serif; font-weight:900; font-size:clamp(24px,3vw,36px); letter-spacing:-.03em; color:var(--ink); margin-bottom:14px; line-height:1.1; }
.single-rating-row { display:flex; align-items:center; gap:8px; margin-bottom:16px; }
.single-stars { color:#d4920a; font-size:18px; letter-spacing:2px; }
.single-rating-num { font-weight:700; font-size:15px; color:var(--ink); }
.single-rating-count { font-size:13px; color:var(--mid); }
.single-price { margin-bottom:18px; }
.single-price .woocommerce-Price-amount { font-size:32px; font-weight:900; color:var(--ink); letter-spacing:-.03em; }
.single-price del .woocommerce-Price-amount { font-size:20px; color:var(--mid); font-weight:400; }
.single-price ins { text-decoration:none; }
.single-short-desc { font-size:15px; color:var(--mid); line-height:1.7; margin-bottom:24px; }

/* Attribute chips */
.single-attrs { margin-bottom:24px; }
.single-attr-group { margin-bottom:16px; }
.single-attr-label { font-size:12px; font-weight:700; color:var(--mid); text-transform:uppercase; letter-spacing:.06em; margin-bottom:8px; }
.single-attr-chips { display:flex; flex-wrap:wrap; gap:8px; }
.attr-chip {
  padding:7px 14px; border:1.5px solid var(--lighter); border-radius:7px;
  font-size:13px; font-weight:500; color:var(--ink);
  cursor:pointer; transition:all .18s; background:var(--white);
}
.attr-chip:hover { border-color:var(--blue-m); color:var(--blue); background:var(--blue-l); }
.attr-chip.active { border-color:var(--blue); background:var(--blue); color:#fff; }

/* Add to cart */
.woocommerce div.product form.cart { display:flex; gap:12px; align-items:center; margin-bottom:24px; flex-wrap:wrap; }
.woocommerce div.product form.cart .quantity input { height:48px; width:72px; border:1.5px solid var(--lighter); border-radius:8px; text-align:center; font-size:16px; font-weight:700; font-family:'Outfit',sans-serif; outline:none; }
.woocommerce div.product form.cart button[type="submit"] { height:48px; padding:0 32px; background:var(--blue); color:#fff; border:none; border-radius:8px; font-family:'Outfit',sans-serif; font-size:15px; font-weight:700; cursor:pointer; transition:all .2s; box-shadow:0 4px 18px rgba(26,58,143,.25); }
.woocommerce div.product form.cart button[type="submit"]:hover { background:#152f75; transform:translateY(-1px); }

/* Trust row */
.single-trust-row { display:flex; gap:16px; flex-wrap:wrap; padding:16px; background:var(--blue-l); border-radius:10px; margin-bottom:20px; }
.single-trust-item { display:flex; align-items:center; gap:7px; font-size:13px; font-weight:500; color:var(--blue); }

/* Meta */
.single-meta { font-size:13px; color:var(--mid); display:flex; gap:16px; flex-wrap:wrap; }
.single-meta-item a { color:var(--blue); }

/* Tabs */
.single-tabs-section { margin-bottom:48px; }
.woocommerce-tabs { }
.woocommerce-tabs .tabs { display:flex; border-bottom:2px solid var(--lighter); margin-bottom:24px; gap:0; padding:0; }
.woocommerce-tabs .tabs li { list-style:none; border:none !important; background:none !important; padding:0 !important; margin:0 !important; border-radius:0 !important; }
.woocommerce-tabs .tabs li::before { display:none; }
.woocommerce-tabs .tabs li a { display:block; padding:11px 20px; font-size:14px; font-weight:600; color:var(--mid); border-bottom:2.5px solid transparent; margin-bottom:-2px; transition:all .2s; }
.woocommerce-tabs .tabs li.active a { color:var(--blue); border-bottom-color:var(--blue); }
.woocommerce-tabs .panel { padding:0; }
.woocommerce-tabs .panel h2 { font-weight:800; font-size:20px; margin-bottom:16px; }

/* Related */
.single-related { margin-top:0; }
.single-related-title { font-family:'Outfit',sans-serif; font-weight:800; font-size:22px; letter-spacing:-.03em; margin-bottom:20px; }

/* Woo notices */
.woocommerce-message, .woocommerce-info, .woocommerce-error { background:var(--white); border-top:3px solid var(--blue); border-radius:0 0 8px 8px; padding:14px 20px; margin-bottom:20px; font-size:14px; list-style:none; display:flex; align-items:center; gap:12px; }
.woocommerce-error { border-top-color:var(--accent); }
.woocommerce-message .button, .woocommerce-info .button { background:var(--blue); color:#fff; border:none; border-radius:7px; padding:8px 16px; font-size:13px; font-weight:600; font-family:'Outfit',sans-serif; cursor:pointer; }

/* ================================================================
   GENERIC PAGE (Apie mus, Kontaktai, etc.)
================================================================ */
.generic-page { padding:40px 0 64px; }
.page-title { font-family:'Outfit',sans-serif; font-weight:900; font-size:clamp(32px,4vw,52px); letter-spacing:-.04em; color:var(--ink); margin-bottom:16px; line-height:1; }
.page-title em { font-family:'Fraunces',serif; font-style:italic; font-weight:300; color:var(--blue); }
.page-lead { font-size:18px; color:var(--mid); line-height:1.7; margin-bottom:32px; max-width:640px; }
.page-body { max-width:860px; }
.page-body h2 { font-family:'Outfit',sans-serif; font-weight:800; font-size:24px; letter-spacing:-.02em; margin:36px 0 14px; color:var(--ink); }
.page-body h3 { font-weight:700; font-size:18px; margin:24px 0 10px; color:var(--ink); }
.page-body p { font-size:15px; color:var(--mid); line-height:1.75; margin-bottom:14px; }
.page-body ul, .page-body ol { margin:0 0 16px 0; padding-left:0; list-style:none; }
.page-body ul li, .page-body ol li { font-size:15px; color:var(--mid); line-height:1.75; padding:4px 0; }
.page-body table { width:100%; border-collapse:collapse; margin-bottom:24px; }
.page-body table th { background:var(--ink2); color:#fff; padding:11px 16px; font-size:13px; font-weight:700; text-align:left; }
.page-body table td { padding:11px 16px; border-bottom:1px solid var(--lighter); font-size:14px; color:var(--mid); }
.page-body table tr:nth-child(even) td { background:var(--bg); }
.page-body a { color:var(--blue); text-decoration:underline; }
.page-body strong { color:var(--ink); font-weight:700; }

/* Contact form */
.prime-contact-form .form-group { margin-bottom:16px; }
.prime-contact-form label { display:block; font-weight:600; font-size:13px; color:var(--ink); margin-bottom:5px; }
.prime-contact-form input, .prime-contact-form textarea {
  width:100%; border:1.5px solid var(--lighter); border-radius:8px;
  padding:11px 14px; font-family:'Outfit',sans-serif; font-size:14px;
  color:var(--ink); outline:none; transition:border-color .2s;
  background:var(--white);
}
.prime-contact-form input:focus, .prime-contact-form textarea:focus { border-color:var(--blue-m); }
.prime-contact-form textarea { resize:vertical; }

/* About stats */
.about-stats-row .wp-block-column { background:var(--white); border:1px solid var(--lighter); border-radius:12px; padding:24px; text-align:center; }

@media (max-width:640px) {
  .single-product-grid { grid-template-columns:1fr; gap:28px; }
  .single-gallery-col { position:static; }
  .single-price .woocommerce-Price-amount { font-size:26px; }
  .woocommerce-tabs .tabs { overflow-x:auto; scrollbar-width:none; white-space:nowrap; }
}

/* ── MEGA MENU JS-controlled (replaces pure CSS hover) ── */
.desktop-nav-list > li.mega-open .mega-menu { display:grid !important; }
.mega-menu { pointer-events:all; }

/* ================================================================
   SHOP ARCHIVE – proper sidebar, filters, empty state
================================================================ */
.shop-page-wrap { padding:28px 0 56px; }
.shop-layout { display:grid; grid-template-columns:260px 1fr; gap:32px; align-items:start; }

/* Sidebar */
.shop-sidebar {
  background:var(--white); border:1px solid var(--lighter);
  border-radius:12px; overflow:hidden;
  position:sticky; top:90px;
}
.sidebar-close-row {
  display:none; align-items:center; justify-content:space-between;
  padding:16px 20px; border-bottom:1px solid var(--lighter);
  font-weight:700; font-size:15px;
}
.sidebar-close-btn { background:none; border:none; font-size:18px; cursor:pointer; color:var(--mid); }
.sidebar-widget { padding:20px; border-bottom:1px solid var(--lighter); }
.sidebar-widget:last-child { border-bottom:none; }
.widget-title { font-size:11px; font-weight:800; color:var(--ink); text-transform:uppercase; letter-spacing:.1em; margin-bottom:14px; }

/* Category list in sidebar */
.sidebar-cats { }
.sidebar-cat-link {
  display:flex; justify-content:space-between; align-items:center;
  padding:7px 0; font-size:14px; color:var(--mid);
  border-bottom:1px solid var(--bg); transition:color .18s;
  text-decoration:none;
}
.sidebar-cat-link:hover { color:var(--ink); }
.sidebar-cat-link.active { color:var(--blue); font-weight:700; }
.sidebar-cat-count { font-size:11px; background:var(--bg); border-radius:100px; padding:2px 7px; color:var(--mid); }
.sidebar-cat-link.active .sidebar-cat-count { background:var(--blue-l); color:var(--blue); }

/* Price slider */
.price-filter-wrap { }
.price-slider-track { position:relative; height:4px; background:var(--lighter); border-radius:2px; margin:12px 0 8px; }
.price-slider-fill { position:absolute; top:0; bottom:0; background:var(--blue); border-radius:2px; }
.price-range { position:absolute; top:50%; transform:translateY(-50%); width:100%; -webkit-appearance:none; appearance:none; background:transparent; pointer-events:none; }
.price-range::-webkit-slider-thumb { -webkit-appearance:none; width:18px; height:18px; border-radius:50%; background:var(--blue); border:2px solid #fff; box-shadow:0 1px 4px rgba(0,0,0,.2); cursor:pointer; pointer-events:all; }
.price-range::-moz-range-thumb { width:16px; height:16px; border-radius:50%; background:var(--blue); border:2px solid #fff; cursor:pointer; pointer-events:all; }
.price-range-labels { display:flex; justify-content:space-between; font-size:13px; font-weight:600; color:var(--ink); margin-bottom:12px; }
.price-filter-btn { width:100%; background:var(--blue); color:#fff; border:none; border-radius:7px; padding:9px; font-family:'Outfit',sans-serif; font-size:13px; font-weight:700; cursor:pointer; transition:background .2s; }
.price-filter-btn:hover { background:#152f75; }

/* Brand list in sidebar */
.sidebar-brand-list { max-height:220px; overflow-y:auto; }
.sidebar-brand-link {
  display:flex; align-items:center; gap:8px;
  padding:6px 0; font-size:13.5px; color:var(--mid);
  border-bottom:1px solid var(--bg); text-decoration:none; transition:color .18s;
}
.sidebar-brand-link:hover { color:var(--ink); }
.sidebar-brand-link.active { color:var(--blue); font-weight:600; }
.sidebar-brand-check { width:16px; height:16px; border:1.5px solid var(--light); border-radius:3px; display:inline-flex; align-items:center; justify-content:center; font-size:10px; flex-shrink:0; background:var(--white); }
.sidebar-brand-link.active .sidebar-brand-check { background:var(--blue); border-color:var(--blue); color:#fff; }

/* On-sale toggle */
.sidebar-toggle-link { display:flex; align-items:center; gap:10px; font-size:14px; color:var(--mid); text-decoration:none; transition:color .18s; }
.sidebar-toggle-link:hover { color:var(--ink); }
.sidebar-toggle-link.active { color:var(--blue); font-weight:600; }
.toggle-box { width:18px; height:18px; border:1.5px solid var(--light); border-radius:4px; display:inline-flex; align-items:center; justify-content:center; font-size:11px; flex-shrink:0; }
.sidebar-toggle-link.active .toggle-box { background:var(--blue); border-color:var(--blue); color:#fff; }

/* Active filters row */
.active-filters-row { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:16px; padding:10px 14px; background:var(--blue-l); border-radius:8px; }
.active-filters-label { font-size:12px; font-weight:700; color:var(--blue); }
.active-filter-tag { background:var(--blue); color:#fff; font-size:12px; font-weight:600; padding:3px 10px; border-radius:100px; }
.clear-filters { font-size:12px; color:var(--accent); font-weight:600; margin-left:auto; text-decoration:underline; }

/* WooCommerce sort/count overrides */
.woocommerce-ordering select { background:var(--white); border:1.5px solid var(--lighter); border-radius:7px; padding:8px 12px; font-family:'Outfit',sans-serif; font-size:13px; color:var(--ink); outline:none; cursor:pointer; }
.woocommerce-result-count { font-size:13px; color:var(--mid); margin:0; }

/* Product grid in archive (use our cards) */
.woocommerce ul.products.columns-4 { display:grid !important; grid-template-columns:repeat(3,1fr) !important; gap:16px !important; margin:0 !important; padding:0 !important; list-style:none !important; }
.woocommerce ul.products.columns-4 > li.product { width:auto !important; float:none !important; margin:0 !important; }

/* Empty state */
.shop-empty { text-align:center; padding:60px 20px; }
.shop-empty-icon { font-size:48px; margin-bottom:16px; }
.shop-empty h3 { font-family:'Outfit',sans-serif; font-weight:800; font-size:22px; margin-bottom:8px; }
.shop-empty p { color:var(--mid); margin-bottom:24px; }

/* Pagination */
.woocommerce-pagination { margin-top:32px; }
.woocommerce-pagination ul { display:flex; gap:6px; justify-content:center; list-style:none; padding:0; margin:0; }
.woocommerce-pagination ul li { display:flex; }
.woocommerce-pagination ul li a, .woocommerce-pagination ul li span { display:flex; align-items:center; justify-content:center; width:38px; height:38px; border-radius:8px; font-size:13px; font-weight:600; color:var(--mid); border:1.5px solid var(--lighter); background:var(--white); transition:all .2s; text-decoration:none; }
.woocommerce-pagination ul li a:hover { border-color:var(--blue-m); color:var(--blue); background:var(--blue-l); }
.woocommerce-pagination ul li span.current { background:var(--blue); color:#fff; border-color:var(--blue); }

/* Filter toggle button */
.filter-toggle-btn { display:none; align-items:center; gap:7px; background:var(--white); border:1.5px solid var(--lighter); border-radius:7px; padding:8px 14px; font-size:13px; font-weight:600; color:var(--ink); transition:all .2s; cursor:pointer; font-family:'Outfit',sans-serif; }
.filter-toggle-btn:hover { border-color:var(--blue-m); background:var(--blue-l); color:var(--blue); }

/* Mobile sidebar */
@media (max-width:900px) {
  .shop-layout { grid-template-columns:1fr; }
  .shop-sidebar {
    display:none; position:fixed; top:0; left:0; bottom:0; right:0;
    z-index:150; overflow-y:auto; border-radius:0;
    transform:translateX(-100%); transition:transform .3s;
    max-width:320px;
  }
  .shop-sidebar.open { display:block; transform:translateX(0); }
  .sidebar-close-row { display:flex; }
  .filter-toggle-btn { display:flex; }
  .woocommerce ul.products.columns-4 { grid-template-columns:repeat(2,1fr) !important; }
}
@media (max-width:480px) {
  .woocommerce ul.products.columns-4 { grid-template-columns:1fr 1fr !important; }
}

/* ================================================================
   SINGLE PRODUCT – image transition
================================================================ */
.single-main-img { transition:opacity .15s ease; }

/* ================================================================
   SHOP ARCHIVE v2 — stable layout
================================================================ */
.shop-page-wrap { padding:28px 0 60px; }
.shop-layout { display:grid; grid-template-columns:250px 1fr; gap:28px; align-items:start; }

/* Sidebar */
.shop-sidebar {
  background:var(--white); border:1px solid var(--lighter);
  border-radius:12px; overflow:hidden;
  position:sticky; top:88px;
}
.sidebar-mobile-header { display:none; align-items:center; justify-content:space-between; padding:16px 20px; border-bottom:1px solid var(--lighter); font-weight:700; }
.sidebar-close-btn { background:none; border:none; font-size:18px; cursor:pointer; color:var(--mid); padding:4px; }
.sidebar-block { padding:18px 20px; border-bottom:1px solid var(--lighter); }
.sidebar-block:last-child { border-bottom:none; }
.sidebar-block-title { font-size:11px; font-weight:800; color:var(--ink); text-transform:uppercase; letter-spacing:.1em; margin-bottom:12px; }
.sidebar-cat-list { margin:0; padding:0; }
.sidebar-cat-item { display:flex; justify-content:space-between; align-items:center; padding:6px 0; font-size:13.5px; color:var(--mid); text-decoration:none; border-bottom:1px solid var(--bg); transition:color .15s; }
.sidebar-cat-item:hover { color:var(--ink); }
.sidebar-cat-item.is-active { color:var(--blue); font-weight:700; }
.scat-count { font-size:11px; background:var(--bg); border-radius:20px; padding:1px 7px; }
.sidebar-cat-item.is-active .scat-count { background:var(--blue-l); color:var(--blue); }

/* Price slider */
.price-range-wrap { }
.price-track { position:relative; height:4px; background:var(--lighter); border-radius:2px; margin:14px 0 8px; }
.price-fill { position:absolute; inset:0; background:var(--blue); border-radius:2px; }
.price-track input[type=range] { position:absolute; top:50%; transform:translateY(-50%); width:100%; -webkit-appearance:none; appearance:none; background:transparent; pointer-events:none; margin:0; }
.price-track input[type=range]::-webkit-slider-thumb { -webkit-appearance:none; width:18px; height:18px; background:var(--blue); border:2px solid #fff; border-radius:50%; box-shadow:0 1px 4px rgba(0,0,0,.2); pointer-events:all; cursor:pointer; }
.price-track input[type=range]::-moz-range-thumb { width:16px; height:16px; background:var(--blue); border:2px solid #fff; border-radius:50%; pointer-events:all; cursor:pointer; border:none; }
.price-labels { display:flex; justify-content:space-between; font-size:13px; font-weight:600; color:var(--ink); margin-bottom:10px; }
.price-apply-btn { width:100%; background:var(--blue); color:#fff; border:none; border-radius:7px; padding:9px; font-family:'Outfit',sans-serif; font-size:13px; font-weight:700; cursor:pointer; }
.price-apply-btn:hover { background:#152f75; }

/* Brand list */
.sidebar-brand-list { max-height:200px; overflow-y:auto; scrollbar-width:thin; }
.sidebar-brand-item { display:flex; align-items:center; gap:8px; padding:5px 0; font-size:13px; color:var(--mid); text-decoration:none; border-bottom:1px solid var(--bg); transition:color .15s; }
.sidebar-brand-item:hover { color:var(--ink); }
.sidebar-brand-item.is-active { color:var(--blue); font-weight:600; }
.brand-check { width:16px; height:16px; border:1.5px solid var(--light); border-radius:3px; display:inline-flex; align-items:center; justify-content:center; font-size:10px; flex-shrink:0; }
.sidebar-brand-item.is-active .brand-check { background:var(--blue); border-color:var(--blue); color:#fff; }

/* On-sale toggle */
.sidebar-toggle { display:flex; align-items:center; gap:10px; font-size:13.5px; color:var(--mid); text-decoration:none; }
.sidebar-toggle:hover { color:var(--ink); }
.sidebar-toggle.is-active { color:var(--blue); font-weight:600; }
.toggle-chk { width:18px; height:18px; border:1.5px solid var(--light); border-radius:4px; display:inline-flex; align-items:center; justify-content:center; font-size:11px; flex-shrink:0; }
.sidebar-toggle.is-active .toggle-chk { background:var(--blue); border-color:var(--blue); color:#fff; }

/* Top bar */
.shop-topbar { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:20px; flex-wrap:wrap; }
.shop-h1 { font-family:'Outfit',sans-serif; font-weight:800; font-size:26px; letter-spacing:-.03em; }
.shop-desc { font-size:14px; color:var(--mid); margin-top:4px; }
.shop-topbar-right { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.shop-count { font-size:13px; color:var(--mid); white-space:nowrap; }
.shop-sort { background:var(--white); border:1.5px solid var(--lighter); border-radius:7px; padding:8px 12px; font-family:'Outfit',sans-serif; font-size:13px; color:var(--ink); outline:none; cursor:pointer; }
.filter-toggle-btn { display:none; align-items:center; gap:6px; background:var(--white); border:1.5px solid var(--lighter); border-radius:7px; padding:8px 12px; font-size:13px; font-weight:600; cursor:pointer; color:var(--ink); font-family:'Outfit',sans-serif; }
.filter-toggle-btn:hover { border-color:var(--blue-m); background:var(--blue-l); color:var(--blue); }

/* Active filters */
.active-filters { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:16px; padding:10px 14px; background:var(--blue-l); border-radius:8px; }
.af-label { font-size:12px; font-weight:700; color:var(--blue); }
.af-tag { background:var(--blue); color:#fff; font-size:12px; padding:3px 10px; border-radius:100px; text-decoration:none; }
.af-clear { font-size:12px; color:var(--accent); font-weight:600; margin-left:auto; text-decoration:underline; }

/* Products grid */
.shop-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.shop-grid .product-card { width:auto; }

/* Pagination */
.shop-pagination { margin-top:32px; }
.shop-pagination ul { display:flex; gap:6px; justify-content:center; padding:0; list-style:none; }
.shop-pagination ul li a, .shop-pagination ul li span { display:flex; align-items:center; justify-content:center; min-width:38px; height:38px; padding:0 10px; border-radius:8px; font-size:13px; font-weight:600; color:var(--mid); border:1.5px solid var(--lighter); background:var(--white); text-decoration:none; transition:all .18s; }
.shop-pagination ul li a:hover { border-color:var(--blue-m); color:var(--blue); background:var(--blue-l); }
.shop-pagination ul li span.current { background:var(--blue); color:#fff; border-color:var(--blue); }

/* Empty state */
.shop-empty { text-align:center; padding:60px 20px; }

/* Mobile */
@media (max-width:900px) {
  .shop-layout { grid-template-columns:1fr; }
  .shop-sidebar { display:none; position:fixed; top:0; left:0; bottom:0; width:300px; z-index:150; overflow-y:auto; border-radius:0; transform:translateX(-100%); transition:transform .3s cubic-bezier(.4,0,.2,1); }
  .shop-sidebar.open { display:block; transform:translateX(0); }
  .sidebar-mobile-header { display:flex; }
  .filter-toggle-btn { display:flex; }
  .shop-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:480px) {
  .shop-grid { grid-template-columns:1fr 1fr; gap:10px; }
}

/* ── Stacked SVG logo ── */
.site-logo-svg { display:inline-flex; align-items:flex-start; }
.site-logo-svg svg { height:52px; width:auto; display:block; }
.site-logo { text-decoration:none; }
/* Footer: use white logo */
.site-footer .site-logo-svg svg { filter:none; }

/* ================================================================
   MOBILE BOTTOM NAV — v2, 3 items only, proper styling
================================================================ */

/* Hidden on desktop */
.mobile-bottom-nav { display:none; }
.mobile-pad-extra { display:none; }

@media (max-width:640px) {

  /* ── Bottom nav bar ── */
  .mobile-bottom-nav {
    display:flex !important;
    position:fixed;
    bottom:0; left:0; right:0;
    height:64px;
    background:#ffffff;
    border-top:1px solid #e8e5df;
    box-shadow:0 -2px 12px rgba(0,0,0,.06);
    z-index:199;
    align-items:stretch;
  }

  .mbn-item {
    flex:1;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:4px;
    text-decoration:none;
    color:#aaa;
    padding:0;
    border:none;
    background:none;
    transition:color .18s;
  }
  .mbn-item svg {
    width:22px; height:22px;
    stroke:#aaa;
    display:block;
    flex-shrink:0;
    transition:stroke .18s;
  }
  .mbn-item span {
    font-size:10px;
    font-weight:600;
    font-family:'Outfit',sans-serif;
    text-transform:uppercase;
    letter-spacing:.05em;
    line-height:1;
    color:#aaa;
    transition:color .18s;
  }
  .mbn-item.mbn-active svg { stroke:var(--blue); }
  .mbn-item.mbn-active span { color:var(--blue); }

  /* Cart icon wrapper + badge */
  .mbn-cart-wrap {
    position:relative;
    display:flex; align-items:center; justify-content:center;
    width:22px; height:22px;
  }
  .mbn-badge {
    position:absolute;
    top:-6px; right:-8px;
    background:var(--blue); color:#fff;
    width:16px; height:16px; border-radius:50%;
    font-size:9px; font-weight:700;
    display:flex; align-items:center; justify-content:center;
    font-family:'Outfit',sans-serif;
    border:2px solid #fff;
  }

  /* Spacer so content doesn't hide behind nav */
  .mobile-pad { display:block !important; height:64px; }

  /* ── Fix product carousel overflow on mobile ── */
  /* Constrain the scroll track so it doesn't stretch the page */
  .products-scroll-track {
    overflow-x:auto !important;
    overflow-y:hidden !important;
    /* Critical: this makes it scroll inside without stretching body */
    max-width:100vw;
    margin-left:-16px;
    margin-right:-16px;
    padding-left:16px;
    padding-right:16px;
    -webkit-overflow-scrolling:touch;
  }
  .products-flex {
    display:flex !important;
    flex-direction:row !important;
    flex-wrap:nowrap !important;
    gap:12px !important;
    width:max-content !important;
    padding-right:16px; /* trailing space */
  }
  /* Make product cards smaller on mobile */
  .products-flex .product-card {
    width:170px !important;
    flex-shrink:0 !important;
  }
  .products-flex .product-card .product-card-img-wrap {
    height:140px !important;
  }

  /* Also fix hero-right card overflow */
  .hero-right { display:none !important; }

  /* Single product related — also scroll, don't stretch */
  .single-related .products-flex {
    max-width:100%;
  }
  .single-related {
    overflow-x:auto;
    max-width:100vw;
    margin-left:-16px;
    margin-right:-16px;
    padding-left:16px;
  }

  /* Prevent ANY horizontal overflow on body */
  body { overflow-x:hidden !important; }
  .container { overflow-x:hidden; }
}

/* Cart/Checkout page title */
.pn-page-title {
  font-family:'Outfit',sans-serif; font-weight:900;
  font-size:clamp(26px,4vw,40px); letter-spacing:-.03em;
  color:var(--ink); padding:28px 0 20px;
  border-bottom:1px solid var(--lighter); margin-bottom:0;
}
.woo-page-wrap { max-width:1200px; margin:0 auto; padding:0 24px 60px; }

/* ================================================================
   MOBILE SIDEBAR — fix overlap with sticky header
================================================================ */
@media (max-width:900px) {
  .shop-sidebar {
    /* Start below the header (header is ~60px + announce ~36px) */
    top:0 !important;
    padding-top:0 !important;
    z-index:150 !important;
    /* Don't cover mobile nav at bottom */
    padding-bottom:72px !important;
  }
  .shop-sidebar .sidebar-mobile-header {
    position:sticky;
    top:0;
    background:var(--white);
    z-index:1;
    border-bottom:1px solid var(--lighter);
  }
}

/* ================================================================
   EYE CANDY — Visual polish & micro-interactions
================================================================ */

/* ── Product card hover lift + image zoom ── */
.product-card {
  transition:box-shadow .25s ease, transform .25s ease, border-color .25s ease !important;
}
.product-card:hover {
  box-shadow:0 12px 40px rgba(0,0,0,.1) !important;
  transform:translateY(-5px) !important;
}
.product-card-img-wrap {
  overflow:hidden;
  transition:background .25s;
}
.product-card-img-wrap img {
  transition:transform .4s cubic-bezier(.25,.46,.45,.94) !important;
}
.product-card:hover .product-card-img-wrap img { transform:scale(1.06) !important; }

/* ── Add to cart button pulse when added ── */
@keyframes cart-pulse {
  0%   { box-shadow:0 0 0 0 rgba(26,58,143,.5); }
  70%  { box-shadow:0 0 0 10px rgba(26,58,143,0); }
  100% { box-shadow:0 0 0 0 rgba(26,58,143,0); }
}
.add-to-cart-btn.added { animation:cart-pulse .6s ease; }

/* ── Category card hover ── */
.cat-card {
  transition:all .25s ease !important;
}
.cat-card:hover {
  transform:translateY(-3px) !important;
  box-shadow:0 8px 28px rgba(26,58,143,.1) !important;
}

/* ── Hero section: animated gradient background ── */
@keyframes hero-shift {
  0%   { background-position:0% 50%; }
  50%  { background-position:100% 50%; }
  100% { background-position:0% 50%; }
}
.hero-section .hero-bg-lines {
  background:linear-gradient(135deg,#eef2fb 0%,#e8edf8 30%,#f0f4fc 60%,#e4eaf6 100%) !important;
  background-size:200% 200% !important;
  animation:hero-shift 12s ease infinite !important;
}

/* ── Sticky header: subtle drop shadow appears on scroll ── */
.site-header { transition:box-shadow .3s ease, background .3s ease; }
.site-header.scrolled {
  background:rgba(255,255,255,.99) !important;
  box-shadow:0 1px 0 var(--lighter), 0 4px 24px rgba(0,0,0,.06) !important;
}

/* ── Stats bar: shimmer effect ── */
@keyframes shimmer-sweep {
  0%   { transform:translateX(-100%); }
  100% { transform:translateX(100%); }
}
.stat-item { position:relative; overflow:hidden; }
.stat-item:hover::after {
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.04),transparent);
  animation:shimmer-sweep .6s ease;
}

/* ── Single product main image zoom on hover ── */
.single-main-img-wrap { overflow:hidden !important; }
.single-main-img { transition:transform .5s cubic-bezier(.25,.46,.45,.94), opacity .2s !important; }
.single-main-img-wrap:hover .single-main-img { transform:scale(1.04) !important; }

/* ── Single product: price pops on load ── */
@keyframes price-pop {
  0%   { transform:scale(.95); opacity:0; }
  60%  { transform:scale(1.02); }
  100% { transform:scale(1); opacity:1; }
}
.single-price { animation:price-pop .4s ease .1s both; }

/* ── Shop grid: stagger card appearance ── */
.shop-grid .product-card:nth-child(1)  { animation-delay:.03s; }
.shop-grid .product-card:nth-child(2)  { animation-delay:.06s; }
.shop-grid .product-card:nth-child(3)  { animation-delay:.09s; }
.shop-grid .product-card:nth-child(4)  { animation-delay:.12s; }
.shop-grid .product-card:nth-child(5)  { animation-delay:.15s; }
.shop-grid .product-card:nth-child(6)  { animation-delay:.18s; }
.shop-grid .product-card:nth-child(7)  { animation-delay:.21s; }
.shop-grid .product-card:nth-child(8)  { animation-delay:.24s; }
.shop-grid .product-card:nth-child(9)  { animation-delay:.27s; }
.shop-grid .product-card:nth-child(10) { animation-delay:.30s; }
.shop-grid .product-card:nth-child(11) { animation-delay:.33s; }
.shop-grid .product-card:nth-child(12) { animation-delay:.36s; }

/* ── Brand chips: smooth active state ── */
.brand-chip {
  transition:all .2s cubic-bezier(.25,.46,.45,.94) !important;
}
.brand-chip:hover { transform:translateY(-1px) !important; }
.brand-chip.on { transform:none !important; }

/* ── Promo banner: radial glow pulse ── */
@keyframes glow-pulse {
  0%, 100% { opacity:.3; }
  50%       { opacity:.5; }
}
.promo-banner::before { animation:glow-pulse 4s ease infinite; }

/* ── Buttons: smooth press feedback ── */
.btn-blue:active { transform:translateY(0) scale(.98) !important; }
.btn-outline:active { transform:scale(.98) !important; }

/* ── Shop sidebar items: smooth active indicator ── */
.sidebar-cat-item {
  position:relative;
  transition:all .18s ease !important;
}
.sidebar-cat-item.is-active::before {
  content:'';
  position:absolute; left:0; top:50%;
  transform:translateY(-50%);
  width:3px; height:60%; border-radius:2px;
  background:var(--blue);
}
.sidebar-cat-item.is-active { padding-left:10px !important; }

/* ── Single product trust row: icon bounce on hover ── */
.single-trust-item { transition:all .2s ease; }
.single-trust-item:hover { transform:translateY(-2px); box-shadow:0 4px 12px rgba(26,58,143,.12); }
.single-trust-item span:first-child { display:inline-block; transition:transform .2s ease; }
.single-trust-item:hover span:first-child { transform:scale(1.2); }

/* ── Page load: smooth reveal for main sections ── */
.hero-section,
.products-section,
.categories-section { animation:fade-up .6s ease both; }
.products-section { animation-delay:.1s; }
.categories-section { animation-delay:.2s; }

/* ── Scrollbar on product tracks: custom thin ── */
.products-scroll-track::-webkit-scrollbar { height:3px; }
.products-scroll-track::-webkit-scrollbar-track { background:var(--lighter); border-radius:2px; }
.products-scroll-track::-webkit-scrollbar-thumb { background:var(--blue-m); border-radius:2px; }

/* ── Badge animations ── */
.product-badge {
  animation:fade-up .3s ease both;
}

/* ── Section title: blue word underline ── */
.section-title .text-blue,
.section-title span.text-blue {
  position:relative;
  display:inline-block;
}
.section-title .text-blue::after {
  content:'';
  position:absolute;
  bottom:-3px; left:0; right:0; height:2px;
  background:var(--blue); border-radius:1px;
  transform:scaleX(0); transform-origin:left;
  transition:transform .4s ease;
}
.section-title:hover .text-blue::after { transform:scaleX(1); }
