/* ============================================================
   INTERFAZ MONTERREY — ELEVATE LAYER v1
   Premium polish overlay. Loaded LAST so it can override
   surface treatments without rewriting the base system.

   Scope:
   - Premium depth (mesh gradients, noise grain, vignettes)
   - Cinematic hero treatment
   - Product card lift / glow / quick actions reveal
   - Navbar refinement (sticky depth, active glow)
   - Buttons (gradient, shimmer, magnetic-ready)
   - Bento, marquee, brands, testimonials polish
   - Service page elevation
   - Microinteractions (reveal stagger, smooth scroll cues)
   - Mobile-first refinements
   ============================================================ */

:root {
  /* Premium motion tokens */
  --ease-out-quint:    cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out-expo:     cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out-expo:  cubic-bezier(0.87, 0, 0.13, 1);
  --ease-out-back:     cubic-bezier(0.34, 1.56, 0.64, 1);

  /* Premium shadow tokens (multi-layered) */
  --shadow-soft:       0 1px 2px rgba(0,0,0,.4), 0 8px 24px rgba(0,0,0,.35);
  --shadow-lift:       0 4px 12px rgba(0,0,0,.5), 0 24px 48px rgba(0,0,0,.45);
  --shadow-float:      0 8px 28px rgba(0,0,0,.55), 0 32px 80px rgba(0,0,0,.5);
  --shadow-red:        0 8px 28px rgba(229,9,20,.18), 0 24px 60px rgba(229,9,20,.12);
  --shadow-blue:       0 8px 28px rgba(10,127,212,.20), 0 24px 60px rgba(10,127,212,.14);

  /* Surface tones */
  --surface-1: #0a0a0a;
  --surface-2: #121212;
  --surface-3: #181818;
  --surface-4: #1f1f1f;

  /* Premium borders */
  --hairline:        rgba(255,255,255,0.06);
  --hairline-strong: rgba(255,255,255,0.10);
  --hairline-red:    rgba(229,9,20,0.22);
  --hairline-blue:   rgba(10,127,212,0.28);
}

/* ── Subtle film grain everywhere ─────────────────────────────
   A barely-visible texture layer on body to break up flat blacks
   and add a tactile, cinematic quality. */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  opacity: 0.025;
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode: overlay;
}

/* ── Selection accent ───────────────────────────────────────── */
::selection { background: rgba(229,9,20,0.85); color: #fff; }

/* ── Smoother focus ring globally ───────────────────────────── */
:focus-visible {
  outline: 2px solid rgba(229,9,20,0.7);
  outline-offset: 2px;
  border-radius: 4px;
}

/* ============================================================
   NAVBAR ELEVATION
   ============================================================ */
.navbar {
  background: linear-gradient(180deg, rgba(8,8,8,0.92) 0%, rgba(8,8,8,0.78) 100%) !important;
  backdrop-filter: blur(28px) saturate(160%);
  -webkit-backdrop-filter: blur(28px) saturate(160%);
  border-bottom: 1px solid var(--hairline);
  transition:
    background 0.5s var(--ease-out-quint),
    box-shadow 0.5s var(--ease-out-quint),
    border-color 0.5s var(--ease-out-quint),
    height 0.4s var(--ease-out-quint);
}

.navbar.scrolled {
  background: linear-gradient(180deg, rgba(6,6,6,0.96) 0%, rgba(6,6,6,0.93) 100%) !important;
  border-bottom-color: var(--hairline-strong);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.04),
    0 10px 32px rgba(0,0,0,0.55),
    0 24px 48px rgba(0,0,0,0.35);
}

/* Subtle hairline under navbar with accent gradient */
.navbar::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -1px;
  transform: translateX(-50%);
  width: 280px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(229,9,20,0.6), transparent);
  opacity: 0;
  transition: opacity 0.45s var(--ease-out-quint);
}
.navbar.scrolled::after { opacity: 1; }

/* Nav links — smoother hover with subtle glow */
.nav-links a {
  transition:
    color 0.35s var(--ease-out-quint),
    transform 0.35s var(--ease-out-quint);
  will-change: transform, color;
}
.nav-links a:hover { transform: translateY(-1px); }

.nav-links a::after {
  height: 2px !important;
  background: linear-gradient(90deg, var(--red), var(--red-light)) !important;
  box-shadow: 0 0 12px rgba(229,9,20,0.5);
  transition: width 0.4s var(--ease-out-quint) !important;
}

