/* V7 single product routing hard patch */
/*
Theme Name: Mr Charms Lovable Theme
Theme URI: https://mrcharms.com.au/
Author: Mr Charms / ChatGPT
Description: WordPress conversion of the Lovable Mr Charms storefront design with WooCommerce support, WordPress menu navigation, shop templates, and single product templates.
Version: 1.5.183
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: mrcharms-lovable
*/

/* Product card image/preview layout reset */
.products .product .product-img-link,
.products-grid .product .product-img-link,
.mrc-products-grid .product .product-img-link,
.mrc-shop-products .product .product-img-link,
.mrc-product-card .product-img-link,
.product-card .product-img-link{
  position:relative !important;
  display:block !important;
  width:100% !important;
  aspect-ratio:1 / 1 !important;
  min-height:0 !important;
  overflow:hidden !important;
  border-radius:18px !important;
}

.products .product .product-img-link > img:first-child,
.products-grid .product .product-img-link > img:first-child,
.mrc-products-grid .product .product-img-link > img:first-child,
.mrc-shop-products .product .product-img-link > img:first-child,
.mrc-product-card .product-img-link > img:first-child,
.product-card .product-img-link > img:first-child,
.products .product img.product-img,
.products-grid .product img.product-img,
.mrc-products-grid .product img.product-img,
.mrc-shop-products .product img.product-img,
.mrc-product-card img.product-img,
.product-card img.product-img{
  display:block !important;
  width:100% !important;
  height:100% !important;
  max-width:100% !important;
  max-height:100% !important;
  object-fit:contain !important;
  object-position:center center !important;
  margin:0 !important;
}

.products .product .product-img-link > img:not(:first-child),
.products-grid .product .product-img-link > img:not(:first-child),
.mrc-products-grid .product .product-img-link > img:not(:first-child),
.mrc-shop-products .product .product-img-link > img:not(:first-child),
.mrc-product-card .product-img-link > img:not(:first-child),
.product-card .product-img-link > img:not(:first-child),
.products .product .product-img-link > picture:not(:first-child),
.products-grid .product .product-img-link > picture:not(:first-child),
.mrc-products-grid .product .product-img-link > picture:not(:first-child),
.mrc-shop-products .product .product-img-link > picture:not(:first-child),
.mrc-product-card .product-img-link > picture:not(:first-child),
.product-card .product-img-link > picture:not(:first-child),
.products .product .product-preview,
.products-grid .product .product-preview,
.mrc-products-grid .product .product-preview,
.mrc-shop-products .product .product-preview,
.products .product .product-secondary-preview,
.products-grid .product .product-secondary-preview,
.mrc-products-grid .product .product-secondary-preview,
.mrc-shop-products .product .product-secondary-preview,
.products .product .mrc-product-preview,
.products-grid .product .mrc-product-preview,
.mrc-products-grid .product .mrc-product-preview,
.mrc-shop-products .product .mrc-product-preview{
  position:absolute !important;
  left:14px !important;
  bottom:14px !important;
  top:auto !important;
  right:auto !important;
  z-index:4 !important;
  display:block !important;
  width:66px !important;
  height:66px !important;
  max-width:22% !important;
  max-height:22% !important;
  aspect-ratio:1 / 1 !important;
  margin:0 !important;
  padding:4px !important;
  border:2px solid rgba(255,255,255,.9) !important;
  border-radius:18px !important;
  background:#fff !important;
  box-shadow:0 0 24px rgba(57,255,20,.34), 0 12px 28px rgba(0,0,0,.38) !important;
  object-fit:cover !important;
  object-position:center center !important;
  transform:none !important;
}

.products .product .product-img-link > picture:not(:first-child) img,
.products-grid .product .product-img-link > picture:not(:first-child) img,
.mrc-products-grid .product .product-img-link > picture:not(:first-child) img,
.mrc-shop-products .product .product-img-link > picture:not(:first-child) img,
.mrc-product-card .product-img-link > picture:not(:first-child) img,
.product-card .product-img-link > picture:not(:first-child) img,
.products .product .product-preview img,
.products-grid .product .product-preview img,
.mrc-products-grid .product .product-preview img,
.mrc-shop-products .product .product-preview img,
.products .product .product-secondary-preview img,
.products-grid .product .product-secondary-preview img,
.mrc-products-grid .product .product-secondary-preview img,
.mrc-shop-products .product .product-secondary-preview img,
.products .product .mrc-product-preview img,
.products-grid .product .mrc-product-preview img,
.mrc-products-grid .product .mrc-product-preview img,
.mrc-shop-products .product .mrc-product-preview img{
  display:block !important;
  width:100% !important;
  height:100% !important;
  margin:0 !important;
  border:0 !important;
  border-radius:14px !important;
  object-fit:cover !important;
  object-position:center center !important;
}

@media (max-width:720px){
  .products .product .product-img-link > img:not(:first-child),
  .products-grid .product .product-img-link > img:not(:first-child),
  .mrc-products-grid .product .product-img-link > img:not(:first-child),
  .mrc-shop-products .product .product-img-link > img:not(:first-child),
  .mrc-product-card .product-img-link > img:not(:first-child),
  .product-card .product-img-link > img:not(:first-child),
  .products .product .product-preview,
  .products-grid .product .product-preview,
  .mrc-products-grid .product .product-preview,
  .mrc-shop-products .product .product-preview,
  .products .product .product-secondary-preview,
  .products-grid .product .product-secondary-preview,
  .mrc-products-grid .product .product-secondary-preview,
  .mrc-shop-products .product .product-secondary-preview,
  .products .product .mrc-product-preview,
  .products-grid .product .mrc-product-preview,
  .mrc-products-grid .product .mrc-product-preview,
  .mrc-shop-products .product .mrc-product-preview{
    left:10px !important;
    bottom:10px !important;
    width:52px !important;
    height:52px !important;
    border-radius:15px !important;
    padding:3px !important;
  }
}

/* Checkout header spacing polish */
body.woocommerce-checkout .ticker{
  height:42px;
  min-height:42px;
  display:flex;
  align-items:center;
  overflow:hidden;
}

body.woocommerce-checkout .ticker-track{
  align-items:center;
  height:42px;
  line-height:1;
}

body.woocommerce-checkout .site-header{
  min-height:82px;
}

body.woocommerce-checkout .site-header .nav{
  min-height:82px;
  padding-top:0;
  padding-bottom:0;
  align-items:center;
}

body.woocommerce-checkout.admin-bar .ticker{
  top:32px;
}

body.woocommerce-checkout.admin-bar .site-header{
  top:74px;
}

@media (max-width:782px){
  body.woocommerce-checkout.admin-bar .ticker{top:46px}
  body.woocommerce-checkout.admin-bar .site-header{top:88px}
}

@media (max-width:720px){
  body.woocommerce-checkout .ticker,
  body.woocommerce-checkout .ticker-track{
    height:34px;
    min-height:34px;
  }
  body.woocommerce-checkout .site-header,
  body.woocommerce-checkout .site-header .nav{
    min-height:68px;
  }
}

/* ============ MR CHARMS — verbatim from source HTML ============ */
:root{
  --bg:           #0A0A0A;
  --surface:      #141414;
  --surface-2:    #1E1E1E;
  --surface-3:    #262626;
  --text:         #FFFFFF;
  --text-muted:   #A8A8A8;
  --text-dim:     #6B6B6B;
  --border:       #262626;
  --border-bright:#3A3A3A;

  --accent:       #39FF14;    /* crocodile neon */
  --accent-glow:  rgba(57,255,20,.35);
  --accent-ink:   #062600;    /* readable dark on neon */

  --pink:  #FF2EC4;
  --gold:  #FFD166;
  --blue:  #2E9CFF;
  --rainbow: linear-gradient(90deg,var(--pink) 0%,var(--gold) 33%,var(--accent) 66%,var(--blue) 100%);
  --page-glow:
    radial-gradient(ellipse 72% 58% at 4% 12%, rgba(255,46,196,.14), rgba(255,46,196,.055) 36%, transparent 74%),
    radial-gradient(ellipse 78% 62% at 96% 10%, rgba(46,156,255,.15), rgba(46,156,255,.055) 38%, transparent 76%),
    radial-gradient(ellipse 115% 64% at 50% -6%, rgba(57,255,20,.055), rgba(57,255,20,.02) 48%, transparent 82%);
  --page-pattern:
    repeating-linear-gradient(
      135deg,
      rgba(255,255,255,.022) 0,
      rgba(255,255,255,.022) 1px,
      transparent 1px,
      transparent 14px
    ),
    repeating-linear-gradient(
      45deg,
      rgba(255,255,255,.018) 0,
      rgba(255,255,255,.018) 1px,
      transparent 1px,
      transparent 14px
    ),
    radial-gradient(circle at 1px 1px, rgba(255,255,255,.075) 1.2px, transparent 0),
    radial-gradient(ellipse 110% 80% at 50% 50%, transparent 50%, rgba(0,0,0,.4) 100%);

  /* Section-accent cycle — rainbow order across the page
     (loops back after 6th section: reviews=P, faq=T, newsletter=L) */

  --danger:  #FF3355;
  --warn:    #FFB020;

  --font-hero:    'Anton', 'Arial Narrow', sans-serif;
  --font-display: 'Fredoka', system-ui, sans-serif;
  --font-chunky:  'Lilita One', 'Fredoka', system-ui, sans-serif;
  --font-body:    'Manrope', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;

  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 22px;
  --radius-pill: 999px;

  --shadow-sm: 0 1px 2px rgba(0,0,0,.4);
  --shadow-md: 0 8px 24px rgba(0,0,0,.5);
  --shadow-neon: 0 0 0 1px rgba(57,255,20,.45), 0 0 24px -4px var(--accent-glow), 0 0 60px -20px var(--accent-glow);

  --ease: cubic-bezier(.2,.7,.2,1);
  --dur-fast: 140ms;
  --dur: 220ms;
  --dur-slow: 420ms;

  --container: 1240px;
  --gutter: clamp(16px, 3vw, 32px);
}

/* Bundle builder optical image centering.
   Some charm files include uneven blank space, so lift the artwork slightly
   inside builder cards without changing the product-card treatment elsewhere. */
.mrc-shop-builder .mrc-shop-design-img{
  align-items:center!important;
  justify-items:center!important;
}
.mrc-shop-builder .mrc-shop-design-img img{
  width:100%!important;
  height:100%!important;
  object-fit:contain!important;
  object-position:center 44%!important;
  padding:10% 12% 16%!important;
  transform:translateY(-5%)!important;
  transform-origin:center center!important;
}
@media (max-width:680px){
  .mrc-shop-builder .mrc-shop-design-img img{
    padding:9% 11% 17%!important;
    transform:translateY(-6%)!important;
  }
}

/* ============ BASE ============ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  background-color:var(--bg);
  /* Layered texture — keeps the dark theme but breaks up the flat black */
  background-image:
    /* 1. Brand glow tint */
    var(--page-glow),
    /* 2. Crossed diagonal warp lines — visible mesh */
    var(--page-pattern);
  background-size:
    100% 1900px,
    100% 1900px,
    100% 1800px,
    auto,
    auto,
    28px 28px,
    100% 100%;
  background-repeat:no-repeat, no-repeat, no-repeat, repeat, repeat, repeat, no-repeat;
  background-attachment:scroll, scroll, scroll, fixed, fixed, fixed, fixed;
  color:var(--text);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}
/* faint analog grain — bumped a touch */
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  z-index:100;
  opacity:.08;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.8'/></svg>");
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;border:0;background:none;cursor:pointer}

::selection{background:var(--accent);color:var(--accent-ink)}

/* ============ TYPE ============ */
.display{
  font-family:var(--font-display);
  font-weight:600;
  letter-spacing:-.01em;
  line-height:1;
}
/* Hero H1 keeps Anton — ultra-condensed stacked caps */
.hero h1.display{
  font-family:var(--font-hero);
  font-weight:400;
  letter-spacing:-.01em;
  line-height:.88;
  text-transform:uppercase;
}
/* Per-section accent color — drives the .gradient span, kicker dot, hover borders */
.hero       {--section-accent:var(--pink)}
#bundles    {--section-accent:var(--gold)}
#shop       {--section-accent:var(--blue)}
#trending   {--section-accent:var(--pink)}   /* cycle */
#vs         {--section-accent:var(--gold)}   /* cycle */
#reviews    {--section-accent:var(--accent)} /* cycle */
#faq        {--section-accent:var(--blue)}   /* cycle */
.newsletter {--section-accent:var(--pink)}   /* cycle */

.shop-heading-pink{
  color:var(--text);
  text-shadow:none;
}
.shop-heading-pink .gradient{
  color:var(--accent);
  text-shadow:0 0 28px var(--accent-glow);
}

.kicker{
  font-family:var(--font-body);
  font-weight:700;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--text-muted);
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.kicker .dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--section-accent, var(--accent));
  box-shadow:0 0 12px var(--section-accent, var(--accent));
}
.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}

/* ============ LAYOUT ============ */
.wrap{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.section{padding:clamp(56px,8vw,104px) 0}
.section-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:24px;
  margin-bottom:clamp(28px,4vw,48px);
  flex-wrap:wrap;
}
.section-head .title-block{max-width:680px}
.section-head h2{
  font-family:var(--font-chunky);
  font-weight:400;
  font-size:clamp(30px,4vw,52px);
  margin:8px 0 0;
  letter-spacing:-.005em;
  line-height:1.05;
}
.section-head .sub{color:var(--text-muted);margin-top:14px;font-size:16px;max-width:52ch}

/* ============ TICKER ============ */
.ticker{
  background:var(--rainbow);
  color:#000;
  overflow:hidden;
  border-bottom:1px solid rgba(0,0,0,.25);
  box-shadow:inset 0 -1px 0 rgba(0,0,0,.12), inset 0 1px 0 rgba(255,255,255,.22);
}
.ticker-track{text-shadow:0 1px 0 rgba(255,255,255,.22)}
.ticker-track{
  display:flex;gap:48px;
  align-items:center;
  font-family:var(--font-display);font-weight:500;
  text-transform:uppercase;
  font-size:13px;
  letter-spacing:.04em;
  padding:10px 0;
  white-space:nowrap;
  animation:marquee 60s linear infinite;
  width:max-content;
}
.ticker-track span{display:inline-flex;align-items:center;gap:12px}
.ticker-track .sep{opacity:.55}
@keyframes marquee{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.ticker-track{animation:none}}

/* ============ HEADER ============ */
.site-header{
  position:sticky;
  top:0;
  z-index:10020;
  width:100%;
  background:rgba(10,10,10,.78);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--border);
  box-shadow:0 16px 40px -32px rgba(0,0,0,.9);
}
.ticker{margin-top:0}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;
}
.brand{
  display:flex;align-items:center;
  /* image logo — height-controlled, width auto */
}
.brand img{
  height:40px;width:auto;display:block;
  /* optional neon glow on hover */
  transition:filter var(--dur) var(--ease);
}
.brand:hover img{filter:drop-shadow(0 0 12px var(--accent-glow))}
.brand-mark{
  width:36px;height:36px;border-radius:10px;
  background:var(--accent);
  display:grid;place-items:center;
  box-shadow:0 0 22px -4px var(--accent-glow);
}
.brand-mark svg{width:24px;height:24px;color:var(--accent-ink)}

.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{
  font-size:14px;font-weight:600;color:var(--text-muted);
  transition:color var(--dur) var(--ease);
  position:relative;
}
.nav-links a:hover{color:var(--text)}
.nav-links a[data-has]::after{
  content:"";display:inline-block;margin-left:6px;
  width:6px;height:6px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:rotate(45deg) translateY(-2px);
}

.nav-actions{display:flex;align-items:center;gap:12px}
.mrc-currency-switcher{
  display:inline-flex;
  align-items:center;
  gap:7px;
  min-height:40px;
  padding:0 9px 0 11px;
  border:1px solid var(--border);
  border-radius:12px;
  background:rgba(255,255,255,.035);
  color:var(--text-muted);
  flex:0 0 auto;
}
.mrc-currency-switcher[data-currency-ready="true"]{
  border-color:rgba(57,255,20,.28);
}
.mrc-currency-switcher label{
  font-family:var(--font-body);
  font-size:10px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.mrc-currency-switcher label{color:var(--text-muted)}
.mrc-currency-switcher select{
  min-width:64px;
  border:0;
  outline:0;
  background:transparent;
  color:var(--text);
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:900;
  cursor:pointer;
}
.mrc-currency-switcher select option{
  color:#07070b;
  background:#fff;
}
body.woocommerce-cart .mrc-currency-switcher,
body.woocommerce-checkout .mrc-currency-switcher{
  display:none!important;
}
.icon-btn{
  width:40px;height:40px;border-radius:10px;
  display:grid;place-items:center;
  border:1px solid var(--border);
  color:var(--text);
  transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.icon-btn:hover{border-color:var(--border-bright);transform:translateY(-1px)}
.cart-btn{
  position:relative;display:inline-flex;align-items:center;gap:10px;
  padding:10px 16px;border-radius:var(--radius-pill);
  border:1px solid var(--border-bright);
  font-weight:700;font-size:14px;
  transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease);
}
.cart-btn:hover{background:var(--surface);border-color:var(--accent)}
.cart-badge{
  display:inline-grid;place-items:center;
  min-width:22px;height:22px;padding:0 6px;
  border-radius:var(--radius-pill);
  background:var(--accent);color:var(--accent-ink);
  font-family:var(--font-mono);font-weight:700;font-size:12px;
}
.menu-btn{display:none}

@media (min-width:921px) and (max-width:1240px){
  .nav-links{gap:18px}
  .mrc-currency-switcher label{display:none}
  .mrc-currency-switcher{padding:0 8px}
  .mrc-currency-switcher select{min-width:58px}
}

@media (max-width:920px){
  .nav{position:relative}
  .nav-links{
    position:absolute;
    z-index:10030;
    top:calc(100% + 10px);
    left:0;
    right:0;
    display:grid;
    gap:6px;
    padding:14px;
    border:1px solid var(--border-bright);
    border-radius:18px;
    background:
      linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02)),
      var(--surface);
    box-shadow:0 22px 54px -26px rgba(0,0,0,.95);
    opacity:0;
    pointer-events:none;
    transform:translateY(-8px);
    visibility:hidden;
    transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease),visibility var(--dur) var(--ease);
  }
  .nav-links::before{
    content:"";
    position:absolute;
    left:14px;
    right:14px;
    top:0;
    height:3px;
    border-radius:999px;
    background:var(--rainbow);
  }
  .nav-links.is-open{
    opacity:1;
    pointer-events:auto;
    transform:translateY(0);
    visibility:visible;
  }
  .nav-links a{
    min-height:46px;
    display:flex;
    align-items:center;
    padding:0 14px;
    border-radius:12px;
    background:rgba(255,255,255,.025);
    color:var(--text);
    font-family:var(--font-chunky);
    font-size:18px;
    font-weight:400;
  }
  .nav-links a:hover{background:var(--surface-2);color:var(--accent)}
  .mrc-currency-switcher{
    position:absolute;
    right:158px;
    top:10px;
    min-height:42px;
    height:42px;
    padding:0 8px;
    gap:5px;
    border-radius:13px;
  }
  .mrc-currency-switcher label{
    display:none;
  }
  .mrc-currency-switcher select{
    min-width:58px;
    font-size:12px;
  }
  .menu-btn{display:grid}
  .menu-btn[aria-expanded="true"]{
    border-color:var(--accent);
    color:var(--accent);
    box-shadow:0 0 18px -8px var(--accent-glow);
  }
}

/* Bundle builder product-image final alignment.
   Match the homepage product-card treatment without the secondary hover image. */
.mrc-shop-builder .mrc-shop-design-img{
  position:relative!important;
  display:grid!important;
  place-items:center!important;
  aspect-ratio:1/1!important;
  width:100%!important;
  min-height:0!important;
  overflow:hidden!important;
  border-radius:14px!important;
  background:#fff!important;
  isolation:isolate!important;
}
.mrc-shop-builder .mrc-shop-design-img img{
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-width:100%!important;
  max-height:100%!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:10%!important;
  margin:0!important;
  transform:none!important;
  opacity:1!important;
  visibility:visible!important;
  box-sizing:border-box!important;
  backface-visibility:hidden!important;
  -webkit-backface-visibility:hidden!important;
  will-change:opacity!important;
  contain:paint!important;
}
.mrc-shop-builder .mrc-shop-design:hover .mrc-shop-design-img img,
.mrc-shop-builder .mrc-shop-design.is-selected .mrc-shop-design-img img{
  transform:none!important;
}
.mrc-shop-builder .mrc-shop-design.has-broken-image .mrc-shop-design-img::after{
  content:"Image loading";
  position:absolute;
  inset:auto 10px 10px;
  z-index:2;
  border-radius:999px;
  padding:6px 8px;
  background:rgba(0,0,0,.72);
  color:#fff;
  font:700 11px/1 Manrope,system-ui,sans-serif;
  text-align:center;
}

@media (max-width:740px){
  .mrc-shop-builder .mrc-shop-design-img{
    border-radius:13px!important;
  }
  .mrc-shop-builder .mrc-shop-design-img img{
    padding:9%!important;
  }
}

/* Desktop checkout layout repair */
@media (min-width:901px){
  .mrc-checkout-panel{
    width:min(1180px,calc(100% - 40px))!important;
    max-width:1180px!important;
    margin-inline:auto!important;
    padding:clamp(18px,2.2vw,28px)!important;
    overflow:visible!important;
  }

  .mrc-checkout-panel .woocommerce form.checkout{
    display:grid!important;
    grid-template-columns:minmax(0,1.35fr) minmax(360px,.75fr)!important;
    grid-template-areas:
      "details review-title"
      "details review"!important;
    gap:clamp(20px,2.6vw,32px)!important;
    align-items:start!important;
    width:100%!important;
  }

  .mrc-checkout-panel .woocommerce form.checkout #customer_details{
    grid-area:details!important;
    display:grid!important;
    grid-template-columns:minmax(0,1fr)!important;
    gap:clamp(16px,2vw,22px)!important;
    width:100%!important;
    max-width:none!important;
    min-width:0!important;
    float:none!important;
    clear:none!important;
  }

  .mrc-checkout-panel .woocommerce form.checkout #order_review_heading{
    grid-area:review-title!important;
    width:100%!important;
    margin:0!important;
    align-self:end!important;
  }

  .mrc-checkout-panel .woocommerce form.checkout #order_review,
  .mrc-checkout-panel .woocommerce form.checkout .woocommerce-checkout-review-order{
    grid-area:review!important;
    width:100%!important;
    max-width:none!important;
    min-width:0!important;
    float:none!important;
    clear:none!important;
  }

  .mrc-checkout-panel .woocommerce form.checkout .col2-set,
  .mrc-checkout-panel .woocommerce form.checkout .col2-set .col-1,
  .mrc-checkout-panel .woocommerce form.checkout .col2-set .col-2{
    float:none!important;
    width:100%!important;
    max-width:none!important;
    min-width:0!important;
    clear:none!important;
  }

  .mrc-checkout-panel .woocommerce form.checkout .woocommerce-billing-fields__field-wrapper{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:12px 14px!important;
    align-items:start!important;
  }

  .mrc-checkout-panel .woocommerce form.checkout .form-row,
  .mrc-checkout-panel .woocommerce form.checkout .form-row-first,
  .mrc-checkout-panel .woocommerce form.checkout .form-row-last,
  .mrc-checkout-panel .woocommerce form.checkout .form-row-wide{
    float:none!important;
    width:100%!important;
    max-width:none!important;
    min-width:0!important;
    margin-right:0!important;
    clear:none!important;
  }

  .mrc-checkout-panel .woocommerce form.checkout #billing_country_field,
  .mrc-checkout-panel .woocommerce form.checkout #billing_address_1_field,
  .mrc-checkout-panel .woocommerce form.checkout #billing_address_2_field,
  .mrc-checkout-panel .woocommerce form.checkout #billing_city_field,
  .mrc-checkout-panel .woocommerce form.checkout #billing_state_field,
  .mrc-checkout-panel .woocommerce form.checkout #billing_postcode_field,
  .mrc-checkout-panel .woocommerce form.checkout #billing_phone_field,
  .mrc-checkout-panel .woocommerce form.checkout #billing_email_field,
  .mrc-checkout-panel .woocommerce form.checkout .woocommerce-additional-fields{
    grid-column:1/-1!important;
  }

  .mrc-checkout-panel .woocommerce form.checkout input.input-text,
  .mrc-checkout-panel .woocommerce form.checkout textarea,
  .mrc-checkout-panel .woocommerce form.checkout select,
  .mrc-checkout-panel .woocommerce form.checkout .select2-container{
    width:100%!important;
    max-width:none!important;
  }
}

@media (min-width:901px) and (max-width:1120px){
  .mrc-checkout-panel .woocommerce form.checkout{
    grid-template-columns:minmax(0,1fr) minmax(330px,.82fr)!important;
  }

  .mrc-checkout-panel .woocommerce form.checkout .woocommerce-billing-fields__field-wrapper{
    grid-template-columns:1fr!important;
  }
}

@media (max-width:420px){
  .nav-links{
    left:-6px;
    right:-6px;
    border-radius:16px;
  }
  .nav-links a{font-size:16px}
}

/* ============ BUTTONS ============ */
.btn{
  --bg:var(--accent);
  --fg:var(--accent-ink);
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:13px 22px;
  border-radius:var(--radius-pill);
  background:var(--bg);color:var(--fg);
  font-family:var(--font-display);font-weight:600;
  font-size:14px;letter-spacing:0;
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),background var(--dur) var(--ease);
  will-change:transform;
  box-shadow:0 0 0 0 transparent;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-neon)}
.btn:focus-visible{outline:3px solid var(--accent);outline-offset:3px}
.btn:active{transform:translateY(0)}
.btn svg{width:16px;height:16px}

.btn-ghost{
  --bg:transparent;--fg:var(--text);
  border:1px solid var(--border-bright);
}
.btn-ghost:hover{--bg:var(--surface);box-shadow:none;border-color:var(--accent)}

/* ============ HERO ============ */
.hero{
  position:relative;
  padding:clamp(48px,7vw,96px) 0 clamp(72px,9vw,128px);
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:clamp(32px,5vw,72px);
  align-items:center;
}
@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:9px 16px;
  position:relative;
  border:1px solid transparent;
  border-radius:var(--radius-pill);
  font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text);
  /* Rainbow border via double-background trick */
  background:
    linear-gradient(rgba(10,10,10,.85), rgba(10,10,10,.85)) padding-box,
    var(--rainbow) border-box;
  border:1px solid transparent;
  box-shadow:0 0 24px -8px rgba(255,46,196,.35), 0 0 24px -8px rgba(57,255,20,.25);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.hero-eyebrow .dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--rainbow);
  box-shadow:0 0 10px rgba(57,255,20,.7), 0 0 8px rgba(255,46,196,.5);
  animation:pulse 2s var(--ease) infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}

.hero h1{
  margin:18px 0 0;
  font-size:clamp(64px,11vw,168px);
}
.gradient{
  display:inline-block;
  color:var(--section-accent, var(--accent));
  position:relative;
}
/* Hero is the only place that keeps the rainbow gradient — all other sections use solid colors */
.hero .gradient{
  background:var(--rainbow);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}
/* Centered variant of section-head (used by bundles) */
.section-head.centered{
  flex-direction:column;
  align-items:center;
  text-align:center;
  justify-content:center;
}
.section-head.centered .title-block{max-width:none;display:flex;flex-direction:column;align-items:center}
/* Pill kicker — gold-bordered, white text for proper contrast */
.kicker-pill{
  padding:9px 18px;
  border-radius:var(--radius-pill);
  background:rgba(0,0,0,.4);
  border:1px solid rgba(255,209,102,.55);
  box-shadow:0 0 28px -10px rgba(255,209,102,.6), inset 0 1px 0 rgba(255,255,255,.06);
  color:var(--text);
  font-size:13px;letter-spacing:.16em;font-weight:800;
}
.kicker-pill .dot{display:none}
.kicker-pill .kicker-ico{
  display:inline-flex;margin-right:4px;font-size:15px;line-height:1;
  transform:translateY(-1px);
}
/* Bundle h2 — Fredoka heavy, more modern than Lilita One */
.bundles-h2{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(38px,5.6vw,72px);
  letter-spacing:-.02em;
  line-height:1.02;
  margin:20px 0 0;
}
/* Blue "Save Big" — overrides the bundles section-accent */
.bundles-h2 .gradient{
  color:var(--blue);
  text-shadow:0 0 32px rgba(46,156,255,.35);
}
.gradient::after{display:none}
.hero .gradient::after{
  content:"";display:block;
  position:absolute;left:0;right:0;bottom:.02em;height:.09em;
  background:var(--rainbow);
  border-radius:999px;
  filter:blur(.01em) drop-shadow(0 0 10px rgba(57,255,20,.4)) drop-shadow(0 0 8px rgba(255,46,196,.3));
}
.hero p.lede{
  margin:24px 0 0;
  font-size:clamp(16px,1.6vw,19px);
  color:var(--text-muted);
  max-width:52ch;
}
.hero p.lede strong{color:var(--text);font-weight:700}

.hero-ctas{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}

.hero-trust{
  display:flex;gap:clamp(20px,3vw,44px);
  margin-top:44px;padding-top:28px;
  border-top:1px solid var(--border);
  flex-wrap:wrap;
}
.trust-item{display:flex;gap:10px;align-items:center;font-size:13px;color:var(--text-muted)}
.trust-item strong{color:var(--text);font-weight:700}
.trust-item .ti-ico{
  width:34px;height:34px;border-radius:10px;
  background:var(--surface);border:1px solid var(--border);
  display:grid;place-items:center;
  color:var(--accent);
}
.trust-item .ti-ico svg{width:18px;height:18px}

/* hero art */
.hero-art{
  position:relative;
  aspect-ratio:1/1;
  max-width:560px;
  justify-self:end;
  width:100%;
}
.hero-art::before{
  content:"";position:absolute;inset:-8%;z-index:0;
  background:radial-gradient(circle at 50% 50%,rgba(57,255,20,.25),transparent 60%);
  filter:blur(40px);
}
.charm-cluster{position:absolute;inset:0}
.charm{
  position:absolute;
  width:38%;aspect-ratio:1/1;border-radius:24px;
  background:transparent;
  border:0;
  overflow:visible;
  box-shadow:none;
  transition:transform 500ms var(--ease);
}
.charm img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  transform:none;
  filter:drop-shadow(0 20px 24px rgba(0,0,0,.42));
}
.charm.c1{top:4%;left:8%;transform:rotate(-8deg)}
.charm.c2{top:2%;right:4%;width:34%;transform:rotate(10deg)}
.charm.c3{top:38%;left:-2%;width:30%;transform:rotate(4deg)}
.charm.c4{top:30%;right:-2%;width:42%;transform:rotate(-12deg)}
.charm.hero-shoe{width:48%;border-radius:28px;background:transparent}
.charm.c5{bottom:4%;left:18%;width:34%;transform:rotate(14deg)}
.charm.c6{bottom:-2%;right:16%;width:30%;transform:rotate(-6deg)}
.charm:hover{transform:rotate(0) scale(1.06)}

.price-sticker{
  position:absolute;z-index:3;
  right:-8px;top:-8px;
  display:grid;place-items:center;
  width:118px;height:118px;
  background:var(--rainbow);color:#071007;
  border-radius:50%;
  font-family:var(--font-hero);font-weight:400;text-transform:uppercase;
  text-align:center;line-height:.95;
  transform:rotate(-12deg);
  box-shadow:0 0 0 6px rgba(255,255,255,.08),0 20px 44px -12px rgba(255,46,196,.32),0 16px 38px -18px rgba(46,156,255,.42);
  animation:bob 4s var(--ease) infinite;
}
.price-sticker .from{font-size:11px;letter-spacing:.18em;margin-bottom:2px}
.price-sticker .big{font-size:40px}
.price-sticker .small{font-size:12px;letter-spacing:.1em;margin-top:2px}
@keyframes bob{0%,100%{transform:rotate(-12deg) translateY(0)}50%{transform:rotate(-10deg) translateY(-6px)}}
@media(prefers-reduced-motion:reduce){.price-sticker{animation:none}}