/* Service link — premium BenQ badge */
.nav-service-link .nav-service-badge {
  background: linear-gradient(135deg, #0a7fd4, #0660a0);
  box-shadow:
    0 2px 8px rgba(10,127,212,0.35),
    inset 0 1px 0 rgba(255,255,255,0.18);
}

/* Cart button */
.nav-cart {
  transition:
    background 0.3s var(--ease-out-quint),
    transform 0.3s var(--ease-out-quint),
    border-color 0.3s var(--ease-out-quint);
}
.nav-cart:hover {
  transform: translateY(-1px) scale(1.05);
  background: rgba(229,9,20,0.08);
  border-color: rgba(229,9,20,0.3);
}

/* Mobile hamburger — refined */
.hamburger span {
  transition: transform 0.35s var(--ease-out-expo), opacity 0.25s ease;
}

/* ============================================================
   HERO — CINEMATIC ELEVATION (no heavy vignette)
   ============================================================ */
.home-hero-compact {
  position: relative;
}

/* Make the hero feel full at desktop — row layout w/ stats on the right */
@media (min-width: 980px) {
  .hhc-inner {
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 64px !important;
  }
  .hhc-left {
    flex: 1 1 0;
    max-width: 640px;
  }
  .hhc-stats {
    flex: 0 0 auto;
    display: grid !important;
    grid-template-columns: repeat(2, auto) !important;
    grid-auto-rows: auto;
    gap: 28px 56px !important;
    border-top: none !important;
    border-bottom: none !important;
    padding: 28px 32px !important;
    background:
      linear-gradient(135deg, rgba(229,9,20,0.06), rgba(229,9,20,0.02) 50%, transparent 100%),
      rgba(255,255,255,0.02) !important;
    border: 1px solid var(--hairline) !important;
    border-radius: 18px;
    backdrop-filter: blur(8px);
    box-shadow:
      0 24px 60px rgba(0,0,0,0.45),
      inset 0 1px 0 rgba(255,255,255,0.04);
  }
  .hhc-stats .hhc-divider { display: none !important; }
  .hhc-stat {
    padding: 0 !important;
    min-width: 140px;
  }
}

/* Enhanced grid — more visible, subtle drift */
.hero-grid {
  background-image:
    linear-gradient(rgba(229,9,20,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(229,9,20,0.06) 1px, transparent 1px) !important;
  background-size: 56px 56px !important;
  mask-image: radial-gradient(ellipse at center, black 25%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 25%, transparent 80%);
  animation: heroGridDrift 28s linear infinite;
  opacity: 0.85;
}
@keyframes heroGridDrift {
  from { transform: translate(0, 0); }
  to   { transform: translate(-56px, -56px); }
}

/* Hero glows — stronger, more present */
.hero-glow {
  background: radial-gradient(ellipse 50% 60% at 70% 40%,
              rgba(229,9,20,0.28) 0%,
              rgba(229,9,20,0.08) 35%,
              transparent 65%) !important;
  filter: blur(20px);
  animation: heroGlowPulse 9s ease-in-out infinite;
}
.hero-glow2 {
  background: radial-gradient(ellipse 45% 55% at 15% 70%,
              rgba(10,127,212,0.16) 0%,
              rgba(10,127,212,0.04) 40%,
              transparent 70%) !important;
  filter: blur(30px);
  animation: heroGlowPulse 12s ease-in-out infinite reverse;
}
@keyframes heroGlowPulse {
  0%, 100% { opacity: 0.85; transform: scale(1); }
  50%      { opacity: 1;    transform: scale(1.06); }
}

/* Hero badge — elevated */
.hero-badge {
  background: linear-gradient(135deg, rgba(229,9,20,0.16), rgba(229,9,20,0.06)) !important;
  border: 1px solid rgba(229,9,20,0.28) !important;
  backdrop-filter: blur(12px);
  box-shadow:
    0 4px 16px rgba(229,9,20,0.12),
    inset 0 1px 0 rgba(255,255,255,0.06);
  position: relative;
  overflow: hidden;
}
.hero-badge::before {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
  animation: badgeShimmer 4.5s ease-in-out infinite;
}
@keyframes badgeShimmer {
  0%, 100% { left: -100%; }
  60%, 100% { left: 100%; }
}

/* Hero title — refined typography */
.hhc-title {
  letter-spacing: -0.02em;
}
.hhc-line2 em {
  background: linear-gradient(135deg, var(--red-light) 0%, var(--red) 60%, var(--red-dark) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 24px rgba(229,9,20,0.35));
}

/* Hero stats — elevated, never invisible */
.hhc-stats { position: relative; }
.hhc-stat {
  position: relative;
  transition: transform 0.4s var(--ease-out-expo);
}
.hhc-stat:hover { transform: translateY(-3px); }
.hhc-stat::before {
  content: '';
  position: absolute;
  left: -16px; top: 6px;
  width: 3px; height: 24px;
  border-radius: 2px;
  background: linear-gradient(180deg, var(--red), transparent);
  opacity: 0.55;
}
.hhc-stat-num {
  background: linear-gradient(180deg, #fff 0%, #c8c8c8 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 2px 8px rgba(229,9,20,0.18));
}
.hhc-stat-label {
  color: rgba(255,255,255,0.55) !important;
}

/* Hero CTAs */
.hhc-ctas .btn-primary,
.promo-ctas .btn-primary {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, var(--red) 0%, var(--red-dark) 100%) !important;
  border: none;
  box-shadow:
    0 6px 20px rgba(229,9,20,0.32),
    0 2px 4px rgba(229,9,20,0.18),
    inset 0 1px 0 rgba(255,255,255,0.18);
  transition:
    transform 0.35s var(--ease-out-quint),
    box-shadow 0.35s var(--ease-out-quint),
    background 0.35s var(--ease-out-quint);
}
.hhc-ctas .btn-primary::before,
.promo-ctas .btn-primary::before {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 60%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.22), transparent);
  transition: left 0.6s var(--ease-out-quint);
}
.hhc-ctas .btn-primary:hover::before,
.promo-ctas .btn-primary:hover::before { left: 130%; }
.hhc-ctas .btn-primary:hover,
.promo-ctas .btn-primary:hover {
  transform: translateY(-2px);
  box-shadow:
    0 12px 32px rgba(229,9,20,0.45),
    0 4px 8px rgba(229,9,20,0.25),
    inset 0 1px 0 rgba(255,255,255,0.22);
}

/* WhatsApp hero button */
.btn-whatsapp-hero {
  background: linear-gradient(135deg, #25d366 0%, #128c7e 100%) !important;
  border: none !important;
  box-shadow:
    0 6px 20px rgba(37,211,102,0.30),
    inset 0 1px 0 rgba(255,255,255,0.18);
  transition: transform 0.35s var(--ease-out-quint), box-shadow 0.35s var(--ease-out-quint);
}
.btn-whatsapp-hero:hover {
  transform: translateY(-2px);
  box-shadow:
    0 12px 32px rgba(37,211,102,0.45),
    inset 0 1px 0 rgba(255,255,255,0.22);
}

/* ============================================================
   HERO — left mini-stats strip
   ============================================================ */
.hhc-mini-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 30px;
  margin-top: 30px;
}
.hhc-mini-stats .hhc-stat { padding: 0; min-width: auto; }
.hhc-mini-stats .hhc-stat-num { font-size: 30px; }

/* ============================================================
   HERO — floating brand logos composition (premium / corporate)
   Crisp typographic lockups (no external assets → no console 404s,
   never pixelated, fully scalable). Swap in official SVGs later by
   replacing the .lk wordmarks with <img> if desired.
   ============================================================ */
.hhc-visual {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.hhc-stage {
  position: relative;
  width: 100%;
  max-width: 470px;
  aspect-ratio: 1 / 1;
}

/* Ambient depth */
.hhc-orb {
  position: absolute;
  inset: 16% 14%;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 38%, rgba(229,9,20,0.26), rgba(229,9,20,0.05) 55%, transparent 72%);
  filter: blur(22px);
  animation: hhcOrb 9s ease-in-out infinite;
}
@keyframes hhcOrb {
  0%, 100% { opacity: 0.85; transform: scale(1); }
  50%      { opacity: 1;    transform: scale(1.08); }
}
.hhc-ring {
  position: absolute;
  inset: 4%;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.07);
  animation: hhcSpin 44s linear infinite;
}
.hhc-ring::before {
  content: '';
  position: absolute;
  inset: 13%;
  border-radius: 50%;
  border: 1px dashed rgba(255,255,255,0.06);
}
@keyframes hhcSpin { to { transform: rotate(360deg); } }

/* Floating particles */
.hhc-particle {
  position: absolute;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: rgba(255,255,255,0.5);
  box-shadow: 0 0 8px rgba(255,255,255,0.4);
  opacity: 0;
  animation: hhcPart 7s ease-in-out infinite;
}
.hp1 { top: 14%; left: 30%; animation-delay: 0.4s; }
.hp2 { top: 70%; left: 22%; width: 4px; height: 4px; animation-delay: 1.6s; }
.hp3 { top: 34%; left: 82%; width: 5px; height: 5px; background: rgba(229,9,20,0.7); box-shadow: 0 0 9px rgba(229,9,20,0.6); animation-delay: 2.4s; }
.hp4 { top: 88%; left: 66%; width: 4px; height: 4px; animation-delay: 3.1s; }
@keyframes hhcPart {
  0%       { opacity: 0; transform: translateY(8px) scale(0.6); }
  30%, 60% { opacity: 0.9; transform: translateY(-6px) scale(1); }
  100%     { opacity: 0; transform: translateY(-18px) scale(0.6); }
}

/* Glass logo tiles */
.hhc-logo {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff, #eef1f4);
  border: 1px solid rgba(255,255,255,0.7);
  box-shadow: 0 20px 46px rgba(0,0,0,0.45), 0 2px 6px rgba(0,0,0,0.28), inset 0 1px 0 rgba(255,255,255,0.9);
  opacity: 0;
  transform: translateY(22px) scale(0.9);
  animation: hhcLogoIn 0.85s cubic-bezier(0.22,1,0.36,1) forwards;
  animation-delay: var(--d, 0s);
}
.hhc-logo-in {
  display: flex;
  align-items: center;
  justify-content: center;
  animation: hhcFloat var(--t, 8s) ease-in-out infinite;
  will-change: transform;
}
@keyframes hhcLogoIn {
  to { opacity: 1; transform: none; }
}
@keyframes hhcFloat {
  0%, 100% { transform: translateY(0) rotate(var(--r, 0deg)); }
  50%      { transform: translateY(-12px) rotate(calc(var(--r, 0deg) * -0.6)); }
}

.hhc-logo--lg { padding: 18px 26px; }
.hhc-logo--sm { padding: 15px 20px; }

/* Real logo images (brand colors on light chip) */
.lk-img { display: block; width: auto; object-fit: contain; }
.hhc-logo--lg .lk-img { height: 34px; max-width: 170px; }
.hhc-logo--sm .lk-img { height: 27px; max-width: 138px; }
.hhc-logo--db .lk-img { height: 66px; max-width: 112px; }

/* Positions within the square stage */
.hhc-pos-shure { top: 3%;  left: 2%; }
.hhc-pos-bose  { top: 37%; left: 46%; }
.hhc-pos-db    { top: 70%; left: 3%; }
.hhc-pos-qsc   { top: 5%;  left: 60%; }
.hhc-pos-onkyo { top: 66%; left: 55%; }

/* Wordmark lockups (fallback when a logo file is missing) */
.lk {
  font-family: var(--font-condensed, 'Barlow Condensed', sans-serif);
  color: #0b0b0b;
  line-height: 1;
  white-space: nowrap;
  user-select: none;
}
.lk-shure {
  font-weight: 700;
  font-size: 32px;
  letter-spacing: 0.16em;
  text-indent: 0.16em;
}
.lk-bose {
  font-weight: 600;
  font-size: 32px;
  letter-spacing: 0.22em;
  text-indent: 0.22em;
}
.lk-db { display: inline-flex; align-items: baseline; gap: 6px; }
.lk-db b {
  font-weight: 800;
  font-size: 30px;
  letter-spacing: -0.01em;
  color: #0b0b0b;
}
.lk-db i {
  font-style: normal;
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #1c63b7;
}
.lk-sec {
  font-weight: 700;
  font-size: 19px;
  letter-spacing: 0.12em;
  text-indent: 0.12em;
}

@media (prefers-reduced-motion: reduce) {
  .hhc-logo, .hhc-logo-in, .hhc-orb, .hhc-ring, .hhc-particle {
    animation: none !important;
  }
  .hhc-logo { opacity: 1; transform: none; }
  .hhc-logo--sm, .hhc-logo--xs { opacity: 1; }
  .hhc-particle { display: none; }
}

/* ── Responsive ──────────────────────────────────────────────── */
@media (min-width: 980px) {
  .hhc-visual { flex: 0 0 470px; align-self: stretch; }
}
@media (max-width: 979px) {
  /* Stage sits below the text, centered */
  .hhc-visual { margin-top: 8px; }
  .hhc-stage { max-width: 420px; }
}
@media (max-width: 600px) {
  .hhc-mini-stats { gap: 12px 22px; margin-top: 22px; }
  .hhc-mini-stats .hhc-stat-num { font-size: 26px; }
  .hhc-stage { max-width: 300px; }
  .hhc-logo--lg { padding: 14px 18px; }
  .hhc-logo--lg .lk-img { height: 28px; max-width: 132px; }
  .hhc-logo--sm .lk-img { height: 22px; max-width: 108px; }
  .hhc-logo--db .lk-img { height: 56px; max-width: 92px; }
}

/* ============================================================
   BENTO GRID — ELEVATED
   ============================================================ */
.cat-bento-card {
  transition:
    transform 0.5s var(--ease-out-quint),
    box-shadow 0.5s var(--ease-out-quint),
    border-color 0.4s var(--ease-out-quint);
  isolation: isolate;
  border: 1px solid var(--hairline) !important;
}
.cat-bento-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 50%),
              rgba(229,9,20,0.18) 0%, transparent 50%);
  opacity: 0;
  transition: opacity 0.5s var(--ease-out-quint);
  pointer-events: none;
  z-index: 2;
}
.cat-bento-card:hover {
  transform: translateY(-6px);
  border-color: rgba(229,9,20,0.4) !important;
  box-shadow:
    0 16px 40px rgba(0,0,0,0.5),
    0 4px 12px rgba(229,9,20,0.18);
}
.cat-bento-card:hover::before { opacity: 1; }

.bento-img {
  transition: transform 1.2s var(--ease-out-quint), filter 0.6s var(--ease-out-quint) !important;
}
.cat-bento-card:hover .bento-img {
  transform: scale(1.08);
  filter: brightness(0.65) saturate(1.05);
}

.bento-overlay {
  background: linear-gradient(180deg,
              rgba(0,0,0,0.20) 0%,
              rgba(0,0,0,0.55) 60%,
              rgba(0,0,0,0.92) 100%) !important;
}

.bento-arrow {
  background: rgba(255,255,255,0.06) !important;
  backdrop-filter: blur(8px);
  border: 1px solid var(--hairline);
  transition:
    background 0.4s var(--ease-out-quint),
    transform 0.4s var(--ease-out-quint),
    border-color 0.4s var(--ease-out-quint);
}
.cat-bento-card:hover .bento-arrow {
  background: var(--red) !important;
  border-color: var(--red);
  transform: translate(2px, -2px) rotate(-2deg);
  box-shadow: 0 4px 14px rgba(229,9,20,0.45);
}

.bento-label {
  letter-spacing: -0.01em;
  text-shadow: 0 2px 8px rgba(0,0,0,0.6);
}
.bento-sub {
  text-shadow: 0 1px 4px rgba(0,0,0,0.7);
}

/* ============================================================
   PRODUCT CARDS — RICH HOVER + QUICK ACTIONS
   ============================================================ */
.product-card {
  background: linear-gradient(180deg, var(--surface-3) 0%, var(--surface-2) 100%) !important;
  border: 1px solid var(--hairline) !important;
  transition:
    transform 0.5s var(--ease-out-quint),
    box-shadow 0.5s var(--ease-out-quint),
    border-color 0.45s var(--ease-out-quint) !important;
  isolation: isolate;
}

/* Animated gradient border on hover */
.product-card::after {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg,
              rgba(229,9,20,0) 0%,
              rgba(229,9,20,0.5) 40%,
              rgba(229,9,20,0.18) 50%,
              transparent 100%);
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  opacity: 0;
  transition: opacity 0.5s var(--ease-out-quint);
  pointer-events: none;
  z-index: 1;
}
.product-card:hover {
  transform: translateY(-8px) !important;
  border-color: rgba(229,9,20,0.25) !important;
  box-shadow: var(--shadow-red), 0 24px 60px rgba(0,0,0,0.6) !important;
}
.product-card:hover::after { opacity: 1; }