/* ============ PRODUCT BANNER SLIDER ============ */
/* ============ STATS BAR (hero → bundles transition) ============ */
.stats-bar{
  position:relative;
  padding:clamp(40px,5vw,60px) 0;
  background:
    radial-gradient(ellipse 70% 100% at 50% 50%, rgba(255,255,255,.025), transparent 70%),
    var(--surface);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  overflow:hidden;
}
.stats-row{
  display:flex;align-items:center;justify-content:space-between;
  gap:clamp(16px,3vw,40px);
}
.stat{
  flex:1;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  text-align:center;
  min-width:0;
}
.stat-num{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(34px,5.2vw,60px);
  letter-spacing:-.02em;
  line-height:.95;
  text-shadow:0 0 36px currentColor;
  filter:saturate(1.05);
}
.stat-num .stat-unit{
  font-size:.45em;font-weight:600;letter-spacing:0;
  color:var(--text-muted);
  margin-left:2px;
  text-shadow:none;
}
.stat-label{
  font-family:var(--font-body);font-weight:700;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-muted);
  white-space:nowrap;
}
.stat-divider{
  width:1px;height:60px;
  background:linear-gradient(180deg, transparent, var(--border-bright), transparent);
  flex-shrink:0;
}
/* Each stat gets its own rainbow color */
.stat-purple .stat-num{color:#FF2EC4}
.stat-teal   .stat-num{color:#2E9CFF}
.stat-yellow .stat-num{color:#FFD166}
.stat-orange .stat-num{color:#39FF14}

@media (max-width: 860px){
  .stats-row{flex-wrap:wrap;gap:28px 20px;justify-content:center}
  .stat{flex:0 0 calc(50% - 10px);min-width:0}
  .stat-divider{display:none}
  .stat-label{font-size:10px;letter-spacing:.16em;white-space:normal}
}

/* ============ BUNDLES ============ */
.bundles{position:relative}
.bundle-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
@media(max-width:960px){.bundle-grid{grid-template-columns:1fr}}

.bundle{
  position:relative;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:28px;
  display:flex;flex-direction:column;
  transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.bundle:hover{
  transform:translateY(-4px);
  border-color:var(--bundle-color);
  box-shadow:0 18px 40px -16px var(--bundle-color);
}

/* Per-bundle color tokens drive title, price, and SAVE-chip accents */
.bundle-starter   {--bundle-color:#2E9CFF}     /* teal */
.bundle-popular   {--bundle-color:#FF2EC4}     /* pink */
.bundle-collector {--bundle-color:#FFD166}     /* gold/yellow */
.bundle-ultimate  {--bundle-color:#39FF14}     /* rainbow card overrides below */

.bundle-starter{
  border-color:rgba(46,156,255,.45);
  box-shadow:0 -1px 0 rgba(46,156,255,.35) inset, 0 0 80px -28px rgba(46,156,255,.55);
}

/* Best Value badge — Collector's Box treatment */
.bundle.best-value{
  border-color:rgba(255,209,102,.45);
  box-shadow:0 -1px 0 rgba(255,209,102,.35) inset, 0 0 80px -28px rgba(255,209,102,.55);
}
.bundle.best-value::before{
  content:"Best Value";
  position:absolute;top:-16px;right:28px;
  background:linear-gradient(90deg,#FFD166,#FF9F3D);
  color:#2a1a00;
  font-family:var(--font-body);font-weight:800;
  letter-spacing:.18em;text-transform:uppercase;
  padding:7px 16px 6px;border-radius:999px;font-size:11px;
  box-shadow:0 8px 22px -6px rgba(255,209,102,.55), inset 0 1px 0 rgba(255,255,255,.45);
  z-index:2;white-space:nowrap;
}

.bundle-starter:hover,
.bundle.best-value:hover{
  transform:translateY(-4px);
  border-color:var(--bundle-color);
  box-shadow:
    0 -1px 0 color-mix(in srgb, var(--bundle-color) 35%, transparent) inset,
    0 18px 40px -16px var(--bundle-color),
    0 0 80px -28px var(--bundle-color);
}

.bundle-ultimate{
  border-color:transparent;
  background:
    linear-gradient(var(--surface),var(--surface)) padding-box,
    var(--rainbow) border-box;
  box-shadow:
    0 -1px 0 rgba(255,255,255,.18) inset,
    0 0 86px -34px rgba(255,46,196,.7),
    0 0 86px -40px rgba(46,156,255,.72);
}
.bundle-ultimate:hover{
  transform:translateY(-4px);
  border-color:transparent;
  box-shadow:
    0 -1px 0 rgba(255,255,255,.24) inset,
    0 18px 42px -22px rgba(255,46,196,.66),
    0 0 80px -34px rgba(57,255,20,.9),
    0 0 80px -34px rgba(46,156,255,.82);
}
.bundle-ultimate h3,
.bundle-ultimate .price-now{
  color:var(--text);
}
.mrc-shop-hero-copy h1 .gradient{
  background:var(--rainbow);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  -webkit-text-fill-color:transparent;
  text-shadow:none;
}
.bundle-ultimate .save-chip{
  background:
    linear-gradient(#121212,#121212) padding-box,
    var(--rainbow) border-box;
  border:1px solid transparent;
  color:var(--text);
  box-shadow:0 0 28px -18px rgba(57,255,20,.85);
}
.bundle-ultimate .btn-bundle:hover{
  background:var(--rainbow);
  border-color:transparent;
  color:#050505;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.22),
    0 0 26px -6px rgba(57,255,20,.9),
    0 18px 34px -20px rgba(46,156,255,.78);
}


/* Preview row — square-rounded chips, side-by-side */
.bundle-preview{
  display:flex;
  gap:6px;
  margin-bottom:24px;
  flex-wrap:nowrap;
}
.bundle-preview .chip{
  width:50px;height:50px;
  flex-shrink:0;
  border-radius:10px;
  background:#fff;
  display:grid;place-items:center;
  overflow:hidden;
  align-items:center;
  justify-items:center;
  box-shadow:0 2px 6px rgba(0,0,0,.4), inset 0 0 0 1px rgba(255,255,255,.1);
}
.bundle-preview .chip img{
  display:block;
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  padding:10%;
  box-sizing:border-box;
  transform:none;
}
.bundle-preview .more{
  background:var(--surface-3);
  color:var(--text-muted);
  font-family:var(--font-body);font-weight:700;font-size:13px;
  letter-spacing:.02em;
  border-radius:10px;
  box-shadow:none;
}

/* Title + sub-label */
.bundle h3{
  font-family:var(--font-chunky);
  font-weight:400;
  font-size:32px;
  letter-spacing:-.005em;
  line-height:1;
  margin:0 0 14px;
  color:var(--bundle-color);
  text-shadow:0 0 32px color-mix(in srgb, var(--bundle-color) 35%, transparent);
}
.bundle .pick{
  color:var(--text);
  font-weight:700;
  font-size:15px;
  letter-spacing:0;
  margin:0 0 22px;
}

/* Price row */
.price-row{
  display:flex;align-items:baseline;gap:14px;margin-bottom:24px;
}
.price-now{
  font-family:var(--font-display);
  font-weight:800;
  font-size:48px;line-height:.9;
  letter-spacing:-.025em;
  color:var(--bundle-color);
}
.price-was{
  font-family:var(--font-display);
  color:var(--text-dim);
  text-decoration:line-through;
  text-decoration-thickness:1px;
  font-size:22px;
  font-weight:600;
}

/* SAVE chip — always green, sits below price */
.save-chip{
  display:inline-flex;align-items:center;
  padding:10px 18px;border-radius:999px;
  background:rgba(57,255,20,.1);
  color:var(--accent);
  font-family:var(--font-display);font-weight:800;
  font-size:13px;letter-spacing:.08em;text-transform:uppercase;
  border:1px solid rgba(57,255,20,.22);
  width:max-content;
  margin-bottom:24px;
}

/* Bundle button — dark/neutral with arrow, full width, sits at bottom */
.bundle .btn-bundle{
  margin-top:auto;width:100%;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 22px;
  border-radius:var(--radius-md);
  background:var(--surface-2);
  color:var(--text);
  border:1px solid var(--border);
  font-family:var(--font-display);font-weight:700;font-size:15px;
  letter-spacing:.005em;
  transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.bundle .btn-bundle:hover{
  background:var(--bundle-color);
  border-color:var(--bundle-color);
  color:#0a0a0a;
  transform:translateY(-1px);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--bundle-color) 42%, transparent),
    0 0 24px -4px color-mix(in srgb, var(--bundle-color) 58%, transparent),
    0 18px 32px -18px var(--bundle-color);
}
.bundle .btn-bundle svg{width:16px;height:16px;transition:transform var(--dur) var(--ease)}
.bundle .btn-bundle:hover svg{transform:translateX(3px)}

/* Ultimate Bundle: final rainbow overrides after shared bundle button rules */
.bundle-ultimate::before{
  content:"Biggest Save";
  position:absolute;
  top:-16px;
  right:28px;
  z-index:3;
  white-space:nowrap;
  padding:7px 16px 6px;
  border-radius:999px;
  background:var(--rainbow);
  color:#050505;
  font-family:var(--font-body);
  font-size:11px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
  box-shadow:
    0 8px 22px -6px rgba(57,255,20,.65),
    0 0 30px -12px rgba(255,46,196,.8),
    inset 0 1px 0 rgba(255,255,255,.45);
}
.bundle-ultimate h3,
.bundle-ultimate .price-now{
  background:var(--rainbow);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  -webkit-text-fill-color:transparent;
  text-shadow:none;
}
.bundle-ultimate .btn-bundle:hover{
  background:var(--rainbow);
  border-color:transparent;
  color:#050505;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.22),
    0 0 26px -6px rgba(57,255,20,.9),
    0 18px 34px -20px rgba(46,156,255,.78);
}


/* ============ PROMINENT END-OF-SECTION CTA ============ */
.section-cta{
  margin-top:clamp(36px,5vw,56px);
  display:flex;justify-content:center;
}
.btn-mega{
  position:relative;
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 38px;
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(15px,1.4vw,17px);
  letter-spacing:.04em;text-transform:uppercase;
  color:var(--text);
  background:#0a0a0a;
  border:0;
  border-radius:var(--radius-pill);
  cursor:pointer;
  /* Use double-bg + clip trick to render rainbow gradient AS the border */
  background:
    linear-gradient(#0a0a0a, #0a0a0a) padding-box,
    var(--rainbow) border-box;
  border:2.5px solid transparent;
  box-shadow:
    0 0 32px -8px rgba(255,46,196,.4),
    0 0 32px -8px rgba(57,255,20,.3),
    0 12px 32px -10px rgba(0,0,0,.6);
  transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.btn-mega:hover{
  transform:translateY(-2px);
  box-shadow:
    0 0 48px -8px rgba(255,46,196,.55),
    0 0 48px -8px rgba(57,255,20,.45),
    0 18px 40px -10px rgba(0,0,0,.65);
}
.btn-mega:active{transform:translateY(0)}
.btn-mega .btn-mega-count{
  font-family:var(--font-mono);font-weight:700;
  font-size:11px;letter-spacing:.08em;
  padding:4px 9px;border-radius:999px;
  background:rgba(255,255,255,.08);
  color:var(--text-muted);
  text-transform:none;
}
.btn-mega .btn-mega-arrow{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;
  background:var(--rainbow);
  color:#0a0a0a;
  transition:transform var(--dur) var(--ease);
}
.btn-mega:hover .btn-mega-arrow{transform:translateX(6px)}
.btn-mega .btn-mega-arrow svg{width:14px;height:14px;stroke-width:3}

@media (max-width:560px){
  .btn-mega{padding:15px 24px;font-size:13px;gap:10px}
  .btn-mega .btn-mega-arrow{width:24px;height:24px}
}

/* ============ CATEGORIES ============ */
.cats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
@media(max-width:900px){.cats{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.cats{grid-template-columns:repeat(2,1fr)}}
.cat{
  position:relative;
  aspect-ratio:1/1;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:20px 20px 22px;
  transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
/* ---- Rotating rainbow accent per card (shared by .cat and .product) ---- */
.cat,
.product{
  --card-accent:#FF2EC4;   /* purple */
  --card-accent-ink:#fff;
}
.cat:nth-child(4n+2),
.product:nth-child(4n+2){--card-accent:#2E9CFF;--card-accent-ink:#fff}            /* teal */
.cat:nth-child(4n+3),
.product:nth-child(4n+3){--card-accent:#FFD166;--card-accent-ink:#2a1a00}         /* yellow */
.cat:nth-child(4n+4),
.product:nth-child(4n+4){--card-accent:#39FF14;--card-accent-ink:#0a0a0a}         /* orange */

.cat:hover{
  transform:translateY(-3px);
  border-color:var(--card-accent);
  box-shadow:0 14px 32px -10px var(--card-accent);
}
.cat-art{
  position:absolute;inset:0;
  display:grid;place-items:center;
  font-size:74px;
  filter:saturate(1.1);
}
.cat-art img{
  width:64%;height:64%;object-fit:contain;
  transition:transform var(--dur-slow) var(--ease);
  filter:drop-shadow(0 10px 20px rgba(0,0,0,.4));
}
.cat:hover .cat-art img{transform:scale(1.06) rotate(-3deg)}
.cat::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.85));
}
.cat h3{
  position:relative;z-index:1;
  font-family:var(--font-display);
  font-weight:700;
  font-size:19px;
  margin:0 0 3px;
  letter-spacing:-.01em;
  line-height:1.1;
}
.cat-count{
  position:relative;z-index:1;
  display:block;
  font-family:var(--font-mono);
  font-size:10.5px;font-weight:500;
  color:var(--text-dim);
  margin:0;
  letter-spacing:.04em;
  line-height:1.2;
}
.cat:hover .cat-count{color:var(--text-muted)}
.cat .arrow{
  position:absolute;top:16px;right:16px;z-index:1;
  width:32px;height:32px;border-radius:50%;
  background:rgba(0,0,0,.5);backdrop-filter:blur(6px);
  display:grid;place-items:center;color:var(--text);
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease);
}
.cat:hover .arrow{background:var(--card-accent);color:var(--card-accent-ink)}
.cat .arrow svg{
  display:block;
  width:14px;
  height:14px;
  flex:0 0 14px;
}
.shop-grid .btn svg,
.shop-layout .btn svg,
.bundle .btn-bundle svg,
.add-btn svg,
.wish svg{
  max-width:18px;
  max-height:18px;
  flex:0 0 auto;
}

/* ============ CATEGORIES PAGE ============ */
#cats-page{--section-accent:var(--accent)}
.categories-intro h1 .gradient{
  background:var(--rainbow);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}
.cats-toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:clamp(18px,3vw,30px);
  flex-wrap:wrap;
}
.cats-search{
  min-width:min(420px,100%);
  flex:1;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  border:1px solid var(--border);
  border-radius:var(--radius-pill);
  background:var(--surface);
  color:var(--text-muted);
  box-shadow:var(--shadow-sm);
}
.cats-search:focus-within{
  border-color:var(--accent);
  box-shadow:0 0 0 4px rgba(57,255,20,.12);
}
.cats-search svg{
  width:16px;
  height:16px;
  flex:0 0 16px;
  color:var(--accent);
}
.cats-search input{
  width:100%;
  min-width:0;
  border:0;
  outline:0;
  background:transparent;
  color:var(--text);
  font:inherit;
}
.cats-search input::placeholder{color:var(--text-dim)}
.cats-result-count{
  margin:0;
  color:var(--text-muted);
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:700;
  letter-spacing:.04em;
}
.cats-page-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.cat-tile--v2{
  --tile-color:var(--accent);
  position:relative;
  min-height:188px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:16px;
  padding:18px;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  background:
    radial-gradient(circle at 18% 12%, color-mix(in srgb, var(--tile-color) 18%, transparent), transparent 36%),
    linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.01)),
    var(--surface);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.cat-tile--v2:hover{
  transform:translateY(-4px);
  border-color:var(--tile-color);
  box-shadow:0 18px 42px -20px var(--tile-color),var(--shadow-md);
}
.cat-tile--v2::after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:2px;
  background:var(--tile-color);
  opacity:.55;
}
.v2-img{
  min-height:96px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  position:relative;
  z-index:1;
}
.v2-emoji{
  width:74px;
  height:74px;
  display:grid;
  place-items:center;
  border-radius:18px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  font-size:38px;
  line-height:1;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.v2-count{
  min-width:44px;
  height:30px;
  display:inline-grid;
  place-items:center;
  padding:0 10px;
  border-radius:var(--radius-pill);
  background:color-mix(in srgb, var(--tile-color) 16%, var(--surface-2));
  border:1px solid color-mix(in srgb, var(--tile-color) 35%, transparent);
  color:var(--text);
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:800;
}
.v2-body{
  position:relative;
  z-index:1;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
}
.v2-title{
  margin:0;
  color:var(--text);
  font-family:var(--font-chunky);
  font-size:clamp(22px,2vw,30px);
  font-weight:400;
  line-height:1.02;
  letter-spacing:0;
}
.v2-arrow{
  width:38px;
  height:38px;
  flex:0 0 38px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:rgba(0,0,0,.35);
  border:1px solid var(--border);
  color:var(--tile-color);
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),transform var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.cat-tile--v2:hover .v2-arrow{
  background:var(--tile-color);
  border-color:var(--tile-color);
  color:#0a0a0a;
  transform:translateX(2px);
}
.v2-arrow svg{
  display:block;
  width:17px;
  height:17px;
  flex:0 0 17px;
}
.cats-empty{
  display:none;
  margin:22px 0 0;
  padding:24px;
  border:1px dashed var(--border-bright);
  border-radius:var(--radius-lg);
  color:var(--text-muted);
  text-align:center;
}
.cats-empty.is-visible{display:block}
@media (max-width:1060px){.cats-page-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:760px){
  .cats-page-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
  .cat-tile--v2{min-height:164px;padding:14px;border-radius:16px}
  .v2-img{min-height:78px}
  .v2-emoji{width:58px;height:58px;border-radius:14px;font-size:30px}
  .v2-count{height:28px;font-size:11px}
  .v2-title{font-size:22px}
  .v2-arrow{width:34px;height:34px;flex-basis:34px}
}
@media (max-width:420px){
  .cats-page-grid{grid-template-columns:1fr}
  .cat-tile--v2{min-height:138px}
}

/* ============ PRODUCTS ============ */
.products{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  position:relative;
}
@media(max-width:1040px){.products{grid-template-columns:repeat(3,1fr)}}
@media(max-width:740px){.products{grid-template-columns:repeat(2,1fr)}}

/* ============ SEARCH ============ */
/* Header overlay — triggered by the magnifier icon in the nav */
.search-overlay{
  position:fixed;
  inset:112px 0 0;
  z-index:9980;
  background:rgba(10,10,10,.72);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  opacity:0;
  transition:opacity .2s var(--ease);
  display:flex;
  align-items:flex-start;
  padding-top:clamp(36px,7vh,86px);
  overflow-y:auto;
}
.search-overlay.is-open{opacity:1}
.search-overlay[hidden]{display:none}
.search-overlay .wrap{width:100%;max-width:820px}
.search-form{
  display:flex;align-items:center;gap:14px;
  padding:18px 22px;
  background:var(--surface);
  border:1px solid var(--border-bright);
  border-radius:var(--radius-pill);
  box-shadow:0 20px 60px rgba(0,0,0,.5), 0 0 0 1px rgba(57,255,20,.15);
}
.search-form svg{flex-shrink:0;color:var(--accent)}
.search-form > svg{display:none}
.search-form input{
  flex:1;
  background:none;border:0;outline:0;
  font-family:var(--font-body);font-size:18px;font-weight:500;
  color:var(--text);
  letter-spacing:-.005em;
}
/* Hide the browser-native ✕ on type=search (was overlapping our close button) */
.search-form input::-webkit-search-cancel-button,
.search-form input::-webkit-search-clear-button,
.search-form input::-webkit-search-results-button,
.search-form input::-webkit-search-results-decoration{display:none}
.search-form input{appearance:none;-webkit-appearance:none}
.search-form input::placeholder{color:var(--text-dim)}
.search-submit{
  flex-shrink:0;
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:var(--accent);
  color:var(--accent-ink);
  box-shadow:0 0 22px -8px var(--accent);
}
.search-submit:hover{
  transform:translateY(-1px);
  filter:brightness(1.04);
}
.search-submit svg{color:currentColor}

/* Wrap the form + close button so the close sits visibly outside the input pill */
.search-overlay .search-shell{
  display:flex;align-items:center;gap:14px;
}
.search-overlay .search-form{flex:1}
.search-close{
  flex-shrink:0;
  width:44px;height:44px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.4);color:var(--text);
  border:1px solid var(--border-bright);
  font-size:14px;line-height:1;
  cursor:pointer;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.search-close:hover{
  background:var(--surface);
  border-color:var(--text);
  transform:rotate(90deg);
}
@media (max-width:560px){
  .search-overlay{
    inset:92px 0 0;
    padding-top:28px;
  }
  .search-overlay .search-shell{gap:8px}
  .search-close{width:38px;height:38px}
}
.search-suggest{
  margin-top:18px;padding:0 22px;
  display:flex;flex-wrap:wrap;align-items:center;gap:8px 10px;
}
.search-suggest-label{
  font-family:var(--font-body);font-weight:700;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-dim);
}
.search-suggest a{
  font-family:var(--font-body);font-weight:600;
  font-size:13px;
  padding:6px 12px;
  border-radius:var(--radius-pill);
  background:rgba(255,255,255,.05);
  border:1px solid var(--border);
  color:var(--text-muted);
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.search-suggest a:hover{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}

/* In-page search — banner style (compact, horizontal) */
.search-strip-card.embedded{
  margin-bottom:clamp(24px,3.5vw,40px);
}
.search-strip-card{
  padding:18px 22px;
  background:
    radial-gradient(60% 180% at 0% 50%, color-mix(in srgb, var(--section-accent) 9%, transparent) 0%, transparent 55%),
    var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-pill);
  display:flex;align-items:center;gap:20px;
  flex-wrap:wrap;
}
.search-banner-label{
  flex-shrink:0;
  font-family:var(--font-body);font-weight:800;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--section-accent);
  display:inline-flex;align-items:center;gap:8px;
}
.search-banner-label .dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--section-accent);
  box-shadow:0 0 10px var(--section-accent);
}
.search-strip-input{
  flex:1;min-width:260px;
  display:flex;gap:8px;
  background:var(--surface-2);
  border:1px solid var(--border-bright);
  border-radius:var(--radius-pill);
  padding:4px 6px 4px 18px;
  align-items:center;
  transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.search-strip-input:focus-within{
  border-color:var(--section-accent);
  box-shadow:0 0 0 1px var(--section-accent), 0 0 24px -10px var(--section-accent);
}
.search-strip-input svg{flex-shrink:0;color:var(--text-muted)}
.search-strip-input input{
  flex:1;
  background:none;border:0;outline:0;
  font-family:var(--font-body);font-size:14px;font-weight:500;
  color:var(--text);
  padding:10px 0;
  min-width:0;
}
.search-strip-input input::placeholder{color:var(--text-dim)}
.search-strip-input button{
  flex-shrink:0;
  padding:9px 18px;
  border-radius:var(--radius-pill);
  background:var(--accent);color:var(--accent-ink);
  font-family:var(--font-display);font-weight:700;font-size:13px;
  letter-spacing:.02em;
  box-shadow:0 0 18px -6px var(--accent-glow);
  transition:transform var(--dur) var(--ease),filter var(--dur) var(--ease);
}
.search-strip-input button:hover{transform:translateY(-1px);filter:brightness(1.08)}

.search-strip-tags{
  flex-shrink:0;
  display:flex;flex-wrap:wrap;align-items:center;gap:6px 8px;
}
.search-strip-tags .label{
  font-family:var(--font-body);font-weight:700;
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-dim);
}
.search-strip-tags a{
  font-size:12px;font-weight:600;
  color:var(--text-muted);
  padding:3px 9px;border-radius:var(--radius-pill);
  border:1px solid var(--border);
  transition:color var(--dur) var(--ease),border-color var(--dur) var(--ease),background var(--dur) var(--ease);
}
.search-strip-tags a:hover{color:var(--text);border-color:var(--border-bright);background:var(--surface)}

/* ============ SHOP SHIPPING STRIP ============ */
.ship-strip{
  padding:clamp(14px,2vw,22px) 0;
  background:linear-gradient(180deg,rgba(255,255,255,.015),rgba(255,255,255,0));
}
.ship-row{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  padding:12px 16px;
  border:1px solid var(--border);
  border-radius:var(--radius-pill);
  background:rgba(255,255,255,.025);
  color:var(--text);
  overflow:hidden;
}
.ship-row-label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--text-muted);
  font-family:var(--font-body);
  font-weight:700;
  font-size:13px;
  white-space:nowrap;
}
.ship-row-label svg{
  width:18px;
  height:18px;
  flex:0 0 18px;
  color:var(--accent);
}
.ship-divider{
  width:1px;
  height:22px;
  background:var(--border);
  flex:0 0 1px;
}
.ship-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  min-height:34px;
  padding:7px 12px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-pill);
  background:rgba(0,0,0,.24);
  color:var(--text);
  font-size:14px;
  line-height:1;
  white-space:nowrap;
}
.ship-pill .flag{font-size:16px;line-height:1}
.ship-pill strong{font-weight:800;color:var(--text)}

@media (max-width:860px){
  .search-strip-card{border-radius:var(--radius-md);padding:16px;gap:14px}
  .search-strip-tags{flex-basis:100%;order:3}
}
@media (max-width:560px){
  .search-strip-input{flex-wrap:wrap;border-radius:var(--radius-md);padding:10px}
  .search-strip-input input{width:100%;padding:6px 6px}
  .search-strip-input button{width:100%;padding:10px}
  .search-banner-label{flex-basis:100%}
}

/* ---- Category filter bar ---- */
.filter-bar{
  display:flex;
  gap:10px;
  margin-bottom:28px;
  flex-wrap:wrap;
  padding-bottom:2px;
}
.filter-chip{
  flex-shrink:0;
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-body);font-weight:700;
  font-size:13px;letter-spacing:.01em;
  padding:10px 16px;
  border-radius:var(--radius-pill);
  background:var(--surface);
  border:1px solid var(--border);
  color:var(--text-muted);
  cursor:pointer;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);
  white-space:nowrap;
}
.filter-chip:hover{color:var(--text);border-color:var(--border-bright)}
.filter-chip:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
/* Default active chip — fallback */
.filter-chip.active{
  background:var(--card);
  color:var(--ink);
  border-color:var(--card);
  box-shadow:0 0 22px -6px var(--card);
}
/* Per-chip brand colors when active — full brand rainbow cycle */
.filter-chip[data-filter="all"].active{--card:#FF2EC4; --ink:#fff}
.filter-chip[data-filter="new"].active{--card:#2E9CFF; --ink:#fff}
.filter-chip[data-filter="bestseller"].active{--card:#FFD166; --ink:#2a1a00}
.filter-chip[data-filter="sale"].active{--card:#39FF14; --ink:#0a0a0a}
.filter-chip[data-filter="food-drink"].active{--card:#FF2EC4; --ink:#fff}
.filter-chip[data-filter="sports"].active{--card:#2E9CFF; --ink:#fff}
.filter-chip[data-filter="movies-games"].active{--card:#FFD166; --ink:#2a1a00}
.filter-chip[data-filter="funny"].active{--card:#FF2EC4; --ink:#fff}
.filter-chip[data-filter="cars-bikes"].active{--card:#39FF14; --ink:#0a0a0a}
      /* purple */
.filter-chip[data-filter="new"].active        {--card:#2E9CFF; --ink:#fff}      /* teal */
.filter-chip[data-filter="bestseller"].active {--card:#FFD166; --ink:#2a1a00}   /* yellow */
.filter-chip[data-filter="sale"].active       {--card:#FFD166; --ink:#2a1a00}   /* orange */
.filter-chip[data-filter="food-drink"].active {--card:#FF2EC4; --ink:#fff}      /* red */
.filter-chip[data-filter="sports"].active     {--card:#2E9CFF; --ink:#fff}      /* blue */
.filter-chip[data-filter="movies-games"].active{--card:#FF2EC4; --ink:#fff}     /* pink */
.filter-chip[data-filter="funny"].active      {--card:#FFD166; --ink:#2a1a00}   /* gold */
.filter-chip[data-filter="cars-bikes"].active {--card:#39FF14; --ink:#0a0a0a}   /* neon green */
.filter-count{
  font-family:var(--font-mono);
  font-size:11px;font-weight:700;
  color:var(--text-dim);
  background:var(--surface-3);
  padding:2px 7px;
  border-radius:999px;
  min-width:22px;text-align:center;
  line-height:1.3;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease);
}
.filter-chip.active .filter-count{
  background:rgba(0,0,0,.22);
  color:var(--accent-ink);
}

/* Empty state when no products match filter */
.products-empty{
  display:none;
  grid-column:1 / -1;
  text-align:center;
  padding:56px 20px;
  border:1px dashed var(--border-bright);
  border-radius:var(--radius-md);
  color:var(--text-muted);
}
.products.is-empty .products-empty{display:block}
.products-empty h4{
  font-family:var(--font-chunky);font-weight:400;
  font-size:22px;line-height:1.1;
  color:var(--text);
  margin:0 0 8px;
  text-transform:uppercase;
  letter-spacing:-.005em;
}
.products-empty p{margin:0;font-size:14px}

.pagination{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  margin:34px 0 0;
}
.pagination a,
.pagination button,
.pagination .dots{
  min-width:38px;
  height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  padding:0 13px;
  border:1px solid var(--border);
  border-radius:var(--radius-pill);
  background:var(--surface);
  color:var(--text-muted);
  font-family:var(--font-body);
  font-weight:800;
  font-size:13px;
  line-height:1;
}
.pagination a.active,
.pagination a[aria-current="page"]{
  background:var(--accent);
  border-color:var(--accent);
  color:var(--accent-ink);
}
.pagination a:hover,
.pagination button:hover{
  border-color:var(--accent);
  color:var(--text);
}
.pagination button:disabled{
  opacity:.42;
  cursor:not-allowed;
}
.pagination svg{
  display:block;
  width:15px;
  height:15px;
  flex:0 0 15px;
}
.pagination .dots{
  border-color:transparent;
  background:transparent;
  min-width:24px;
  padding:0 4px;
}

@media (max-width: 640px){
  .filter-bar{
    flex-wrap:nowrap;
    overflow-x:auto;
    scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
    margin-left:calc(var(--gutter) * -1);
    margin-right:calc(var(--gutter) * -1);
    padding:0 var(--gutter) 4px;
  }
  .filter-bar::-webkit-scrollbar{display:none}
  .filter-chip{font-size:12px;padding:9px 13px}
}

.product{
  position:relative;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.product:hover{
  transform:translateY(-4px);
  border-color:var(--card-accent);
  box-shadow:0 14px 32px -10px var(--card-accent);
}
.product:hover .product-img img{transform:scale(1.05)}

.product-img{
  position:relative;aspect-ratio:1/1;
  background:radial-gradient(circle at 50% 40%,var(--surface-2),var(--surface) 70%);
  overflow:hidden;
}
.product-img img{
  width:100%;height:100%;
  object-fit:contain;
  padding:10%;
  transition:transform var(--dur-slow) var(--ease), opacity .18s var(--ease);
}
/* Secondary product thumbnail — bottom-left corner of the main image */
.product-thumb{
  position:absolute;
  left:12px;bottom:12px;
  z-index:3;
  width:54px;height:54px;
  border-radius:50%;
  background:radial-gradient(circle at 50% 40%,var(--surface-2),var(--surface) 70%);
  border:2px solid var(--surface);
  box-shadow:0 4px 14px rgba(0,0,0,.4), 0 0 0 1px var(--border-bright);
  overflow:hidden;
  transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.product-thumb img{
  width:100%;height:100%;
  object-fit:contain;
  padding:6px;
  display:block;
  transition:transform var(--dur-slow) var(--ease);
}
.product:hover .product-thumb{
  transform:scale(1.08);
  border-color:var(--card-accent);
  box-shadow:0 6px 22px rgba(0,0,0,.5), 0 0 0 1px var(--card-accent);
}
@media (max-width:740px){
  .product-thumb{width:44px;height:44px;left:10px;bottom:10px}
}
.badge{
  position:absolute;top:12px;left:12px;z-index:2;
  padding:4px 9px;border-radius:999px;
  font-family:var(--font-display);font-weight:700;font-size:9px;letter-spacing:.08em;text-transform:uppercase;
  background:var(--accent);color:var(--accent-ink);
}
.badge.best{background:var(--pink);color:#fff}
.badge.sold{background:var(--danger);color:#fff}

.wish{
  position:absolute;top:12px;right:12px;z-index:2;
  width:34px;height:34px;border-radius:50%;
  background:rgba(0,0,0,.5);backdrop-filter:blur(6px);
  display:grid;place-items:center;color:var(--text);
  transition:color var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.wish:hover{color:var(--pink);transform:scale(1.1)}
.wish svg{width:16px;height:16px}

.product-body{
  padding:16px 16px 18px;
  display:flex;flex-direction:column;gap:12px;
  flex:1;
}
.product h3{
  margin:0;
  font-size:14px;font-weight:600;
  line-height:1.35;
  color:var(--text);
  /* 2-line clamp */
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;
  min-height:2.7em;
}
.product-foot{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin-top:auto;
}
.product-price{font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-.01em}
.add-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:var(--radius-pill);
  background:var(--surface-3);color:var(--text);
  font-weight:700;font-size:13px;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease);
}
.add-btn:hover{background:var(--accent);color:var(--accent-ink)}
.add-btn svg{width:14px;height:14px}
.product.out .add-btn{background:transparent;color:var(--text-muted);border:1px solid var(--border-bright)}
.product.out .add-btn:hover{background:var(--surface-3);color:var(--text)}

/* ============ FILTER DRAWER ============ */
.filter-drawer-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:var(--radius-pill);
  background:var(--surface);
  border:1px solid var(--border);
  color:var(--text);
  font-family:var(--font-body);font-weight:700;
  font-size:13px;letter-spacing:.01em;
  cursor:pointer;flex-shrink:0;
  transition:border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.filter-drawer-btn:hover{border-color:var(--border-bright);background:var(--surface-2)}
.filter-drawer-btn svg{width:14px;height:14px;color:var(--text-muted);transition:color var(--dur) var(--ease)}
.filter-drawer-btn:hover svg{color:var(--text)}
.filter-drawer-btn .badge-count{
  display:inline-grid;place-items:center;
  min-width:20px;height:20px;padding:0 6px;
  border-radius:999px;
  background:var(--section-accent);
  color:#fff;
  font-family:var(--font-mono);font-weight:700;font-size:11px;
  margin-left:2px;
}
.filter-drawer-btn:not(.has-filters) .badge-count{display:none}

/* Drawer overlay + panel */
.drawer-overlay{
  position:fixed;inset:0;z-index:80;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  opacity:0;
  transition:opacity .25s var(--ease);
}
.drawer-overlay[hidden]{display:none}
.drawer-overlay.is-open{opacity:1}

.filter-drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:81;
  width:min(420px, 100vw);
  background:var(--bg);
  border-left:1px solid var(--border-bright);
  box-shadow:-30px 0 60px rgba(0,0,0,.5);
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .3s var(--ease);
}
.filter-drawer[hidden]{display:none}
.filter-drawer.is-open{transform:translateX(0)}

.drawer-head{
  flex-shrink:0;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 24px;
  border-bottom:1px solid var(--border);
  background:var(--surface);
}
.drawer-head h3{
  font-family:var(--font-chunky);font-weight:400;
  font-size:24px;line-height:1;letter-spacing:-.005em;
  margin:0;
}
.drawer-close{
  width:36px;height:36px;border-radius:50%;
  display:grid;place-items:center;
  background:var(--surface-2);
  color:var(--text-muted);
  cursor:pointer;
  font-size:14px;line-height:1;
  transition:background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.drawer-close:hover{background:var(--surface-3);color:var(--text)}

.drawer-body{
  flex:1;
  overflow-y:auto;
  padding:8px 0;
}
/* Subtle custom scrollbar for the drawer */
.drawer-body::-webkit-scrollbar{width:8px}
.drawer-body::-webkit-scrollbar-track{background:transparent}
.drawer-body::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:999px}
.drawer-body::-webkit-scrollbar-thumb:hover{background:var(--border-bright)}

/* Drawer search field at the top */
.drawer-search{
  position:sticky;top:0;z-index:1;
  margin:0;padding:14px 24px;
  background:linear-gradient(180deg, var(--bg) 0%, var(--bg) 80%, transparent 100%);
}
.drawer-search-input{
  display:flex;align-items:center;gap:10px;
  padding:11px 16px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-pill);
  transition:border-color var(--dur) var(--ease);
}
.drawer-search-input:focus-within{border-color:var(--section-accent)}
.drawer-search-input svg{color:var(--text-dim);flex-shrink:0}
.drawer-search-input input{
  flex:1;background:none;border:0;outline:0;
  font-family:var(--font-body);font-size:14px;font-weight:500;
  color:var(--text);
}
.drawer-search-input input::placeholder{color:var(--text-dim)}

/* Filter groups (accordion) */
.filter-group{
  border-bottom:1px solid var(--border);
  --group-color:var(--accent); /* default; overridden inline per group */
}
.filter-group > summary .group-emoji{
  display:inline-grid;place-items:center;
  width:26px;height:26px;
  border-radius:8px;
  background:color-mix(in srgb, var(--group-color) 14%, transparent);
  border:1px solid color-mix(in srgb, var(--group-color) 35%, transparent);
  font-size:14px;line-height:1;
  margin-right:4px;
  text-transform:none;letter-spacing:0;
  box-shadow:0 0 16px -8px var(--group-color);
}
/* Color the group title text using the group's color */
.filter-group > summary{color:var(--group-color)}
.filter-group > summary:hover{filter:brightness(1.15)}
/* Reset count + chevron back to neutral so they're not overpowering */
.filter-group > summary .group-count{color:var(--text-dim)}
.filter-group > summary .chevron{color:var(--text-muted)}
.filter-group[open] > summary .chevron{color:var(--group-color)}

/* Drawer chip emoji */
.drawer-chip .chip-emoji{
  font-size:13px;line-height:1;
  margin-right:1px;
  filter:saturate(1.1);
  text-transform:none;letter-spacing:0;
}
.filter-group > summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:16px 24px;
  font-family:var(--font-body);font-weight:800;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text);
  user-select:none;
  transition:color var(--dur) var(--ease);
}
.filter-group > summary::-webkit-details-marker{display:none}
.filter-group > summary:hover{color:var(--section-accent)}
.filter-group > summary .group-meta{
  display:inline-flex;align-items:center;gap:8px;
}
.filter-group > summary .group-count{
  font-family:var(--font-mono);font-weight:600;font-size:11px;
  color:var(--text-dim);letter-spacing:.04em;
  text-transform:none;
}
.filter-group > summary .chevron{
  width:14px;height:14px;color:var(--text-muted);
  transition:transform .2s var(--ease);
}
.filter-group[open] > summary .chevron{transform:rotate(180deg)}

.filter-group-options{
  padding:4px 18px 18px;
  display:flex;flex-wrap:wrap;gap:6px;
}
.drawer-chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 12px;
  border-radius:var(--radius-pill);
  background:var(--surface);
  border:1px solid var(--border);
  color:var(--text-muted);
  font-family:var(--font-body);font-weight:600;font-size:12.5px;
  cursor:pointer;
  transition:background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.drawer-chip:hover{color:var(--text);border-color:var(--border-bright)}
.drawer-chip.checked{
  background:var(--section-accent);
  color:#fff;
  border-color:var(--section-accent);
  box-shadow:0 0 16px -6px var(--section-accent);
}
.drawer-chip.checked::before{
  content:"✓";font-weight:900;font-size:11px;line-height:1;
}
.drawer-chip[hidden]{display:none}
.drawer-chip .chip-count{
  font-family:var(--font-mono);font-weight:600;font-size:10.5px;
  color:var(--text-dim);
  background:var(--surface-3);
  padding:1px 6px;
  border-radius:999px;
  letter-spacing:.04em;
  transition:background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.drawer-chip:hover .chip-count{color:var(--text-muted)}
.drawer-chip.checked .chip-count{
  background:rgba(0,0,0,.25);
  color:#fff;
}
.filter-group-empty{
  display:none;
  padding:0 6px;
  font-family:var(--font-body);font-size:12px;font-style:italic;
  color:var(--text-dim);
}
.filter-group.no-matches .filter-group-empty{display:block}
.filter-group.no-matches .filter-group-options > .drawer-chip{display:none}

/* Footer with apply / clear actions */
.drawer-foot{
  flex-shrink:0;
  display:flex;gap:10px;
  padding:18px 22px;
  border-top:1px solid var(--border);
  background:var(--surface);
}
.drawer-foot .btn-clear{
  flex:0 0 auto;
  padding:13px 22px;border-radius:var(--radius-pill);
  background:transparent;
  border:1px solid var(--border);
  color:var(--text-muted);
  font-family:var(--font-display);font-weight:700;font-size:13px;
  cursor:pointer;
  transition:color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.drawer-foot .btn-clear:hover{color:var(--text);border-color:var(--border-bright)}
.drawer-foot .btn-apply{
  flex:1;
  padding:13px 22px;border-radius:var(--radius-pill);
  background:var(--accent);color:var(--accent-ink);
  border:0;
  font-family:var(--font-display);font-weight:700;font-size:14px;letter-spacing:.01em;
  cursor:pointer;
  box-shadow:0 0 24px -6px var(--accent-glow);
  transition:filter var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.drawer-foot .btn-apply:hover{filter:brightness(1.08);transform:translateY(-1px)}

@media (max-width:560px){
  .filter-drawer{width:100vw;border-left:0}
}

/* Live search results inside overlay */
.search-results{
  margin-top:18px;
  padding:0 22px 22px;
}
.search-results-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 0 12px;
}
.search-results-count{
  font-family:var(--font-body);font-weight:700;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-dim);
}
.search-results-view-all{
  color:var(--accent);
  font-family:var(--font-display);
  font-size:13px;
  font-weight:900;
}
.search-results-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  max-height:60vh;overflow-y:auto;
  padding-right:4px;
}
.search-results-grid::-webkit-scrollbar{width:6px}
.search-results-grid::-webkit-scrollbar-track{background:transparent}
.search-results-grid::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:999px}
@media (max-width:740px){.search-results-grid{grid-template-columns:repeat(2,1fr)}}
.search-result{
  display:flex;flex-direction:column;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  overflow:hidden;
  text-decoration:none;
  transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.search-result:hover{border-color:var(--accent);transform:translateY(-2px)}
.search-result-img{
  aspect-ratio:1/1;
  background:radial-gradient(circle at 50% 40%,var(--surface-2),var(--surface) 70%);
  display:grid;place-items:center;padding:12%;
}
.search-result-img img{width:100%;height:100%;object-fit:contain}
.search-result-name{
  padding:8px 10px 2px;
  font-family:var(--font-display);font-weight:600;font-size:12px;
  color:var(--text);
  line-height:1.25;
  display:-webkit-box;
  -webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;
}
.search-result-meta{
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
  padding:0 10px 10px;
  color:var(--text-muted);
  font-size:11px;
  font-weight:800;
}
.search-no-results{
  text-align:center;padding:40px 20px;
  color:var(--text-muted);
}
.search-no-results p{margin:0}
.search-no-results .hint{
  font-size:13px;color:var(--text-dim);margin-top:8px;
}
.search-suggest-tag{
  font-family:var(--font-body);font-weight:600;
  font-size:13px;
  padding:6px 12px;
  border-radius:var(--radius-pill);
  background:rgba(255,255,255,.05);
  border:1px solid var(--border);
  color:var(--text-muted);
  cursor:pointer;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.search-suggest-tag:hover{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}

/* Homepage live product search */
.mrc-home-product-search{
  position:relative;
  display:grid;
  grid-template-columns:minmax(240px,.8fr) minmax(0,1.35fr);
  gap:clamp(16px,3vw,28px);
  align-items:start;
  margin:0 0 clamp(22px,3vw,34px);
  padding:clamp(18px,3vw,28px);
  overflow:hidden;
  border:1px solid var(--border-bright);
  border-radius:22px;
  background:
    radial-gradient(circle at 8% 12%,rgba(255,46,196,.15),transparent 30%),
    radial-gradient(circle at 88% 6%,rgba(46,156,255,.14),transparent 34%),
    linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.022));
  box-shadow:0 26px 70px -50px rgba(57,255,20,.68);
}
.mrc-home-product-search::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:4px;
  background:var(--rainbow);
}
.mrc-home-product-search-copy{
  position:relative;
  z-index:1;
}
.mrc-home-product-search-copy h3{
  margin:10px 0 8px;
  color:var(--text);
  font-family:var(--font-chunky);
  font-size:clamp(34px,4vw,54px);
  font-weight:400;
  line-height:.95;
}
.mrc-home-product-search-copy p{
  max-width:390px;
  margin:0;
  color:var(--text-muted);
  font-size:15px;
  line-height:1.5;
}
.mrc-home-product-search-main{
  position:relative;
  z-index:1;
  min-width:0;
}
.mrc-home-product-search-form{
  display:flex;
  align-items:center;
  gap:12px;
  min-height:64px;
  padding:8px 8px 8px 18px;
  border:1px solid var(--border-bright);
  border-radius:18px;
  background:rgba(5,5,5,.62);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.mrc-home-product-search-form:focus-within{
  border-color:var(--accent);
  box-shadow:0 0 30px -16px var(--accent),inset 0 1px 0 rgba(255,255,255,.05);
}
.mrc-home-product-search-form svg{
  flex:0 0 auto;
  color:var(--accent);
}
.mrc-home-product-search-form input{
  width:100%;
  min-width:0;
  border:0;
  outline:0;
  background:transparent;
  color:var(--text);
  font:800 16px/1.2 var(--font-body);
}
.mrc-home-product-search-form input::placeholder{color:var(--text-dim)}
.mrc-home-product-search-form button{
  flex:0 0 auto;
  min-height:48px;
  padding:0 18px;
  border-radius:14px;
  background:var(--accent);
  color:var(--accent-ink);
  font-family:var(--font-display);
  font-weight:900;
  text-transform:uppercase;
  box-shadow:0 0 26px -10px var(--accent);
}
.mrc-home-product-search-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}
.mrc-home-product-search-tags button{
  min-height:34px;
  padding:0 12px;
  border:1px solid var(--border);
  border-radius:999px;
  background:rgba(255,255,255,.045);
  color:var(--text-muted);
  font-family:var(--font-display);
  font-size:13px;
  font-weight:900;
}
.mrc-home-product-search-tags button:hover{
  border-color:var(--blue);
  color:var(--blue);
}
.mrc-home-product-search-results{
  margin-top:14px;
  padding:14px;
  border:1px solid var(--border);
  border-radius:18px;
  background:rgba(0,0,0,.28);
}
.mrc-home-product-search-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.mrc-home-product-search-head span{
  color:var(--text-muted);
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
}
.mrc-home-product-search-head a{
  color:var(--accent);
  font-family:var(--font-display);
  font-size:13px;
  font-weight:900;
}
.mrc-home-product-search-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  max-height:430px;
  overflow:auto;
  padding-right:4px;
}
.mrc-home-product-search-grid .search-result{
  background:rgba(20,20,20,.92);
  border-radius:16px;
}
.mrc-home-product-search-empty{
  padding:22px;
  color:var(--text-muted);
  text-align:center;
  font-weight:800;
}
@media(max-width:980px){
  .mrc-home-product-search{grid-template-columns:1fr}
  .mrc-home-product-search-copy p{max-width:640px}
}
@media(max-width:720px){
  .mrc-home-product-search{border-radius:18px;padding:16px}
  .mrc-home-product-search-copy p,
  .mrc-home-product-search-tags{display:none}
  .mrc-home-product-search-form{align-items:stretch;flex-wrap:wrap;padding:12px}
  .mrc-home-product-search-form input{flex:1 1 calc(100% - 40px);font-size:15px}
  .mrc-home-product-search-form button{width:100%}
  .mrc-home-product-search-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* ============ VERSUS TABLE ============ */

.vs-table{
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  background:var(--surface);
  overflow:hidden;
  position:relative;
}
.vs-row{
  display:grid;
  grid-template-columns:1.1fr 1fr 1fr;
  align-items:stretch;
}
.vs-row + .vs-row{border-top:1px solid var(--border)}
.vs-cell{
  padding:22px 24px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  font-size:15px;
  color:var(--text);
  min-height:64px;
  position:relative;
}

/* Feature column — labels */
.vs-cell.vs-feat{
  justify-content:flex-start;
  text-align:left;
  font-family:var(--font-body);
  font-weight:700;
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--text-muted);
}

/* Mr Charms column — highlighted w/ green glow */
.vs-cell.vs-us{
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(57,255,20,.18) 0%, rgba(57,255,20,.05) 45%, transparent 75%),
    rgba(57,255,20,.03);
  font-weight:600;
  box-shadow:inset 1px 0 0 rgba(57,255,20,.18), inset -1px 0 0 rgba(57,255,20,.18);
}

/* Other sellers column — muted */
.vs-cell.vs-them{
  color:var(--text-dim);
  font-weight:500;
}

/* Header row */
.vs-row.vs-thead .vs-cell{
  min-height:104px;
  padding-top:32px;padding-bottom:22px;
}
.vs-row.vs-thead .vs-cell.vs-feat{color:var(--text-dim)}
.vs-col-name{
  font-family:var(--font-chunky);
  font-weight:400;
  font-size:clamp(20px,2.4vw,28px);
  letter-spacing:-.005em;
  line-height:1;
  text-transform:uppercase;
  color:var(--accent);
}
.vs-cell.vs-them .vs-col-name{color:var(--text-muted)}

/* Winner badge — floats above the Mr Charms header cell */
.vs-winner{
  position:absolute;top:14px;left:50%;transform:translateX(-50%);
  background:var(--accent);
  color:var(--accent-ink);
  font-family:var(--font-body);
  font-weight:800;
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  padding:5px 14px 4px;
  border-radius:var(--radius-pill);
  box-shadow:0 0 24px -4px var(--accent-glow), 0 2px 8px rgba(0,0,0,.5);
  white-space:nowrap;
  z-index:2;
}

/* Check & cross icons */
.vs-check, .vs-cross{
  display:inline-grid;place-items:center;
  width:32px;height:32px;border-radius:50%;
  font-size:15px;line-height:1;font-weight:900;
}
.vs-check{
  background:var(--accent);color:var(--accent-ink);
  box-shadow:0 0 18px -4px var(--accent-glow);
}
.vs-cross{
  background:var(--surface-3);color:var(--text-dim);
}

@media (max-width: 720px){
  .vs-row{grid-template-columns:1.2fr 1fr 1fr}
  .vs-cell{padding:14px 10px;font-size:13px;min-height:56px}
  .vs-cell.vs-feat{font-size:10px;letter-spacing:.1em;padding-left:14px}
  .vs-row.vs-thead .vs-cell{min-height:86px;padding-top:26px}
  .vs-col-name{font-size:15px}
  .vs-winner{font-size:9px;letter-spacing:.14em;padding:4px 10px 3px;top:10px}
  .vs-check,.vs-cross{width:26px;height:26px;font-size:12px}
}

/* ============ REVIEWS ============ */
.reviews-wrap{position:relative}
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
@media(max-width:1040px){.reviews-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.reviews-grid{grid-template-columns:1fr}}
.review{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  padding:24px;
  display:flex;flex-direction:column;gap:16px;
}
.stars{color:var(--accent);font-size:14px;letter-spacing:.15em}
.review p{
  margin:0;font-size:15px;line-height:1.55;
  /* subtle quote marks */
}
.review p::before{content:"\201C";color:var(--pink);font-family:var(--font-display);font-weight:700;font-size:22px;margin-right:2px;line-height:0;vertical-align:-.18em}
.reviewer{display:flex;align-items:center;gap:12px;margin-top:auto}
.avatar{
  width:40px;height:40px;border-radius:50%;
  background:var(--section-accent);
  display:grid;place-items:center;
  font-family:var(--font-display);font-weight:700;color:#000;font-size:16px;
}
.reviewer-meta{display:flex;flex-direction:column}
.reviewer-meta b{font-size:14px;font-weight:700}
.reviewer-meta span{font-size:11px;color:var(--text-muted);letter-spacing:.14em;text-transform:uppercase}
.reviewer-meta span::before{
  content:"";display:inline-block;width:10px;height:10px;margin-right:4px;
  background:var(--accent);border-radius:50%;vertical-align:-1px;
}

/* overall rating strip */
.rating-lead{
  display:flex;align-items:center;gap:28px;
  padding:28px;border-radius:var(--radius-lg);
  background:var(--surface);border:1px solid var(--border);
  margin-bottom:24px;flex-wrap:wrap;
}
.rating-big{font-family:var(--font-display);font-weight:700;font-size:44px;line-height:.9;color:var(--accent);letter-spacing:-.02em}
.rating-meta{display:flex;flex-direction:column;gap:4px}
.rating-meta .stars-big{color:var(--accent);letter-spacing:.2em;font-size:20px}
.rating-meta small{color:var(--text-muted);font-size:13px}
.rating-spark{
  margin-left:auto;
  display:flex;align-items:end;gap:4px;
  height:54px;
}
.rating-spark i{
  display:block;width:10px;background:var(--accent);border-radius:3px;
  opacity:.4;
  animation:grow 2.4s var(--ease) infinite;
}
.rating-spark i:nth-child(1){height:20%;animation-delay:0s}
.rating-spark i:nth-child(2){height:45%;animation-delay:.15s}
.rating-spark i:nth-child(3){height:70%;animation-delay:.3s}
.rating-spark i:nth-child(4){height:90%;animation-delay:.45s}
.rating-spark i:nth-child(5){height:60%;animation-delay:.6s}
.rating-spark i:nth-child(6){height:80%;animation-delay:.75s}
.rating-spark i:nth-child(7){height:100%;animation-delay:.9s;opacity:1}
@keyframes grow{0%,100%{transform:scaleY(.8);opacity:.4}50%{transform:scaleY(1.05);opacity:1}}
@media(prefers-reduced-motion:reduce){.rating-spark i{animation:none}}

/* ============ FAQ ============ */

.faq-grid{
  display:grid;
  grid-template-columns:1fr 1.3fr;
  gap:clamp(40px,6vw,80px);
  align-items:start;
}
@media (max-width: 900px){
  .faq-grid{grid-template-columns:1fr;gap:40px}
}

.faq-intro .section-head{margin-bottom:0}
.faq-intro h2.display{
  font-family:var(--font-chunky);
  font-weight:400;
  font-size:clamp(34px,4.4vw,60px);
  line-height:1.02;
  letter-spacing:-.005em;
  margin:10px 0 0;
}
.faq-intro > .sub{color:var(--text-muted);margin-top:20px;font-size:16px;max-width:42ch}

/* Still stuck card */
.faq-help{
  margin-top:32px;
  padding:26px 28px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
}
.faq-help-label{
  display:inline-block;
  font-family:var(--font-body);font-weight:800;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text);
  margin-bottom:10px;
}
.faq-help p{color:var(--text-muted);font-size:14.5px;line-height:1.55;margin:0 0 14px}
.faq-help-link{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-weight:500;font-size:14px;
  color:var(--accent);
  text-decoration:underline;
  text-underline-offset:4px;
  text-decoration-thickness:1px;
  transition:text-shadow var(--dur) var(--ease);
}
.faq-help-link:hover{text-shadow:0 0 12px var(--accent-glow)}

/* Accordion */
.faq-list{display:flex;flex-direction:column;gap:12px}

.faq-item{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  overflow:hidden;
  transition:border-color var(--dur) var(--ease);
}
.faq-item:hover{border-color:var(--border-bright)}
.faq-item[open]{border-color:var(--border-bright)}

.faq-item > summary{
  list-style:none;
  cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:22px 24px;
  user-select:none;
}
.faq-item > summary::-webkit-details-marker{display:none}

.faq-q{
  font-family:var(--font-body);
  font-weight:800;
  font-size:13px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--text);
  line-height:1.3;
}

.faq-toggle{
  flex-shrink:0;
  display:inline-grid;place-items:center;
  width:28px;height:28px;border-radius:50%;
  font-size:20px;line-height:1;font-weight:400;
  color:var(--text-muted);
  background:transparent;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.faq-toggle::before{content:"+"}
.faq-item[open] .faq-toggle{
  background:var(--accent);
  color:var(--accent-ink);
  font-size:14px;font-weight:900;
  box-shadow:0 0 18px -4px var(--accent-glow);
}
.faq-item[open] .faq-toggle::before{content:"✕"}

.faq-a{
  padding:0 24px 24px;
  color:var(--text-muted);
  font-size:15px;line-height:1.6;
  max-width:64ch;
}
.faq-a a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.faq-a a:hover{text-shadow:0 0 10px var(--accent-glow)}
.faq-ship{
  list-style:none;padding:0;margin:14px 0 0;
  display:flex;flex-direction:column;gap:8px;
}
.faq-ship li{
  padding:12px 14px;
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
}
.faq-ship-head{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-size:14px;
}
.faq-ship strong{color:var(--text);font-weight:700}
.faq-ship-head span{
  font-family:var(--font-mono);font-size:12px;font-weight:700;
  color:var(--accent);
  white-space:nowrap;
}
.faq-ship li p{margin:4px 0 0;color:var(--text-muted);font-size:13px;line-height:1.5}
.faq-ship-group{
  margin:14px 0 8px;
  font-family:var(--font-body);font-weight:800;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--text);
}
/* Inline "heads up" note inside a FAQ answer */
.faq-note{
  margin:12px 0 0;
  padding:10px 14px;
  background:var(--surface-2);
  border:1px solid var(--border);
  border-left:3px solid var(--gold);
  border-radius:var(--radius-sm);
  color:var(--text-muted);
  font-size:13px;line-height:1.55;
}
.faq-note strong{color:var(--text)}

@media (max-width: 540px){
  .faq-item > summary{padding:18px 18px}
  .faq-a{padding:0 18px 20px;font-size:14px}
  .faq-q{font-size:12px;letter-spacing:.12em}
}

/* ============ NEWSLETTER ============ */
.newsletter-card{
  position:relative;
  padding:1px;border-radius:var(--radius-lg);
  background:var(--section-accent);
  box-shadow:0 0 36px -14px var(--section-accent);
  overflow:hidden;
}
.newsletter-inner{
  background:var(--surface);
  border-radius:calc(var(--radius-lg) - 1px);
  padding:clamp(40px,6vw,72px);
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:40px;align-items:center;
  position:relative;overflow:hidden;
}
@media(max-width:820px){.newsletter-inner{grid-template-columns:1fr}}
.newsletter-inner::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 0% 100%,rgba(255,46,196,.18),transparent 40%),
    radial-gradient(circle at 100% 0%,rgba(57,255,20,.14),transparent 45%);
  pointer-events:none;
}
.newsletter-inner > *{position:relative;z-index:1}
.newsletter h2{
  font-family:var(--font-chunky);font-weight:400;
  font-size:clamp(26px,3.5vw,42px);
  line-height:1.05;
  letter-spacing:-.005em;
  margin:10px 0 0;
}
.newsletter p{color:var(--text-muted);margin:16px 0 0;max-width:44ch}
.newsletter-form{
  display:flex;gap:10px;
  background:var(--bg);
  border:1px solid var(--border-bright);
  border-radius:var(--radius-pill);
  padding:6px;
  transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.newsletter-form:focus-within{
  border-color:var(--pink);
  box-shadow:0 0 0 4px rgba(255,46,196,.14);
}
.newsletter-form .btn{
  background:var(--pink);color:#fff;
}
.newsletter-form .btn:hover{
  box-shadow:0 0 0 1px rgba(255,46,196,.45), 0 0 24px -4px rgba(255,46,196,.45), 0 0 60px -18px rgba(255,46,196,.4);
}
.newsletter-form input{
  flex:1;min-width:0;
  background:transparent;border:0;outline:0;color:var(--text);
  font:inherit;padding:10px 18px;
}
.newsletter-form input::placeholder{color:var(--text-dim)}
.newsletter-form .btn{padding:14px 22px;font-size:14px}
.newsletter .fineprint{font-size:12px;color:var(--text-dim);margin-top:10px}

/* ============ POLICY / CONTENT PAGES ============ */
.page-intro{padding:clamp(26px,3vw,44px) 0 clamp(28px,4vw,48px)}
.page-hero{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);gap:clamp(22px,4vw,46px);align-items:stretch}
.page-hero-copy{
  position:relative;padding:clamp(28px,4vw,44px);
  border:1px solid var(--border);border-radius:var(--radius-lg);
  background:
    radial-gradient(circle at top left, rgba(255,46,196,.12), transparent 34%),
    radial-gradient(circle at 88% 18%, rgba(46,156,255,.12), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.02), transparent 28%),
    var(--surface);
  overflow:hidden;box-shadow:var(--shadow-md);
}
.page-hero-copy::after{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:var(--rainbow);opacity:.9}
.page-intro h1.display{
  font-family:var(--font-hero);font-weight:400;
  font-size:clamp(54px,10vw,132px);line-height:.88;
  letter-spacing:-.01em;text-transform:uppercase;margin:18px 0 0;
}
.page-intro .sub{color:var(--text-muted);font-size:clamp(16px,1.7vw,19px);line-height:1.7;margin:22px 0 0;max-width:52ch}
.page-hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.page-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 14px;border-radius:var(--radius-pill);
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--text);font-size:13px;font-weight:700;
}
.page-chip .dot{width:8px;height:8px;border-radius:50%;background:var(--chip-color,var(--accent));box-shadow:0 0 14px var(--chip-color,var(--accent))}
.page-hero-side{display:grid;gap:14px}
.policy-summary,.policy-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}
.policy-summary{padding:24px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-md)}
.policy-summary h2{margin:0;font-family:var(--font-display);font-weight:700;font-size:clamp(24px,3vw,34px);letter-spacing:-.02em;line-height:1}
.policy-summary p{margin:0;color:var(--text-muted);font-size:14px;line-height:1.65}
.policy-summary-list{display:grid;gap:10px}
.policy-summary-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:var(--radius-md);background:var(--surface-2);border:1px solid rgba(255,255,255,.05)}
.policy-summary-item strong{display:block;color:var(--text);font-size:13px;margin-bottom:2px}
.policy-summary-item span{color:var(--text-muted);font-size:13px;line-height:1.55}
.policy-summary-icon{
  width:32px;height:32px;flex-shrink:0;border-radius:10px;
  display:grid;place-items:center;font-size:15px;
  background:color-mix(in srgb, var(--item-color,var(--accent)) 16%, var(--surface-2));
  border:1px solid color-mix(in srgb, var(--item-color,var(--accent)) 35%, transparent);
}
.policy-meta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.policy-stat{
  padding:18px 18px 16px;min-height:124px;
  background:radial-gradient(circle at top right, color-mix(in srgb, var(--stat-color,var(--accent)) 18%, transparent) 0%, transparent 38%),var(--surface);
}
.policy-stat-label{display:block;margin-bottom:20px;font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim)}
.policy-stat-value{
  font-family:var(--font-display);font-weight:700;font-size:clamp(30px,4vw,44px);
  line-height:.95;color:var(--stat-color,var(--accent));
  text-shadow:0 0 24px color-mix(in srgb, var(--stat-color,var(--accent)) 38%, transparent);
}
.policy-stat-note{margin-top:10px;color:var(--text-muted);font-size:13px;line-height:1.45}
.policy-strip{padding:18px 0 0}
.policy-strip-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding:22px 0 0;border-top:1px solid var(--border)}
.policy-strip-item{display:flex;align-items:flex-start;gap:14px}
.policy-strip-icon{width:40px;height:40px;border-radius:12px;flex-shrink:0;display:grid;place-items:center;background:var(--surface);border:1px solid var(--border);color:var(--strip-color,var(--accent))}
.policy-strip-item strong{display:block;color:var(--text);font-size:14px;margin-bottom:4px}
.policy-strip-item span{color:var(--text-muted);font-size:13px;line-height:1.55}
.policy-content{padding:clamp(12px,2vw,24px) 0 clamp(64px,8vw,96px)}
.policy-grid{display:grid;grid-template-columns:260px minmax(0,1fr);gap:clamp(24px,4vw,56px);align-items:start}
.policy-toc{
  position:sticky;top:96px;display:flex;flex-direction:column;gap:8px;
  padding:20px 18px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), transparent 24%),var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);
}
.policy-toc-label{font-family:var(--font-body);font-weight:800;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim);margin-bottom:4px}
.policy-toc-meta{margin:0 0 8px;color:var(--text-muted);font-size:13px;line-height:1.55}
.policy-toc a{display:flex;align-items:center;gap:10px;padding:10px 12px;color:var(--text-muted);border-radius:12px;border:1px solid transparent;transition:color var(--dur) var(--ease),background var(--dur) var(--ease),border-color var(--dur) var(--ease),transform var(--dur) var(--ease)}
.policy-toc a::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--toc-color,var(--accent));box-shadow:0 0 12px var(--toc-color,var(--accent));opacity:.5;flex-shrink:0}
.policy-toc a:hover{color:var(--text);background:var(--surface-2);border-color:rgba(255,255,255,.06);transform:translateX(2px)}
.policy-toc a.active{color:var(--text);background:var(--surface-2);border-color:color-mix(in srgb, var(--toc-color,var(--accent)) 35%, transparent)}
.policy-toc a.active::before{opacity:1}
.policy-body{display:grid;gap:18px}
.last-updated{display:flex;align-items:center;gap:10px;margin:0 0 4px;font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--text-dim)}
.last-updated::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px var(--accent)}
.policy-body section{
  position:relative;padding:24px 24px 22px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), transparent 26%),var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);scroll-margin-top:96px;
}
.policy-body section::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:999px;background:var(--section-color,var(--accent));box-shadow:0 0 20px color-mix(in srgb, var(--section-color,var(--accent)) 55%, transparent)}
.policy-body h2{font-family:var(--font-chunky);font-weight:400;font-size:clamp(24px,2.7vw,34px);letter-spacing:-.01em;line-height:1.02;color:var(--text);margin:0 0 14px}
.policy-body h3{font-family:var(--font-display);font-weight:800;font-size:16px;color:var(--text);margin:18px 0 6px}
.policy-body p,.policy-body li{color:var(--text-muted);font-size:15.5px;line-height:1.75}
.policy-body p{margin:0 0 14px}
.policy-body ul{padding-left:22px;margin:0 0 18px}
.policy-body li{margin-bottom:8px}
.policy-body strong{color:var(--text)}
.policy-body a{color:var(--blue);text-decoration:underline;text-underline-offset:3px}
.policy-body a:hover{color:var(--accent)}
.policy-callout{display:flex;gap:14px;padding:18px 20px;margin:18px 0 0;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-md)}
.policy-callout::before{content:"";flex-shrink:0;width:4px;border-radius:999px;background:var(--callout-color,var(--accent))}
.policy-callout p{margin:0;color:var(--text);font-size:14.5px}
.policy-callout.gold{--callout-color:var(--gold)}
.policy-callout.pink{--callout-color:var(--pink)}
.policy-callout.blue{--callout-color:var(--blue)}
.policy-callout.green{--callout-color:var(--accent)}
#what{--section-color:var(--pink)}
#why{--section-color:var(--gold)}
#share{--section-color:var(--accent)}
#cookies{--section-color:var(--blue)}
#rights{--section-color:var(--pink)}
#security{--section-color:var(--gold)}
#changes{--section-color:var(--accent)}
@media (max-width:920px){
  .page-hero,.policy-grid{grid-template-columns:1fr}
  .policy-meta-grid{grid-template-columns:1fr}
  .policy-toc{position:static}
}
@media (max-width:820px){.policy-strip-row{grid-template-columns:1fr}}
@media (max-width:720px){
  .page-intro h1.display{font-size:clamp(34px,9vw,60px);line-height:.95}
  .page-intro .sub{font-size:clamp(15px,4vw,17px);line-height:1.6}
  .policy-summary h2{font-size:clamp(20px,5.5vw,28px)}
  .policy-content{padding:8px 0 48px}
  .policy-content p,.policy-content li{font-size:15px;line-height:1.7}
  .policy-content h2{font-size:clamp(22px,6vw,30px);line-height:1.2}
  .policy-content h3{font-size:clamp(18px,5vw,22px);line-height:1.25}
  .policy-content p,.policy-content ul,.policy-content ol{max-width:64ch}
  .page-hero-copy{padding:20px}
  .policy-toc{position:static;padding:14px}
  .policy-toc a{padding:12px;min-height:44px}
  .policy-toc a + a{margin-top:6px}
  .page-chip{min-height:44px}
}
@media (max-width:560px){
  .page-hero-copy{padding:16px}
  .policy-meta-grid,.policy-strip-row{gap:10px}
  .page-hero-actions{gap:8px}
  .page-chip{padding:10px 12px;font-size:12px}
}

/* ============ CONTACT PAGE ============ */
.contact-hero{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);
  gap:clamp(22px,4vw,46px);
  align-items:stretch;
}
.contact-hero-copy{
  position:relative;
  padding:clamp(28px,4vw,44px);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  background:
    radial-gradient(circle at top left, rgba(255,46,196,.12), transparent 34%),
    radial-gradient(circle at 88% 18%, rgba(46,156,255,.12), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.02), transparent 28%),
    var(--surface);
  overflow:hidden;
  box-shadow:var(--shadow-md);
}
.contact-hero-copy::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:2px;
  background:var(--rainbow);
  opacity:.9;
}
.contact-hero-copy h1 .gradient{
  background:var(--rainbow);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}
.contact-hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:28px;
}
.contact-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:var(--radius-pill);
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  color:var(--text);
  font-size:13px;
  font-weight:700;
}
.contact-chip .dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--chip-color,var(--accent));
  box-shadow:0 0 14px var(--chip-color,var(--accent));
}
.contact-hero-side{
  display:grid;
  gap:14px;
}
.contact-status,
.contact-stat{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
}
.contact-status{
  padding:24px;
  display:flex;
  flex-direction:column;
  gap:16px;
  box-shadow:var(--shadow-md);
}
.contact-status h2{
  margin:0;
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(24px,3vw,34px);
  letter-spacing:-.02em;
  line-height:1;
}
.contact-status p{
  margin:0;
  color:var(--text-muted);
  font-size:14px;
  line-height:1.65;
}
.contact-status-list{
  display:grid;
  gap:10px;
}
.contact-status-item{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:12px 14px;
  border-radius:var(--radius-md);
  background:var(--surface-2);
  border:1px solid rgba(255,255,255,.05);
}
.contact-status-icon{
  width:32px;
  height:32px;
  flex-shrink:0;
  border-radius:10px;
  display:grid;
  place-items:center;
  font-size:14px;
  color:var(--text);
  background:color-mix(in srgb, var(--item-color,var(--accent)) 16%, var(--surface-2));
  border:1px solid color-mix(in srgb, var(--item-color,var(--accent)) 35%, transparent);
}
.contact-status-item strong{
  display:block;
  color:var(--text);
  font-size:13px;
  margin-bottom:2px;
}
.contact-status-item span{
  color:var(--text-muted);
  font-size:13px;
  line-height:1.55;
}
.contact-status-item.primary{
  background:
    radial-gradient(circle at 100% 0%, rgba(57,255,20,.14), transparent 42%),
    var(--surface-2);
  border-color:rgba(57,255,20,.24);
}
.contact-status-item.primary .contact-status-icon{
  box-shadow:0 0 22px -8px var(--accent);
}
.contact-stat-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.contact-stat{
  padding:18px 18px 16px;
  min-height:124px;
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--stat-color,var(--accent)) 18%, transparent) 0%, transparent 38%),
    var(--surface);
}
.contact-stat-label{
  display:block;
  margin-bottom:20px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--text-dim);
}
.contact-stat-value{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(30px,4vw,44px);
  line-height:.95;
  color:var(--stat-color,var(--accent));
  text-shadow:0 0 24px color-mix(in srgb, var(--stat-color,var(--accent)) 38%, transparent);
}
.contact-stat-note{
  margin-top:10px;
  color:var(--text-muted);
  font-size:13px;
  line-height:1.45;
}
.contact-strip{
  padding:18px 0 0;
}
.contact-strip-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  padding:22px 0 0;
  border-top:1px solid var(--border);
}
.contact-strip-item{
  display:flex;
  align-items:flex-start;
  gap:14px;
}
.contact-strip-icon{
  width:40px;
  height:40px;
  border-radius:12px;
  flex-shrink:0;
  display:grid;
  place-items:center;
  background:var(--surface);
  border:1px solid var(--border);
  color:var(--strip-color,var(--accent));
}
.contact-strip-item strong{
  display:block;
  color:var(--text);
  font-size:14px;
  margin-bottom:4px;
}
.contact-strip-item span{
  color:var(--text-muted);
  font-size:13px;
  line-height:1.55;
}
.contact-content{
  padding:clamp(12px,2vw,24px) 0 clamp(64px,8vw,96px);
}
.contact-layout{
  display:grid;
  grid-template-columns:minmax(0,1.12fr) minmax(340px,.88fr);
  gap:clamp(24px,4vw,56px);
  align-items:start;
}
.contact-methods{
  display:grid;
  gap:18px;
}
.contact-section-label{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:2px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--text-dim);
}
.contact-section-label::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--section-accent,var(--accent));
  box-shadow:0 0 14px var(--section-accent,var(--accent));
}
.contact-card{
  position:relative;
  display:flex;
  gap:16px;
  align-items:flex-start;
  padding:22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.02), transparent 28%),
    var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-md);
  transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.contact-card.primary{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:20px;
  padding:clamp(26px,3.2vw,36px);
  border-color:rgba(57,255,20,.42);
  background:
    radial-gradient(circle at 100% 0%, rgba(57,255,20,.16), transparent 38%),
    linear-gradient(180deg, rgba(255,255,255,.035), transparent 30%),
    var(--surface);
  box-shadow:0 0 0 1px rgba(57,255,20,.12), 0 24px 56px -24px rgba(57,255,20,.45);
}
.contact-card.primary::before{width:4px}
.contact-card.primary .contact-card-icon{
  width:64px;
  height:64px;
  border-radius:18px;
  font-size:22px;
  box-shadow:0 0 26px -8px var(--accent);
}
.contact-card.primary .contact-card-body h3{
  font-size:13px;
  color:var(--accent);
}
.contact-card.primary .contact-card-body p{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(24px,3vw,38px);
  line-height:1;
  letter-spacing:-.02em;
  color:var(--text);
  overflow-wrap:anywhere;
}
.contact-card.primary .contact-card-body .hint{
  margin-top:12px;
  max-width:52ch;
  font-size:14px;
  line-height:1.65;
  color:var(--text-muted);
}
.contact-email-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.contact-email-actions a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:42px;
  padding:11px 16px;
  border-radius:var(--radius-pill);
  font-family:var(--font-display);
  font-weight:800;
  font-size:13px;
  text-decoration:none;
}
.contact-email-actions .primary-action{
  background:var(--accent);
  color:var(--accent-ink);
  box-shadow:0 0 24px -6px var(--accent-glow);
}
.contact-email-actions .secondary-action{
  background:rgba(255,255,255,.04);
  border:1px solid var(--border-bright);
  color:var(--text);
}
.contact-email-actions a:hover{
  transform:translateY(-1px);
}
.contact-card.secondary{
  box-shadow:none;
}
.contact-card.secondary .contact-card-icon{
  width:42px;
  height:42px;
  border-radius:12px;
  font-size:15px;
}
.contact-card::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:3px;
  background:var(--card-color,var(--accent));
  box-shadow:0 0 20px color-mix(in srgb, var(--card-color,var(--accent)) 55%, transparent);
}
.contact-card:hover{
  border-color:var(--card-color,var(--border-bright));
  transform:translateY(-2px);
  box-shadow:0 18px 40px -18px var(--card-color, rgba(57,255,20,.45));
}
.contact-card-icon{
  flex-shrink:0;
  display:grid;
  place-items:center;
  width:48px;
  height:48px;
  border-radius:14px;
  background:color-mix(in srgb, var(--card-color,var(--accent)) 15%, var(--surface-2));
  border:1px solid color-mix(in srgb, var(--card-color,var(--accent)) 35%, transparent);
  color:var(--text);
  font-size:18px;
}
.contact-card-body h3{
  font-family:var(--font-display);
  font-weight:800;
  font-size:15px;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--text);
  margin:0 0 6px;
}
.contact-card-body p{
  margin:0;
  color:var(--text-muted);
  font-size:14px;
  line-height:1.55;
}
.contact-card-body .hint{
  display:block;
  font-size:12px;
  color:var(--text-dim);
  margin-top:6px;
}
.contact-card-body a{
  color:var(--text);
  text-decoration:none;
}
.contact-card-body a:hover{color:var(--card-color,var(--accent))}
.contact-card-body .contact-email-actions .primary-action,
.contact-card-body .contact-email-actions .primary-action:hover{color:var(--accent-ink)}
.contact-card-body .contact-email-actions .secondary-action,
.contact-card-body .contact-email-actions .secondary-action:hover{color:var(--text)}
.contact-card.email{--card-color:var(--accent)}
.contact-card.insta{--card-color:var(--pink)}
.contact-card.fb{--card-color:var(--blue)}
.contact-card.location{--card-color:var(--gold)}
.contact-form{
  position:relative;
  background:
    radial-gradient(circle at top right, rgba(57,255,20,.1), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.025), transparent 28%),
    var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:clamp(22px,3vw,34px);
  box-shadow:var(--shadow-md);
  overflow:hidden;
  opacity:.9;
}
.contact-form::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:2px;
  background:var(--rainbow);
  opacity:.55;
}
.contact-form h2{
  font-family:var(--font-chunky);
  font-weight:400;
  font-size:clamp(24px,3vw,34px);
  letter-spacing:-.005em;
  line-height:1;
  margin:0 0 10px;
  color:var(--text);
}
.contact-form .form-intro{
  color:var(--text-muted);
  margin:0 0 22px;
  font-size:14px;
  line-height:1.65;
}
.contact-form .field{margin-bottom:16px}
.contact-form .field label{
  display:block;
  font-family:var(--font-body);
  font-weight:800;
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--text-muted);
  margin-bottom:7px;
}
.contact-form .field input,
.contact-form .field textarea,
.contact-form .field select{
  width:100%;
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  padding:13px 14px;
  font-family:var(--font-body);
  font-size:14px;
  color:var(--text);
  outline:0;
  transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), background var(--dur) var(--ease);
}
.contact-form .field input:focus,
.contact-form .field textarea:focus,
.contact-form .field select:focus{
  background:#202020;
  border-color:var(--accent);
  box-shadow:0 0 0 1px var(--accent), 0 0 18px -5px var(--accent-glow);
}
.contact-form .field textarea{
  resize:vertical;
  min-height:140px;
  font-family:var(--font-body);
}
.contact-form .field textarea::placeholder{color:var(--text-dim)}
.contact-form button[type="submit"]{
  width:100%;
  margin-top:8px;
  padding:15px 22px;
  border:0;
  border-radius:var(--radius-pill);
  background:var(--accent);
  color:var(--accent-ink);
  font-family:var(--font-display);
  font-weight:800;
  font-size:14px;
  letter-spacing:0;
  cursor:pointer;
  box-shadow:0 0 24px -4px var(--accent-glow);
  transition:filter var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.contact-form button[type="submit"]:hover{
  filter:brightness(1.08);
  transform:translateY(-2px);
  box-shadow:var(--shadow-neon);
}
.contact-form-note{
  margin:12px 0 0;
  color:var(--text-dim);
  font-size:12px;
  line-height:1.55;
  text-align:center;
}
@media (max-width:920px){
  .contact-hero,
  .contact-layout{grid-template-columns:1fr}
  .contact-stat-grid{grid-template-columns:1fr}
}
@media (max-width:820px){
  .contact-strip-row{grid-template-columns:1fr}
}

/* ============ FOOTER ============ */
footer{
  background:var(--surface);
  border-top:1px solid var(--border);
  padding:72px 0 32px;
  margin-top:40px;
}
.foot-grid{
  display:grid;
  grid-template-columns:1.6fr repeat(3,1fr);
  gap:48px;
}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr;gap:32px}}
.foot-brand p{color:var(--text-muted);max-width:38ch;margin:16px 0 20px;font-size:14px}
.socials{display:flex;gap:10px}
.socials a{
  width:40px;height:40px;border-radius:10px;
  border:1px solid var(--border-bright);
  display:grid;place-items:center;color:var(--text);
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.socials a:hover{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.socials a:nth-child(1):hover{background:var(--pink);color:#fff;border-color:var(--pink)}
.socials a:nth-child(2):hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.socials a:nth-child(3):hover{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.socials svg{width:18px;height:18px}
.foot-col h4{
  font-family:var(--font-display);font-weight:700;
  font-size:12px;letter-spacing:.1em;
  text-transform:uppercase;margin:0 0 16px;
  color:var(--text-muted);
}
.foot-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.foot-col a{font-size:14px;color:var(--text);transition:color var(--dur) var(--ease)}
.foot-col a:hover{color:var(--accent)}
.mrc-footer-simple{
  grid-template-columns:minmax(0,1.35fr) minmax(220px,.65fr);
  align-items:start;
}
.mrc-footer-pages ul{gap:12px}
.mrc-footer-pages a{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.mrc-footer-pages a::before{
  content:"";
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 12px var(--accent-glow);
}

.legal{
  margin-top:56px;padding-top:24px;
  border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;
  gap:16px;flex-wrap:wrap;
  font-size:12px;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase;
}
.legal .mono{color:var(--text-muted)}

/* ============ REVEAL ============ */
[data-reveal]{
  opacity:0;transform:translateY(14px);
  transition:opacity 600ms var(--ease),transform 600ms var(--ease);
}
[data-reveal].in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
}

/* ============ SKIP LINK ============ */
.skip{
  position:absolute;left:-9999px;top:0;
  background:var(--accent);color:var(--accent-ink);
  padding:10px 16px;border-radius:6px;font-weight:700;
  z-index:200;
}
.skip:focus{left:16px;top:16px}

/* ============ MOBILE OPTIMIZATIONS ============ */
@media (max-width:720px){
  .nav{height:60px;gap:8px}
  .nav-actions{gap:6px}
  .nav-actions .icon-btn[aria-label="Account"]{display:none}
  .brand img{height:32px}
  .cart-btn{padding:8px 12px;font-size:13px;gap:6px}
  .icon-btn{width:38px;height:38px}
}
@media (max-width:560px){
  .section{padding:48px 0}
  .hero{padding:32px 0 56px}
  .hero h1{font-size:clamp(52px,15vw,96px)}
  .hero p.lede{font-size:15px}
  .hero-trust{gap:18px;margin-top:32px;padding-top:20px}
  .hero-art{max-width:420px;margin:0 auto}
  .price-sticker{
    width:76px;
    height:76px;
    top:0;
    right:50%;
    transform:translateX(50%) rotate(-10deg);
    animation:none;
    box-shadow:0 0 0 5px rgba(57,255,20,.12),0 14px 28px -12px rgba(57,255,20,.35);
  }
  .price-sticker .big{font-size:30px}
  .price-sticker .from{font-size:9px}
  .price-sticker .small{font-size:10px}

  .bundle{padding:22px}
  .bundle h3{font-size:26px}
  .price-now{font-size:38px}
  .price-was{font-size:18px}
  .bundle .btn-bundle{padding:14px 18px;font-size:14px}

  .stats-row{gap:20px 16px}
  .stat-num{font-size:clamp(28px,9vw,44px)}

  .products{gap:12px}
  .product-body{padding:12px 12px 14px;gap:8px}
  .product h3{font-size:13px}
  .product-price{font-size:16px}
  .add-btn{padding:10px 12px;font-size:12px;min-height:40px}

  .btn{padding:13px 20px;min-height:44px}
  .btn-ghost{min-height:44px}

  .reviews-grid{gap:12px}
  .review{padding:18px}
  .rating-lead{padding:20px;gap:18px}
  .rating-big{font-size:36px}
  .rating-spark{display:none}

  .vs-row{grid-template-columns:1.3fr 1fr 1fr}
  .vs-cell{padding:12px 6px;font-size:12px}
  .vs-cell.vs-feat{font-size:9px;padding-left:10px}

  .newsletter-inner{padding:32px 22px}
  .newsletter-form{flex-wrap:wrap;background:transparent;border:0;padding:0;gap:10px;border-radius:0}
  .newsletter-form input{
    width:100%;background:var(--bg);border:1px solid var(--border-bright);
    border-radius:var(--radius-pill);padding:14px 18px;font-size:16px;
  }
  .newsletter-form .btn{width:100%;padding:14px 22px;min-height:46px}

  .drawer-search-input input,
  .search-strip-input input{font-size:16px}

  .foot-grid{grid-template-columns:1fr;gap:28px}
  footer{padding:48px 0 24px}
  .legal{flex-direction:column;align-items:flex-start;gap:8px}

  .filter-drawer{width:100vw;border-left:0}
  .drawer-head{padding:18px 18px}
  .drawer-foot{padding:14px 16px}
  .drawer-foot .btn-clear,
  .drawer-foot .btn-apply{padding:14px 18px;min-height:46px}
  .filter-chip{min-height:38px}

  .ticker-track{font-size:12px;gap:32px}
}
@media (max-width:380px){
  .hero h1{font-size:54px}
  .bundles-h2{font-size:32px}
  .section-head h2{font-size:26px}
  .nav-actions .icon-btn[aria-label="Search"]{display:none}
}

/* Prevent any wide inline content from causing horizontal scroll */
img,video,iframe{max-width:100%}
.wrap{width:100%}

/* ============================================================
   GLOBAL OVERRIDES — applied to every page that loads styles.css
   ============================================================ */

/* --- Product hover: swap to second image cleanly --- */
.product-thumb{display:none !important}
.product .product-img-link{position:relative;display:block;width:100%;height:100%}
.product .product-img-link img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:opacity 220ms ease, transform var(--dur-slow) var(--ease);
}
.product .product-img-primary{opacity:1;z-index:1}
.product .product-img-secondary{opacity:0;z-index:2}
.product:hover .product-img-primary{opacity:0}
.product:hover .product-img-secondary{opacity:1}
.product:hover .product-img-link img{transform:scale(1.05)}

/* --- Bundle grid: center on mobile, downscale cards --- */
@media (max-width:960px){
  .bundle-grid{
    grid-template-columns:1fr;
    max-width:440px;
    margin-left:auto;
    margin-right:auto;
    justify-items:center;
    gap:16px;
  }
  .bundle{
    width:100%;
    max-width:380px;
    padding:20px;
    text-align:left;
  }
  .bundle h3{font-size:24px;margin-bottom:10px}
  .bundle .pick{font-size:14px;margin-bottom:16px}
  .bundle-preview{gap:6px;margin-bottom:18px;justify-content:flex-start;flex-wrap:wrap}
  .bundle-preview .chip,.bundle-preview .more{width:42px;height:42px;border-radius:8px;font-size:12px}
  .price-row{margin-bottom:16px;gap:10px}
  .price-now{font-size:36px}
  .price-was{font-size:18px}
  .save-chip{padding:8px 14px;font-size:11px;margin-bottom:18px}
  .bundle .btn-bundle{padding:13px 18px;font-size:14px}
}
@media (max-width:560px){
  .bundle-grid{max-width:360px;gap:14px}
  .bundle{padding:18px;max-width:340px}
  .bundle h3{font-size:22px}
  .price-now{font-size:32px}
  .bundle-preview .chip,.bundle-preview .more{width:38px;height:38px;font-size:11px}
}

/* --- Ship-strip on shop page: stack into a clean mobile chip list --- */
@media (max-width:880px){
  .ship-strip .ship-row{
    flex-direction:column;
    align-items:stretch;
    gap:8px;
    padding:14px;
    border-radius:var(--radius-md);
  }
  .ship-strip .ship-row-label{
    flex-basis:auto;margin-bottom:4px;
    font-size:10px;
  }
  .ship-strip .ship-divider{display:none}
  .ship-strip .ship-pill{
    width:100%;justify-content:space-between;
    padding:10px 14px;font-size:13px;
  }
  .ship-strip .ship-pill strong{font-size:12px;white-space:nowrap}
}

/* --- Shop page: tighter mobile layout --- */
@media (max-width:740px){
  .shop-intro{padding-top:24px;padding-bottom:16px}
  .shop-intro .breadcrumb{font-size:12px}
  .shop-intro .section-head{margin-bottom:18px}
  .shop-intro .section-head h2{font-size:clamp(26px,7vw,36px)}
  .shop-intro .title-block .sub{font-size:14px}
  /* Sidebar stacks above grid on small screens */
  .shop-layout{display:block !important}
  .cat-sidebar{margin-bottom:20px}
  .shop-grid .pagination{flex-wrap:wrap;justify-content:center;gap:6px}
}


/* WordPress/WooCommerce compatibility additions */
.admin-bar .site-header{top:32px}@media(max-width:782px){.admin-bar .site-header{top:46px}}.mrc-wp-content{min-height:60vh}.mrc-wp-products.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:clamp(16px,2vw,28px)}.mrc-wp-notice{max-width:980px;margin:40px auto;padding:24px;border:1px solid rgba(255,255,255,.15);border-radius:20px;background:rgba(255,255,255,.05)}.mrc-hidden{display:none!important}.woocommerce .site-main{max-width:1200px;margin:0 auto;padding:48px 20px}.woocommerce ul.products li.product a img{border-radius:22px;background:#fff}.woocommerce div.product{max-width:1200px;margin:0 auto;padding:48px 20px}.screen-reader-text{clip:rect(1px,1px,1px,1px);word-wrap:normal!important;border:0;clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.mrc-page-shell{background-color:var(--bg,#05050a);background-image:var(--page-glow),var(--page-pattern);background-size:100% 1900px,100% 1900px,100% 1800px,auto,auto,28px 28px,100% 100%;background-repeat:no-repeat,no-repeat,no-repeat,repeat,repeat,repeat,no-repeat;color:var(--text,#fff)}


/* V3 safety fix: Lovable reveal elements must never stay invisible on WordPress. */
body [data-reveal]{opacity:1;transform:none;}
body [data-reveal].in, body [data-reveal].revealed{opacity:1;transform:none;}


/* V4 WordPress/WooCommerce integration helpers */
.nav-links ul, .nav-links li { list-style: none; margin: 0; padding: 0; }
.nav-links ul { display: contents; }
.mrc-wc-shell { min-height: 100vh; }
.mrc-wc-content { padding: clamp(32px, 5vw, 72px) 0; }
.mrc-wc-content .woocommerce { width: min(1180px, calc(100% - 32px)); margin: 0 auto; }
.woocommerce .woocommerce-result-count, .woocommerce .woocommerce-ordering { color: rgba(255,255,255,.78); }
.woocommerce-message, .woocommerce-info, .woocommerce-error { border-radius: 18px; background: rgba(255,255,255,.08); color: #fff; border-top-color: #9dff3f; }


/* ============ WooCommerce single product / product detail page ============ */
.single-product .mrc-product-detail-shell,
.mrc-product-detail-shell{
  min-height:100vh;
  background:
    radial-gradient(circle at 18% 12%, rgba(57,255,20,.13), transparent 28%),
    radial-gradient(circle at 82% 22%, rgba(255,78,205,.10), transparent 26%),
    radial-gradient(circle at 50% 110%, rgba(0,195,255,.10), transparent 35%),
    var(--bg);
  color:var(--text);
}
.mrc-product-detail{
  padding:clamp(32px,5vw,72px) 0 clamp(48px,7vw,96px);
}
.mrc-product-breadcrumbs{
  font:800 12px/1.2 Manrope,system-ui,sans-serif;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--text-muted);
  margin-bottom:22px;
}
.mrc-product-breadcrumbs a{color:var(--accent);text-decoration:none}
.mrc-product-breadcrumbs a:hover{text-decoration:underline}
.mrc-product-layout{
  display:grid;
  grid-template-columns:minmax(280px, 1fr) minmax(320px, 520px);
  gap:clamp(24px,5vw,64px);
  align-items:start;
}
.mrc-product-gallery,
.mrc-product-summary,
.mrc-product-panel{
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.035));
  box-shadow:0 24px 90px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.08);
  border-radius:28px;
}
.mrc-product-gallery{padding:clamp(16px,3vw,28px);position:relative;overflow:hidden}
.mrc-product-gallery:before{content:"";position:absolute;inset:-30%;background:radial-gradient(circle, rgba(57,255,20,.12), transparent 48%);pointer-events:none}
.mrc-product-gallery .woocommerce-product-gallery{position:relative;z-index:1;width:100%!important;float:none!important;margin:0!important}
.mrc-product-gallery img{border-radius:22px;background:rgba(255,255,255,.04)}
.mrc-product-gallery .flex-control-thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:14px 0 0!important;padding:0!important}
.mrc-product-gallery .flex-control-thumbs li{width:auto!important;float:none!important;list-style:none}
.mrc-product-gallery .flex-control-thumbs img{opacity:.7;border:1px solid rgba(255,255,255,.14);transition:.2s ease;cursor:pointer}
.mrc-product-gallery .flex-control-thumbs img.flex-active,
.mrc-product-gallery .flex-control-thumbs img:hover{opacity:1;border-color:var(--accent);box-shadow:0 0 24px rgba(57,255,20,.22)}
.mrc-product-summary{padding:clamp(20px,4vw,36px)}
.mrc-product-kicker{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(57,255,20,.12);border:1px solid rgba(57,255,20,.28);color:var(--accent);font:900 12px/1 Manrope,system-ui,sans-serif;letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px}
.mrc-product-summary .product_title,
.mrc-product-title{font-family:Anton,Impact,sans-serif;font-size:clamp(34px,5vw,64px);line-height:.95;letter-spacing:.01em;text-transform:uppercase;margin:0 0 14px;color:#fff;text-shadow:0 0 34px rgba(57,255,20,.10)}
.mrc-product-summary .price{font:900 clamp(24px,3vw,36px)/1 Manrope,system-ui,sans-serif;color:var(--accent);margin:14px 0 18px;display:block}
.mrc-product-summary .woocommerce-product-rating{margin:0 0 16px;color:#ffd166}
.mrc-product-summary .woocommerce-review-link{color:var(--text-muted);text-decoration:none;margin-left:8px}
.mrc-product-short-desc{color:var(--text-muted);font:600 15px/1.75 Manrope,system-ui,sans-serif;margin:16px 0 22px}
.mrc-product-summary form.cart{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin:22px 0!important}
.mrc-product-summary .quantity .qty{width:86px;height:50px;border-radius:16px;border:1px solid rgba(255,255,255,.16);background:rgba(0,0,0,.38);color:#fff;text-align:center;font:900 16px Manrope,system-ui,sans-serif}
.mrc-product-summary .single_add_to_cart_button,
.mrc-product-summary .button.alt,
.mrc-product-summary button.button{
  min-height:50px;border:0;border-radius:999px;padding:0 26px!important;background:linear-gradient(90deg,var(--accent),#00c3ff,#ff4ecd)!important;color:#071007!important;font:1000 14px/1 Manrope,system-ui,sans-serif!important;letter-spacing:.04em;text-transform:uppercase;box-shadow:0 14px 45px rgba(57,255,20,.22);cursor:pointer;transition:.2s ease;
}
.mrc-product-summary .single_add_to_cart_button:hover{transform:translateY(-1px);filter:saturate(1.12)}
.mrc-product-summary .product_meta{margin-top:22px;padding-top:18px;border-top:1px solid rgba(255,255,255,.10);display:grid;gap:8px;color:var(--text-muted);font:700 13px Manrope,system-ui,sans-serif}
.mrc-product-summary .product_meta a{color:#fff;text-decoration:none}
.mrc-product-trust{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:22px}
.mrc-product-trust span{padding:12px;border:1px solid rgba(255,255,255,.1);border-radius:16px;background:rgba(0,0,0,.24);font:900 12px/1.25 Manrope,system-ui,sans-serif;color:#fff;text-align:center}
.mrc-product-panels{display:grid;gap:18px;margin-top:clamp(28px,5vw,56px)}
.mrc-product-panel{padding:clamp(20px,4vw,34px)}
.mrc-product-panel h2,
.mrc-product-panel .related > h2{font-family:Anton,Impact,sans-serif;font-size:clamp(28px,4vw,48px);line-height:1;text-transform:uppercase;margin:0 0 18px;color:#fff}
.mrc-product-panel p,
.mrc-product-panel li{color:var(--text-muted);font:600 15px/1.75 Manrope,system-ui,sans-serif}
.mrc-product-panel .woocommerce-tabs ul.tabs{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 20px!important;padding:0!important}
.mrc-product-panel .woocommerce-tabs ul.tabs:before{display:none!important}
.mrc-product-panel .woocommerce-tabs ul.tabs li{border:1px solid rgba(255,255,255,.12)!important;background:rgba(0,0,0,.25)!important;border-radius:999px!important;padding:0!important;margin:0!important}
.mrc-product-panel .woocommerce-tabs ul.tabs li:before,
.mrc-product-panel .woocommerce-tabs ul.tabs li:after{display:none!important}
.mrc-product-panel .woocommerce-tabs ul.tabs li a{padding:12px 16px!important;color:#fff!important;font:900 13px Manrope,system-ui,sans-serif;text-transform:uppercase;letter-spacing:.04em}
.mrc-product-panel .woocommerce-tabs ul.tabs li.active{border-color:var(--accent)!important;box-shadow:0 0 24px rgba(57,255,20,.16)}
.mrc-product-panel .related ul.products,
.mrc-product-panel ul.products{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin:0!important;padding:0!important}
.mrc-product-panel ul.products li.product{width:auto!important;margin:0!important;float:none!important}
@media (max-width: 900px){
  .mrc-product-layout{grid-template-columns:1fr}
  .mrc-product-trust{grid-template-columns:1fr}
  .mrc-product-panel .related ul.products,.mrc-product-panel ul.products{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 520px){
  .mrc-product-summary form.cart{display:grid;grid-template-columns:1fr}
  .mrc-product-summary .quantity .qty{width:100%}
  .mrc-product-summary .single_add_to_cart_button{width:100%}
  .mrc-product-panel .related ul.products,.mrc-product-panel ul.products{grid-template-columns:1fr}
}


/* =========================================================
   V6 — Lovable product page remap for WooCommerce singles
   Uses the original Lovable product detail class names: pd-grid,
   pd-gallery, pd-info, pd-bundle, pd-tabs, related-products.
   ========================================================= */
body.single-product{background-color:var(--bg);color:var(--text)}
.mrc-lovable-product-shell{min-height:100vh;background:var(--bg);color:var(--text)}
.mrc-lovable-product-shell .woocommerce-breadcrumb{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);margin:0 0 18px}
.mrc-lovable-product-shell .woocommerce-breadcrumb a{color:var(--accent);text-decoration:none}
/* ============ PRODUCT PAGE — LAYOUT ============ */
#product-detail{padding:clamp(20px,3vw,40px) 0 clamp(40px,5vw,72px)}
.pd-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:clamp(28px,4vw,64px);
  align-items:flex-start;
}
@media (max-width:880px){.pd-grid{grid-template-columns:1fr}}

/* ---- Gallery ---- */
.pd-gallery{display:flex;flex-direction:column;gap:14px;position:sticky;top:96px}
@media (max-width:880px){.pd-gallery{position:static}}
.pd-main-img{
  position:relative;
  aspect-ratio:1/1;
  background:radial-gradient(circle at 50% 40%,var(--surface-2),var(--surface) 70%);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  display:grid;place-items:center;
  box-shadow:0 0 60px -20px rgba(255,46,196,.25);
}
.pd-main-img img{
  display:block;
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  padding:8%;
  box-sizing:border-box;
  transition:opacity .25s var(--ease);
}
.pd-main-img .badge{
  position:absolute;top:18px;left:18px;z-index:2;
  background:var(--accent);color:var(--accent-ink);
  font-family:var(--font-body);font-weight:800;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  padding:6px 12px;border-radius:999px;
  box-shadow:0 0 18px -4px var(--accent-glow);
}
.pd-thumbs{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;
}
.pd-thumb{
  aspect-ratio:1/1;
  background:radial-gradient(circle at 50% 40%,var(--surface-2),var(--surface) 70%);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  overflow:hidden;
  cursor:pointer;
  display:grid;place-items:center;
  padding:10%;
  transition:border-color var(--dur) var(--ease);
}
.pd-thumb img{
  display:block;
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  box-sizing:border-box;
}
.pd-thumb:hover{border-color:var(--border-bright)}
.pd-thumb.active{border-color:var(--accent);box-shadow:0 0 16px -6px var(--accent-glow)}

/* ---- Product info column ---- */
.pd-info{display:flex;flex-direction:column;gap:18px}
.pd-cat{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-body);font-weight:700;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-muted);
  margin:0;
}
.pd-cat::before{
  content:"";display:inline-block;
  width:8px;height:8px;border-radius:50%;
  background:var(--pink);
  box-shadow:0 0 12px rgba(255,46,196,.5);
}
.pd-title{
  font-family:var(--font-chunky);font-weight:400;
  font-size:clamp(28px,3.4vw,42px);
  line-height:1.05;
  letter-spacing:-.005em;
  margin:0;
  color:var(--text);
}
.pd-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.pd-rating{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--gold);font-size:14px;
}
.pd-rating-num{
  color:var(--text-muted);font-family:var(--font-mono);font-size:12px;font-weight:600;
  margin-left:4px;
}
.pd-stock{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-body);font-weight:700;
  font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent);
}
.pd-stock::before{
  content:"";width:7px;height:7px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 10px var(--accent);
}

.pd-price{
  display:flex;align-items:baseline;gap:14px;
  margin:0;
}
.pd-price-now{
  font-family:var(--font-display);font-weight:800;
  font-size:48px;line-height:1;
  letter-spacing:-.02em;
  color:var(--accent);
  text-shadow:0 0 28px rgba(57,255,20,.4);
}
.pd-price-each{
  font-family:var(--font-body);font-weight:600;
  font-size:14px;
  color:var(--text-muted);
}

.pd-desc{
  color:var(--text-muted);
  font-size:15.5px;line-height:1.65;
  margin:0;
  max-width:54ch;
}

.pd-notify-card{
  position:relative;
  display:grid;
  gap:18px;
  padding:22px;
  border:1.5px solid rgba(255,46,196,.52);
  border-radius:var(--radius-lg);
  background:linear-gradient(180deg,rgba(255,46,196,.08),rgba(255,255,255,.025)),var(--surface);
  box-shadow:0 18px 48px -26px rgba(255,46,196,.55), inset 0 1px 0 rgba(255,255,255,.06);
  overflow:hidden;
}
.pd-notify-card::before{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:calc(var(--radius-lg) - 1px);
  background:radial-gradient(80% 80% at 0% 0%, rgba(255,46,196,.1), transparent 62%);
  pointer-events:none;
}
.pd-notify-copy{
  position:relative;
  display:grid;
  gap:8px;
}
.pd-notify-kicker{
  font-family:var(--font-body);
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--pink);
}
.pd-notify-copy h2{
  margin:0;
  font-family:var(--font-chunky);
  font-size:clamp(24px,2.5vw,34px);
  font-weight:400;
  line-height:1;
  color:var(--text);
}
.pd-notify-copy p{
  max-width:56ch;
  margin:0;
  color:var(--text-muted);
  font-size:15px;
  line-height:1.55;
}
.pd-notify-btn{
  position:relative;
  width:100%;
  min-height:54px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 22px;
  border:0;
  border-radius:var(--radius-md);
  background:linear-gradient(90deg,var(--pink),#A855E0);
  color:#fff;
  font-family:var(--font-display);
  font-size:15px;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  cursor:pointer;
  box-shadow:0 0 28px -8px rgba(255,46,196,.72);
  transition:filter var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.pd-notify-btn:hover{
  filter:brightness(1.08);
  transform:translateY(-2px);
}

/* ---- Bundle tier picker (interactive) ---- */
.pd-bundle{
  position:relative;
  background:var(--surface);
  border:1.5px solid var(--gold);
  border-radius:var(--radius-lg);
  padding:22px 22px 24px;
  margin-top:6px;
  box-shadow:0 0 32px -16px rgba(255,209,102,.4);
}
.pd-bundle::before{
  /* Subtle gold radial wash inside the card */
  content:"";position:absolute;inset:1px;border-radius:calc(var(--radius-lg) - 1px);
  background:radial-gradient(80% 80% at 0% 0%, rgba(255,209,102,.06), transparent 60%);
  pointer-events:none;
}
.pd-bundle-head{
  position:relative;
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:18px;
  flex-wrap:wrap;gap:8px;
}
.pd-bundle-title{
  font-family:var(--font-chunky);font-weight:400;
  font-size:18px;letter-spacing:-.005em;
  color:var(--text);
  display:inline-flex;align-items:center;gap:8px;
}
.pd-bundle-title .gradient{
  color:var(--gold);
  text-shadow:0 0 24px rgba(255,209,102,.4);
}
.pd-bundle-help{
  font-family:var(--font-body);font-weight:600;
  font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-dim);
}
.pd-tiers{
  position:relative;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(112px,1fr));
  gap:10px;
}
@media (max-width:560px){
  .pd-tiers{grid-template-columns:repeat(2,1fr);gap:12px}
}
.pd-tier{
  cursor:pointer;
  padding:18px 8px 14px;
  background:var(--surface-2);
  border:2px solid var(--border);
  border-radius:var(--radius-md);
  text-align:center;
  display:flex;flex-direction:column;gap:6px;
  align-items:center;justify-content:flex-start;
  position:relative;
  min-height:128px;
  transition:border-color var(--dur) var(--ease), background var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.pd-tier:hover{
  border-color:var(--tier-color, var(--border-bright));
  transform:translateY(-2px);
}
.pd-tier.selected{
  border-color:var(--tier-color, var(--accent));
  background:color-mix(in srgb, var(--tier-color, var(--accent)) 10%, var(--surface));
  box-shadow:0 0 32px -8px var(--tier-color, var(--accent));
}
.pd-tier-qty{
  font-family:var(--font-chunky);font-weight:400;
  font-size:32px;color:var(--text);line-height:1;
  letter-spacing:-.01em;
}
.pd-tier.selected .pd-tier-qty{color:var(--tier-color)}
.pd-tier-qty-label{
  font-family:var(--font-body);font-weight:700;
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-dim);
  margin-top:-2px;
}
.pd-tier.selected .pd-tier-qty-label{color:var(--text-muted)}
.pd-tier-price{
  font-family:var(--font-display);font-weight:800;
  font-size:18px;color:var(--text);line-height:1;
  letter-spacing:-.01em;
  margin-top:6px;
}
.pd-tier-each{
  font-family:var(--font-mono);font-size:10.5px;font-weight:600;
  color:var(--text-dim);letter-spacing:.02em;
  margin-top:2px;
}
.pd-tier.selected .pd-tier-each{color:var(--text-muted)}
.pd-tier-save{
  position:absolute;
  top:-10px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:var(--accent-ink);
  font-family:var(--font-body);font-weight:800;
  font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;
  padding:3px 9px;border-radius:999px;
  box-shadow:0 0 14px -4px var(--accent-glow);
  white-space:nowrap;
  z-index:1;
}
/* tier color tokens */
.pd-tier[data-tier="1"] {--tier-color:var(--text-muted)}
.pd-tier[data-tier="5"] {--tier-color:var(--blue)}
.pd-tier[data-tier="10"]{--tier-color:var(--pink)}
.pd-tier[data-tier="20"]{--tier-color:var(--gold)}
.pd-tier[data-tier="20"] .pd-tier-save{background:var(--gold);color:#2a1a00;box-shadow:0 0 14px -4px rgba(255,209,102,.7)}
.pd-tier[data-tier="10"] .pd-tier-save{background:var(--pink);color:#fff;box-shadow:0 0 14px -4px rgba(255,46,196,.55)}
.pd-tier[data-tier="5"]  .pd-tier-save{background:var(--blue);color:#fff;box-shadow:0 0 14px -4px rgba(46,156,255,.55)}

.pd-variable-bundles{
  position:relative;
  background:var(--surface);
  border:1.5px solid var(--gold);
  border-radius:var(--radius-lg);
  padding:22px 22px 20px;
  margin-top:6px;
  box-shadow:0 0 32px -16px rgba(255,209,102,.4);
}
.pd-variable-bundles .pd-bundle-head{margin-bottom:16px}
.pd-variable-tiers{margin-bottom:16px}
.pd-bundle-progress{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  margin-bottom:12px;
  font-family:var(--font-body);font-weight:800;
  color:var(--text-muted);
}
.pd-bundle-progress button{
  min-height:36px;
  padding:0 14px;
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--surface-2);
  color:var(--text);
  font-family:var(--font-body);font-weight:800;
  cursor:pointer;
}
.pd-bundle-progress button:hover{border-color:var(--accent);color:var(--accent)}
.pd-bundle-slots{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:8px;
}
.pd-bundle-slot{
  min-width:0;
  min-height:54px;
  border:1px dashed var(--border-bright);
  border-radius:12px;
  background:rgba(255,255,255,.03);
  color:var(--text-dim);
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-body);font-weight:800;
  overflow:hidden;
}
button.pd-bundle-slot{
  cursor:pointer;
  border-style:solid;
  color:var(--text);
  padding:6px;
}
.pd-bundle-slot img{
  width:38px;height:38px;object-fit:contain;
  background:#fff;border-radius:8px;
  flex-shrink:0;
}
.pd-bundle-slot span{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

/* ---- Variable product design picker ---- */
.pd-design-builder{
  position:relative;
  background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.018)),var(--surface);
  border:1px solid var(--border-bright);
  border-radius:24px;
  padding:24px;
  margin-top:6px;
  box-shadow:0 18px 48px -28px rgba(0,0,0,.85), inset 0 1px 0 rgba(255,255,255,.06);
  overflow:hidden;
}
.pd-design-builder::before{
  content:"";
  position:absolute;inset:0;
  background:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:28px 28px;
  mask-image:linear-gradient(#000,transparent 78%);
  pointer-events:none;
}
.pd-design-head{
  position:relative;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  margin-bottom:18px;
}
.pd-design-title{
  font-family:var(--font-chunky);font-weight:400;
  font-size:clamp(18px,2vw,25px);
  line-height:1;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--text);
}
.pd-design-status{
  font-family:var(--font-body);font-weight:600;
  font-size:clamp(15px,1.7vw,22px);
  color:var(--text-muted);
  text-align:right;
}
.pd-design-search{
  position:relative;
  display:flex;align-items:center;gap:12px;
  min-height:60px;
  padding:0 18px;
  margin-bottom:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.015)),var(--surface-2);
  border:1px solid var(--border-bright);
  border-radius:999px;
  color:var(--text-muted);
}
.pd-design-search svg{width:24px;height:24px;flex-shrink:0}
.pd-design-search input{
  width:100%;
  min-width:0;
  background:transparent;border:0;outline:0;
  color:var(--text);
  font-family:var(--font-body);font-size:20px;font-weight:600;
}
.pd-design-search input::placeholder{color:var(--text-muted)}
.pd-design-search:focus-within{
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(57,255,20,.14),0 0 24px -10px var(--accent-glow);
}
.pd-design-grid{
  position:relative;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  max-height:560px;
  overflow:auto;
  padding:0 2px 2px 0;
  scrollbar-color:var(--border-bright) transparent;
}
.pd-design-card{
  min-width:0;
  cursor:pointer;
  display:flex;flex-direction:column;gap:10px;
  padding:8px 8px 14px;
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.018)),var(--surface-2);
  border:2px solid var(--border);
  border-radius:12px;
  color:var(--text);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
  transition:border-color var(--dur) var(--ease),transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),opacity var(--dur) var(--ease);
}
.pd-design-card:hover{
  border-color:var(--border-bright);
  transform:translateY(-2px);
}
.pd-design-card.selected{
  border-color:var(--accent);
  box-shadow:0 0 0 1px var(--accent),0 0 24px -8px var(--accent-glow);
}
.pd-design-count{
  position:absolute;
  top:8px;right:8px;
  min-width:28px;height:28px;
  padding:0 8px;
  display:grid;place-items:center;
  border-radius:999px;
  background:var(--accent);
  color:var(--accent-ink);
  font-family:var(--font-display);font-size:14px;font-weight:900;
  box-shadow:0 0 16px -4px var(--accent-glow);
}
.pd-design-card:focus-visible{
  outline:3px solid rgba(57,255,20,.55);
  outline-offset:3px;
}
.pd-design-img{
  display:grid;place-items:center;
  aspect-ratio:1/1;
  background:#fff;
  border-radius:8px;
  overflow:hidden;
}
.pd-design-img img{
  width:100%;height:100%;object-fit:contain;
  padding:6px;
}
.pd-design-name{
  display:block;
  min-height:2.6em;
  color:var(--text);
  font-family:var(--font-body);font-size:14px;font-weight:800;
  line-height:1.3;
  text-align:center;
  overflow-wrap:anywhere;
}
.pd-design-card.is-unavailable{opacity:.42}
.pd-design-card.is-unavailable .pd-design-name{
  text-decoration:line-through;
  color:var(--text-muted);
}
.pd-design-empty{
  position:relative;
  margin:14px 0 0;
  color:var(--text-muted);
  font-weight:700;
  text-align:center;
}