/* Product image — premium white container w/ subtle gradient */
.product-card-img {
  background: linear-gradient(135deg, #ffffff 0%, #f4f4f4 100%) !important;
  position: relative;
}
.product-card-img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 100%, rgba(0,0,0,0.05) 0%, transparent 60%);
  opacity: 1;
  z-index: 0;
}
.product-card-img img {
  position: relative;
  z-index: 1;
  transition: transform 0.7s var(--ease-out-quint) !important;
}
.product-card:hover .product-card-img img {
  transform: scale(1.10) !important;
}

/* Brand badge on card — refined */
.product-card-brand {
  backdrop-filter: blur(8px);
  background: rgba(0,0,0,0.55) !important;
  border: 1px solid var(--hairline);
}

/* Featured badge */
.product-card-badge {
  background: linear-gradient(135deg, var(--red), var(--red-dark)) !important;
  box-shadow:
    0 4px 12px rgba(229,9,20,0.35),
    inset 0 1px 0 rgba(255,255,255,0.18);
}

/* Rent pill — premium */
.product-card-rent-pill {
  background: linear-gradient(135deg, #f59e0b, #d97706) !important;
  box-shadow:
    0 4px 10px rgba(245,158,11,0.32),
    inset 0 1px 0 rgba(255,255,255,0.18);
}

/* Quote/rent action buttons */
.card-quote-modal-btn,
.card-rent-btn,
.card-add-btn {
  transition:
    transform 0.3s var(--ease-out-quint),
    box-shadow 0.3s var(--ease-out-quint),
    background 0.3s var(--ease-out-quint) !important;
}
.card-quote-modal-btn:hover,
.card-rent-btn:hover {
  transform: translateY(-1px) scale(1.04);
}
.card-add-btn:hover {
  transform: translateY(-1px) scale(1.08);
  box-shadow: 0 6px 14px rgba(229,9,20,0.32);
}

/* Category eyebrow on card */
.product-card-cat {
  color: rgba(229,9,20,0.85) !important;
}

/* ============================================================
   FEATURED SLIDER POLISH
   ============================================================ */
.featured-nav-btn {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid var(--hairline) !important;
  backdrop-filter: blur(8px);
  transition:
    background 0.3s var(--ease-out-quint),
    border-color 0.3s var(--ease-out-quint),
    transform 0.3s var(--ease-out-quint);
}
.featured-nav-btn:hover {
  background: var(--red) !important;
  border-color: var(--red) !important;
  transform: scale(1.1);
  box-shadow: 0 6px 20px rgba(229,9,20,0.45);
}

.slider-dots .dot {
  transition: all 0.4s var(--ease-out-quint);
}
.slider-dots .dot.active {
  background: var(--red) !important;
  box-shadow: 0 0 12px rgba(229,9,20,0.6);
}

/* ============================================================
   MARQUEE BAND — PREMIUM POLISH
   ============================================================ */
.marquee-band {
  position: relative;
  background: linear-gradient(180deg, #050505 0%, #0a0a0a 50%, #050505 100%) !important;
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
}
.marquee-band .dot {
  color: rgba(229,9,20,0.7) !important;
}

/* ============================================================
   VALUE PROPS — PREMIUM
   ============================================================ */
.vp-row {
  transition: transform 0.45s var(--ease-out-quint), background 0.45s var(--ease-out-quint);
  position: relative;
}
.vp-row::before {
  content: '';
  position: absolute;
  inset: -16px -20px;
  background: linear-gradient(135deg, rgba(229,9,20,0.04), transparent 50%);
  border-radius: 12px;
  opacity: 0;
  transition: opacity 0.45s var(--ease-out-quint);
  pointer-events: none;
}
.vp-row:hover::before { opacity: 1; }
.vp-row:hover { transform: translateX(4px); }

.vp-row-icon {
  background: linear-gradient(135deg, rgba(229,9,20,0.12), rgba(229,9,20,0.04)) !important;
  border: 1px solid rgba(229,9,20,0.2) !important;
  transition:
    transform 0.45s var(--ease-out-back),
    background 0.45s var(--ease-out-quint);
}
.vp-row:hover .vp-row-icon {
  transform: rotate(-6deg) scale(1.08);
  background: linear-gradient(135deg, rgba(229,9,20,0.22), rgba(229,9,20,0.08)) !important;
}

.vp-row-num {
  background: linear-gradient(180deg, rgba(229,9,20,0.15) 0%, transparent 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.vp-left-cta {
  transition: gap 0.35s var(--ease-out-quint), color 0.35s var(--ease-out-quint);
}
.vp-left-cta:hover { gap: 14px; }
.vp-left-cta svg { transition: transform 0.4s var(--ease-out-quint); }
.vp-left-cta:hover svg { transform: translateX(4px); }

/* ============================================================
   PROMO BANNER ELEVATION
   ============================================================ */
.promo-banner {
  background: radial-gradient(ellipse at top left, rgba(229,9,20,0.06) 0%, transparent 60%),
              linear-gradient(180deg, var(--surface-2), var(--surface-1)) !important;
  position: relative;
  overflow: hidden;
}
.promo-banner::before {
  content: '';
  position: absolute;
  top: -50%; right: -10%;
  width: 600px; height: 600px;
  background: radial-gradient(ellipse, rgba(229,9,20,0.10) 0%, transparent 60%);
  filter: blur(40px);
  pointer-events: none;
}

.promo-circle {
  background: radial-gradient(circle at 35% 35%, rgba(229,9,20,0.20), rgba(229,9,20,0.05) 70%) !important;
  border: 1px solid rgba(229,9,20,0.25);
  box-shadow:
    0 20px 60px rgba(229,9,20,0.15),
    inset 0 2px 0 rgba(255,255,255,0.05);
  animation: promoCircleFloat 6s ease-in-out infinite;
}
@keyframes promoCircleFloat {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50%      { transform: translateY(-12px) rotate(2deg); }
}
.promo-circle svg { animation: promoMicGlow 3s ease-in-out infinite; }
@keyframes promoMicGlow {
  0%, 100% { filter: drop-shadow(0 0 0 transparent); }
  50%      { filter: drop-shadow(0 0 18px rgba(229,9,20,0.45)); }
}

.promo-badge {
  background: linear-gradient(135deg, var(--red), var(--red-dark)) !important;
  box-shadow:
    0 8px 24px rgba(229,9,20,0.32),
    inset 0 1px 0 rgba(255,255,255,0.2);
}

/* ============================================================
   TESTIMONIALS — PREMIUM
   ============================================================ */
.testimonial-card {
  background: linear-gradient(180deg, var(--surface-3), var(--surface-2)) !important;
  border: 1px solid var(--hairline) !important;
  transition:
    transform 0.5s var(--ease-out-quint),
    border-color 0.5s var(--ease-out-quint),
    box-shadow 0.5s var(--ease-out-quint);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.testimonial-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--red), transparent);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.6s var(--ease-out-quint);
}
.testimonial-card:hover {
  transform: translateY(-6px);
  border-color: rgba(229,9,20,0.22) !important;
  box-shadow: 0 24px 60px rgba(0,0,0,0.4), 0 0 24px rgba(229,9,20,0.06);
}
.testimonial-card:hover::before {
  transform: scaleX(1);
}

.featured-t {
  background: linear-gradient(180deg, rgba(229,9,20,0.06) 0%, var(--surface-3) 60%) !important;
  border-color: rgba(229,9,20,0.22) !important;
}

.t-quote {
  background: linear-gradient(180deg, rgba(229,9,20,0.5), rgba(229,9,20,0.05)) !important;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.t-stars .t-star {
  color: #fbbf24;
  filter: drop-shadow(0 0 4px rgba(251,191,36,0.4));
}

.t-avatar {
  background: linear-gradient(135deg, var(--red), var(--red-dark)) !important;
  box-shadow: 0 4px 12px rgba(229,9,20,0.32);
}

/* ============================================================
   BRANDS BAR — PREMIUM
   ============================================================ */
.brand-pill {
  background: rgba(255,255,255,0.03) !important;
  border: 1px solid var(--hairline) !important;
  transition:
    transform 0.35s var(--ease-out-quint),
    background 0.35s var(--ease-out-quint),
    border-color 0.35s var(--ease-out-quint),
    box-shadow 0.35s var(--ease-out-quint);
}
.brand-pill:hover {
  transform: translateY(-2px);
  background: rgba(229,9,20,0.06) !important;
  border-color: rgba(229,9,20,0.35) !important;
  box-shadow: 0 6px 18px rgba(0,0,0,0.4), 0 0 16px rgba(229,9,20,0.12);
  color: #fff;
}
.brand-pill.brand-featured {
  background: linear-gradient(135deg, rgba(229,9,20,0.18), rgba(229,9,20,0.06)) !important;
  border-color: rgba(229,9,20,0.35) !important;
  color: #fff !important;
}
.brand-pill.brand-featured:hover {
  background: linear-gradient(135deg, rgba(229,9,20,0.28), rgba(229,9,20,0.10)) !important;
  box-shadow: 0 8px 22px rgba(229,9,20,0.25);
}

/* ============================================================
   SECTION HEADERS — TYPOGRAPHY POLISH
   ============================================================ */
.section-eyebrow {
  position: relative;
  display: inline-block;
  padding-left: 24px;
}
.section-eyebrow::before {
  content: '';
  position: absolute;
  left: 0; top: 50%;
  width: 16px; height: 1.5px;
  background: linear-gradient(90deg, var(--red), transparent);
  transform: translateY(-50%);
}

.section-header h2 .accent,
h2 .accent {
  background: linear-gradient(135deg, var(--red-light) 0%, var(--red) 60%, var(--red-dark) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 18px rgba(229,9,20,0.3));
}

/* ============================================================
   QUOTE MODAL — POLISHED
   ============================================================ */
#quoteModal { backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); }
.qm-panel,
.quote-modal-panel,
.qm-modal-panel {
  box-shadow:
    0 32px 80px rgba(0,0,0,0.7),
    0 16px 32px rgba(229,9,20,0.08),
    inset 0 1px 0 rgba(255,255,255,0.04) !important;
}
.qm-submit {
  background: linear-gradient(135deg, var(--red), var(--red-dark)) !important;
  box-shadow:
    0 8px 24px rgba(229,9,20,0.32),
    inset 0 1px 0 rgba(255,255,255,0.18) !important;
  transition: transform 0.3s var(--ease-out-quint), box-shadow 0.3s var(--ease-out-quint) !important;
}
.qm-submit:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow:
    0 14px 32px rgba(229,9,20,0.45),
    inset 0 1px 0 rgba(255,255,255,0.22) !important;
}

/* ============================================================
   POPUP UPGRADES — composition + motion
   ============================================================ */
.im-popup-backdrop {
  backdrop-filter: blur(18px) saturate(120%) !important;
  -webkit-backdrop-filter: blur(18px) saturate(120%) !important;
  background: rgba(0,0,0,0.78) !important;
}
.im-popup-panel {
  box-shadow:
    0 40px 100px rgba(0,0,0,0.7),
    0 20px 40px rgba(0,0,0,0.5),
    inset 0 1px 0 rgba(255,255,255,0.05) !important;
}
.im-popup-btn-primary {
  background: linear-gradient(135deg, var(--red), var(--red-dark)) !important;
  box-shadow:
    0 8px 22px rgba(229,9,20,0.32),
    inset 0 1px 0 rgba(255,255,255,0.18) !important;
  transition: transform 0.3s var(--ease-out-quint), box-shadow 0.3s var(--ease-out-quint) !important;
}
.im-popup-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow:
    0 14px 32px rgba(229,9,20,0.45),
    inset 0 1px 0 rgba(255,255,255,0.22) !important;
}
.im-popup-btn-secondary {
  transition: transform 0.3s var(--ease-out-quint), background 0.3s var(--ease-out-quint), border-color 0.3s var(--ease-out-quint) !important;
}
.im-popup-btn-secondary:hover {
  transform: translateY(-2px);
}

/* ============================================================
   SERVICE PAGE — ELEVATION
   ============================================================ */
.sv-hero {
  position: relative;
}
.sv-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse at 50% 100%, transparent 40%, rgba(0,0,0,0.7) 100%),
    radial-gradient(ellipse at 30% 30%, rgba(10,127,212,0.08) 0%, transparent 50%);
  z-index: 1;
}
.sv-hero-inner { position: relative; z-index: 2; }