/* ---- Quantity + add to cart ---- */
.pd-buy{
  display:flex;gap:10px;align-items:stretch;
}
.mrc-has-variable-builder .pd-qty{display:none}
.pd-qty{
  flex-shrink:0;
  display:inline-flex;align-items:center;
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  overflow:hidden;
}
.pd-qty button{
  width:44px;height:52px;
  background:none;border:0;
  color:var(--text);
  font-size:18px;line-height:1;cursor:pointer;
  transition:background var(--dur) var(--ease);
}
.pd-qty button:hover{background:var(--surface-3)}
.pd-qty input{
  width:48px;height:52px;
  text-align:center;
  background:none;border:0;outline:0;
  color:var(--text);
  font-family:var(--font-display);font-weight:800;font-size:16px;
  appearance:textfield;-moz-appearance:textfield;
}
.pd-qty input::-webkit-outer-spin-button,
.pd-qty input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

.pd-add{
  flex:1;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:0 22px;
  border:0;border-radius:var(--radius-md);
  background:var(--accent);color:var(--accent-ink);
  font-family:var(--font-display);font-weight:800;font-size:15px;
  letter-spacing:.04em;text-transform:uppercase;
  cursor:pointer;
  box-shadow:0 0 24px -4px var(--accent-glow);
  transition:filter var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.pd-add:hover{filter:brightness(1.08);transform:translateY(-2px)}
.pd-add svg{width:18px;height:18px}

.pd-wish{
  flex-shrink:0;
  width:52px;height:52px;
  display:grid;place-items:center;
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  color:var(--text-muted);
  cursor:pointer;
  transition:color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.pd-wish:hover{color:var(--pink);border-color:var(--pink)}
.pd-wish svg{width:18px;height:18px}

/* ---- Trust strip (small icons under buy button) ---- */
.pd-trust{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;
  margin-top:8px;
}
.pd-trust-item{
  text-align:center;
  padding:16px 8px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  position:relative;
  overflow:hidden;
  transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.pd-trust-item::before{
  /* Top accent bar in the trust color */
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--trust-color, var(--accent));
}
.pd-trust-item:hover{
  border-color:var(--trust-color, var(--accent));
  transform:translateY(-2px);
}
.pd-trust-item:nth-child(1){--trust-color:var(--accent)}   /* green - shipping */
.pd-trust-item:nth-child(2){--trust-color:var(--blue)}     /* blue - waterproof */
.pd-trust-item:nth-child(3){--trust-color:var(--pink)}     /* pink - secure */
.pd-trust-item:nth-child(4){--trust-color:var(--gold)}     /* gold - gift */
.pd-trust-icon{
  display:inline-grid;place-items:center;
  width:36px;height:36px;border-radius:10px;
  margin:0 auto 8px;
  background:color-mix(in srgb, var(--trust-color, var(--accent)) 15%, var(--surface-2));
  border:1px solid color-mix(in srgb, var(--trust-color, var(--accent)) 40%, transparent);
  font-size:18px;line-height:1;
  box-shadow:0 0 16px -8px var(--trust-color, var(--accent));
}
.pd-trust-label{
  font-family:var(--font-body);font-weight:700;
  font-size:11px;letter-spacing:.06em;
  color:var(--text);line-height:1.2;
}

/* Express delivery callout */
.pd-express{
  position:relative;
  display:flex;align-items:center;gap:12px;
  padding:14px 18px 14px 22px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  font-size:13.5px;color:var(--text-muted);
  line-height:1.5;
  overflow:hidden;
}
.pd-express::before{
  /* Blue vertical accent bar */
  content:"";position:absolute;top:0;bottom:0;left:0;width:4px;
  background:var(--blue);
}
.pd-express .icon{
  flex-shrink:0;font-size:20px;
}
.pd-express strong{color:var(--text)}

/* ---- Tabs ---- */
.pd-tabs{margin-top:clamp(40px,5vw,64px)}
.pd-tabs-nav{
  display:flex;gap:2px;
  border-bottom:1px solid var(--border);
  margin-bottom:24px;
}
.pd-tab{
  position:relative;
  background:none;border:0;
  padding:14px 22px;
  font-family:var(--font-body);font-weight:700;
  font-size:13px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-muted);
  cursor:pointer;
  transition:color var(--dur) var(--ease);
}
.pd-tab::after{
  content:"";position:absolute;
  left:50%;bottom:-1px;
  width:0;height:3px;
  background:var(--accent);
  border-radius:999px;
  transform:translateX(-50%);
  transition:width .25s var(--ease);
  box-shadow:0 0 12px var(--accent-glow);
}
.pd-tab:hover{color:var(--text)}
.pd-tab.active{color:var(--text)}
.pd-tab.active::after{width:calc(100% - 22px)}
.pd-tab-count{
  margin-left:6px;
  font-family:var(--font-mono);font-size:11px;font-weight:600;
  color:var(--text-dim);
}
.pd-tab-panel{display:none}
.pd-tab-panel.active{display:block}
.pd-tab-panel p{color:var(--text-muted);font-size:15.5px;line-height:1.7;max-width:64ch;margin:0 0 14px}
.pd-tab-panel ul{color:var(--text-muted);font-size:15px;line-height:1.7;padding-left:20px}
.pd-tab-panel ul li{margin-bottom:6px}

/* Reviews tab — empty state */
.pd-reviews-empty{
  text-align:center;
  padding:56px 20px;
  border:1px dashed var(--border-bright);
  border-radius:var(--radius-md);
  color:var(--text-muted);
}
.pd-reviews-empty h4{
  font-family:var(--font-chunky);font-weight:400;
  font-size:22px;color:var(--text);
  text-transform:uppercase;
  letter-spacing:-.005em;
  margin:0 0 6px;
}
.pd-reviews-empty p{margin:0;font-size:14px}

/* ---- "You May Also Like" carousel ---- */
.related-products .products{margin-top:clamp(20px,2.5vw,32px)}
.mrc-product-slider-section{
  overflow:hidden;
}
.mrc-related-head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:18px;
}
.mrc-related-controls{
  display:flex;
  gap:10px;
  flex-shrink:0;
}
.mrc-related-arrow{
  width:46px;
  height:46px;
  display:grid;
  place-items:center;
  border:1px solid var(--border-bright);
  border-radius:14px;
  background:rgba(255,255,255,.045);
  color:var(--text);
  cursor:pointer;
  transition:transform var(--dur) var(--ease), border-color var(--dur) var(--ease), color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.mrc-related-arrow:hover{
  transform:translateY(-2px);
  border-color:var(--accent);
  color:var(--accent);
  box-shadow:0 0 24px -10px var(--accent-glow);
}
.mrc-related-arrow:disabled{
  opacity:.35;
  cursor:default;
  transform:none;
  box-shadow:none;
}
.mrc-related-carousel{
  position:relative;
  overflow:hidden;
  margin-top:clamp(18px,2.4vw,30px);
  isolation:isolate;
}
.mrc-related-carousel::before,
.mrc-related-carousel::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  z-index:2;
  width:min(70px,10vw);
  pointer-events:none;
  opacity:1;
  transition:opacity .22s var(--ease);
}
.mrc-related-carousel::before{
  left:0;
  background:linear-gradient(90deg,var(--bg),transparent);
}
.mrc-related-carousel::after{
  right:0;
  background:linear-gradient(270deg,var(--bg),transparent);
}
.mrc-related-carousel.is-at-start::before,
.mrc-related-carousel.is-at-end::after{
  opacity:0;
}
.related-products .products.mrc-related-track{
  display:flex!important;
  grid-template-columns:none!important;
  flex-wrap:nowrap!important;
  gap:18px;
  overflow-x:auto!important;
  overflow-y:hidden!important;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  padding:2px 2px 14px;
  margin-top:0;
  scrollbar-width:none;
  outline:0;
  -webkit-overflow-scrolling:touch;
}
.related-products .products.mrc-related-track:focus-visible{
  box-shadow:0 0 0 2px rgba(57,255,20,.82);
  border-radius:22px;
}
.related-products .products.mrc-related-track::-webkit-scrollbar{display:none}
.related-products .products.mrc-related-track .product{
  flex:0 0 clamp(220px,23vw,285px)!important;
  width:auto!important;
  max-width:none!important;
  scroll-snap-align:start;
  scroll-snap-stop:always;
  list-style:none;
}