.sv-auth-badge {
  background: linear-gradient(135deg, rgba(10,127,212,0.18), rgba(10,127,212,0.06)) !important;
  border: 1px solid rgba(10,127,212,0.35) !important;
  backdrop-filter: blur(10px);
  box-shadow:
    0 4px 16px rgba(10,127,212,0.18),
    inset 0 1px 0 rgba(255,255,255,0.06);
  position: relative;
  overflow: hidden;
}
.sv-auth-badge::before {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(10,127,212,0.20), transparent);
  animation: badgeShimmer 5s ease-in-out infinite;
}

.sv-blue {
  background: linear-gradient(135deg, #4cb5ff 0%, #0a7fd4 60%, #075a96 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 24px rgba(10,127,212,0.32));
}

.sv-stat-n {
  background: linear-gradient(180deg, #fff, #b8d4ec);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Service page primary button = blue accent */
.sv-page .btn-primary {
  background: linear-gradient(135deg, #0a7fd4 0%, #0660a0 100%) !important;
  box-shadow:
    0 6px 20px rgba(10,127,212,0.32),
    inset 0 1px 0 rgba(255,255,255,0.18) !important;
  transition: transform 0.35s var(--ease-out-quint), box-shadow 0.35s var(--ease-out-quint);
  position: relative;
  overflow: hidden;
}
.sv-page .btn-primary::before {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 60%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.22), transparent);
  transition: left 0.6s var(--ease-out-quint);
}
.sv-page .btn-primary:hover {
  transform: translateY(-2px);
  box-shadow:
    0 12px 32px rgba(10,127,212,0.45),
    inset 0 1px 0 rgba(255,255,255,0.22) !important;
}
.sv-page .btn-primary:hover::before { left: 130%; }

.sv-page .btn-ghost {
  background: linear-gradient(135deg, rgba(37,211,102,0.12), rgba(37,211,102,0.04)) !important;
  border: 1px solid rgba(37,211,102,0.32) !important;
  color: #fff;
  transition: transform 0.35s var(--ease-out-quint), background 0.35s var(--ease-out-quint), box-shadow 0.35s var(--ease-out-quint);
}
.sv-page .btn-ghost:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, rgba(37,211,102,0.22), rgba(37,211,102,0.08)) !important;
  box-shadow: 0 8px 20px rgba(37,211,102,0.18);
  border-color: rgba(37,211,102,0.5) !important;
}