.pd-title .gradient{
  background:var(--rainbow);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}
.breadcrumb .bc-current{color:var(--text)}

/* ============ PRODUCT PAGE — RAINBOW STATS STRIP ============ */
.pd-stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  margin:clamp(28px,3.5vw,44px) 0 clamp(20px,2.5vw,32px);
  padding:18px 8px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  position:relative;
  overflow:hidden;
}
.pd-stats::before{
  /* Top pink accent line */
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--pink);
}
.pd-stat{
  text-align:center;
  padding:6px 12px;
  border-right:1px solid var(--border);
}
.pd-stat:last-child{border-right:0}
.pd-stat-num{
  font-family:var(--font-chunky);font-weight:400;
  font-size:clamp(22px,2.5vw,30px);
  line-height:1;letter-spacing:-.005em;
  color:var(--stat-color, var(--text));
  text-shadow:0 0 24px color-mix(in srgb, var(--stat-color, var(--text)) 35%, transparent);
}
.pd-stat-label{
  font-family:var(--font-body);font-weight:700;
  font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-muted);
  margin-top:6px;
}
.pd-stat:nth-child(1){--stat-color:var(--pink)}
.pd-stat:nth-child(2){--stat-color:var(--gold)}
.pd-stat:nth-child(3){--stat-color:var(--accent)}
.pd-stat:nth-child(4){--stat-color:var(--blue)}
@media (max-width:560px){
  .pd-stats{grid-template-columns:repeat(2,1fr)}
  .pd-stat{border-right:0;padding:10px 8px}
  .pd-stat:nth-child(1),.pd-stat:nth-child(3){border-right:1px solid var(--border)}
  .pd-stat:nth-child(1),.pd-stat:nth-child(2){border-bottom:1px solid var(--border)}
}

/* Express delivery — rainbow border instead of single blue */

/* ============ FILTER DRAWER ============ */
.filter-drawer-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:var(--radius-pill);
  background:var(--surface);
  border:1px solid var(--border);
  color:var(--text);
  font-family:var(--font-body);font-weight:700;
  font-size:13px;letter-spacing:.01em;
  cursor:pointer;flex-shrink:0;
  transition:border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.filter-drawer-btn:hover{border-color:var(--border-bright);background:var(--surface-2)}
.filter-drawer-btn svg{width:14px;height:14px;color:var(--text-muted);transition:color var(--dur) var(--ease)}
.filter-drawer-btn:hover svg{color:var(--text)}
.filter-drawer-btn .badge-count{
  display:inline-grid;place-items:center;
  min-width:20px;height:20px;padding:0 6px;
  border-radius:999px;
  background:var(--section-accent);
  color:#fff;
  font-family:var(--font-mono);font-weight:700;font-size:11px;
  margin-left:2px;
}
.filter-drawer-btn:not(.has-filters) .badge-count{display:none}

/* Drawer overlay + panel */
.drawer-overlay{
  position:fixed;inset:0;z-index:80;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  opacity:0;
  transition:opacity .25s var(--ease);
}
.drawer-overlay[hidden]{display:none}
.drawer-overlay.is-open{opacity:1}

.filter-drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:81;
  width:min(420px, 100vw);
  background:var(--bg);
  border-left:1px solid var(--border-bright);
  box-shadow:-30px 0 60px rgba(0,0,0,.5);
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .3s var(--ease);
}
.filter-drawer[hidden]{display:none}
.filter-drawer.is-open{transform:translateX(0)}

.drawer-head{
  flex-shrink:0;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 24px;
  border-bottom:1px solid var(--border);
  background:var(--surface);
}
.drawer-head h3{
  font-family:var(--font-chunky);font-weight:400;
  font-size:24px;line-height:1;letter-spacing:-.005em;
  margin:0;
}
.drawer-close{
  width:36px;height:36px;border-radius:50%;
  display:grid;place-items:center;
  background:var(--surface-2);
  color:var(--text-muted);
  cursor:pointer;
  font-size:14px;line-height:1;
  transition:background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.drawer-close:hover{background:var(--surface-3);color:var(--text)}

.drawer-body{
  flex:1;
  overflow-y:auto;
  padding:8px 0;
}
/* Subtle custom scrollbar for the drawer */
.drawer-body::-webkit-scrollbar{width:8px}
.drawer-body::-webkit-scrollbar-track{background:transparent}
.drawer-body::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:999px}
.drawer-body::-webkit-scrollbar-thumb:hover{background:var(--border-bright)}

/* Drawer search field at the top */
.drawer-search{
  position:sticky;top:0;z-index:1;
  margin:0;padding:14px 24px;
  background:linear-gradient(180deg, var(--bg) 0%, var(--bg) 80%, transparent 100%);
}
.drawer-search-input{
  display:flex;align-items:center;gap:10px;
  padding:11px 16px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-pill);
  transition:border-color var(--dur) var(--ease);
}
.drawer-search-input:focus-within{border-color:var(--section-accent)}
.drawer-search-input svg{color:var(--text-dim);flex-shrink:0}
.drawer-search-input input{
  flex:1;background:none;border:0;outline:0;
  font-family:var(--font-body);font-size:14px;font-weight:500;
  color:var(--text);
}
.drawer-search-input input::placeholder{color:var(--text-dim)}

/* Filter groups (accordion) */
.filter-group{
  border-bottom:1px solid var(--border);
  --group-color:var(--accent); /* default; overridden inline per group */
}
.filter-group > summary .group-emoji{
  display:inline-grid;place-items:center;
  width:26px;height:26px;
  border-radius:8px;
  background:color-mix(in srgb, var(--group-color) 14%, transparent);
  border:1px solid color-mix(in srgb, var(--group-color) 35%, transparent);
  font-size:14px;line-height:1;
  margin-right:4px;
  text-transform:none;letter-spacing:0;
  box-shadow:0 0 16px -8px var(--group-color);
}
/* Color the group title text using the group's color */
.filter-group > summary{color:var(--group-color)}
.filter-group > summary:hover{filter:brightness(1.15)}
/* Reset count + chevron back to neutral so they're not overpowering */
.filter-group > summary .group-count{color:var(--text-dim)}
.filter-group > summary .chevron{color:var(--text-muted)}
.filter-group[open] > summary .chevron{color:var(--group-color)}

/* Drawer chip emoji */
.drawer-chip .chip-emoji{
  font-size:13px;line-height:1;
  margin-right:1px;
  filter:saturate(1.1);
  text-transform:none;letter-spacing:0;
}
.filter-group > summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:16px 24px;
  font-family:var(--font-body);font-weight:800;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text);
  user-select:none;
  transition:color var(--dur) var(--ease);
}
.filter-group > summary::-webkit-details-marker{display:none}
.filter-group > summary:hover{color:var(--section-accent)}
.filter-group > summary .group-meta{
  display:inline-flex;align-items:center;gap:8px;
}
.filter-group > summary .group-count{
  font-family:var(--font-mono);font-weight:600;font-size:11px;
  color:var(--text-dim);letter-spacing:.04em;
  text-transform:none;
}
.filter-group > summary .chevron{
  width:14px;height:14px;color:var(--text-muted);
  transition:transform .2s var(--ease);
}
.filter-group[open] > summary .chevron{transform:rotate(180deg)}

.filter-group-options{
  padding:4px 18px 18px;
  display:flex;flex-wrap:wrap;gap:6px;
}
.drawer-chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 12px;
  border-radius:var(--radius-pill);
  background:var(--surface);
  border:1px solid var(--border);
  color:var(--text-muted);
  font-family:var(--font-body);font-weight:600;font-size:12.5px;
  cursor:pointer;
  transition:background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.drawer-chip:hover{color:var(--text);border-color:var(--border-bright)}
.drawer-chip.checked{
  background:var(--section-accent);
  color:#fff;
  border-color:var(--section-accent);
  box-shadow:0 0 16px -6px var(--section-accent);
}
.drawer-chip.checked::before{
  content:"✓";font-weight:900;font-size:11px;line-height:1;
}
.drawer-chip[hidden]{display:none}
.drawer-chip .chip-count{
  font-family:var(--font-mono);font-weight:600;font-size:10.5px;
  color:var(--text-dim);
  background:var(--surface-3);
  padding:1px 6px;
  border-radius:999px;
  letter-spacing:.04em;
  transition:background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.drawer-chip:hover .chip-count{color:var(--text-muted)}
.drawer-chip.checked .chip-count{
  background:rgba(0,0,0,.25);
  color:#fff;
}
.filter-group-empty{
  display:none;
  padding:0 6px;
  font-family:var(--font-body);font-size:12px;font-style:italic;
  color:var(--text-dim);
}
.filter-group.no-matches .filter-group-empty{display:block}
.filter-group.no-matches .filter-group-options > .drawer-chip{display:none}

/* Footer with apply / clear actions */
.drawer-foot{
  flex-shrink:0;
  display:flex;gap:10px;
  padding:18px 22px;
  border-top:1px solid var(--border);
  background:var(--surface);
}
.drawer-foot .btn-clear{
  flex:0 0 auto;
  padding:13px 22px;border-radius:var(--radius-pill);
  background:transparent;
  border:1px solid var(--border);
  color:var(--text-muted);
  font-family:var(--font-display);font-weight:700;font-size:13px;
  cursor:pointer;
  transition:color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.drawer-foot .btn-clear:hover{color:var(--text);border-color:var(--border-bright)}
.drawer-foot .btn-apply{
  flex:1;
  padding:13px 22px;border-radius:var(--radius-pill);
  background:var(--accent);color:var(--accent-ink);
  border:0;
  font-family:var(--font-display);font-weight:700;font-size:14px;letter-spacing:.01em;
  cursor:pointer;
  box-shadow:0 0 24px -6px var(--accent-glow);
  transition:filter var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.drawer-foot .btn-apply:hover{filter:brightness(1.08);transform:translateY(-1px)}

@media (max-width:560px){
  .filter-drawer{width:100vw;border-left:0}
}

/* ============ SHOP GRID — 20 products in a 4-col grid ============ */
.products-grid{
  /* Inherits .products grid; just overrides count */
  grid-template-columns:repeat(4,1fr);
}
@media(max-width:1040px){.products-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:740px){.products-grid{grid-template-columns:repeat(2,1fr)}}

/* ============ MOBILE OPTIMISATIONS ============ */
html,body{max-width:100%;overflow-x:hidden}
img,video{max-width:100%;height:auto}

@media (max-width:900px){
  .pd-grid{grid-template-columns:1fr}
  .pd-gallery{position:static}
}

@media (max-width:720px){
  .pd-tabs-nav{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .pd-tabs-nav::-webkit-scrollbar{display:none}
  .pd-tab{flex-shrink:0;padding:14px 16px;min-height:44px}
}

@media (max-width:640px){
  section.section{padding-top:clamp(28px,6vw,40px);padding-bottom:clamp(28px,6vw,40px)}
  .pd-title{font-size:clamp(22px,7.2vw,34px)}
  .pd-price-now{font-size:38px}
  .pd-desc{font-size:15px}
  .pd-buy{flex-wrap:wrap;gap:10px}
  .pd-qty{order:1}
  .pd-wish{order:2;width:52px;height:52px;min-height:44px;min-width:44px}
  .pd-add{order:3;flex:1 0 100%;width:100%;min-height:52px;padding:14px 16px}
  .pd-trust{grid-template-columns:repeat(2,1fr)}
  .pd-trust-item{padding:14px 8px;min-height:44px}
  .pd-bundle{padding:18px 14px 20px}
  .pd-variable-bundles{padding:18px 14px 16px}
  .pd-bundle-slots{grid-template-columns:repeat(2,minmax(0,1fr))}
  .pd-bundle-slot{min-height:50px}
  .pd-design-builder{padding:16px 12px;border-radius:20px}
  .pd-design-head{align-items:flex-start;gap:8px;flex-direction:column}
  .pd-design-status{text-align:left}
  .pd-design-search{min-height:52px;padding:0 14px}
  .pd-design-search input{font-size:16px}
  .pd-design-grid{grid-template-columns:repeat(2,minmax(0,1fr));max-height:470px;gap:10px}
  .pd-design-name{font-size:13px}
  .pd-tier{padding:18px 6px 14px}
  .pd-tier-qty{font-size:28px}
  .pd-tier-price{font-size:16px}
  .pd-tier-save{font-size:8.5px;letter-spacing:.1em;padding:3px 7px}
  .pd-bundle-head{margin-bottom:14px}
  .pd-thumbs{grid-template-columns:repeat(4,1fr);gap:8px}
}

@media (max-width:560px){
  .foot-grid{grid-template-columns:1fr;gap:28px}
  .pd-tier{min-height:118px}
}

@media (max-width:380px){
  .pd-title{font-size:24px}
  .pd-price-now{font-size:34px}
  .pd-tier-qty{font-size:24px}
}

/* WordPress/WooCommerce dynamic remap helpers */
.pd-main-img .woocommerce-product-gallery{width:100% !important;float:none !important;margin:0 !important}
.pd-main-img .woocommerce-product-gallery__wrapper{margin:0 !important}
.pd-main-img .woocommerce-product-gallery__image a{display:block}
.pd-main-img .woocommerce-product-gallery__image img{width:100%;height:auto;object-fit:contain;border-radius:inherit}
.pd-main-img .flex-control-thumbs{display:none !important}
.pd-thumbs .pd-thumb img{width:100%;height:100%;object-fit:contain}
.pd-price .price{margin:0 !important;display:inline-flex;gap:8px;align-items:baseline;color:inherit}
.pd-price .amount{color:inherit}
.pd-price del{opacity:.45;font-size:.55em}
.pd-price ins{text-decoration:none}
.pd-hidden-cart-form{position:absolute;left:-99999px;top:auto;width:1px;height:1px;overflow:hidden}
.pd-hidden-cart-form .quantity input.qty{width:80px}
.pd-hidden-cart-form form.cart{display:block !important}
.pd-add.loading{opacity:.7;pointer-events:none}
.pd-stock.out-of-stock{color:var(--danger)}
.pd-tab-panel .woocommerce-Reviews-title,
.pd-tab-panel .comment-reply-title{font-family:var(--font-display);color:var(--text)}
.pd-tab-panel input,
.pd-tab-panel textarea,
.pd-tab-panel select{background:var(--surface-2);border:1px solid var(--border-bright);border-radius:12px;color:var(--text);padding:12px}
.pd-tab-panel .form-submit .submit{background:var(--accent);color:var(--accent-ink);border:0;border-radius:999px;padding:13px 20px;font-weight:800}
.related-products .products{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.related-products .products.mrc-related-track{display:flex;grid-template-columns:none}
.related-products .products .product{list-style:none}
.mrc-lovable-product-shell .product_meta{margin-top:18px;padding-top:18px;border-top:1px solid var(--border);color:var(--text-muted);font-size:12px}
.mrc-lovable-product-shell .product_meta a{color:var(--text)}

/* =========================================================
   Custom WooCommerce cart
   ========================================================= */
body.woocommerce-cart{background:var(--bg);color:var(--text)}
.mrc-commerce-shell{min-height:100vh;background:var(--bg);color:var(--text)}
.mrc-cart-shell{
  width:min(1180px,calc(100% - 32px));
  margin:0 auto;
  padding:clamp(24px,4vw,56px) 0 clamp(56px,6vw,84px);
}
.mrc-cart-hero{
  display:flex;align-items:flex-end;justify-content:space-between;gap:24px;
  margin-bottom:24px;
  padding-bottom:22px;
  border-bottom:1px solid var(--border);
}
.mrc-cart-kicker{
  display:inline-flex;align-items:center;gap:10px;
  margin:0 0 10px;
  color:var(--text-muted);
  font-family:var(--font-body);font-weight:800;font-size:12px;
  letter-spacing:.18em;text-transform:uppercase;
}
.mrc-cart-kicker span{
  width:9px;height:9px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 14px var(--accent-glow);
}
.mrc-cart-hero h1,
.mrc-empty-cart h1{
  margin:0;
  color:var(--text);
  font-family:var(--font-chunky);font-size:clamp(32px,5vw,58px);
  font-weight:400;line-height:.98;
}
.mrc-cart-hero h1 span,
.mrc-empty-cart h1 span{color:var(--accent)}
.mrc-cart-hero p,
.mrc-empty-cart p{
  max-width:54ch;
  margin:12px 0 0;
  color:var(--text-muted);
  font-size:16px;line-height:1.6;
}
.mrc-cart-hero-cta,
.mrc-empty-cart .button{
  flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:52px;
  padding:0 24px;
  border:0;border-radius:var(--radius-pill);
  background:var(--accent);
  color:var(--accent-ink);
  font-family:var(--font-display);font-weight:900;
  text-transform:uppercase;letter-spacing:.04em;
  box-shadow:0 0 26px -8px var(--accent-glow);
}
.mrc-cart-hero-cta svg{width:18px;height:18px}
.mrc-cart-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,390px);
  gap:24px;
  align-items:start;
}
.mrc-cart-form,
.mrc-cart-summary-card,
.mrc-empty-cart{
  background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.018)),var(--surface);
  border:1px solid var(--border);
  border-radius:24px;
  box-shadow:0 20px 54px -32px rgba(0,0,0,.9);
}
.mrc-cart-form{padding:18px}
.mrc-cart-list-head{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:8px 4px 18px;
}
.mrc-cart-list-head div{display:flex;flex-direction:column;gap:4px}
.mrc-cart-count{
  color:var(--accent);
  font-family:var(--font-mono);font-size:12px;font-weight:800;
  letter-spacing:.12em;text-transform:uppercase;
}
.mrc-cart-list-head strong{
  font-family:var(--font-chunky);font-size:24px;font-weight:400;
}
.mrc-cart-list-head a{
  color:var(--text);
  border:1px solid var(--border);
  border-radius:999px;
  padding:10px 14px;
  font-weight:800;font-size:13px;
}
.mrc-cart-list-head a:hover{border-color:var(--accent);color:var(--accent)}
.mrc-cart-item{
  display:grid;
  grid-template-columns:116px minmax(0,1fr);
  gap:16px;
  padding:16px 0;
  border-top:1px solid var(--border);
}
.mrc-cart-item-media{
  aspect-ratio:1/1;
  border-radius:16px;
  overflow:hidden;
  background:#fff;
  display:grid;place-items:center;
}
.mrc-cart-item-media img{
  width:100%;height:100%;object-fit:contain;
  padding:8px;
}
.mrc-cart-item-title-row{
  display:flex;align-items:flex-start;justify-content:space-between;gap:14px;
}
.mrc-cart-item h2{
  margin:0;
  font-family:var(--font-display);font-size:18px;line-height:1.25;
}
.mrc-cart-item h2 a{color:var(--text)}
.mrc-cart-remove{
  flex-shrink:0;
  color:var(--text-muted)!important;
  border:1px solid var(--border);
  border-radius:999px;
  padding:8px 12px;
  font-size:12px;font-weight:900;
}
.mrc-cart-remove:hover{color:var(--pink)!important;border-color:var(--pink)}
.mrc-cart-item-meta{
  margin-top:8px;
  color:var(--text-muted);
  font-size:13px;
}
.mrc-cart-item-meta dl{margin:0;display:flex;flex-wrap:wrap;gap:7px 10px}
.mrc-cart-item-meta dt{font-weight:900;color:var(--text)}
.mrc-cart-item-meta dd{margin:0}
.mrc-cart-item-controls{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin-top:14px;
}
.mrc-cart-price,
.mrc-cart-qty,
.mrc-cart-subtotal{
  min-width:0;
  padding:12px;
  border:1px solid var(--border);
  border-radius:14px;
  background:rgba(255,255,255,.025);
}
.mrc-cart-price span,
.mrc-cart-qty > span,
.mrc-cart-subtotal span{
  display:block;
  margin-bottom:6px;
  color:var(--text-dim);
  font-size:10px;font-weight:900;
  letter-spacing:.14em;text-transform:uppercase;
}
.mrc-cart-price .amount,
.mrc-cart-subtotal .amount{
  color:var(--accent);
  font-family:var(--font-display);font-weight:900;
}
.mrc-cart-qty .quantity{display:flex}
.mrc-cart-qty input.qty{
  width:100%;
  min-height:36px;
  border:0;border-radius:10px;
  background:var(--surface-2);
  color:var(--text);
  text-align:center;
  font-family:var(--font-display);font-weight:900;
}
.mrc-cart-actions{
  display:flex;align-items:flex-end;justify-content:space-between;gap:14px;
  padding-top:18px;
  border-top:1px solid var(--border);
}
.mrc-cart-coupon{flex:1;max-width:420px}
.mrc-cart-coupon label{
  display:block;
  margin:0 0 8px;
  color:var(--text-muted);
  font-size:11px;font-weight:900;
  letter-spacing:.14em;text-transform:uppercase;
}
.mrc-cart-coupon div{display:flex;gap:8px}
.mrc-cart-coupon input{
  min-width:0;flex:1;
  min-height:44px;
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--surface-2);
  color:var(--text);
  padding:0 14px;
}
.mrc-cart-actions .button,
.mrc-cart-summary .button,
.mrc-cart-summary .checkout-button{
  min-height:44px;
  border:0!important;
  border-radius:14px!important;
  background:var(--accent)!important;
  color:var(--accent-ink)!important;
  font-family:var(--font-display)!important;
  font-weight:900!important;
  text-transform:uppercase;
}
.mrc-cart-update{padding:0 18px!important}
.mrc-cart-summary{position:sticky;top:96px}
.mrc-cart-summary-card{padding:18px}
.mrc-cart-summary-head{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding-bottom:14px;
  border-bottom:1px solid var(--border);
}
.mrc-cart-summary-head span{
  font-family:var(--font-chunky);font-size:24px;
}
.mrc-cart-summary-head strong{
  display:grid;place-items:center;
  min-width:34px;height:34px;padding:0 8px;
  border-radius:999px;
  background:var(--accent);
  color:var(--accent-ink);
  font-family:var(--font-mono);
}
.mrc-cart-summary .cart_totals{float:none!important;width:100%!important}
.mrc-cart-summary .cart_totals h2{display:none}
.mrc-cart-summary table.shop_table{
  width:100%;
  margin:12px 0!important;
  border:0!important;
  border-collapse:separate;
  border-spacing:0 8px;
}
.mrc-cart-summary table.shop_table th,
.mrc-cart-summary table.shop_table td{
  border:0!important;
  padding:10px 0!important;
  color:var(--text-muted);
  background:transparent!important;
}
.mrc-cart-summary table.shop_table td{text-align:right;color:var(--text)}
.mrc-cart-summary .order-total th,
.mrc-cart-summary .order-total td{font-size:18px;color:var(--text)!important}
.mrc-cart-summary .order-total .amount{
  color:var(--accent);
  font-family:var(--font-display);font-size:26px;font-weight:900;
}
.mrc-cart-summary .wc-proceed-to-checkout{padding:8px 0 0!important}
.mrc-cart-summary .checkout-button{
  display:flex!important;align-items:center;justify-content:center;
  width:100%;
  min-height:56px;
  margin:0!important;
  box-shadow:0 0 26px -8px var(--accent-glow);
}
.mrc-cart-trust{
  display:grid;gap:8px;
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid var(--border);
}
.mrc-cart-trust div{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  color:var(--text-muted);
  font-size:12px;
}
.mrc-cart-trust strong{color:var(--text)}
.mrc-empty-cart{
  width:min(760px,calc(100% - 32px));
  margin:clamp(40px,8vw,100px) auto;
  padding:clamp(28px,5vw,56px);
  text-align:center;
}
.mrc-empty-cart .mrc-cart-kicker{justify-content:center}
.mrc-empty-cart .button{margin-top:20px}

.mrc-checkout-intro{
  width:min(1180px,calc(100% - 32px));
  margin:0 auto;
  padding:clamp(28px,5vw,64px) 0 20px;
}
.mrc-checkout-intro h1{
  margin:0;
  font-family:var(--font-chunky);font-size:clamp(36px,5vw,64px);
  font-weight:400;line-height:1;
}
.mrc-checkout-intro p:not(.mrc-cart-kicker){
  max-width:58ch;
  color:var(--text-muted);
  font-size:16px;line-height:1.6;
}
.mrc-checkout-panel{
  width:min(1180px,calc(100% - 32px));
  margin:0 auto clamp(56px,6vw,84px);
  padding:clamp(16px,3vw,24px);
  background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.018)),var(--surface);
  border:1px solid var(--border);
  border-radius:24px;
}
.mrc-checkout-panel .woocommerce form .form-row input.input-text,
.mrc-checkout-panel .woocommerce form .form-row textarea,
.mrc-checkout-panel .woocommerce form .form-row select,
.mrc-checkout-panel .select2-container--default .select2-selection--single{
  min-height:44px;
  border:1px solid var(--border)!important;
  border-radius:12px!important;
  background:var(--surface-2)!important;
  color:var(--text)!important;
}
.mrc-commerce-shell,
.mrc-checkout-shell,
.mrc-checkout-panel,
.mrc-checkout-panel .woocommerce,
.mrc-checkout-panel .woocommerce form.checkout,
.mrc-checkout-panel .woocommerce-billing-fields,
.mrc-checkout-panel .woocommerce-shipping-fields,
.mrc-checkout-panel .woocommerce-additional-fields{
  overflow:visible!important;
}
.mrc-checkout-panel .select2-container{
  position:relative;
  z-index:2;
}
.select2-container--open{
  z-index:100120!important;
}
.select2-container--open .select2-dropdown{
  z-index:100121!important;
  border:1px solid rgba(57,255,20,.36)!important;
  border-radius:14px!important;
  overflow:hidden!important;
  background:#101014!important;
  color:#fff!important;
  box-shadow:0 24px 70px -30px rgba(0,0,0,.96),0 0 32px -20px rgba(57,255,20,.72)!important;
}
.select2-container--default .select2-search--dropdown{
  padding:10px!important;
  background:#101014!important;
}
.select2-container--default .select2-search--dropdown .select2-search__field{
  min-height:42px!important;
  border:1px solid rgba(255,255,255,.14)!important;
  border-radius:10px!important;
  background:rgba(255,255,255,.08)!important;
  color:#fff!important;
  outline:0!important;
}
.select2-container--default .select2-results__option{
  padding:10px 12px!important;
  color:#fff!important;
}
.select2-container--default .select2-results__option--highlighted,
.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted[data-selected]{
  background:rgba(255,255,255,.14)!important;
  color:#fff!important;
}
.select2-container--default .select2-results__option[aria-selected=true],
.select2-container--default .select2-results__option[data-selected=true]{
  background:rgba(255,255,255,.12)!important;
  color:#fff!important;
}
.mrc-checkout-panel .woocommerce form .form-row select option,
.mrc-checkout-panel .woocommerce form .form-row select option:hover,
.mrc-checkout-panel .woocommerce form .form-row select option:checked{
  background:#101014!important;
  color:#fff!important;
}
.mrc-checkout-panel .woocommerce table.shop_table{
  border:1px solid var(--border)!important;
  border-radius:16px;
  overflow:hidden;
}
.mrc-checkout-panel .woocommerce table.shop_table th,
.mrc-checkout-panel .woocommerce table.shop_table td{
  border-color:var(--border)!important;
}
.mrc-checkout-panel #place_order{
  min-height:54px;
  border:0!important;
  border-radius:14px!important;
  background:var(--accent)!important;
  color:var(--accent-ink)!important;
  font-family:var(--font-display)!important;
  font-weight:900!important;
}

/* Commerce refresh: cart + checkout */
.mrc-commerce-shell{
  position:relative;
  overflow:hidden;
}
.mrc-commerce-shell::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 12% 12%,rgba(255,46,196,.16),transparent 30%),
    radial-gradient(circle at 88% 16%,rgba(46,156,255,.14),transparent 34%),
    radial-gradient(circle at 52% 88%,rgba(57,255,20,.10),transparent 34%);
}
.mrc-commerce-shell > *{position:relative;z-index:1}
.mrc-cart-shell{
  padding-top:clamp(34px,5vw,72px);
}
.mrc-cart-hero,
.mrc-checkout-intro{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  border-radius:28px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.018)),
    rgba(10,10,10,.62);
  box-shadow:0 26px 80px -52px rgba(0,0,0,.95);
}
.mrc-cart-hero{
  padding:clamp(20px,3vw,34px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.mrc-cart-hero::before,
.mrc-checkout-intro::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:3px;
  background:var(--rainbow);
}
.mrc-cart-kicker{
  color:var(--text-muted);
}
.mrc-cart-kicker span{background:var(--accent)}
.mrc-cart-hero h1,
.mrc-empty-cart h1,
.mrc-checkout-intro h1{
  max-width:900px;
  font-family:var(--font-hero);
  font-size:clamp(48px,7.4vw,104px);
  line-height:.88;
  text-transform:uppercase;
  letter-spacing:0;
}
.mrc-cart-hero h1 span:first-child,
.mrc-checkout-intro h1 span:first-child{
  color:var(--text);
}
.mrc-cart-hero h1 span:last-child,
.mrc-empty-cart h1 span,
.mrc-checkout-intro h1 span:last-child{
  background:var(--rainbow);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  -webkit-text-fill-color:transparent;
}
.mrc-cart-hero-cta,
.mrc-empty-cart .button,
.mrc-cart-actions .button,
.mrc-cart-summary .button,
.mrc-cart-summary .checkout-button,
.mrc-checkout-panel #place_order{
  border-radius:16px!important;
  background:var(--rainbow)!important;
  color:#050505!important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.18),
    0 18px 44px -24px rgba(57,255,20,.9),
    0 0 30px -12px rgba(255,46,196,.78)!important;
}
.mrc-cart-form,
.mrc-cart-summary-card,
.mrc-checkout-panel,
.mrc-empty-cart{
  border-color:rgba(255,255,255,.09);
  background:
    linear-gradient(180deg,rgba(255,255,255,.052),rgba(255,255,255,.018)),
    rgba(15,15,15,.82);
  box-shadow:
    0 22px 70px -42px rgba(0,0,0,.95),
    inset 0 1px 0 rgba(255,255,255,.05);
}
.mrc-cart-list-head,
.mrc-cart-summary-head{
  border-color:rgba(255,255,255,.08);
}
.mrc-cart-count,
.mrc-cart-price .amount,
.mrc-cart-subtotal .amount,
.mrc-cart-summary .order-total .amount{
  color:var(--accent);
  text-shadow:0 0 28px rgba(57,255,20,.2);
}
.mrc-cart-list-head strong,
.mrc-cart-summary-head span{
  font-family:var(--font-chunky);
  color:var(--text);
}
.mrc-cart-list-head a,
.mrc-cart-remove{
  background:rgba(255,255,255,.035);
}
.mrc-cart-item{
  margin-top:12px;
  padding:16px;
  border:1px solid rgba(255,255,255,.07);
  border-radius:20px;
  background:
    radial-gradient(circle at 8% 10%,rgba(46,156,255,.08),transparent 36%),
    rgba(255,255,255,.022);
}
.mrc-cart-item-media{
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 16px 34px -26px rgba(0,0,0,.9);
}
.mrc-cart-price,
.mrc-cart-qty,
.mrc-cart-subtotal,
.mrc-cart-coupon input{
  border-color:rgba(255,255,255,.08);
  background:rgba(255,255,255,.035);
}
.mrc-cart-qty input.qty,
.mrc-checkout-panel .woocommerce form .form-row input.input-text,
.mrc-checkout-panel .woocommerce form .form-row textarea,
.mrc-checkout-panel .woocommerce form .form-row select,
.mrc-checkout-panel .select2-container--default .select2-selection--single{
  border-color:rgba(255,255,255,.10)!important;
  background:rgba(255,255,255,.045)!important;
  color:var(--text)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.mrc-cart-qty input.qty:focus,
.mrc-cart-coupon input:focus,
.mrc-checkout-panel .woocommerce form .form-row input.input-text:focus,
.mrc-checkout-panel .woocommerce form .form-row textarea:focus{
  outline:0;
  border-color:var(--accent)!important;
  box-shadow:0 0 0 1px rgba(57,255,20,.28),0 0 26px -14px var(--accent)!important;
}
.mrc-cart-trust{
  gap:10px;
}
.mrc-cart-trust div{
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.07);
  border-radius:14px;
  background:rgba(255,255,255,.025);
}
.mrc-checkout-intro{
  padding:clamp(24px,4vw,46px);
  margin-top:clamp(34px,5vw,72px);
}
.mrc-checkout-panel{
  display:block;
}
.mrc-checkout-panel .woocommerce{
  color:var(--text);
}
.mrc-checkout-panel .woocommerce form.checkout{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,430px);
  gap:clamp(18px,3vw,28px);
  align-items:start;
}
.mrc-checkout-panel .woocommerce-billing-fields,
.mrc-checkout-panel .woocommerce-shipping-fields,
.mrc-checkout-panel .woocommerce-additional-fields,
.mrc-checkout-panel #order_review,
.mrc-checkout-panel .woocommerce-checkout-review-order{
  padding:clamp(16px,2vw,22px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  background:rgba(255,255,255,.025);
}
.mrc-checkout-panel #order_review_heading{
  margin:0 0 12px;
  font-family:var(--font-chunky);
  font-size:clamp(28px,3vw,38px);
  font-weight:400;
  color:var(--accent);
}
.mrc-checkout-panel h3,
.mrc-checkout-panel .woocommerce-billing-fields h3,
.mrc-checkout-panel .woocommerce-additional-fields h3{
  font-family:var(--font-chunky);
  font-size:clamp(26px,2.7vw,36px);
  font-weight:400;
  color:var(--text);
}
.mrc-checkout-panel .form-row label{
  color:var(--text-muted);
  font-weight:900;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.mrc-checkout-panel .woocommerce table.shop_table{
  overflow:hidden;
  border-color:rgba(255,255,255,.08)!important;
  background:rgba(0,0,0,.18);
}
.mrc-checkout-panel .woocommerce table.shop_table th,
.mrc-checkout-panel .woocommerce table.shop_table td{
  padding:13px 14px!important;
  color:var(--text-muted);
}
.mrc-checkout-panel .woocommerce table.shop_table td{
  color:var(--text);
}
.mrc-checkout-panel .woocommerce table.shop_table .order-total .amount{
  color:var(--accent);
  font-family:var(--font-display);
  font-size:24px;
  font-weight:900;
}
.mrc-checkout-order-table .cart_item .product-name{
  min-width:0;
}
.mrc-checkout-order-product{
  display:grid;
  grid-template-columns:58px minmax(0,1fr);
  gap:12px;
  align-items:center;
}
.mrc-checkout-order-thumb{
  width:58px;
  aspect-ratio:1;
  display:grid;
  place-items:center;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;
  background:linear-gradient(145deg,rgba(255,255,255,.08),rgba(255,255,255,.025));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.035);
}
.mrc-checkout-order-thumb img{
  width:100%;
  height:100%;
  display:block;
  object-fit:contain!important;
  object-position:center center!important;
  padding:10%!important;
  box-sizing:border-box;
}
.mrc-checkout-order-copy{
  min-width:0;
  display:block;
}
.mrc-checkout-order-title{
  display:block;
  color:var(--text);
  font-family:var(--font-display);
  font-weight:800;
  line-height:1.2;
}
.mrc-checkout-order-table .product-quantity{
  display:inline-flex;
  align-items:center;
  margin-top:5px;
  color:var(--accent);
  font-family:var(--font-mono);
  font-size:12px;
}
.mrc-checkout-order-table .variation{
  margin:6px 0 0;
  color:var(--text-muted);
  font-size:12px;
}
.mrc-checkout-order-table .product-total{
  white-space:nowrap;
}
.mrc-checkout-panel #payment{
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  background:rgba(255,255,255,.03)!important;
}
.mrc-checkout-panel #payment ul.payment_methods,
.mrc-checkout-panel #payment ul.wc_payment_methods{
  display:block!important;
  width:100%!important;
  margin:0!important;
  padding:16px!important;
  list-style:none!important;
}
.mrc-checkout-panel #payment ul.payment_methods li,
.mrc-checkout-panel #payment ul.wc_payment_methods li{
  display:block!important;
  width:100%!important;
  max-width:100%!important;
  margin:0!important;
  padding:0!important;
  overflow-wrap:break-word!important;
  word-break:normal!important;
  white-space:normal!important;
}
.mrc-checkout-panel #payment div.payment_box{
  border-radius:14px;
  background:rgba(255,255,255,.045)!important;
  color:var(--text-muted)!important;
}
.mrc-checkout-panel .woocommerce-privacy-policy-text,
.mrc-checkout-panel .woocommerce-terms-and-conditions-wrapper{
  color:var(--text-muted);
  font-size:13px;
}
.mrc-checkout-panel a{color:var(--accent)}
.mrc-checkout-panel .woocommerce-error,
.mrc-checkout-panel .woocommerce-info,
.mrc-checkout-panel .woocommerce-message,
.mrc-cart-shell .woocommerce-error,
.mrc-cart-shell .woocommerce-info,
.mrc-cart-shell .woocommerce-message{
  border:1px solid rgba(255,255,255,.09)!important;
  border-radius:16px;
  background:rgba(255,255,255,.045)!important;
  color:var(--text)!important;
}

/* =========================================================
   Side cart drawer
   ========================================================= */