/* Service tech dashboard polish */
.sv-hero-dashboard {
  box-shadow:
    0 32px 80px rgba(0,0,0,0.6),
    inset 0 1px 0 rgba(10,127,212,0.18) !important;
}

/* Service cards hover */
[class*="sv-card"],
.sv-step,
.sv-benq-card,
.sv-brand-card {
  transition:
    transform 0.45s var(--ease-out-quint),
    border-color 0.45s var(--ease-out-quint),
    box-shadow 0.45s var(--ease-out-quint),
    background 0.45s var(--ease-out-quint) !important;
}
.sv-step:hover,
.sv-benq-card:hover,
.sv-brand-card:hover {
  transform: translateY(-4px);
  border-color: rgba(10,127,212,0.4) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,0.4), 0 0 24px rgba(10,127,212,0.10);
}

.sv-pill {
  transition: transform 0.3s var(--ease-out-quint), background 0.3s var(--ease-out-quint);
}
.sv-pill:hover {
  transform: translateY(-1px);
  background: rgba(10,127,212,0.10);
}

.sv-benq-wordmark {
  background: linear-gradient(135deg, #fff 0%, #b8d4ec 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 4px 16px rgba(10,127,212,0.3));
}
.sv-benq-wordmark span {
  background: linear-gradient(135deg, #4cb5ff 0%, #0a7fd4 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Service form — premium input states */
.sv-input,
.sv-select,
.sv-textarea {
  transition:
    border-color 0.3s var(--ease-out-quint),
    background 0.3s var(--ease-out-quint),
    box-shadow 0.3s var(--ease-out-quint) !important;
}
.sv-input:focus,
.sv-select:focus,
.sv-textarea:focus {
  border-color: rgba(10,127,212,0.6) !important;
  box-shadow:
    0 0 0 3px rgba(10,127,212,0.12),
    inset 0 1px 0 rgba(255,255,255,0.04) !important;
}

.sv-submit {
  background: linear-gradient(135deg, #0a7fd4 0%, #0660a0 100%) !important;
  box-shadow:
    0 8px 24px rgba(10,127,212,0.32),
    inset 0 1px 0 rgba(255,255,255,0.18) !important;
  transition: transform 0.35s var(--ease-out-quint), box-shadow 0.35s var(--ease-out-quint) !important;
}
.sv-submit:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow:
    0 14px 32px rgba(10,127,212,0.45),
    inset 0 1px 0 rgba(255,255,255,0.22) !important;
}

/* ============================================================
   FOOTER REFINE
   ============================================================ */
.footer {
  background: linear-gradient(180deg, var(--surface-1) 0%, #050505 100%) !important;
  border-top: 1px solid var(--hairline);
}

/* ============================================================
   CONTACT FORM — INPUT POLISH
   ============================================================ */
.contact-form input,
.contact-form select,
.contact-form textarea {
  transition:
    border-color 0.3s var(--ease-out-quint),
    background 0.3s var(--ease-out-quint),
    box-shadow 0.3s var(--ease-out-quint) !important;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  border-color: rgba(229,9,20,0.5) !important;
  box-shadow:
    0 0 0 3px rgba(229,9,20,0.10),
    inset 0 1px 0 rgba(255,255,255,0.04) !important;
}

/* ============================================================
   REVEAL ANIMATIONS — REFINED
   ============================================================ */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 0.9s var(--ease-out-quint),
    transform 0.9s var(--ease-out-quint);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger children when parent reveals */
.reveal.visible > * {
  animation: childIn 0.7s var(--ease-out-quint) both;
}
.reveal.visible > *:nth-child(1) { animation-delay: 0.05s; }
.reveal.visible > *:nth-child(2) { animation-delay: 0.10s; }
.reveal.visible > *:nth-child(3) { animation-delay: 0.15s; }
.reveal.visible > *:nth-child(4) { animation-delay: 0.20s; }
.reveal.visible > *:nth-child(5) { animation-delay: 0.25s; }
.reveal.visible > *:nth-child(6) { animation-delay: 0.30s; }
@keyframes childIn {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* But don't break bento / grid items by overriding their layout transforms */
.reveal.visible > .cat-bento-grid,
.reveal.visible > .testimonials-grid,
.reveal.visible > .brands-bar,
.reveal.visible > .vp-layout,
.reveal.visible > .featured-header,
.reveal.visible > .featured-slider-inner,
.reveal.visible > .promo-content,
.reveal.visible > .section-header,
.reveal.visible > .vp-inner,
.reveal.visible > .cat-bento-inner { animation: none; opacity: 1; transform: none; }

/* ============================================================
   WHATSAPP FLOAT — REFINED
   ============================================================ */
.whatsapp-float {
  background: linear-gradient(135deg, #25d366 0%, #128c7e 100%) !important;
  box-shadow:
    0 10px 28px rgba(37,211,102,0.4),
    0 4px 8px rgba(37,211,102,0.2),
    inset 0 1px 0 rgba(255,255,255,0.18) !important;
  animation: waFloat 3s ease-in-out infinite;
}
@keyframes waFloat {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-4px); }
}
.whatsapp-float:hover {
  animation-play-state: paused;
  transform: scale(1.08);
  box-shadow:
    0 14px 36px rgba(37,211,102,0.5),
    0 6px 12px rgba(37,211,102,0.3) !important;
}

/* ============================================================
   TOAST — POLISH
   ============================================================ */
.toast {
  background: linear-gradient(135deg, var(--surface-3), var(--surface-2)) !important;
  border: 1px solid var(--hairline-strong) !important;
  box-shadow:
    0 16px 40px rgba(0,0,0,0.6),
    inset 0 1px 0 rgba(255,255,255,0.05) !important;
  backdrop-filter: blur(12px);
}
.toast::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, var(--red), var(--red-dark));
}

/* ============================================================
   CATALOG PAGE POLISH
   ============================================================ */
.cat-card-premium {
  background: linear-gradient(180deg, var(--surface-3), var(--surface-2)) !important;
  border: 1px solid var(--hairline) !important;
  transition:
    transform 0.45s var(--ease-out-quint),
    border-color 0.45s var(--ease-out-quint),
    box-shadow 0.45s var(--ease-out-quint) !important;
}
.cat-card-premium:hover {
  transform: translateY(-4px);
  border-color: rgba(229,9,20,0.32) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,0.45), 0 0 20px rgba(229,9,20,0.08);
}

/* ============================================================
   CATALOG — Category Header + Brand Pills Premium Upgrade
   ============================================================ */

/* Breadcrumb refined */
.cat-breadcrumb {
  border-bottom: 1px solid var(--hairline) !important;
  padding: 22px 0 20px !important;
}
.bc-home-link,
.bc-back-btn {
  background: rgba(255,255,255,0.02) !important;
  border-color: var(--hairline) !important;
  transition: all 0.3s var(--ease-out-quint) !important;
}
.bc-home-link:hover,
.bc-back-btn:hover {
  background: rgba(229,9,20,0.08) !important;
  border-color: rgba(229,9,20,0.45) !important;
  transform: translateY(-1px);
}
.bc-current {
  position: relative;
  padding: 5px 12px;
  background: linear-gradient(135deg, rgba(229,9,20,0.18), rgba(229,9,20,0.06));
  border: 1px solid rgba(229,9,20,0.3);
  border-radius: 100px;
  color: #fff !important;
  font-weight: 600;
  box-shadow: 0 4px 12px rgba(229,9,20,0.12);
}
.bc-sep { color: rgba(255,255,255,0.25) !important; }

/* Cat header icon — bigger, glowing presence */
.cat-header-icon-wrap {
  width: 64px !important;
  height: 64px !important;
  border-radius: 16px !important;
  background: linear-gradient(135deg, rgba(229,9,20,0.20), rgba(229,9,20,0.05)) !important;
  border: 1px solid rgba(229,9,20,0.32) !important;
  position: relative;
  box-shadow:
    0 8px 24px rgba(229,9,20,0.18),
    inset 0 1px 0 rgba(255,255,255,0.08);
  overflow: hidden;
}
.cat-header-icon-wrap::before {
  content: '';
  position: absolute;
  inset: -50%;
  background: conic-gradient(from 0deg, transparent 0deg, rgba(229,9,20,0.25) 90deg, transparent 180deg);
  animation: catIconSpin 6s linear infinite;
  opacity: 0.6;
}
.cat-header-icon-wrap::after {
  content: '';
  position: absolute;
  inset: 2px;
  border-radius: 14px;
  background: linear-gradient(135deg, #1a0608, #0a0203);
}
.cat-header-icon-wrap > * {
  position: relative;
  z-index: 1;
}
.cat-header-icon-wrap svg {
  filter: drop-shadow(0 2px 8px rgba(229,9,20,0.5));
  width: 32px; height: 32px;
}
@keyframes catIconSpin {
  to { transform: rotate(360deg); }
}

/* Cat header title — accent underline */
.cat-header-title {
  position: relative;
  display: inline-block;
  letter-spacing: 0.01em !important;
  background: linear-gradient(180deg, #fff 0%, #d4d4d4 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.cat-header-text {
  position: relative;
}
.cat-header-text::after {
  content: '';
  display: block;
  width: 48px;
  height: 3px;
  margin-top: 6px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--red), transparent);
  box-shadow: 0 0 12px rgba(229,9,20,0.45);
}
.cat-header-desc {
  color: rgba(255,255,255,0.5) !important;
  margin-top: 10px !important;
  font-size: 14px !important;
}

/* Cat header search/sort — refined */
.cat-header-controls .catalog-search-box,
.cat-header-controls select {
  background: rgba(255,255,255,0.03) !important;
  border: 1px solid var(--hairline) !important;
  transition: all 0.3s var(--ease-out-quint) !important;
}
.cat-header-controls .catalog-search-box:focus-within,
.cat-header-controls select:focus {
  border-color: rgba(229,9,20,0.5) !important;
  background: rgba(229,9,20,0.04) !important;
  box-shadow: 0 0 0 3px rgba(229,9,20,0.10) !important;
}

/* ── Brand pills — premium structured ──────────────────────────── */
.cat-brand-pills {
  gap: 8px !important;
  margin-bottom: 22px !important;
}

.brand-pill {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 8px 16px 8px 14px !important;
  font-family: var(--font-condensed, 'Barlow Condensed', sans-serif) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase !important;
  border-radius: 100px !important;
  background: rgba(255,255,255,0.025) !important;
  border: 1px solid var(--hairline) !important;
  color: rgba(255,255,255,0.62) !important;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition:
    transform 0.35s var(--ease-out-quint),
    background 0.35s var(--ease-out-quint),
    border-color 0.35s var(--ease-out-quint),
    box-shadow 0.35s var(--ease-out-quint),
    color 0.35s var(--ease-out-quint) !important;
}
.brand-pill .bp-label {
  line-height: 1;
}
.brand-pill .bp-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 18px;
  padding: 0 6px;
  border-radius: 9px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.48);
  transition: all 0.35s var(--ease-out-quint);
}
.brand-pill::before {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 60%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.10), transparent);
  transition: left 0.6s var(--ease-out-quint);
}
.brand-pill:hover {
  transform: translateY(-2px);
  background: rgba(229,9,20,0.07) !important;
  border-color: rgba(229,9,20,0.42) !important;
  color: #fff !important;
  box-shadow:
    0 8px 20px rgba(0,0,0,0.35),
    0 0 0 1px rgba(229,9,20,0.12);
}
.brand-pill:hover::before { left: 130%; }
.brand-pill:hover .bp-count {
  background: rgba(229,9,20,0.18);
  color: #fff;
}