body.mrc-side-cart-open{overflow:hidden}
body.mrc-notify-open{overflow:hidden}
.mrc-notify-modal{
  position:fixed;
  inset:0;
  z-index:99995;
  display:grid;
  place-items:center;
  padding:20px;
  opacity:0;
  pointer-events:none;
  transition:opacity .22s var(--ease);
}
.mrc-notify-modal[aria-hidden="false"]{
  opacity:1;
  pointer-events:auto;
}
.mrc-notify-backdrop{
  position:absolute;
  inset:0;
  border:0;
  background:rgba(0,0,0,.68);
  backdrop-filter:blur(8px);
}
.mrc-notify-panel{
  position:relative;
  width:min(100%,420px);
  padding:22px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:18px;
  background:linear-gradient(180deg,rgba(28,28,28,.98),rgba(12,12,12,.98));
  box-shadow:0 30px 90px rgba(0,0,0,.52),inset 0 1px 0 rgba(255,255,255,.08);
  color:var(--text);
  transform:translateY(10px) scale(.98);
  transition:transform .22s var(--ease);
}
.mrc-notify-modal[aria-hidden="false"] .mrc-notify-panel{transform:translateY(0) scale(1)}
.mrc-notify-close{
  position:absolute;
  top:12px;right:12px;
  width:34px;height:34px;
  border:1px solid var(--border);
  border-radius:999px;
  background:rgba(255,255,255,.05);
  color:var(--text);
  font-size:22px;
  line-height:1;
}
.mrc-notify-kicker{
  margin:0 0 8px;
  color:var(--accent);
  font-family:var(--font-body);
  font-size:11px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.mrc-notify-panel h2{
  margin:0 36px 8px 0;
  color:var(--text);
  font-family:var(--font-display);
  font-size:28px;
  line-height:1;
}
.mrc-notify-panel p{
  margin:0 0 16px;
  color:var(--text-muted);
  font-family:var(--font-body);
  font-size:14px;
  line-height:1.45;
}
.mrc-notify-panel label{
  display:grid;
  gap:7px;
  margin:0 0 10px;
  color:var(--text);
  font-family:var(--font-body);
  font-size:12px;
  font-weight:900;
}
.mrc-notify-panel input[type="email"]{
  width:100%;
  min-height:48px;
  padding:0 14px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:12px;
  background:rgba(255,255,255,.07);
  color:var(--text);
  font-family:var(--font-body);
  font-size:15px;
}
.mrc-notify-panel input[type="email"]:focus{
  outline:2px solid rgba(57,255,20,.42);
  outline-offset:2px;
}
.mrc-notify-privacy{
  margin:0 0 14px!important;
  font-size:12px!important;
  color:var(--text-soft)!important;
}
.mrc-notify-submit{
  width:100%;
  min-height:50px;
  border:0;
  border-radius:14px;
  background:var(--accent);
  color:var(--accent-ink);
  font-family:var(--font-display);
  font-size:15px;
  font-weight:900;
  text-transform:uppercase;
  box-shadow:0 0 24px -8px var(--accent-glow);
}
.mrc-notify-panel.is-loading .mrc-notify-submit{
  opacity:.72;
  pointer-events:none;
}
.mrc-notify-status{
  min-height:20px;
  margin:12px 0 0!important;
  font-size:13px!important;
  font-weight:800;
}
.mrc-notify-status.is-success{color:var(--accent)!important}
.mrc-notify-status.is-error{color:var(--pink)!important}
@media (max-width:520px){
  .mrc-notify-modal{
    padding:14px;
    align-items:end;
  }
  .mrc-notify-panel{
    padding:20px;
    border-radius:16px;
  }
  .mrc-notify-panel h2{font-size:24px}
}
.mrc-side-cart{
  position:fixed;
  inset:0;
  z-index:99990;
  pointer-events:none;
}
.mrc-side-cart[aria-hidden="true"]{visibility:hidden}
.mrc-side-cart-backdrop{
  position:absolute;
  inset:0;
  border:0;
  background:rgba(0,0,0,.58);
  opacity:0;
  cursor:pointer;
  transition:opacity .22s var(--ease);
}
.mrc-side-cart-panel{
  position:absolute;
  top:0;right:0;
  width:min(440px,calc(100vw - 18px));
  height:100%;
  display:grid;
  grid-template-rows:auto minmax(0,1fr) auto;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.015)),var(--surface);
  border-left:1px solid var(--border-bright);
  box-shadow:-24px 0 70px -34px rgba(0,0,0,.95);
  transform:translateX(104%);
  transition:transform .26s var(--ease);
  will-change:transform;
  contain:layout paint;
}
.mrc-side-cart-panel::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:4px;
  background:var(--rainbow);
  pointer-events:none;
}
.mrc-side-cart[aria-hidden="false"]{pointer-events:auto;visibility:visible}
.mrc-side-cart[aria-hidden="false"] .mrc-side-cart-backdrop{opacity:1}
.mrc-side-cart[aria-hidden="false"] .mrc-side-cart-panel{transform:translateX(0)}
.mrc-side-cart-head{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:24px 20px 18px;
  border-bottom:1px solid var(--border);
}
.mrc-side-cart-kicker{
  margin:0 0 4px;
  color:var(--accent);
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.mrc-side-cart-head h2{
  margin:0;
  color:var(--text);
  font-family:var(--font-chunky);
  font-size:30px;
  font-weight:400;
  line-height:1;
}
.mrc-side-cart-close{
  width:44px;height:44px;
  display:grid;place-items:center;
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--surface-2);
  color:var(--text);
  font-size:26px;
  line-height:1;
  cursor:pointer;
}
.mrc-side-cart-close:hover{border-color:var(--pink);color:var(--pink)}
.mrc-side-cart-body{
  min-height:0;
  overflow:auto;
  padding:14px 16px;
  scrollbar-color:var(--border-bright) transparent;
}
.mrc-side-cart-progress{
  position:relative;
  overflow:hidden;
  margin:0 0 14px;
  padding:14px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:18px;
  background:linear-gradient(145deg,rgba(255,46,196,.12),rgba(46,156,255,.08) 55%,rgba(57,255,20,.06));
  box-shadow:0 18px 42px -30px rgba(255,46,196,.75);
}
.mrc-side-cart-progress::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:2px;
  background:var(--rainbow);
  pointer-events:none;
}
.mrc-side-cart-progress-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:var(--text-muted);
  font-family:var(--font-body);
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.mrc-side-cart-progress-head strong{
  color:var(--text);
  font-family:var(--font-mono);
  letter-spacing:0;
}
.mrc-side-cart-progress-track{
  height:10px;
  margin:12px 0 10px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.1);
  border-radius:999px;
  background:rgba(0,0,0,.38);
}
.mrc-side-cart-progress-track span{
  display:block;
  height:100%;
  min-width:8px;
  border-radius:inherit;
  background:var(--rainbow);
  box-shadow:0 0 22px -7px var(--accent);
  transition:width .22s var(--ease);
}
.mrc-side-cart-progress-status{
  margin:0;
  color:var(--text);
  font-family:var(--font-chunky);
  font-size:22px;
  line-height:1.05;
}
.mrc-side-cart-progress-sub{
  margin:6px 0 0;
  color:var(--text-muted);
  font-size:12px;
  line-height:1.35;
}
.mrc-side-cart-deal-steps{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  margin-top:12px;
}
.mrc-side-cart-deal-step{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 10px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  color:var(--text-muted);
  background:rgba(255,255,255,.04);
  font-family:var(--font-display);
  font-size:12px;
  font-weight:900;
}
.mrc-side-cart-deal-step.is-hit{
  color:#071006;
  border-color:transparent;
  background:var(--accent);
}
.mrc-side-cart-deal-step.is-pink.is-hit{background:var(--pink);color:#fff}
.mrc-side-cart-deal-step.is-green.is-hit{background:var(--accent);color:var(--accent-ink)}
.mrc-side-cart-deal-step.is-blue.is-hit{background:var(--blue);color:#fff}
.mrc-side-cart-deal-step.is-rainbow.is-hit{background:var(--rainbow);color:#080808}
.mrc-side-cart-items{display:grid;gap:12px}
.mrc-side-cart-item{
  position:relative;
  display:grid;
  grid-template-columns:76px minmax(0,1fr);
  gap:12px;
  padding:12px 42px 12px 12px;
  background:rgba(255,255,255,.025);
  border:1px solid var(--border);
  border-radius:16px;
  transition:opacity 160ms var(--ease), transform 160ms var(--ease);
}
.mrc-side-cart-item.is-removing{
  opacity:.45;
  transform:translateX(8px);
  pointer-events:none;
}
.mrc-side-cart-img{
  aspect-ratio:1/1;
  display:grid;
  place-items:center;
  overflow:hidden;
  border-radius:12px;
  background:#fff;
  border:1px solid rgba(255,255,255,.12);
}
.mrc-side-cart-img img{
  display:block;
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  padding:12%;
  transform:none;
}
.mrc-side-cart-info h3{
  margin:0;
  color:var(--text);
  font-family:var(--font-body);
  font-size:14px;
  font-weight:900;
  line-height:1.28;
}
.mrc-side-cart-info h3 a{color:inherit}
.mrc-side-cart-meta{
  margin-top:6px;
  color:var(--text-muted);
  font-size:12px;
  line-height:1.4;
}
.mrc-side-cart-meta dl{margin:0;display:flex;flex-wrap:wrap;gap:3px 7px}
.mrc-side-cart-meta dt{font-weight:900;color:var(--text)}
.mrc-side-cart-meta dd{margin:0}
.mrc-side-cart-line{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-top:9px;
  color:var(--text-muted);
  font-family:var(--font-mono);
  font-size:12px;
}
.mrc-side-cart-line strong{
  color:var(--accent);
  font-weight:900;
}
.mrc-side-cart-remove{
  position:absolute;
  top:10px;right:10px;
  width:28px;height:28px;
  display:grid;place-items:center;
  border:1px solid var(--border);
  border-radius:999px;
  color:var(--text-muted);
  font-size:20px;
  line-height:1;
}
.mrc-side-cart-remove:hover{border-color:var(--pink);color:var(--pink)}
.mrc-side-cart-empty{
  min-height:100%;
  display:grid;
  align-content:center;
  justify-items:center;
  text-align:center;
  padding:36px 12px;
  color:var(--text-muted);
}
.mrc-side-cart-empty-title{
  margin:0 0 8px;
  color:var(--text);
  font-family:var(--font-chunky);
  font-size:28px;
  line-height:1;
}
.mrc-side-cart-empty a{
  margin-top:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:0 18px;
  border-radius:999px;
  background:var(--accent);
  color:var(--accent-ink);
  font-family:var(--font-display);
  font-weight:900;
  text-transform:uppercase;
}
.mrc-side-cart-foot{
  padding:16px;
  border-top:1px solid var(--border);
  background:rgba(0,0,0,.18);
}
.mrc-side-cart-total{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:14px;
}
.mrc-side-cart-total span{
  color:var(--text-muted);
  font-family:var(--font-body);
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:11px;
}
.mrc-side-cart-total strong{
  color:var(--accent);
  font-family:var(--font-mono);
  font-size:20px;
}
.mrc-side-cart-checkout,
.mrc-side-cart-view{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  border-radius:14px;
  font-family:var(--font-display);
  font-weight:900;
  text-transform:uppercase;
}
.mrc-side-cart-checkout{
  background:var(--accent);
  color:var(--accent-ink);
  box-shadow:0 0 26px -8px var(--accent-glow);
}
.mrc-side-cart-view{
  margin-top:10px;
  border:1px solid var(--border-bright);
  color:var(--text);
}
.mrc-side-cart-view:hover{border-color:var(--blue);color:var(--blue)}

/* =========================================================
   Bundle-first shop page
   ========================================================= */
.mrc-shop-builder-page{background:transparent}
.mrc-shop-builder{padding-bottom:72px}
.mrc-shop-hero{
  position:relative;
  overflow:hidden;
  padding:clamp(54px,8vw,96px) 0 34px;
}
.mrc-shop-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 18% 22%,rgba(255,46,196,.18),transparent 28%),
    radial-gradient(circle at 86% 12%,rgba(46,156,255,.18),transparent 28%),
    linear-gradient(180deg,rgba(255,255,255,.03),transparent 70%);
  pointer-events:none;
}
.mrc-shop-hero-grid{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,390px);
  gap:clamp(24px,5vw,64px);
  align-items:end;
}
.mrc-shop-hero-copy h1{
  max-width:720px;
  margin:8px 0 10px;
  font-family:var(--font-hero);
  font-size:clamp(42px,6.2vw,78px);
  font-weight:400;
  line-height:.9;
  text-transform:uppercase;
  color:var(--text);
}
.mrc-shop-hero-copy h1 .gradient{
  background:var(--rainbow);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  -webkit-text-fill-color:transparent;
  text-shadow:none;
}
.mrc-shop-hero-copy p{
  max-width:720px;
  margin:0;
  color:var(--text-muted);
  font-size:clamp(17px,2vw,21px);
  line-height:1.5;
}
.mrc-shop-hero-stats{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:26px;
}
.mrc-shop-hero-stats span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:42px;
  padding:0 16px;
  border:1px solid var(--border-bright);
  border-radius:999px;
  background:rgba(255,255,255,.045);
  color:var(--text);
  font-family:var(--font-display);
  font-weight:900;
}
.mrc-shop-hero-stats strong{color:var(--accent);font-family:var(--font-mono)}
.mrc-shop-fast-panel{
  display:grid;
  gap:12px;
  padding:18px;
  border:1px solid var(--border-bright);
  border-radius:22px;
  background:rgba(20,20,20,.82);
  box-shadow:0 24px 70px -42px rgba(57,255,20,.7);
  backdrop-filter:blur(12px);
}
.mrc-shop-fast-panel div{
  display:grid;
  grid-template-columns:44px minmax(0,1fr);
  align-items:center;
  gap:12px;
  min-height:62px;
  padding:12px;
  border:1px solid var(--border);
  border-radius:16px;
  background:rgba(255,255,255,.035);
}
.mrc-shop-fast-panel span{
  display:grid;
  place-items:center;
  width:38px;
  height:38px;
  border-radius:12px;
  background:var(--step-color,var(--accent));
  color:#050505;
  font-weight:900;
  box-shadow:0 10px 24px -16px var(--step-color,var(--accent));
}
.mrc-shop-fast-panel div:nth-child(1){--step-color:var(--pink)}
.mrc-shop-fast-panel div:nth-child(2){--step-color:var(--accent)}
.mrc-shop-fast-panel div:nth-child(3){--step-color:var(--blue)}
.mrc-shop-fast-panel strong{
  font-family:var(--font-display);
  font-size:18px;
}
.mrc-shop-deals{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:clamp(10px,1.2vw,14px);
  margin-bottom:18px;
}
.mrc-shop-tier{
  position:relative;
  display:grid;
  gap:6px;
  min-height:126px;
  padding:clamp(15px,1.45vw,20px);
  overflow:hidden;
  text-align:left;
  border:1px solid var(--border-bright);
  border-radius:18px;
  background:
    radial-gradient(circle at 16% 4%,color-mix(in srgb,var(--tier-color,var(--accent)) 16%,transparent),transparent 42%),
    linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.025));
  box-shadow:0 14px 34px -28px rgba(255,255,255,.45);
  transition:transform .2s var(--ease),border-color .2s var(--ease),box-shadow .2s var(--ease);
}
.mrc-shop-tier::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:5px;
  background:var(--tier-color,var(--accent));
  box-shadow:0 0 26px var(--tier-color,var(--accent));
}
.mrc-shop-tier:nth-child(1){--tier-color:var(--blue)}
.mrc-shop-tier:nth-child(2){--tier-color:var(--pink)}
.mrc-shop-tier:nth-child(3){--tier-color:var(--gold)}
.mrc-shop-tier:nth-child(4){--tier-color:var(--accent)}
.mrc-shop-tier:nth-child(4){
  border-color:transparent;
  background:
    linear-gradient(var(--surface),var(--surface)) padding-box,
    var(--rainbow) border-box;
  box-shadow:
    0 -1px 0 rgba(255,255,255,.18) inset,
    0 0 74px -38px rgba(255,46,196,.78),
    0 0 74px -42px rgba(46,156,255,.76);
}
.mrc-shop-tier:nth-child(4)::before{
  background:var(--rainbow);
  box-shadow:
    0 0 24px rgba(255,46,196,.5),
    0 0 30px rgba(57,255,20,.38),
    0 0 30px rgba(46,156,255,.34);
}
.mrc-shop-tier:hover,
.mrc-shop-tier.is-active{
  transform:translateY(-3px);
  border-color:var(--tier-color,var(--accent));
  box-shadow:0 0 0 1px color-mix(in srgb,var(--tier-color,var(--accent)) 42%,transparent),0 22px 52px -34px var(--tier-color,var(--accent));
}
.mrc-shop-tier:nth-child(4):hover,
.mrc-shop-tier:nth-child(4).is-active{
  border-color:transparent;
  box-shadow:
    0 -1px 0 rgba(255,255,255,.24) inset,
    0 16px 42px -24px rgba(255,46,196,.62),
    0 0 80px -36px rgba(57,255,20,.88),
    0 0 80px -36px rgba(46,156,255,.8);
}
.mrc-shop-tier-name{
  color:var(--tier-color,var(--accent));
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.mrc-shop-tier:nth-child(4) .mrc-shop-tier-name,
.mrc-shop-tier:nth-child(4) strong{
  background:var(--rainbow);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  -webkit-text-fill-color:transparent;
}
.mrc-shop-tier strong{
  font-family:var(--font-chunky);
  font-size:clamp(30px,3.15vw,44px);
  font-weight:400;
  line-height:.95;
  white-space:nowrap;
}
.mrc-shop-tier span:last-child{color:var(--text-muted);font-weight:900}
.mrc-shop-workspace{
  display:grid;
  grid-template-columns:minmax(280px,360px) minmax(0,1fr);
  gap:18px;
  align-items:start;
}
.mrc-shop-builder-panel{
  position:sticky;
  top:92px;
  display:grid;
  gap:16px;
  padding:18px;
  border:1px solid var(--border-bright);
  border-radius:22px;
  background:linear-gradient(180deg,rgba(20,20,20,.94),rgba(14,14,14,.94));
  box-shadow:0 24px 70px -48px rgba(0,0,0,.95);
}
.mrc-shop-builder-head{
  display:flex;
  align-items:start;
  justify-content:space-between;
  gap:14px;
}
.mrc-shop-builder-head h2{
  margin:6px 0 0;
  font-family:var(--font-chunky);
  font-size:34px;
  font-weight:400;
  line-height:1;
}
.mrc-shop-builder-head button{
  min-height:38px;
  padding:0 12px;
  border:1px solid var(--border);
  border-radius:12px;
  color:var(--text-muted);
  font-family:var(--font-display);
  font-weight:900;
}
.mrc-shop-builder-head button:hover{border-color:var(--pink);color:var(--pink)}
.mrc-shop-progress-meta,
.mrc-shop-total{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:var(--text-muted);
  font-size:13px;
  font-weight:900;
}
.mrc-shop-progress-meta strong,
.mrc-shop-total strong{color:var(--accent);font-family:var(--font-mono)}
.mrc-shop-progress-bar{
  display:block;
  height:10px;
  margin-top:10px;
  overflow:hidden;
  border-radius:999px;
  background:rgba(255,255,255,.08);
}
.mrc-shop-progress-bar i{
  display:block;
  width:0;
  height:100%;
  border-radius:inherit;
  background:var(--rainbow);
  transition:width .22s var(--ease);
}
.mrc-shop-slots{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:8px;
}
.mrc-shop-slot{
  aspect-ratio:1/1;
  min-width:0;
  display:grid;
  place-items:center;
  overflow:hidden;
  border:1px dashed var(--border-bright);
  border-radius:14px;
  background:rgba(255,255,255,.035);
  color:var(--text-dim);
  font-family:var(--font-chunky);
  font-size:28px;
}
.mrc-shop-slot.is-filled{
  position:relative;
  border-style:solid;
  border-color:var(--accent);
  background:#fff;
}
.mrc-shop-slot img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:12%;
}
.mrc-shop-slot span{
  position:absolute;
  inset:auto 4px 4px;
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
  padding:2px 4px;
  border-radius:8px;
  background:rgba(0,0,0,.72);
  color:#fff;
  font-size:9px;
  font-family:var(--font-body);
  font-weight:900;
}
.mrc-shop-total{
  padding:14px;
  border:1px solid var(--border);
  border-radius:16px;
  background:rgba(255,255,255,.035);
  text-transform:uppercase;
  letter-spacing:.08em;
}
.mrc-shop-total strong{
  color:var(--gold);
  font-size:24px;
  letter-spacing:0;
}
.mrc-shop-add{
  min-height:54px;
  border-radius:16px;
  background:var(--accent);
  color:var(--accent-ink);
  font-family:var(--font-display);
  font-weight:900;
  text-transform:uppercase;
  box-shadow:0 0 28px -10px var(--accent);
}
.mrc-shop-add:disabled{
  cursor:not-allowed;
  background:var(--surface-3);
  color:var(--text-muted);
  box-shadow:none;
}
.mrc-shop-error{
  margin:0;
  padding:10px 12px;
  border:1px solid rgba(255,46,196,.45);
  border-radius:12px;
  background:rgba(255,46,196,.1);
  color:#ffd8f5;
  font-size:13px;
  font-weight:800;
}
.mrc-shop-catalog{
  min-width:0;
  display:grid;
  gap:16px;
}
.mrc-shop-tools{
  position:sticky;
  top:76px;
  z-index:5;
  display:grid;
  gap:12px;
  padding:14px;
  border:1px solid var(--border);
  border-radius:20px;
  background:rgba(10,10,10,.88);
  backdrop-filter:blur(14px);
}
.mrc-shop-search{
  display:flex;
  align-items:center;
  gap:12px;
  min-height:58px;
  padding:0 16px;
  border:1px solid var(--border-bright);
  border-radius:16px;
  background:rgba(255,255,255,.04);
  color:var(--text-muted);
}
.mrc-shop-search:focus-within{border-color:var(--accent);box-shadow:0 0 26px -14px var(--accent)}
.mrc-shop-search input{
  width:100%;
  min-width:0;
  border:0;
  outline:0;
  background:transparent;
  color:var(--text);
  font:800 16px/1.2 var(--font-body);
}
.mrc-shop-filter-row{
  display:flex;
  gap:8px;
  overflow:auto;
  padding-bottom:2px;
  scrollbar-width:none;
}
.mrc-shop-filter-row::-webkit-scrollbar{display:none}
.mrc-shop-filter-row button{
  flex:0 0 auto;
  min-height:36px;
  padding:0 12px;
  border:1px solid var(--border);
  border-radius:999px;
  background:rgba(255,255,255,.035);
  color:var(--text-muted);
  font-family:var(--font-display);
  font-weight:900;
}
.mrc-shop-filter-row button.is-active,
.mrc-shop-filter-row button:hover{
  border-color:var(--blue);
  color:var(--blue);
}
.mrc-shop-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(156px,1fr));
  gap:12px;
}
.mrc-shop-design{
  position:relative;
  display:grid;
  gap:10px;
  min-width:0;
  padding:10px;
  text-align:left;
  border:1px solid var(--border);
  border-radius:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.02));
  transition:transform .18s var(--ease),border-color .18s var(--ease),box-shadow .18s var(--ease);
}
.mrc-shop-design[hidden],
.mrc-shop-design.is-page-hidden{
  display:none!important;
}
.mrc-shop-design:hover,
.mrc-shop-design.is-selected{
  transform:translateY(-2px);
  border-color:var(--accent);
  box-shadow:0 0 0 1px rgba(57,255,20,.22),0 18px 36px -28px var(--accent);
}
.mrc-shop-design-img{
  aspect-ratio:1/1;
  display:grid;
  place-items:center;
  overflow:hidden;
  border-radius:14px;
  background:#fff;
  isolation:isolate;
}
.mrc-shop-design-img img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:14%;
  transform:none;
}
.mrc-shop-design-body{
  display:grid;
  gap:4px;
  min-width:0;
}
.mrc-shop-design-body strong{
  overflow:hidden;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  color:var(--text);
  font-size:14px;
  font-weight:900;
  line-height:1.2;
}
.mrc-shop-design-body span{
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
  color:var(--text-muted);
  font-size:12px;
  font-weight:800;
}
.mrc-shop-design-check{
  position:absolute;
  top:8px;
  right:8px;
  display:grid;
  place-items:center;
  width:30px;
  height:30px;
  border-radius:999px;
  background:var(--surface);
  color:var(--accent);
  border:1px solid var(--border-bright);
  font-family:var(--font-display);
  font-weight:900;
}
.mrc-shop-design.is-selected .mrc-shop-design-check{
  background:var(--accent);
  color:var(--accent-ink);
  border-color:var(--accent);
}

.mrc-shop-design.is-sold-out,
.mrc-shop-design:disabled{
  cursor:not-allowed;
  opacity:.72;
  filter:saturate(.72);
}

.mrc-shop-design.is-sold-out:hover,
.mrc-shop-design:disabled:hover{
  transform:none;
  border-color:rgba(255,46,85,.44);
  box-shadow:0 0 0 1px rgba(255,46,85,.18);
}

.mrc-shop-design.is-sold-out .mrc-shop-design-img,
.mrc-shop-design:disabled .mrc-shop-design-img{
  background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(235,235,235,.86));
}

.mrc-shop-design.is-sold-out .mrc-shop-design-img img,
.mrc-shop-design:disabled .mrc-shop-design-img img{
  opacity:.42!important;
  filter:grayscale(.35);
}

.mrc-shop-design-sold{
  position:absolute;
  left:8px;
  top:8px;
  z-index:3;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:26px;
  padding:0 10px;
  border-radius:999px;
  background:var(--danger);
  color:#fff;
  font-family:var(--font-display);
  font-size:10px;
  font-weight:900;
  letter-spacing:.06em;
  line-height:1;
  text-transform:uppercase;
  box-shadow:0 10px 20px rgba(255,46,85,.28),0 0 0 1px rgba(255,255,255,.16);
}

.mrc-shop-design.is-sold-out .mrc-shop-design-body strong,
.mrc-shop-design:disabled .mrc-shop-design-body strong{
  color:rgba(255,255,255,.62);
}

.mrc-shop-design.is-sold-out .mrc-shop-design-body span,
.mrc-shop-design:disabled .mrc-shop-design-body span{
  color:var(--danger);
}

.mrc-shop-design.is-sold-out .mrc-shop-design-check,
.mrc-shop-design:disabled .mrc-shop-design-check{
  background:rgba(255,46,85,.14);
  color:#fff;
  border-color:rgba(255,46,85,.52);
}
.mrc-shop-empty,
.mrc-wp-notice{
  padding:24px;
  border:1px solid var(--border);
  border-radius:18px;
  background:rgba(255,255,255,.035);
  color:var(--text-muted);
  font-weight:800;
}
.mrc-shop-live-status{
  margin:2px 0 0;
  color:var(--text-muted);
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.mrc-shop-pagination{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:16px;
  border:1px solid var(--border);
  border-radius:18px;
  background:rgba(10,10,10,.78);
}
.mrc-shop-pagination[hidden]{display:none}
.mrc-shop-pagination > span{
  color:var(--text-muted);
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  white-space:nowrap;
}
.mrc-shop-pagination [data-shop-page-numbers]{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}
.mrc-shop-pagination button{
  min-width:40px;
  min-height:40px;
  padding:0 12px;
  border:1px solid var(--border);
  border-radius:12px;
  background:rgba(255,255,255,.035);
  color:var(--text);
  font-family:var(--font-display);
  font-weight:900;
  transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease),color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.mrc-shop-pagination button:hover:not(:disabled),
.mrc-shop-pagination button.is-active{
  border-color:var(--accent);
  background:var(--accent);
  color:var(--accent-ink);
  box-shadow:0 0 22px -10px var(--accent);
}
.mrc-shop-pagination button:disabled{
  cursor:not-allowed;
  opacity:.42;
}

@media (max-width:980px){
  .mrc-shop-hero-grid,
  .mrc-shop-workspace{grid-template-columns:1fr}
  .mrc-shop-builder-panel{position:relative;top:auto}
  .mrc-shop-tools{top:64px}
}
@media (max-width:720px){
  .mrc-shop-hero{padding-top:38px}
  .mrc-shop-hero-copy h1{font-size:clamp(54px,15vw,76px)}
  .mrc-shop-deals{grid-template-columns:1fr}
  .mrc-shop-tier{min-height:112px}
  .mrc-shop-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .mrc-shop-workspace{width:min(100% - 20px,var(--container))}
  .mrc-shop-slots{grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}
  .mrc-shop-slot{border-radius:10px}
  .mrc-shop-tools{position:relative;top:auto}
  .mrc-shop-pagination{flex-wrap:wrap;padding:12px}
  .mrc-shop-pagination > span{width:100%;text-align:center}
}
@media (max-width:420px){
  .mrc-shop-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .mrc-shop-design{padding:8px;border-radius:14px}
  .mrc-shop-design-body strong{font-size:12px}
}

@media (max-width:900px){
  .mrc-cart-hero{align-items:flex-start;flex-direction:column}
  .mrc-cart-layout{grid-template-columns:1fr}
  .mrc-cart-summary{position:static}
  .mrc-checkout-panel .woocommerce form.checkout{grid-template-columns:1fr}
}
@media (max-width:640px){
  .mrc-cart-shell{width:min(100% - 20px,1180px)}
  .mrc-cart-form,.mrc-cart-summary-card{border-radius:18px;padding:12px}
  .mrc-cart-hero,
  .mrc-checkout-intro{border-radius:20px;padding:18px}
  .mrc-cart-hero h1,
  .mrc-empty-cart h1,
  .mrc-checkout-intro h1{font-size:clamp(46px,14vw,72px)}
  .mrc-cart-item{grid-template-columns:86px minmax(0,1fr);gap:12px}
  .mrc-cart-item-title-row{flex-direction:column;gap:8px}
  .mrc-cart-remove{align-self:flex-start}
  .mrc-cart-item-controls{grid-template-columns:1fr}
  .mrc-cart-actions{align-items:stretch;flex-direction:column}
  .mrc-cart-coupon{max-width:none}
  .mrc-cart-list-head{align-items:flex-start;flex-direction:column}
  .mrc-checkout-intro,
  .mrc-checkout-panel{width:min(100% - 20px,1180px)}
  .mrc-checkout-panel{padding:12px;border-radius:18px}
  .mrc-checkout-panel .woocommerce-billing-fields,
  .mrc-checkout-panel .woocommerce-shipping-fields,
  .mrc-checkout-panel .woocommerce-additional-fields,
  .mrc-checkout-panel #order_review,
  .mrc-checkout-panel .woocommerce-checkout-review-order{padding:14px;border-radius:16px}
}
@media(max-width:900px){.related-products .products:not(.mrc-related-track){grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:520px){
  .mrc-related-head{align-items:start}
  .mrc-related-controls{align-self:end}
  .mrc-related-arrow{width:42px;height:42px;border-radius:12px}
  .related-products .products:not(.mrc-related-track){grid-template-columns:1fr}
  .related-products .products.mrc-related-track .product{flex-basis:78vw}
}

/* =========================================================
   Clean standard shop page
   ========================================================= */
.mrc-standard-shop .ticker{position:relative;z-index:10}
.mrc-shop-clean{padding-bottom:clamp(48px,6vw,88px)}
.mrc-clean-shop-hero{
  position:relative;
  overflow:hidden;
  padding:clamp(26px,4vw,44px) 0 clamp(16px,2.2vw,24px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.mrc-clean-shop-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 14% 10%,rgba(255,46,196,.14),transparent 30%),
    radial-gradient(circle at 88% 18%,rgba(46,156,255,.13),transparent 32%),
    linear-gradient(180deg,rgba(255,255,255,.035),transparent 70%);
  pointer-events:none;
}
.mrc-clean-shop-hero-grid{
  position:relative;
  display:block;
}
.mrc-clean-shop-hero .breadcrumb{
  margin:0 0 10px;
  display:flex;
  align-items:center;
  gap:8px;
  color:var(--text-dim);
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:800;
}
.mrc-clean-shop-hero .breadcrumb a{color:var(--text-muted)}
.mrc-clean-shop-hero h1{
  max-width:720px;
  margin:8px 0 10px;
  font-family:var(--font-hero);
  font-size:clamp(42px,6.2vw,78px);
  font-weight:400;
  line-height:.9;
  text-transform:uppercase;
  color:var(--text);
}
.mrc-clean-shop-hero h1 .gradient{
  background:var(--rainbow);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  -webkit-text-fill-color:transparent;
  text-shadow:none;
}
.mrc-clean-shop-hero p{
  max-width:700px;
  margin:0;
  color:var(--text-muted);
  font-size:clamp(15px,1.45vw,17px);
  line-height:1.48;
}
.mrc-clean-shop-panel{
  display:grid;
  gap:14px;
  margin-top:clamp(12px,1.8vw,20px);
  padding:clamp(14px,2vw,20px);
  border:1px solid var(--border);
  border-radius:22px;
  background:rgba(10,10,10,.58);
}
.mrc-clean-shop-toolbar{
  position:sticky;
  top:72px;
  z-index:20;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  padding:12px;
  border:1px solid var(--border);
  border-radius:18px;
  background:rgba(10,10,10,.9);
  backdrop-filter:blur(14px);
}
.admin-bar .mrc-clean-shop-toolbar{top:104px}
.mrc-clean-shop-search{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:54px;
  padding:0 8px 0 14px;
  border:1px solid var(--border-bright);
  border-radius:15px;
  background:rgba(255,255,255,.04);
}
.mrc-clean-shop-search:focus-within{
  border-color:var(--accent);
  box-shadow:0 0 28px -14px var(--accent);
}
.mrc-clean-shop-search svg{flex:0 0 auto;color:var(--accent)}
.mrc-clean-shop-search input{
  width:100%;
  min-width:0;
  border:0;
  outline:0;
  background:transparent;
  color:var(--text);
  font:800 16px/1.2 var(--font-body);
}
.mrc-clean-shop-search input::placeholder{color:var(--text-dim)}
.mrc-clean-shop-search button,
.mrc-clean-shop-builder-link{
  min-height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 16px;
  border-radius:12px;
  font-family:var(--font-display);
  font-weight:900;
  text-transform:uppercase;
  white-space:nowrap;
}
.mrc-clean-shop-search button{
  background:var(--accent);
  color:var(--accent-ink);
}
.mrc-clean-shop-builder-link{
  border:1px solid var(--blue);
  color:var(--blue);
  background:rgba(46,156,255,.08);
}
.mrc-clean-shop-builder-link:hover{
  background:var(--blue);
  color:#001327;
}
.mrc-clean-shop-chips{
  display:flex;
  gap:8px;
  overflow:auto;
  padding:2px 2px 8px;
  scrollbar-width:none;
}
.mrc-clean-shop-chips::-webkit-scrollbar{display:none}
.mrc-clean-shop-chips button,
.mrc-clean-shop-chips a{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:0 13px;
  border:1px solid var(--border);
  border-radius:999px;
  background:rgba(255,255,255,.035);
  color:var(--text-muted);
  font-family:var(--font-display);
  font-size:13px;
  font-weight:900;
  white-space:nowrap;
}
.mrc-clean-shop-chips button.is-active,
.mrc-clean-shop-chips button:hover,
.mrc-clean-shop-chips a.is-active,
.mrc-clean-shop-chips a:hover{
  border-color:var(--accent);
  color:var(--accent);
}
.mrc-filter-menu{
  position:relative;
}
.mrc-filter-menu-row{
  display:flex;
  align-items:center;
  gap:8px;
  overflow:auto;
  padding:2px 2px 8px;
  scrollbar-width:none;
}
.mrc-filter-menu-row::-webkit-scrollbar{display:none}
.mrc-clean-shop-chips.mrc-filter-menu,
.mrc-shop-filter-row.mrc-filter-menu{
  display:block;
  overflow:visible;
  padding:0;
}
.mrc-clean-shop-chips .mrc-filter-menu-row a,
.mrc-clean-shop-chips .mrc-filter-menu-row button,
.mrc-shop-filter-row .mrc-filter-menu-row button{
  flex:0 0 auto;
}
.mrc-clean-shop-chips .mrc-filter-more,
.mrc-shop-filter-row .mrc-filter-more{
  border-color:rgba(46,156,255,.55);
  color:var(--blue);
  background:rgba(46,156,255,.09);
}
.chip-emoji{
  display:inline-grid;
  place-items:center;
  min-width:1.35em;
  margin-right:3px;
}
.mrc-filter-popover{
  position:absolute;
  z-index:60;
  top:calc(100% + 8px);
  left:0;
  right:auto;
  width:min(720px,calc(100vw - 32px));
  padding:14px;
  border:1px solid var(--border-bright);
  border-radius:18px;
  background:rgba(14,14,14,.96);
  box-shadow:0 26px 70px -36px rgba(0,0,0,.95),0 0 40px -30px var(--blue);
  backdrop-filter:blur(16px);
}
.mrc-filter-popover[hidden]{display:none!important}
.mrc-filter-popover-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.mrc-filter-popover-head strong{
  color:var(--text);
  font-family:var(--font-display);
  font-weight:900;
}
.mrc-filter-popover-head button{
  width:34px;
  height:34px;
  border:1px solid var(--border);
  border-radius:10px;
  color:var(--text-muted);
}
.mrc-filter-popover-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  max-height:min(420px,60vh);
  overflow:auto;
  padding-right:4px;
}
.mrc-filter-popover-grid a,
.mrc-filter-popover-grid button{
  min-height:42px;
  justify-content:flex-start;
  gap:6px;
  padding:0 12px;
  border:1px solid var(--border);
  border-radius:12px;
  background:rgba(255,255,255,.035);
  color:var(--text-muted);
  font-family:var(--font-display);
  font-size:13px;
  font-weight:900;
  text-align:left;
}
.mrc-filter-popover-grid a:hover,
.mrc-filter-popover-grid a.is-active,
.mrc-filter-popover-grid button:hover,
.mrc-filter-popover-grid button.is-active{
  border-color:var(--accent);
  color:var(--accent);
  background:rgba(57,255,20,.07);
}
.mrc-clean-shop-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:var(--text-muted);
  font-size:13px;
  font-weight:800;
}
.mrc-clean-products{
  display:grid!important;
  grid-template-columns:repeat(auto-fill,minmax(188px,1fr))!important;
  gap:14px!important;
  margin:0!important;
  padding:0!important;
}
.mrc-clean-products .product{
  min-width:0;
  border-radius:18px;
}
.mrc-clean-products .product-img{
  aspect-ratio:1/1;
  border-radius:16px;
}
.mrc-clean-products .product-body{
  padding:12px 4px 2px;
}
.mrc-clean-products .product-body h3,
.mrc-clean-products .product-body h3 a{
  font-size:14px;
  line-height:1.22;
  min-height:auto;
}
.mrc-clean-products .product-foot{
  margin-top:10px;
  gap:8px;
}
.mrc-clean-products .product-price{
  font-size:14px;
}
.mrc-clean-products .add-btn{
  min-height:36px;
  padding:0 12px;
  border-radius:11px;
  font-size:13px;
}
.mrc-clean-products .products-empty{
  grid-column:1/-1;
}
.mrc-clean-shop-pagination{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:16px;
  border:1px solid var(--border);
  border-radius:18px;
  background:rgba(10,10,10,.72);
}
.mrc-clean-shop-pagination > span{
  color:var(--text-muted);
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:800;
  white-space:nowrap;
}
.mrc-clean-shop-pagination > div{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}
.mrc-clean-shop-pagination a{
  min-width:40px;
  min-height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 12px;
  border:1px solid var(--border);
  border-radius:12px;
  background:rgba(255,255,255,.035);
  color:var(--text);
  font-family:var(--font-display);
  font-weight:900;
}
.mrc-clean-shop-pagination a:hover,
.mrc-clean-shop-pagination a.is-active{
  border-color:var(--accent);
  background:var(--accent);
  color:var(--accent-ink);
  box-shadow:0 0 22px -10px var(--accent);
}
.mrc-clean-shop-pagination a.is-disabled{
  pointer-events:none;
  opacity:.42;
}
.mrc-clean-shop-panel.is-loading-products .mrc-clean-products{
  opacity:.5;
  pointer-events:none;
}
.mrc-clean-shop-panel.is-loading-products .mrc-clean-shop-pagination{
  opacity:.65;
  pointer-events:none;
}
@media(max-width:980px){
  .mrc-clean-shop-toolbar{top:72px}
  .mrc-clean-products{grid-template-columns:repeat(auto-fill,minmax(158px,1fr))!important}
}
@media(max-width:680px){
  .mrc-clean-shop-hero{padding-top:32px}
  .mrc-clean-shop-hero h1{font-size:clamp(54px,15vw,76px)}
  .mrc-clean-shop-panel{
    width:100%;
    padding:0 12px 12px;
    border:0;
    border-radius:0;
    background:transparent;
  }
  .mrc-clean-shop-toolbar{
    position:relative;
    top:auto;
    grid-template-columns:1fr;
    gap:10px;
    padding:0;
    border:0;
    border-radius:0;
    background:transparent;
    backdrop-filter:none;
  }
  .mrc-clean-shop-search{
    min-height:0;
    display:grid;
    grid-template-columns:24px minmax(0,1fr);
    gap:10px 8px;
    padding:14px;
    border-radius:18px;
    background:rgba(255,255,255,.045);
  }
  .mrc-clean-shop-search input{font-size:15px}
  .mrc-clean-shop-search button{
    grid-column:1/-1;
    min-height:44px;
    border-radius:12px;
  }
  .mrc-clean-shop-search button,
  .mrc-clean-shop-builder-link{width:100%}
  .mrc-clean-shop-builder-link{
    min-height:44px;
    border-radius:14px;
    background:rgba(46,156,255,.08);
  }
  .mrc-clean-shop-chips{
    margin:0 -12px;
    padding:4px 12px 8px;
  }
  .mrc-filter-popover{
    left:12px;
    right:12px;
    width:auto;
    padding:12px;
  }
  .mrc-filter-popover-grid{
    grid-template-columns:1fr;
    max-height:56vh;
  }
  .mrc-clean-shop-meta{align-items:flex-start;flex-direction:column}
  .mrc-clean-products{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px!important}
  .mrc-clean-shop-pagination{flex-wrap:wrap;padding:12px}
  .mrc-clean-shop-pagination > span{width:100%;text-align:center;order:-1}
}

/* Product second-image preview swap */
.product .product-img{
  position:relative;
}
.product .product-img-link{
  position:relative;
  display:block;
  width:100%;
  height:100%;
}
.product .product-img-link img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:contain;
  padding:12%;
  transition:opacity 260ms var(--ease);
}
.product .product-img-primary{opacity:1;z-index:1}
.product .product-img-secondary{opacity:0;z-index:2}
.product:hover .product-img-primary{
  opacity:0;
  transform:none;
}
.product:hover .product-img-secondary{
  opacity:1;
  transform:none;
}
.product:hover .product-img-link img{transform:none}
.product .product-thumb.product-thumb-swap{
  position:absolute;
  left:12px;
  bottom:12px;
  z-index:6;
  width:56px;
  height:56px;
  display:grid!important;
  place-items:center;
  overflow:hidden;
  border:2px solid rgba(255,255,255,.88);
  border-radius:999px;
  background:var(--surface-2);
  box-shadow:0 12px 28px -16px rgba(0,0,0,.9),0 0 18px -8px var(--accent);
  cursor:pointer;
  opacity:1;
  transform:none;
  transition:border-color 260ms var(--ease),box-shadow 260ms var(--ease);
}
.product:hover .product-thumb.product-thumb-swap{
  border-color:var(--accent);
  box-shadow:0 0 0 2px rgba(57,255,20,.22),0 14px 30px -16px rgba(0,0,0,.95),0 0 28px -10px var(--accent);
  transform:none;
}
.product .product-thumb.product-thumb-swap img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  padding:0;
  transform:scale(1.18);
  transition:opacity 260ms var(--ease);
}
.product .product-thumb.product-thumb-swap .product-thumb-secondary{opacity:1}
.product .product-thumb.product-thumb-swap .product-thumb-primary{opacity:0}
.product:hover .product-thumb.product-thumb-swap .product-thumb-secondary{
  opacity:0;
  transform:scale(1.18);
}
.product:hover .product-thumb.product-thumb-swap .product-thumb-primary{
  opacity:1;
  transform:scale(1.18);
}
@media(max-width:720px){
  .product .product-thumb.product-thumb-swap{
    left:9px;
    bottom:9px;
    width:44px;
    height:44px;
  }
  .product .product-thumb.product-thumb-swap img{padding:0}
}

/* Compact homepage bundle cards */
.bundles .bundle-grid{
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.bundles .bundle{
  padding:20px;
  border-radius:22px;
  min-width:0;
}
.bundles .bundle-preview{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:5px;
  margin-bottom:16px;
  max-width:100%;
}
.bundles .bundle-preview .chip,
.bundles .bundle-preview .more{
  width:100%;
  height:auto;
  aspect-ratio:1;
  border-radius:9px;
  font-size:12px;
}
.bundles .bundle h3{
  font-size:clamp(23px,2vw,28px);
  margin-bottom:9px;
}
.bundles .bundle .pick{
  font-size:14px;
  margin-bottom:14px;
}
.bundles .price-row{
  gap:10px;
  margin-bottom:15px;
}
.bundles .price-now{
  font-size:clamp(34px,3vw,40px);
}
.bundles .price-was{
  font-size:18px;
}
.bundles .save-chip{
  padding:7px 12px;
  margin-bottom:16px;
  font-size:11px;
}
.bundles .bundle .btn-bundle{
  min-height:44px;
  padding:12px 14px;
  border-radius:14px;
  font-size:13px;
}
.bundles .bundle.best-value::before,
.bundles .bundle-ultimate::before{
  top:-13px;
  right:18px;
  padding:6px 12px 5px;
  font-size:10px;
  letter-spacing:.14em;
}
@media(max-width:1100px){
  .bundles .bundle-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    max-width:760px;
    margin-inline:auto;
  }
}
@media(max-width:640px){
  .bundles .bundle-grid{
    grid-template-columns:1fr;
    max-width:330px;
    gap:12px;
  }
  .bundles .bundle{
    max-width:none;
    padding:16px;
    border-radius:18px;
  }
  .bundles .bundle-preview{
    grid-template-columns:repeat(6,minmax(0,1fr));
    margin-bottom:12px;
  }
  .bundles .bundle-preview .chip,
  .bundles .bundle-preview .more{
    border-radius:8px;
    font-size:11px;
  }
  .bundles .bundle h3{
    font-size:22px;
    margin-bottom:7px;
  }
  .bundles .bundle .pick{
    font-size:13px;
    margin-bottom:11px;
  }
  .bundles .price-row{
    margin-bottom:11px;
  }
  .bundles .price-now{
    font-size:30px;
  }
  .bundles .price-was{
    font-size:15px;
  }
  .bundles .save-chip{
    margin-bottom:12px;
  }
  .bundles .bundle .btn-bundle{
    min-height:40px;
    padding:10px 12px;
    font-size:12px;
  }
}

/* Theme-wide storefront image alignment normalization.
   Keep product/artwork imagery centered and uncropped everywhere. */
.product-img,
.product .product-img-link,
.product-thumb,
.product-thumb.product-thumb-swap,
.bundle-preview .chip,
.cat-art,
.search-result-img,
.pd-main-img,
.pd-thumb,
.pd-bundle-slot,
.pd-design-img,
.mrc-cart-item-media,
.mrc-side-cart-img,
.mrc-shop-slot,
.mrc-shop-design-img{
  display:grid;
  place-items:center;
}
.product-img img,
.product .product-img-link img,
.product-thumb img,
.product .product-thumb.product-thumb-swap img,
.bundle-preview .chip img,
.cat-art img,
.search-result-img img,
.pd-main-img img,
.pd-thumb img,
.pd-bundle-slot img,
.pd-design-img img,
.mrc-cart-item-media img,
.mrc-side-cart-img img,
.mrc-shop-slot img,
.mrc-shop-design-img img,
.woocommerce ul.products li.product a img{
  object-fit:contain!important;
  object-position:center center!important;
  box-sizing:border-box;
}
.product .product-img-link img{
  padding:14%!important;
}
.product .product-thumb.product-thumb-swap img{
  padding:10%!important;
  transform:none!important;
}
.product:hover .product-img-link img,
.product:hover .product-thumb.product-thumb-swap img{
  transform:none!important;
}
.mrc-shop-design-img img,
.pd-design-img img,
.mrc-shop-slot img,
.pd-bundle-slot img{
  padding:12%!important;
}
.search-result-img img,
.mrc-cart-item-media img,
.mrc-side-cart-img img,
.bundle-preview .chip img{
  padding:10%!important;
}

/* Cart preview tidy-up */
.mrc-cart-list{
  display:grid;
  gap:12px;
}
.mrc-cart-item{
  grid-template-columns:124px minmax(0,1fr)!important;
  align-items:start;
  gap:16px!important;
}
.mrc-cart-item-media{
  width:124px;
  max-width:100%;
  aspect-ratio:1;
  align-self:start;
  overflow:hidden;
  border-radius:18px!important;
  background:linear-gradient(145deg,rgba(255,255,255,.08),rgba(255,255,255,.025))!important;
}
.mrc-cart-item-media a{
  width:100%;
  height:100%;
  display:grid;
  place-items:center;
}
.mrc-cart-item-media img{
  width:100%!important;
  height:100%!important;
  display:block;
  object-fit:contain!important;
  object-position:center center!important;
  padding:12%!important;
  box-sizing:border-box;
  transform:none!important;
}
.mrc-cart-item-main{
  min-width:0;
}
.mrc-cart-item-title-row{
  min-width:0;
}
.mrc-cart-item h2{
  min-width:0;
  overflow-wrap:anywhere;
}
.mrc-cart-item-controls{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
}

@media (max-width:640px){
  .mrc-cart-list{
    gap:10px;
  }
  .mrc-cart-item{
    grid-template-columns:88px minmax(0,1fr)!important;
    gap:12px!important;
    padding:12px!important;
    border-radius:18px!important;
  }
  .mrc-cart-item-media{
    width:88px;
    border-radius:14px!important;
  }
  .mrc-cart-item-media img{
    padding:13%!important;
  }
  .mrc-cart-item h2{
    font-size:15px!important;
    line-height:1.22!important;
  }
  .mrc-cart-remove{
    padding:6px 10px!important;
    font-size:11px!important;
  }
  .mrc-cart-item-meta{
    margin-top:6px!important;
    font-size:12px!important;
  }
  .mrc-cart-item-controls{
    grid-template-columns:1fr!important;
    gap:8px!important;
    margin-top:10px!important;
  }
  .mrc-cart-price,
  .mrc-cart-qty,
  .mrc-cart-subtotal{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    padding:10px 12px!important;
    border-radius:12px!important;
  }
  .mrc-cart-price span,
  .mrc-cart-qty > span,
  .mrc-cart-subtotal span{
    margin:0!important;
  }
  .mrc-cart-qty .quantity{
    width:96px;
  }
}

@media (max-width:420px){
  .mrc-cart-item{
    grid-template-columns:76px minmax(0,1fr)!important;
  }
  .mrc-cart-item-media{
    width:76px;
  }
  .mrc-cart-item h2{
    font-size:14px!important;
  }
}

/* Mobile product grid alignment */
@media (max-width:740px){
  .products:not(.mrc-related-track),
  .products-grid,
  .mrc-clean-products,
  .mrc-home-product-search-grid,
  .mrc-wp-products.products-grid,
  .woocommerce ul.products:not(.mrc-related-track),
  .mrc-product-panel ul.products:not(.mrc-related-track){
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important;
    width:100%!important;
    max-width:100%!important;
    margin-left:0!important;
    margin-right:0!important;
    padding-left:0!important;
    padding-right:0!important;
    overflow:visible!important;
  }
  .products:not(.mrc-related-track) > .product,
  .products-grid > .product,
  .mrc-clean-products > .product,
  .mrc-home-product-search-grid > .product,
  .mrc-wp-products.products-grid > .product,
  .woocommerce ul.products:not(.mrc-related-track) > li.product,
  .mrc-product-panel ul.products:not(.mrc-related-track) > li.product{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    margin:0!important;
    float:none!important;
  }
  .product,
  .woocommerce ul.products li.product{
    min-width:0!important;
    overflow:hidden;
  }
  .product-body,
  .product h3,
  .product h3 a,
  .product-foot,
  .product-price,
  .add-btn{
    min-width:0!important;
  }
  .product-body{
    padding:10px!important;
    gap:8px!important;
  }
  .product h3{
    font-size:12.5px!important;
    line-height:1.22!important;
  }
  .product-foot{
    flex-wrap:wrap;
    align-items:flex-start!important;
    gap:7px!important;
  }
  .product-price{
    font-size:14px!important;
    line-height:1.1;
  }
  .add-btn{
    width:100%;
    justify-content:center;
    padding:9px 8px!important;
    font-size:11.5px!important;
    line-height:1.05;
    white-space:normal;
  }
  .badge{
    top:8px;
    left:8px;
    max-width:calc(100% - 16px);
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .wish{
    top:8px;
    right:8px;
    width:30px;
    height:30px;
  }
  .mrc-shop-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important;
    width:100%!important;
    max-width:100%!important;
    overflow:visible!important;
  }
  .mrc-shop-design{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
  }
}

@media (max-width:420px){
  .products:not(.mrc-related-track),
  .products-grid,
  .mrc-clean-products,
  .mrc-home-product-search-grid,
  .mrc-wp-products.products-grid,
  .woocommerce ul.products:not(.mrc-related-track),
  .mrc-product-panel ul.products:not(.mrc-related-track),
  .mrc-shop-grid{
    gap:8px!important;
  }
  .product-body{
    padding:9px!important;
  }
  .product h3{
    font-size:12px!important;
  }
}

/* Bundle builder mobile grid hard stop */
@media (max-width:740px){
  .mrc-shop-builder-page,
  .mrc-shop-builder{
    width:100%!important;
    max-width:100vw!important;
    overflow-x:hidden!important;
  }
  .mrc-shop-builder .wrap,
  .mrc-shop-workspace,
  .mrc-shop-catalog{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
  }
  .mrc-shop-workspace{
    padding-left:10px!important;
    padding-right:10px!important;
    margin-left:auto!important;
    margin-right:auto!important;
  }
  .mrc-shop-catalog{
    overflow:hidden!important;
  }
  .mrc-shop-grid{
    grid-template-columns:repeat(2,minmax(0,calc((100vw - 42px) / 2)))!important;
    justify-content:center!important;
    align-items:start!important;
    gap:10px!important;
    width:100%!important;
    max-width:100%!important;
    overflow:hidden!important;
  }
  .mrc-shop-design{
    min-width:0!important;
    max-width:100%!important;
    padding:8px!important;
    border-radius:16px!important;
  }
  .mrc-shop-design-img{
    border-radius:13px!important;
  }
  .mrc-shop-design-body strong{
    font-size:12px!important;
    line-height:1.18!important;
  }
  .mrc-shop-design-body span{
    font-size:11px!important;
  }
}

@media (max-width:380px){
  .mrc-shop-grid{
    grid-template-columns:repeat(2,minmax(0,calc((100vw - 34px) / 2)))!important;
    gap:8px!important;
  }
  .mrc-shop-workspace{
    padding-left:8px!important;
    padding-right:8px!important;
  }
}

/* =========================================================
   Full-site mobile UX pass
   ========================================================= */
@media (max-width:760px){
  html,
  body,
  .mrc-page-shell{
    width:100%!important;
    max-width:100%!important;
    overflow-x:hidden!important;
  }
  body{
    min-width:0!important;
    overscroll-behavior-x:none;
    -webkit-tap-highlight-color:rgba(57,255,20,.18);
  }
  a,
  button,
  input,
  select,
  textarea,
  [role="button"]{
    touch-action:manipulation;
  }
  button,
  .btn,
  .add-btn,
  .icon-btn,
  .cart-btn,
  .mrc-shop-tier,
  .mrc-shop-design,
  .mrc-filter-menu-row a,
  .mrc-filter-menu-row button,
  .mrc-clean-shop-builder-link,
  .mrc-side-cart-checkout,
  .mrc-side-cart-view,
  .mrc-cart-hero-cta,
  .mrc-cart-actions .button,
  .mrc-cart-summary .checkout-button,
  .pd-add,
  .pd-wish,
  .pd-tier,
  .pd-design-card{
    min-height:44px;
  }
  input,
  select,
  textarea{
    font-size:16px!important;
  }
  .wrap,
  .section .wrap,
  main > .wrap,
  .mrc-cart-shell,
  .mrc-checkout-intro,
  .mrc-checkout-panel{
    width:100%!important;
    max-width:100%!important;
    padding-left:clamp(14px,4vw,18px)!important;
    padding-right:clamp(14px,4vw,18px)!important;
  }
  .section{
    padding-top:clamp(42px,10vw,58px)!important;
    padding-bottom:clamp(42px,10vw,58px)!important;
  }
  .ticker{
    height:34px;
    overflow:hidden;
  }
  .ticker-track{
    align-items:center!important;
    padding:0!important;
    min-height:34px;
    gap:26px!important;
    font-size:11px!important;
    line-height:1!important;
    white-space:nowrap;
  }
  .ticker-track span{
    min-height:34px;
    align-items:center!important;
  }
  .site-header{
    z-index:10040;
  }
  .nav{
    height:62px!important;
    min-width:0;
    gap:8px!important;
  }
  .brand{
    min-width:0;
    flex:0 1 auto;
  }
  .brand img{
    height:31px!important;
    max-width:126px!important;
    object-fit:contain;
  }
  .nav-actions{
    flex:0 0 auto;
    gap:6px!important;
    min-width:0;
  }
  .nav-actions .icon-btn{
    width:42px!important;
    height:42px!important;
    border-radius:13px!important;
  }
  .cart-btn{
    min-height:42px!important;
    height:42px;
    padding:0 10px!important;
    gap:7px!important;
    font-size:13px!important;
    border-radius:999px!important;
    white-space:nowrap;
  }
  .cart-badge{
    min-width:24px;
    height:24px;
    font-size:12px;
  }
  .nav-links{
    left:12px!important;
    right:12px!important;
    top:calc(100% + 8px)!important;
    max-height:calc(100dvh - 92px);
    overflow:auto;
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
  }
  .nav-links a{
    min-height:48px!important;
  }
  .search-overlay{
    inset:96px 0 0!important;
    padding-top:18px!important;
    align-items:flex-start!important;
  }
  .search-overlay .wrap{
    padding-left:12px!important;
    padding-right:12px!important;
  }
  .search-overlay .search-shell{
    align-items:flex-start;
    gap:8px!important;
  }
  .search-form{
    min-width:0;
    padding:12px 12px!important;
    border-radius:18px!important;
  }
  .search-form input{
    min-width:0;
    font-size:16px!important;
  }
  .search-submit,
  .search-close{
    width:44px!important;
    height:44px!important;
  }
  .search-results{
    max-height:calc(100dvh - 210px);
    overflow:auto;
    -webkit-overflow-scrolling:touch;
  }
  .search-results-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important;
  }
  .hero,
  .mrc-shop-hero,
  .mrc-clean-shop-hero,
  .page-shell,
  .policy-content{
    overflow:hidden;
  }
  .hero-grid,
  .page-hero,
  .contact-hero,
  .contact-layout,
  .policy-grid,
  .policy-strip-row,
  .policy-meta-grid,
  .newsletter-inner,
  .faq-grid,
  .mrc-clean-shop-hero-grid,
  .mrc-shop-hero-grid,
  .mrc-shop-workspace,
  .mrc-cart-layout,
  .pd-grid{
    grid-template-columns:1fr!important;
  }
  .hero h1,
  .page-intro h1.display,
  .mrc-shop-hero-copy h1,
  .mrc-clean-shop-hero h1,
  .mrc-cart-hero h1,
  .mrc-checkout-intro h1{
    font-size:clamp(42px,13.5vw,72px)!important;
    line-height:.92!important;
    letter-spacing:0!important;
  }
  .section-head{
    align-items:flex-start!important;
    flex-direction:column!important;
    gap:12px!important;
  }
  .section-head h2,
  .faq-title,
  .policy-summary h2,
  .policy-body h2,
  .contact-card h2{
    font-size:clamp(25px,8vw,38px)!important;
    line-height:1.05!important;
  }
  .hero p.lede,
  .mrc-shop-hero-copy p,
  .mrc-clean-shop-hero p,
  .page-intro .sub,
  .policy-summary p,
  .policy-body p,
  .policy-body li,
  .contact-copy p,
  .faq-copy p{
    font-size:15.5px!important;
    line-height:1.62!important;
  }
  .hero-art{
    max-width:min(100%,430px)!important;
    margin-inline:auto!important;
  }
  .stats-row,
  .pd-trust{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important;
  }
  .bundles .bundle-grid,
  .bundle-grid{
    grid-template-columns:1fr!important;
    max-width:360px!important;
    margin-inline:auto!important;
  }
  .bundles .bundle,
  .bundle{
    padding:16px!important;
    border-radius:18px!important;
  }
  .bundles .bundle-preview,
  .bundle-preview{
    gap:6px!important;
  }
  .mrc-clean-shop-panel,
  .mrc-shop-builder-panel,
  .mrc-shop-tools,
  .mrc-cart-form,
  .mrc-cart-summary-card,
  .mrc-checkout-panel,
  .policy-summary,
  .policy-body section,
  .contact-card{
    border-radius:18px!important;
  }
  .mrc-filter-menu-row,
  .mrc-clean-shop-chips,
  .mrc-shop-filter-row{
    display:flex!important;
    flex-wrap:nowrap!important;
    overflow-x:auto!important;
    overflow-y:hidden!important;
    scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
    gap:8px!important;
    padding-bottom:6px!important;
  }
  .mrc-filter-menu-row::-webkit-scrollbar,
  .mrc-clean-shop-chips::-webkit-scrollbar,
  .mrc-shop-filter-row::-webkit-scrollbar{
    display:none;
  }
  .mrc-filter-menu-row a,
  .mrc-filter-menu-row button,
  .mrc-clean-shop-chips a,
  .mrc-clean-shop-chips button,
  .mrc-shop-filter-row button{
    flex:0 0 auto!important;
    min-height:44px!important;
    padding:0 14px!important;
    font-size:13px!important;
  }
  .mrc-filter-popover{
    position:fixed!important;
    left:12px!important;
    right:12px!important;
    top:96px!important;
    width:auto!important;
    max-height:calc(100dvh - 116px)!important;
    overflow:auto!important;
    z-index:10080!important;
  }
  .mrc-filter-popover-grid{
    grid-template-columns:1fr!important;
    max-height:none!important;
  }
  .mrc-clean-shop-chips .mrc-filter-more,
  .mrc-shop-filter-row .mrc-filter-more{
    order:-1!important;
    position:relative!important;
    left:auto!important;
    z-index:4!important;
    flex:0 0 auto!important;
    margin-right:8px!important;
    border-color:rgba(46,156,255,.9)!important;
    background:linear-gradient(135deg,rgba(46,156,255,.24),rgba(57,255,20,.13))!important;
    box-shadow:0 0 24px -16px var(--blue)!important;
  }
  .mrc-clean-shop-chips .mrc-filter-more::after,
  .mrc-shop-filter-row .mrc-filter-more::after{
    content:none!important;
  }
  .products:not(.mrc-related-track),
  .products-grid,
  .mrc-clean-products,
  .mrc-home-product-search-grid,
  .mrc-wp-products.products-grid,
  .woocommerce ul.products:not(.mrc-related-track){
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important;
  }
  .product-img,
  .mrc-shop-design-img,
  .pd-design-img,
  .search-result-img{
    border-radius:14px!important;
  }
  .product-thumb{
    width:40px!important;
    height:40px!important;
    left:8px!important;
    bottom:8px!important;
  }
  .mrc-home-product-search{
    padding:14px!important;
    border-radius:18px!important;
  }
  .mrc-home-product-search-form{
    gap:8px!important;
  }
  .mrc-shop-deals{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important;
    padding-left:12px!important;
    padding-right:12px!important;
  }
  .mrc-shop-tier{
    min-height:96px!important;
    padding:14px 12px!important;
    border-radius:18px!important;
  }
  .mrc-shop-tier strong{
    font-size:clamp(25px,8vw,34px)!important;
    white-space:normal!important;
  }
  .mrc-shop-fast-panel{
    gap:10px!important;
  }
  .mrc-shop-fast-panel div{
    grid-template-columns:42px minmax(0,1fr)!important;
    min-height:76px!important;
    padding:12px!important;
    border-radius:16px!important;
  }
  .mrc-shop-slots,
  .pd-bundle-slots{
    grid-template-columns:repeat(5,minmax(0,1fr))!important;
    gap:6px!important;
  }
  .mrc-shop-grid,
  .pd-design-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important;
    max-height:none!important;
    width:100%!important;
    max-width:100%!important;
  }
  .mrc-shop-design,
  .pd-design-card{
    min-width:0!important;
    width:100%!important;
    max-width:100%!important;
  }
  .pd-gallery{
    position:static!important;
  }
  .pd-main-img{
    border-radius:18px!important;
  }
  .pd-thumbs{
    grid-template-columns:repeat(4,minmax(0,1fr))!important;
    gap:8px!important;
  }
  .pd-info,
  .pd-bundle,
  .pd-design-builder{
    gap:12px!important;
  }
  .pd-tiers{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important;
  }
  .pd-buy{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
  }
  .related-products .products.mrc-related-track{
    gap:12px!important;
    padding-bottom:8px!important;
    scroll-padding-left:12px;
  }
  .related-products .products.mrc-related-track .product{
    flex:0 0 min(76vw,280px)!important;
  }
  .mrc-cart-hero,
  .mrc-checkout-intro{
    padding:18px!important;
    border-radius:20px!important;
  }
  .mrc-cart-actions,
  .mrc-cart-coupon div{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
  }
  .mrc-cart-actions .button,
  .mrc-cart-summary .checkout-button,
  .mrc-cart-hero-cta{
    width:100%!important;
    min-height:50px!important;
  }
  .mrc-checkout-panel .woocommerce form.checkout{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:14px!important;
  }
  .mrc-checkout-panel .woocommerce-billing-fields,
  .mrc-checkout-panel .woocommerce-shipping-fields,
  .mrc-checkout-panel .woocommerce-additional-fields,
  .mrc-checkout-panel #order_review,
  .mrc-checkout-panel .woocommerce-checkout-review-order{
    padding:14px!important;
    border-radius:16px!important;
    min-width:0!important;
  }
  .mrc-checkout-panel .woocommerce table.shop_table{
    table-layout:fixed!important;
    width:100%!important;
  }
  .mrc-checkout-panel .woocommerce table.shop_table th,
  .mrc-checkout-panel .woocommerce table.shop_table td{
    padding:10px 8px!important;
    overflow-wrap:anywhere;
  }
  .mrc-checkout-order-product{
    grid-template-columns:50px minmax(0,1fr)!important;
    gap:10px!important;
  }
  .mrc-checkout-order-thumb{
    width:50px!important;
    border-radius:12px!important;
  }
  .mrc-side-cart-panel{
    width:100vw!important;
    max-width:100vw!important;
    border-left:0!important;
  }
  .mrc-side-cart-head,
  .mrc-side-cart-foot{
    padding:14px!important;
  }
  .mrc-side-cart-body{
    padding:12px!important;
  }
  .mrc-side-cart-item{
    grid-template-columns:66px minmax(0,1fr)!important;
    gap:10px!important;
    padding:10px 40px 10px 10px!important;
    border-radius:14px!important;
  }
  .mrc-side-cart-img{
    border-radius:11px!important;
  }
  .mrc-side-cart-progress-status{
    font-size:20px!important;
  }
  .policy-toc{
    position:static!important;
    max-height:none!important;
  }
  .policy-toc a,
  .mrc-footer-pages a{
    min-height:44px!important;
  }
  .policy-body section{
    padding:18px!important;
  }
  .policy-callout{
    padding:14px!important;
    border-radius:14px!important;
  }
  .foot-grid,
  .mrc-footer-simple{
    grid-template-columns:1fr!important;
    gap:24px!important;
  }
  footer{
    padding:42px 0 22px!important;
  }
  .mrc-footer-pages ul{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:8px!important;
  }
}

@media (max-width:430px){
  .brand img{
    max-width:118px!important;
  }
  .nav-actions .icon-btn{
    width:40px!important;
    height:40px!important;
  }
  .cart-btn{
    padding:0 8px!important;
    font-size:12px!important;
  }
  .products:not(.mrc-related-track),
  .products-grid,
  .mrc-clean-products,
  .mrc-home-product-search-grid,
  .mrc-wp-products.products-grid,
  .woocommerce ul.products:not(.mrc-related-track),
  .mrc-shop-grid,
  .pd-design-grid{
    gap:8px!important;
  }
  .product-body{
    padding:9px!important;
  }
  .product h3{
    font-size:12px!important;
  }
  .add-btn{
    font-size:11px!important;
  }
  .mrc-shop-deals{
    gap:8px!important;
    padding-left:8px!important;
    padding-right:8px!important;
  }
  .mrc-shop-tier{
    padding:12px 10px!important;
  }
  .mrc-shop-tier-name{
    font-size:10px!important;
    letter-spacing:.1em!important;
  }
  .mrc-shop-tier strong{
    font-size:clamp(22px,7vw,30px)!important;
  }
  .stats-row,
  .pd-trust{
    grid-template-columns:1fr!important;
  }
}

@media (prefers-reduced-motion:reduce){
  *,
  *::before,
  *::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    scroll-behavior:auto!important;
    transition-duration:.01ms!important;
  }
}

/* Mobile UX addendum for older converted sections */
@media (max-width:760px){
  .cats,
  .cats-page-grid,
  .reviews-grid,
  .pd-stats,
  .contact-stat-grid{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important;
  }
  .cat,
  .cat-tile--v2,
  .review-card,
  .pd-stat,
  .contact-stat{
    min-width:0!important;
    border-radius:16px!important;
  }
  .cat h3,
  .cat-tile--v2 h3,
  .review-card p,
  .pd-stat-label,
  .contact-stat-note{
    overflow-wrap:anywhere;
  }
  .contact-card,
  .contact-card.primary{
    display:grid!important;
    grid-template-columns:48px minmax(0,1fr)!important;
    gap:12px!important;
    padding:16px!important;
  }
  .contact-card.primary .contact-card-icon,
  .contact-card-icon{
    width:48px!important;
    height:48px!important;
    border-radius:14px!important;
  }
  .contact-card.primary .contact-card-body p{
    font-size:clamp(20px,6vw,28px)!important;
    line-height:1.08!important;
  }
  .contact-email-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:8px!important;
  }
  .contact-email-actions a,
  .contact-form button[type="submit"]{
    width:100%!important;
    min-height:48px!important;
  }
  .contact-form{
    padding:18px!important;
    border-radius:18px!important;
  }
  .contact-form .field input,
  .contact-form .field textarea,
  .contact-form .field select{
    min-height:48px!important;
    border-radius:14px!important;
  }
  .contact-form .field textarea{
    min-height:132px!important;
  }
  .faq-help,
  .faq-item,
  .newsletter-card,
  .newsletter-inner{
    border-radius:18px!important;
  }
  .faq-help{
    margin-top:18px!important;
    padding:18px!important;
  }
  .faq-item > summary{
    min-height:54px!important;
    gap:12px!important;
  }
  .faq-toggle{
    width:32px!important;
    height:32px!important;
  }
  .faq-ship-head{
    align-items:flex-start!important;
    flex-direction:column!important;
    gap:4px!important;
  }
  .newsletter-inner{
    padding:22px!important;
  }
  .newsletter-form{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
    padding:0!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
  }
  .newsletter-form input{
    width:100%!important;
    min-height:50px!important;
    padding:0 16px!important;
    border:1px solid var(--border-bright)!important;
    border-radius:14px!important;
    background:var(--bg)!important;
  }
  .newsletter-form .btn{
    width:100%!important;
    min-height:50px!important;
  }
  .drawer-overlay{
    z-index:10090!important;
  }
  .filter-drawer{
    width:100vw!important;
    max-width:100vw!important;
    border-left:0!important;
  }
  .drawer-head,
  .drawer-foot{
    padding:14px!important;
  }
  .drawer-body{
    padding:14px!important;
  }
  .drawer-search-input{
    min-height:48px!important;
    border-radius:14px!important;
  }
  .drawer-chip{
    min-height:44px!important;
  }
}

@media (max-width:430px){
  .cats,
  .cats-page-grid,
  .reviews-grid,
  .pd-stats,
  .contact-stat-grid{
    gap:8px!important;
  }
  .cat h3,
  .cat-tile--v2 h3{
    font-size:clamp(17px,5.2vw,22px)!important;
  }
  .contact-card,
  .contact-card.primary{
    grid-template-columns:42px minmax(0,1fr)!important;
  }
  .contact-card.primary .contact-card-icon,
  .contact-card-icon{
    width:42px!important;
    height:42px!important;
  }
}

/* Mobile overflow fixes from screenshot QA */
@media (max-width:760px){
  .nav-actions{
    max-width:calc(100vw - 150px);
  }
  .cart-btn{
    width:46px!important;
    min-width:46px!important;
    max-width:46px!important;
    padding:0!important;
    justify-content:center!important;
    font-size:0!important;
  }
  .cart-btn svg{
    width:19px!important;
    height:19px!important;
  }
  .cart-badge{
    position:absolute!important;
    top:-7px!important;
    right:-7px!important;
    min-width:22px!important;
    height:22px!important;
    padding:0 6px!important;
    font-size:11px!important;
    border:2px solid var(--bg);
  }
  .menu-btn{
    display:grid!important;
  }
  .display,
  h1.display,
  .hero h1,
  .page-intro h1.display,
  .contact-hero-copy h1,
  .categories-intro h1,
  .mrc-shop-hero-copy h1,
  .mrc-clean-shop-hero h1,
  .mrc-empty-cart h1,
  .mrc-cart-hero h1,
  .mrc-checkout-intro h1,
  .pd-title{
    max-width:100%!important;
    font-size:clamp(36px,10.6vw,50px)!important;
    line-height:.98!important;
    white-space:normal!important;
    overflow-wrap:normal!important;
    word-break:normal!important;
  }
  .display span,
  h1.display span,
  .hero h1 span,
  .page-intro h1.display span,
  .contact-hero-copy h1 span,
  .categories-intro h1 span,
  .mrc-shop-hero-copy h1 span,
  .mrc-clean-shop-hero h1 span,
  .mrc-empty-cart h1 span,
  .mrc-cart-hero h1 span,
  .mrc-checkout-intro h1 span{
    display:inline!important;
    white-space:normal!important;
  }
  .hero .eyebrow,
  .breadcrumb,
  .kicker,
  .page-chip,
  .contact-chip,
  .search-banner-label{
    max-width:100%!important;
    white-space:normal!important;
    overflow-wrap:anywhere!important;
  }
  .page-hero-actions,
  .contact-hero-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:8px!important;
    width:100%!important;
    max-width:100%!important;
  }
  .page-chip,
  .contact-chip{
    width:100%!important;
    min-height:42px!important;
    justify-content:flex-start!important;
    padding:10px 12px!important;
    border-radius:14px!important;
  }
  .hero p.lede,
  .mrc-shop-hero-copy p,
  .mrc-clean-shop-hero p,
  .page-intro .sub,
  .contact-hero-copy .sub,
  .mrc-empty-cart p,
  .mrc-cart-hero p,
  .mrc-checkout-intro p:not(.mrc-cart-kicker){
    max-width:100%!important;
    overflow-wrap:break-word!important;
  }
  .hero-actions,
  .contact-hero-actions,
  .page-hero-actions{
    overflow:hidden!important;
  }
  .pd-grid,
  .pd-gallery,
  .pd-info,
  .pd-main-img{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
  }
  .pd-main-img{
    aspect-ratio:1/1!important;
    overflow:hidden!important;
  }
  .pd-main-img img{
    width:100%!important;
    height:100%!important;
    object-fit:contain!important;
    object-position:center center!important;
    padding:10%!important;
    box-sizing:border-box!important;
  }
  .mrc-empty-cart{
    width:calc(100% - 28px)!important;
    max-width:560px!important;
    padding:22px 16px!important;
    overflow:hidden!important;
  }
  .mrc-empty-cart .button{
    min-height:50px!important;
    padding:0 18px!important;
  }
}

@media (max-width:430px){
  .display,
  h1.display,
  .hero h1,
  .page-intro h1.display,
  .contact-hero-copy h1,
  .categories-intro h1,
  .mrc-shop-hero-copy h1,
  .mrc-clean-shop-hero h1,
  .mrc-empty-cart h1,
  .mrc-cart-hero h1,
  .mrc-checkout-intro h1,
  .pd-title{
    font-size:clamp(34px,10vw,44px)!important;
  }
  .brand img{
    max-width:112px!important;
  }
  .nav-actions{
    max-width:calc(100vw - 132px);
  }
}