/* Active state — gradient red w/ glow */
.brand-pill.active,
.brand-pill.active:hover {
  background: linear-gradient(135deg, var(--red) 0%, var(--red-dark) 100%) !important;
  border-color: var(--red) !important;
  color: #fff !important;
  box-shadow:
    0 8px 24px rgba(229,9,20,0.38),
    0 2px 4px rgba(229,9,20,0.20),
    inset 0 1px 0 rgba(255,255,255,0.18) !important;
  transform: translateY(-1px);
}
.brand-pill.active .bp-count,
.brand-pill.active:hover .bp-count {
  background: rgba(255,255,255,0.22);
  color: #fff;
}

/* "Todas" pill — distinct treatment */
.brand-pill--all {
  letter-spacing: 0.12em !important;
}
.brand-pill--all:not(.active) {
  background: linear-gradient(135deg, rgba(229,9,20,0.10), rgba(229,9,20,0.02)) !important;
  border-color: rgba(229,9,20,0.22) !important;
  color: rgba(255,255,255,0.82) !important;
}

/* Touch press feedback already in elevate.js — also for pills */
.brand-pill.is-pressed { transform: scale(0.96) !important; }

/* ── Results bar — chips + active filters ──────────────────────── */
.cat-results-bar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  padding: 14px 0 16px !important;
  margin-bottom: 14px !important;
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
}
.products-count {
  display: inline-flex !important;
  align-items: center !important;
  flex-wrap: wrap;
  gap: 10px !important;
  font-size: 12px !important;
  letter-spacing: 0.08em !important;
  color: rgba(255,255,255,0.55) !important;
}
.pc-num {
  font-family: var(--font-display, 'Bebas Neue', sans-serif);
  font-size: 18px;
  letter-spacing: 0.05em;
  color: #fff;
  margin-right: 2px;
}
.pc-sep {
  color: rgba(255,255,255,0.18);
  margin: 0 2px;
}