/* Mobile screenshot QA refinements */
@media (max-width:760px){
  .nav{
    justify-content:flex-start!important;
  }
  .nav-actions{
    width:auto!important;
    max-width:none!important;
    margin-left:auto!important;
    display:grid!important;
    grid-template-columns:42px 46px 42px!important;
    align-items:center!important;
    justify-content:end!important;
    gap:6px!important;
    overflow:visible!important;
  }
  .nav-actions .icon-btn[aria-label="Search"],
  .nav-actions .menu-btn{
    width:42px!important;
    min-width:42px!important;
  }
  .nav-actions .icon-btn[aria-label="Account"]{
    display:none!important;
  }
  .mrc-clean-shop-hero h1 span,
  .mrc-shop-hero-copy h1 span,
  .page-intro h1.display span,
  .categories-intro h1 span,
  .contact-hero-copy h1 span,
  .mrc-cart-hero h1 span,
  .mrc-checkout-intro h1 span{
    display:block!important;
  }
  .hero h1 span{
    display:block!important;
  }
  .mrc-empty-cart h1 span{
    display:inline!important;
  }
  .mrc-clean-shop-hero h1,
  .mrc-shop-hero-copy h1,
  .page-intro h1.display,
  .categories-intro h1,
  .contact-hero-copy h1,
  .mrc-empty-cart h1{
    font-size:clamp(34px,9.4vw,42px)!important;
    max-width:calc(100vw - 32px)!important;
  }
  .mrc-clean-shop-hero h1 .gradient,
  .mrc-shop-hero-copy h1 .gradient,
  .page-intro h1.display .gradient,
  .categories-intro h1 .gradient,
  .contact-hero-copy h1 .gradient{
    display:block!important;
  }
  .mrc-clean-shop-search button,
  .mrc-home-product-search-form button,
  .search-strip-input button{
    max-width:100%!important;
  }
  .breadcrumb{
    display:flex!important;
    flex-wrap:wrap!important;
    min-width:0!important;
    max-width:100%!important;
    overflow:hidden!important;
  }
  .breadcrumb a,
  .breadcrumb span{
    min-width:0!important;
    max-width:100%!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
  }
  .pd-grid{
    width:100%!important;
    max-width:calc(100vw - 28px)!important;
    margin-left:auto!important;
    margin-right:auto!important;
    overflow:hidden!important;
  }
  .pd-main-img,
  .pd-thumbs{
    width:100%!important;
    max-width:calc(100vw - 36px)!important;
    margin-left:auto!important;
    margin-right:auto!important;
  }
  .pd-main-img img{
    padding:14%!important;
  }
}

@media (max-width:430px){
  .mrc-clean-shop-hero h1,
  .mrc-shop-hero-copy h1,
  .page-intro h1.display,
  .categories-intro h1,
  .contact-hero-copy h1,
  .mrc-empty-cart h1{
    font-size:clamp(32px,9vw,38px)!important;
  }
  .nav-actions{
    grid-template-columns:40px 44px 40px!important;
    gap:5px!important;
  }
  .cart-btn{
    width:44px!important;
    min-width:44px!important;
    max-width:44px!important;
  }
}

/* Keep mobile/tablet capture widths from inheriting desktop overflow */
@media (max-width:920px){
  .nav{
    justify-content:flex-start!important;
    position:relative!important;
  }
  .nav-actions{
    position:absolute!important;
    right:clamp(12px,4vw,18px)!important;
    top:50%!important;
    transform:translateY(-50%)!important;
    display:grid!important;
    grid-template-columns:42px 46px 42px!important;
    gap:6px!important;
    align-items:center!important;
    width:140px!important;
    max-width:calc(100vw - 150px)!important;
    overflow:visible!important;
  }
  .nav-actions .icon-btn[aria-label="Account"]{
    display:none!important;
  }
  .nav-actions .icon-btn[aria-label="Search"],
  .nav-actions .menu-btn{
    display:grid!important;
    width:42px!important;
    min-width:42px!important;
    height:42px!important;
  }
  .cart-btn{
    width:46px!important;
    min-width:46px!important;
    max-width:46px!important;
    height:42px!important;
    padding:0!important;
    justify-content:center!important;
    font-size:0!important;
  }
  .cart-btn svg{
    width:19px!important;
    height:19px!important;
  }
  .mrc-clean-shop-hero h1 span,
  .mrc-shop-hero-copy h1 span,
  .page-intro h1.display span,
  .categories-intro h1 span,
  .contact-hero-copy h1 span{
    display:block!important;
    max-width:100%!important;
    white-space:normal!important;
  }
  .mrc-shop-hero-copy h1{
    font-size:clamp(32px,8.7vw,36px)!important;
    max-width:calc(100vw - 32px)!important;
  }
  .mrc-clean-shop-hero h1,
  .page-intro h1.display,
  .categories-intro h1,
  .contact-hero-copy h1,
  .mrc-empty-cart h1{
    font-size:clamp(34px,9.4vw,42px)!important;
    max-width:calc(100vw - 32px)!important;
  }
}

/* Bundle builder image hard override.
   Keep this last so older converted image rules cannot shift, crop, or hide builder images. */
.mrc-shop-builder .mrc-shop-design-img{
  position:relative!important;
  display:grid!important;
  place-items:center!important;
  aspect-ratio:1/1!important;
  width:100%!important;
  min-height:0!important;
  overflow:hidden!important;
  border-radius:14px!important;
  background:#fff!important;
  isolation:isolate!important;
}
.mrc-shop-builder .mrc-shop-design-img img{
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-width:100%!important;
  max-height:100%!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:10%!important;
  margin:0!important;
  transform:none!important;
  opacity:1!important;
  visibility:visible!important;
  box-sizing:border-box!important;
}
.mrc-shop-builder .mrc-shop-design:hover .mrc-shop-design-img img,
.mrc-shop-builder .mrc-shop-design.is-selected .mrc-shop-design-img img{
  transform:none!important;
}

@media (max-width:740px){
  .mrc-shop-builder .mrc-shop-design-img{
    border-radius:13px!important;
  }
  .mrc-shop-builder .mrc-shop-design-img img{
    padding:9%!important;
  }
}

/* Keep shop pagination controls first, with the page count tucked underneath. */
.mrc-clean-shop-pagination{
  flex-wrap:wrap!important;
}
.mrc-clean-shop-pagination > a,
.mrc-clean-shop-pagination > div{
  order:1!important;
}
.mrc-clean-shop-pagination > span{
    order:2!important;
    flex:0 0 100%!important;
    width:100%!important;
    margin-top:2px!important;
    text-align:center!important;
  }

/* Performance pass: avoid painting large off-screen product grids until needed. */
.products-grid .product,
.mrc-clean-products .product,
.mrc-shop-design,
.bundle-card,
.cat-card{
  content-visibility:auto;
  contain-intrinsic-size:1px 430px;
}

.mrc-shop-design-img img,
.product-img img,
.mrc-side-cart-thumb img,
.mrc-cart-product-img img,
.checkout-product-thumb img,
.search-result-img img{
  aspect-ratio:1/1;
}

/* Universal bundle preview thumbnail centering.
   Product files often include uneven white/transparent canvas, so bundle chips
   need a tighter crop box than normal product cards. */
.bundle-preview .chip:not(.more),
.bundle-card .chip:not(.more),
.bundle-card [class*="preview"] [class*="chip"]:not(.more){
  position:relative!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  overflow:hidden!important;
  padding:5px!important;
  background:#fff!important;
  aspect-ratio:1/1!important;
}

.bundle-preview .chip:not(.more) img,
.bundle-card .chip:not(.more) img,
.bundle-card [class*="preview"] [class*="chip"]:not(.more) img{
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  max-height:none!important;
  padding:0!important;
  margin:0!important;
  object-fit:cover!important;
  object-position:50% 50%!important;
  transform:scale(1.08)!important;
  transform-origin:center center!important;
  border-radius:6px!important;
}

.bundle-preview .chip.more,
.bundle-card .chip.more{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}

.bundles .bundle,
.bundle-grid .bundle{
  transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)!important;
}
.bundles .bundle:hover,
.bundle-grid .bundle:hover{
  transform:translateY(-4px)!important;
}

/* Checkout order summary polish.
   Keeps long product names from collapsing into one-word lines in the review box. */
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table{
  table-layout:auto!important;
  width:100%!important;
  border-collapse:separate!important;
  border-spacing:0!important;
}
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table thead th{
  color:var(--text-muted)!important;
  font-family:var(--font-body)!important;
  font-size:13px!important;
  font-weight:900!important;
}
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table .product-name{
  width:auto!important;
  min-width:0!important;
}
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table .product-total{
  width:92px!important;
  min-width:80px!important;
  text-align:right!important;
  white-space:nowrap!important;
  vertical-align:top!important;
}
.mrc-checkout-order-product{
  grid-template-columns:58px minmax(0,1fr)!important;
  align-items:start!important;
}
.mrc-checkout-order-title{
  font-family:var(--font-body)!important;
  font-size:13px!important;
  font-weight:900!important;
  line-height:1.22!important;
  overflow-wrap:normal!important;
  word-break:normal!important;
  hyphens:none!important;
}
.mrc-checkout-order-table .product-quantity{
  margin-top:6px!important;
  font-size:13px!important;
}
.mrc-checkout-order-table .variation{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:4px 8px!important;
  margin:7px 0 0!important;
  font-size:12px!important;
  line-height:1.3!important;
}
.mrc-checkout-order-table .variation dt,
.mrc-checkout-order-table .variation dd{
  display:inline!important;
  float:none!important;
  margin:0!important;
  padding:0!important;
}
.mrc-checkout-order-table .variation dt{
  color:var(--text-muted)!important;
  font-weight:800!important;
}
.mrc-checkout-order-table .variation dd{
  color:var(--text)!important;
}
.mrc-checkout-order-table .variation p{
  display:inline!important;
  margin:0!important;
}
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tfoot tr.woocommerce-shipping-totals{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:12px!important;
  align-items:start!important;
}
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tfoot tr.woocommerce-shipping-totals th,
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tfoot tr.woocommerce-shipping-totals td{
  display:block!important;
  width:100%!important;
  padding-inline:0!important;
  text-align:left!important;
}
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tfoot tr.woocommerce-shipping-totals th{
  color:var(--text-muted)!important;
  font-size:clamp(18px,2.4vw,26px)!important;
  line-height:1.1!important;
}
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table ul#shipping_method,
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table .woocommerce-shipping-methods{
  display:grid!important;
  gap:10px!important;
  width:100%!important;
  margin:0!important;
  padding:0!important;
  list-style:none!important;
}
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table ul#shipping_method li,
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table .woocommerce-shipping-methods li{
  display:flex!important;
  gap:10px!important;
  align-items:start!important;
  width:100%!important;
  margin:0!important;
  padding:12px!important;
  border:1px solid rgba(255,255,255,.08)!important;
  border-radius:14px!important;
  background:rgba(255,255,255,.035)!important;
}
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table ul#shipping_method input.shipping_method,
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table .woocommerce-shipping-methods input.shipping_method{
  flex:0 0 18px!important;
  width:18px!important;
  height:18px!important;
  margin:3px 0 0!important;
}
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table ul#shipping_method label,
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table .woocommerce-shipping-methods label{
  display:block!important;
  flex:1 1 auto!important;
  min-width:0!important;
  max-width:100%!important;
  margin:0!important;
  color:var(--text)!important;
  font-family:var(--font-body)!important;
  font-size:clamp(14px,1.9vw,16px)!important;
  font-weight:900!important;
  line-height:1.28!important;
  letter-spacing:0!important;
  text-align:left!important;
  overflow-wrap:break-word!important;
  word-break:normal!important;
  white-space:normal!important;
}
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table ul#shipping_method label .amount,
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table .woocommerce-shipping-methods label .amount{
  color:var(--accent)!important;
  white-space:nowrap!important;
}
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tfoot tr.fee td{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:8px!important;
}
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table input.fee[type="checkbox"]{
  flex:0 0 18px!important;
  width:18px!important;
  height:18px!important;
  accent-color:var(--accent)!important;
}
.mrc-checkout-panel .woocommerce table.mrc-checkout-order-table input.fee[type="checkbox"] + label{
  margin:0!important;
  color:var(--accent)!important;
  font-family:var(--font-mono)!important;
  font-weight:900!important;
  white-space:nowrap!important;
}
.mrc-checkout-panel .blockUI.blockOverlay,
.mrc-checkout-panel .processing .blockUI.blockOverlay,
.mrc-checkout-panel .woocommerce-checkout-review-order .blockUI.blockOverlay{
  background:rgba(10,10,10,.72)!important;
  opacity:.78!important;
}
.mrc-checkout-panel .blockUI.blockMsg{
  border:0!important;
  background:rgba(10,10,10,.82)!important;
  color:var(--text)!important;
}

@media (max-width:640px){
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table,
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table thead,
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tbody,
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tfoot{
    display:block!important;
    width:100%!important;
  }
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table thead{
    display:none!important;
  }
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tbody tr.cart_item{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) auto!important;
    gap:10px 12px!important;
    align-items:start!important;
    padding:13px 0!important;
    border-bottom:1px solid rgba(255,255,255,.08)!important;
  }
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tbody tr.cart_item:first-child{
    padding-top:0!important;
  }
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tbody tr.cart_item:last-child{
    border-bottom:0!important;
  }
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tbody td{
    display:block!important;
    padding:0!important;
    border:0!important;
  }
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tbody td.product-total{
    width:auto!important;
    min-width:64px!important;
    padding-top:7px!important;
    font-family:var(--font-mono)!important;
    font-size:14px!important;
    text-align:right!important;
  }
  .mrc-checkout-order-product{
    grid-template-columns:52px minmax(0,1fr)!important;
    gap:10px!important;
  }
  .mrc-checkout-order-thumb{
    width:52px!important;
    border-radius:13px!important;
  }
  .mrc-checkout-order-title{
    font-size:12.5px!important;
    line-height:1.2!important;
  }
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tfoot tr{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) auto!important;
    gap:12px!important;
    align-items:center!important;
    padding:10px 0!important;
    border-top:1px solid rgba(255,255,255,.08)!important;
  }
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tfoot th,
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tfoot td{
    display:block!important;
    padding:0!important;
    border:0!important;
  }
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tfoot td{
    text-align:right!important;
  }
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tfoot tr.woocommerce-shipping-totals{
    grid-template-columns:1fr!important;
    gap:10px!important;
  }
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tfoot tr.woocommerce-shipping-totals td{
    text-align:left!important;
  }
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tfoot tr.fee{
    grid-template-columns:1fr!important;
    align-items:start!important;
  }
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table tfoot tr.fee td{
    justify-content:flex-start!important;
    text-align:left!important;
  }
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table ul#shipping_method li,
  .mrc-checkout-panel .woocommerce table.mrc-checkout-order-table .woocommerce-shipping-methods li{
    gap:9px!important;
    padding:11px!important;
  }
}

/* Universal product image alignment.
   This intentionally targets commerce product imagery only, leaving logos,
   category illustrations, and page artwork alone. */
.product-img,
.product .product-img-link,
.product-thumb,
.mrc-shop-design-img,
.pd-design-img,
.pd-main-img,
.pd-thumbs .pd-thumb,
.search-result-img,
.mrc-cart-item-media,
.mrc-side-cart-img,
.mrc-checkout-order-thumb{
  --mrc-product-img-padding:10%;
  --mrc-product-img-scale:1;
  --mrc-product-img-y:-2%;
  position:relative!important;
  display:grid!important;
  place-items:center!important;
  overflow:hidden!important;
  aspect-ratio:1/1!important;
}

.product-img img,
.product .product-img-link img,
.product-thumb img,
.mrc-shop-design-img img,
.pd-design-img img,
.pd-main-img img,
.pd-main-img .woocommerce-product-gallery__image img,
.pd-thumbs .pd-thumb img,
.search-result-img img,
.mrc-cart-item-media img,
.mrc-side-cart-img img,
.mrc-checkout-order-thumb img{
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  max-height:none!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:var(--mrc-product-img-padding)!important;
  margin:0!important;
  box-sizing:border-box!important;
  transform:translateY(var(--mrc-product-img-y)) scale(var(--mrc-product-img-scale))!important;
  transform-origin:center center!important;
}

.product-img,
.mrc-shop-design-img,
.pd-design-img,
.pd-main-img{
  --mrc-product-img-padding:11%;
  --mrc-product-img-y:-1%;
}

.pd-thumbs .pd-thumb{
  --mrc-product-img-padding:8%;
  --mrc-product-img-y:-2%;
}

.mrc-cart-item-media,
.mrc-side-cart-img,
.search-result-img{
  --mrc-product-img-padding:9%;
  --mrc-product-img-scale:1.03;
  --mrc-product-img-y:-3%;
  background:#fff!important;
}

.mrc-checkout-order-thumb{
  --mrc-product-img-padding:6%;
  --mrc-product-img-scale:1.12;
  --mrc-product-img-y:-8%;
  background:#fff!important;
}

.product-thumb{
  --mrc-product-img-padding:0%;
  --mrc-product-img-scale:1.14;
  --mrc-product-img-y:-2%;
  background:#fff!important;
}

.product-thumb img{
  object-fit:cover!important;
}

.product:hover .product-img-link img,
.product:hover .product-img img,
.mrc-shop-design:hover .mrc-shop-design-img img,
.pd-design-card:hover .pd-design-img img{
  transform:translateY(var(--mrc-product-img-y)) scale(var(--mrc-product-img-scale))!important;
}

/* Product card hover swap cleanup.
   At rest: primary image in the card, secondary image in the corner preview.
   On hover: secondary image in the card, primary image in the corner preview. */
.product .product-img{
  position:relative!important;
  isolation:isolate!important;
}

.product .product-img-link{
  position:relative!important;
  display:grid!important;
  place-items:center!important;
  width:100%!important;
  height:100%!important;
  aspect-ratio:1/1!important;
  overflow:hidden!important;
}

.product .product-img-link .product-img-primary,
.product .product-img-link .product-img-secondary{
  position:absolute!important;
  inset:0!important;
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  max-height:none!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:13%!important;
  margin:0!important;
  opacity:1!important;
  visibility:visible!important;
  transform:none!important;
  transition:opacity 220ms var(--ease)!important;
  z-index:1!important;
}

.product .product-img-link .product-img-primary{
  opacity:1!important;
  visibility:visible!important;
  z-index:1!important;
}

.product .product-img-link .product-img-secondary{
  opacity:0!important;
  visibility:visible!important;
  z-index:2!important;
}

.product:hover .product-img-link .product-img-primary{
  opacity:0!important;
  transform:none!important;
}

.product:hover .product-img-link .product-img-secondary{
  opacity:1!important;
  transform:none!important;
}

.product:hover .product-img-link img{
  transform:none!important;
}

.product .product-img-link .product-img-secondary:only-child{
  opacity:0!important;
}

.product .product-thumb.product-thumb-swap{
  position:absolute!important;
  left:0!important;
  bottom:0!important;
  top:auto!important;
  right:auto!important;
  z-index:7!important;
  display:grid!important;
  place-items:center!important;
  width:54px!important;
  height:54px!important;
  max-width:none!important;
  max-height:none!important;
  aspect-ratio:1/1!important;
  padding:0!important;
  margin:0!important;
  overflow:hidden!important;
  border:2px solid rgba(255,255,255,.18)!important;
  border-radius:999px!important;
  background:radial-gradient(circle at 50% 45%,rgba(255,255,255,.12),rgba(255,255,255,.025) 62%,rgba(0,0,0,.45))!important;
  box-shadow:0 12px 26px rgba(0,0,0,.42),0 0 0 1px rgba(57,255,20,.2),0 0 24px rgba(57,255,20,.18)!important;
  opacity:1!important;
  transform:none!important;
  cursor:default!important;
}

.product:hover .product-thumb.product-thumb-swap{
  border-color:rgba(57,255,20,.52)!important;
  box-shadow:0 14px 30px rgba(0,0,0,.48),0 0 0 1px rgba(57,255,20,.34),0 0 28px rgba(57,255,20,.24)!important;
  opacity:1!important;
  transform:none!important;
}

.product .product-thumb.product-thumb-swap img{
  position:absolute!important;
  inset:-10%!important;
  display:block!important;
  width:120%!important;
  height:120%!important;
  max-width:none!important;
  max-height:none!important;
  padding:0!important;
  margin:0!important;
  border:0!important;
  border-radius:999px!important;
  object-fit:cover!important;
  object-position:center center!important;
  visibility:visible!important;
  transform:none!important;
  transition:opacity 220ms var(--ease)!important;
}

.product .product-thumb.product-thumb-swap .product-thumb-secondary{
  opacity:1!important;
  z-index:1!important;
}

.product .product-thumb.product-thumb-swap .product-thumb-primary{
  display:block!important;
  opacity:0!important;
  z-index:2!important;
}

.product:hover .product-thumb.product-thumb-swap .product-thumb-secondary{
  opacity:0!important;
}

.product:hover .product-thumb.product-thumb-swap .product-thumb-primary{
  opacity:1!important;
}

@media (max-width:720px){
  .product .product-img-link .product-img-primary{
    padding:14%!important;
  }

  .product .product-thumb.product-thumb-swap{
    left:0!important;
    bottom:0!important;
    width:42px!important;
    height:42px!important;
    padding:0!important;
    border-radius:999px!important;
  }
}

/* High-specificity correction for earlier img:not(:first-child) preview rules.
   The secondary image inside .product-img-link must cover the main card area,
   never shrink into the thumbnail corner. */
.products .product .product-img-link > img.product-img-primary,
.products-grid .product .product-img-link > img.product-img-primary,
.mrc-products-grid .product .product-img-link > img.product-img-primary,
.mrc-shop-products .product .product-img-link > img.product-img-primary,
.product .product-img-link > img.product-img-primary,
.products .product .product-img-link > img.product-img-secondary,
.products-grid .product .product-img-link > img.product-img-secondary,
.mrc-products-grid .product .product-img-link > img.product-img-secondary,
.mrc-shop-products .product .product-img-link > img.product-img-secondary,
.product .product-img-link > img.product-img-secondary{
  position:absolute!important;
  inset:0!important;
  left:0!important;
  right:0!important;
  top:0!important;
  bottom:0!important;
  z-index:1!important;
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  max-height:none!important;
  aspect-ratio:1/1!important;
  margin:0!important;
  padding:13%!important;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
  box-shadow:none!important;
  object-fit:contain!important;
  object-position:center center!important;
  transform:none!important;
}

.products .product .product-img-link > img.product-img-primary,
.products-grid .product .product-img-link > img.product-img-primary,
.mrc-products-grid .product .product-img-link > img.product-img-primary,
.mrc-shop-products .product .product-img-link > img.product-img-primary,
.product .product-img-link > img.product-img-primary{
  opacity:1!important;
  z-index:1!important;
}

.products .product .product-img-link > img.product-img-secondary,
.products-grid .product .product-img-link > img.product-img-secondary,
.mrc-products-grid .product .product-img-link > img.product-img-secondary,
.mrc-shop-products .product .product-img-link > img.product-img-secondary,
.product .product-img-link > img.product-img-secondary{
  opacity:0!important;
  z-index:2!important;
}

.products .product:hover .product-img-link > img.product-img-primary,
.products-grid .product:hover .product-img-link > img.product-img-primary,
.mrc-products-grid .product:hover .product-img-link > img.product-img-primary,
.mrc-shop-products .product:hover .product-img-link > img.product-img-primary,
.product:hover .product-img-link > img.product-img-primary{
  opacity:0!important;
  transform:none!important;
}

.products .product:hover .product-img-link > img.product-img-secondary,
.products-grid .product:hover .product-img-link > img.product-img-secondary,
.mrc-products-grid .product:hover .product-img-link > img.product-img-secondary,
.mrc-shop-products .product:hover .product-img-link > img.product-img-secondary,
.product:hover .product-img-link > img.product-img-secondary{
  opacity:1!important;
  transform:none!important;
}

/* Product card layer lock: badges and actions must stay above hover media. */
.products .product .product-img,
.products-grid .product .product-img,
.mrc-products-grid .product .product-img,
.mrc-shop-products .product .product-img,
.mrc-product-card .product-img,
.product-card .product-img,
.product .product-img{
  isolation:isolate!important;
}

.products .product .product-img-link,
.products-grid .product .product-img-link,
.mrc-products-grid .product .product-img-link,
.mrc-shop-products .product .product-img-link,
.mrc-product-card .product-img-link,
.product-card .product-img-link,
.product .product-img-link{
  z-index:1!important;
}

.products .product .product-thumb,
.products-grid .product .product-thumb,
.mrc-products-grid .product .product-thumb,
.mrc-shop-products .product .product-thumb,
.mrc-product-card .product-thumb,
.product-card .product-thumb,
.product .product-thumb{
  z-index:4!important;
}

.products .product .badge,
.products-grid .product .badge,
.mrc-products-grid .product .badge,
.mrc-shop-products .product .badge,
.mrc-product-card .badge,
.product-card .badge,
.product .badge{
  z-index:30!important;
}

.products .product .wish,
.products-grid .product .wish,
.mrc-products-grid .product .wish,
.mrc-shop-products .product .wish,
.mrc-product-card .wish,
.product-card .wish,
.product .wish{
  z-index:31!important;
}

/* Homepage mobile hero headline: keep the brand statement big and punchy. */
@media (max-width:760px){
  .hero h1.display{
    font-size:clamp(58px,17vw,86px)!important;
    line-height:.88!important;
    letter-spacing:0!important;
    max-width:100%!important;
  }
}

@media (max-width:430px){
  .hero h1.display{
    font-size:clamp(58px,17.5vw,76px)!important;
  }
}

@media (max-width:760px){
  .hero h1.display .gradient{
    display:inline-block!important;
    width:max-content!important;
    max-width:100%!important;
  }
  .hero h1.display .gradient::after{
    right:auto!important;
    width:100%!important;
  }
}

/* Checkout header tidy-up: keep the rainbow ticker and nav connected at top. */
body.woocommerce-checkout .mrc-checkout-shell{
  display:flex!important;
  flex-direction:column!important;
  padding-top:0!important;
}
body.woocommerce-checkout .mrc-checkout-shell > .ticker{
  order:0!important;
  position:sticky!important;
  top:0!important;
  z-index:10061!important;
  margin:0!important;
  border-radius:0!important;
}
body.woocommerce-checkout .mrc-checkout-shell > .site-header{
  order:1!important;
  position:sticky!important;
  top:42px!important;
  z-index:10060!important;
  margin:0!important;
  border-top:0!important;
}
body.woocommerce-checkout.admin-bar .mrc-checkout-shell > .ticker,
body.woocommerce-checkout.admin-bar .mrc-checkout-shell > .site-header{
  top:0!important;
}
body.woocommerce-checkout .mrc-checkout-shell > .search-overlay{
  order:2!important;
}
body.woocommerce-checkout .mrc-checkout-shell > main{
  order:3!important;
}
body.woocommerce-checkout .mrc-checkout-intro{
  margin-top:clamp(22px,4vw,48px)!important;
}
html:has(body.woocommerce-checkout),
body.woocommerce-checkout.admin-bar{
  margin-top:0!important;
}
body.woocommerce-checkout #wpadminbar{
  display:none!important;
}

@media (max-width:720px){
  body.woocommerce-checkout .mrc-checkout-shell > .site-header{
    top:34px!important;
  }
}

/* Final product-card stacking guard.
   Keep hover images permanently below badges, even when older card rules
   give secondary images their own z-index. */
.product .product-img,
.products .product .product-img,
.products-grid .product .product-img,
.mrc-products-grid .product .product-img,
.mrc-shop-products .product .product-img,
.mrc-clean-products .product .product-img{
  position:relative!important;
  isolation:isolate!important;
}

.product .product-img-link,
.products .product .product-img-link,
.products-grid .product .product-img-link,
.mrc-products-grid .product .product-img-link,
.mrc-shop-products .product .product-img-link,
.mrc-clean-products .product .product-img-link,
.product .product-img-link > img,
.products .product .product-img-link > img,
.products-grid .product .product-img-link > img,
.mrc-products-grid .product .product-img-link > img,
.mrc-shop-products .product .product-img-link > img,
.mrc-clean-products .product .product-img-link > img{
  z-index:0!important;
}

.product .badge,
.products .product .badge,
.products-grid .product .badge,
.mrc-products-grid .product .badge,
.mrc-shop-products .product .badge,
.mrc-clean-products .product .badge{
  position:absolute!important;
  z-index:100!important;
  transform:translateZ(0)!important;
}

.product .wish,
.products .product .wish,
.products-grid .product .wish,
.mrc-products-grid .product .wish,
.mrc-shop-products .product .wish,
.mrc-clean-products .product .wish{
  position:absolute!important;
  z-index:101!important;
  transform:translateZ(0)!important;
}

.mrc-shop-trust-block{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:14px;
  align-items:center;
  margin:14px 0 14px;
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:12px;
  background:rgba(255,255,255,.035);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.045);
}

.mrc-shop-trust-copy{
  min-width:0;
}

.mrc-shop-trust-copy strong{
  display:block;
  margin:0 0 3px;
  color:var(--text);
  font-family:var(--font-display);
  font-size:15px;
  font-weight:800;
  letter-spacing:.01em;
}

.mrc-shop-trust-copy p{
  margin:0;
  max-width:54ch;
  color:var(--text-muted);
  font-family:var(--font-body);
  font-size:13px;
  font-weight:600;
  line-height:1.35;
}

.mrc-shop-trust-action{
  display:flex;
  align-items:center;
  gap:12px;
  text-align:left;
}

.mrc-shop-trust-action span{
  color:var(--text-muted);
  font-family:var(--font-body);
  font-size:12px;
  font-weight:800;
  line-height:1.2;
  white-space:nowrap;
}

.mrc-shop-trust-action a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 12px;
  border:1px solid rgba(57,255,20,.34);
  border-radius:999px;
  background:rgba(57,255,20,.08);
  color:var(--accent);
  font-family:var(--font-body);
  font-size:12px;
  font-weight:900;
  text-decoration:none;
  white-space:nowrap;
  transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease),transform var(--dur) var(--ease);
}

.mrc-shop-trust-action a:hover{
  border-color:var(--accent);
  background:rgba(57,255,20,.18);
  transform:translateY(-1px);
}

@media (max-width:760px){
  .mrc-shop-trust-block{
    grid-template-columns:1fr;
    gap:10px;
    margin:12px 0;
    padding:12px;
    border-radius:12px;
  }

  .mrc-shop-trust-copy strong{
    font-size:15px;
  }

  .mrc-shop-trust-copy p{
    font-size:12.5px;
    line-height:1.35;
  }

  .mrc-shop-trust-action{
    flex-wrap:wrap;
    align-items:flex-start;
    text-align:left;
    gap:8px;
  }

.mrc-shop-trust-action a{
  min-height:34px;
  padding:0 12px;
  font-size:12px;
  }
}

/* Desktop shop performance pass.
   The shop grid has many image cards; avoid fixed overlays, blur, and hover-swap
   layers that force extra repaints while scrolling on larger viewports. */
@media (min-width:761px){
  body.mrc-shop-view{
    background-attachment:scroll!important;
  }

  body.mrc-shop-view::before{
    display:none!important;
  }

  body.mrc-shop-view .site-header{
    backdrop-filter:none!important;
    -webkit-backdrop-filter:none!important;
    background:rgba(5,5,10,.96)!important;
  }

  body.mrc-shop-view .mrc-clean-products{
    content-visibility:auto;
    contain:layout paint style;
    contain-intrinsic-size:1px 1400px;
  }

  body.mrc-shop-view .mrc-clean-products .product{
    contain:layout paint style;
    box-shadow:none!important;
    transition:border-color 160ms var(--ease),background 160ms var(--ease)!important;
  }

  body.mrc-shop-view .mrc-clean-products .product:hover{
    box-shadow:none!important;
    transform:none!important;
  }

  body.mrc-shop-view .mrc-clean-products .product-img-secondary,
  body.mrc-shop-view .mrc-clean-products .product-thumb.product-thumb-swap{
    display:none!important;
  }

  body.mrc-shop-view .mrc-clean-products .product-img-primary,
  body.mrc-shop-view .mrc-clean-products .product:hover .product-img-primary{
    opacity:1!important;
  }

  body.mrc-shop-view .mrc-clean-products .product-img,
  body.mrc-shop-view .mrc-clean-products .product-img-link,
  body.mrc-shop-view .mrc-clean-products .product-img-link img{
    will-change:auto!important;
    transform:none!important;
  }
}

/* Desktop scroll performance pass.
   Fixed page textures, blend-mode grain, and backdrop blur are expensive to
   repaint during long desktop scrolls, especially on product-heavy pages. */
@media (min-width:761px){
  body{
    background-attachment:scroll!important;
  }

  body::before{
    display:none!important;
  }

  .site-header{
    backdrop-filter:none!important;
    -webkit-backdrop-filter:none!important;
    background:rgba(5,5,10,.96)!important;
  }

  .hero-art::before{
    filter:none!important;
    opacity:.45!important;
  }

  .charm img{
    filter:none!important;
  }

  .ticker-track{
    will-change:transform;
  }

  .brand:hover img{
    filter:none!important;
  }
}

/* Product page gallery fit guard.
   Any selected image ratio should scale inside the frame without clipping. */
.mrc-lovable-product-shell .pd-main-img,
.mrc-lovable-product-shell .pd-thumb,
.mrc-lovable-product-shell .pd-design-img{
  display:grid!important;
  place-items:center!important;
  overflow:hidden!important;
}

.mrc-lovable-product-shell .pd-main-img{
  aspect-ratio:1/1!important;
  min-height:0!important;
}

.mrc-lovable-product-shell #pd-main-img,
.mrc-lovable-product-shell .pd-main-img > img,
.mrc-lovable-product-shell .pd-main-img .woocommerce-product-gallery__image img{
  position:relative!important;
  inset:auto!important;
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-width:100%!important;
  max-height:100%!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:14%!important;
  margin:0!important;
  box-sizing:border-box!important;
  transform:none!important;
  scale:1!important;
  clip-path:none!important;
}

.mrc-lovable-product-shell .pd-thumb img,
.mrc-lovable-product-shell .pd-design-img img{
  width:100%!important;
  height:100%!important;
  object-fit:contain!important;
  object-position:center center!important;
  transform:none!important;
  scale:1!important;
  clip-path:none!important;
}

@media (max-width:760px){
  .mrc-lovable-product-shell #pd-main-img,
  .mrc-lovable-product-shell .pd-main-img > img,
  .mrc-lovable-product-shell .pd-main-img .woocommerce-product-gallery__image img{
    padding:16%!important;
  }
}

body.woocommerce-checkout .mrc-checkout-panel select.select2-hidden-accessible{
  position:absolute!important;
  width:1px!important;
  min-width:1px!important;
  max-width:1px!important;
  height:1px!important;
  min-height:1px!important;
  max-height:1px!important;
  padding:0!important;
  margin:-1px!important;
  border:0!important;
  clip:rect(0 0 0 0)!important;
  clip-path:inset(50%)!important;
  overflow:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}

.mrc-track-hero{
  padding-top:clamp(44px,6vw,82px);
}
.mrc-track-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,460px);
  gap:clamp(24px,4vw,56px);
  align-items:center;
}
.mrc-track-copy .breadcrumb{
  margin-bottom:22px;
}
.mrc-track-copy .display{
  margin:12px 0 18px;
}
.mrc-track-copy .sub{
  max-width:58ch;
}
.mrc-track-card{
  display:grid;
  gap:16px;
  padding:clamp(20px,3vw,30px);
  border:1px solid rgba(57,255,20,.34);
  border-radius:24px;
  background:linear-gradient(180deg,rgba(57,255,20,.08),rgba(255,255,255,.025)),var(--surface);
  box-shadow:0 24px 70px -34px rgba(57,255,20,.55), inset 0 1px 0 rgba(255,255,255,.06);
}
.mrc-track-card-head{
  display:grid;
  gap:8px;
}
.mrc-track-pill{
  width:max-content;
  padding:6px 10px;
  border:1px solid rgba(57,255,20,.42);
  border-radius:999px;
  color:var(--accent);
  font-family:var(--font-body);
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.mrc-track-card h2{
  margin:0;
  font-family:var(--font-chunky);
  font-size:clamp(28px,3vw,42px);
  font-weight:400;
  line-height:1;
}
.mrc-track-card p,
.mrc-track-info-card p{
  margin:0;
  color:var(--text-muted);
  line-height:1.55;
}
.mrc-track-card label{
  display:grid;
  gap:8px;
  color:var(--text-muted);
  font-family:var(--font-body);
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.mrc-track-card input,
.mrc-track-card select{
  width:100%;
  min-height:52px;
  padding:0 14px;
  border:1px solid var(--border-bright);
  border-radius:14px;
  background:var(--surface-2);
  color:var(--text);
  font-family:var(--font-body);
  font-size:15px;
  font-weight:700;
  outline:0;
}
.mrc-track-card input:focus,
.mrc-track-card select:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(57,255,20,.14);
}
.mrc-track-card button{
  min-height:52px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 20px;
  border-radius:14px;
  background:var(--accent);
  color:var(--accent-ink);
  font-family:var(--font-display);
  font-size:15px;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  text-decoration:none;
  box-shadow:0 0 24px -6px var(--accent-glow);
}
.mrc-track-status{
  min-height:22px;
  color:var(--accent)!important;
  font-weight:800;
}
.mrc-track-note{
  font-size:12px;
}
.mrc-track-info{
  padding:0 0 clamp(34px,5vw,62px);
}
.mrc-track-info-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.mrc-track-info-card{
  min-height:180px;
  padding:20px;
  border:1px solid var(--border);
  border-radius:18px;
  background:var(--surface);
}
.mrc-track-info-icon{
  display:inline-flex;
  margin-bottom:16px;
  color:var(--accent);
  font-family:var(--font-mono);
  font-weight:900;
}
.mrc-track-info-card h3{
  margin:0 0 8px;
  font-family:var(--font-display);
  font-size:20px;
}
.mrc-track-info-card a{
  color:var(--accent);
}
@media (max-width:860px){
  .mrc-track-hero-grid,
  .mrc-track-info-grid{
    grid-template-columns:1fr;
  }
}