/* Active filter chips (removable) */
.pc-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px 4px 12px;
  border-radius: 100px;
  background: rgba(229,9,20,0.10);
  border: 1px solid rgba(229,9,20,0.30);
  color: #fff;
  font-family: var(--font-condensed, 'Barlow Condensed', sans-serif);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.3s var(--ease-out-quint);
}
.pc-chip:hover {
  background: rgba(229,9,20,0.18);
  border-color: rgba(229,9,20,0.5);
  transform: translateY(-1px);
}
.pc-chip--search {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.15);
}
.pc-chip--search:hover {
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.25);
}
.pc-chip-x {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  font-size: 13px;
  line-height: 1;
  color: #fff;
  margin-left: 2px;
}

/* Mobile-tighter brand pills */
@media (max-width: 600px) {
  .brand-pill {
    padding: 7px 12px 7px 11px !important;
    font-size: 11px !important;
  }
  .brand-pill .bp-count {
    min-width: 20px;
    height: 16px;
    font-size: 9px;
  }
  .cat-header-icon-wrap {
    width: 52px !important;
    height: 52px !important;
  }
  .cat-header-icon-wrap svg {
    width: 26px; height: 26px;
  }
}

/* Search input polish */
input[type="search"],
input[type="text"].search-input,
#searchInput, #catSearchInput {
  transition:
    border-color 0.3s var(--ease-out-quint),
    background 0.3s var(--ease-out-quint),
    box-shadow 0.3s var(--ease-out-quint) !important;
}
input[type="search"]:focus,
input[type="text"].search-input:focus,
#searchInput:focus, #catSearchInput:focus {
  border-color: rgba(229,9,20,0.5) !important;
  box-shadow:
    0 0 0 3px rgba(229,9,20,0.10) !important;
}

/* ============================================================
   PRODUCT DETAIL PAGE
   ============================================================ */
.detail-add-cart,
.detail-quote-btn,
.detail-buy-btn {
  background: linear-gradient(135deg, var(--red), var(--red-dark)) !important;
  box-shadow:
    0 8px 24px rgba(229,9,20,0.30),
    inset 0 1px 0 rgba(255,255,255,0.18) !important;
  transition: transform 0.3s var(--ease-out-quint), box-shadow 0.3s var(--ease-out-quint) !important;
}
.detail-add-cart:hover,
.detail-quote-btn:hover,
.detail-buy-btn:hover {
  transform: translateY(-2px);
  box-shadow:
    0 14px 32px rgba(229,9,20,0.45),
    inset 0 1px 0 rgba(255,255,255,0.22) !important;
}

/* Sticky panel polish */
.product-sticky-panel {
  background: linear-gradient(180deg, rgba(15,15,15,0.98), rgba(10,10,10,0.98)) !important;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid var(--hairline-strong);
  box-shadow: 0 -8px 24px rgba(0,0,0,0.5);
}

/* ============================================================
   CTX FLOAT BTN — REFINED
   ============================================================ */
.ctx-float-btn {
  background: linear-gradient(135deg, var(--surface-3), var(--surface-2)) !important;
  border: 1px solid var(--hairline-strong) !important;
  backdrop-filter: blur(12px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.5);
  transition: transform 0.3s var(--ease-out-quint), background 0.3s var(--ease-out-quint), border-color 0.3s var(--ease-out-quint) !important;
}
.ctx-float-btn:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, var(--surface-4), var(--surface-3)) !important;
  border-color: rgba(229,9,20,0.32) !important;
}

/* ============================================================
   ACCESSIBILITY — REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  body::before { display: none; }
  .hero-grid { animation: none !important; }
  .hero-glow, .hero-glow2 { animation: none !important; }
}

/* ============================================================
   MOBILE REFINEMENTS
   ============================================================ */
@media (max-width: 768px) {
  /* Disable expensive grain on mobile for performance */
  body::before { display: none; }

  /* Tighter hero spacing on mobile */
  .hhc-inner { padding: 24px 18px !important; }
  .hhc-title { font-size: clamp(38px, 12vw, 64px) !important; }
  .hhc-sub { font-size: 14px !important; }

  /* Hero CTAs full width on mobile */
  .hhc-ctas {
    flex-direction: column !important;
    gap: 10px !important;
  }
  .hhc-ctas > * { width: 100% !important; justify-content: center !important; }

  /* Bigger touch targets */
  .nav-cart,
  .hamburger {
    min-width: 44px !important;
    min-height: 44px !important;
  }

  /* Product card hover -> tap state on touch */
  .product-card:active {
    transform: scale(0.98) !important;
  }
  .cat-bento-card:active {
    transform: scale(0.98) !important;
  }

  /* Cards more compact */
  .product-card-body { padding: 12px 14px 14px !important; }
  .product-card-name { font-size: 14px !important; }
  .product-card-price { font-size: 17px !important; }

  /* Buttons in cards — bigger tap targets */
  .card-quote-modal-btn,
  .card-rent-btn,
  .card-add-btn {
    min-height: 36px !important;
    padding: 6px 10px !important;
  }

  /* Bento grid stays usable */
  .cat-bento-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }
  .bento-body { padding: 14px !important; }
  .bento-label { font-size: 15px !important; }
  .bento-sub { font-size: 11px !important; }

  /* Marquee speed up on mobile */
  .marquee-inner { animation-duration: 25s !important; }

  /* Testimonials full-width stack */
  .testimonials-grid {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  /* Brands bar wraps tighter */
  .brands-bar { gap: 8px !important; }
  .brand-pill { font-size: 11px !important; padding: 6px 12px !important; }

  /* Promo banner stack */
  .promo-content {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  .promo-visual { order: -1; }

  /* WhatsApp float — smaller on mobile */
  .whatsapp-float {
    width: 52px !important;
    height: 52px !important;
    bottom: 16px !important;
    right: 16px !important;
  }
  .wa-label { display: none !important; }

  /* Service hero — stack actions */
  .sv-hero-actions {
    flex-direction: column !important;
    gap: 10px !important;
  }
  .sv-hero-actions > * { width: 100% !important; justify-content: center !important; }

  /* Stats bar in service — 2x2 grid */
  .sv-stats-bar {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
  }

  /* Quote modal — better mobile fit */
  .qm-panel,
  .quote-modal-panel,
  .qm-modal-panel {
    max-height: 90dvh !important;
    border-radius: 16px 16px 0 0 !important;
    margin-top: auto;
  }

  /* Contact form layout */
  .contact-form .field-row {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
}

/* ============================================================
   ULTRA-WIDE / DESKTOP REFINEMENTS
   ============================================================ */
@media (min-width: 1400px) {
  .nav-inner,
  .hhc-inner,
  .cat-bento-inner,
  .vp-inner {
    max-width: 1440px;
  }
}

/* ============================================================
   PRINT (just in case)
   ============================================================ */
@media print {
  body::before,
  .whatsapp-float,
  .ctx-float-btn,
  .navbar,
  .footer,
  #quote-modal-container,
  .toast { display: none !important; }
}
