/* ═══════════════════════════════════════════════════════
   Apple iOS 26 Liquid Glass — matched to Figma reference
   ═══════════════════════════════════════════════════════ */

.liquid-glass-filter {
  filter: url(#liquid-distort);
}

.glass-panel {
  position: relative;
  background: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(2rem) saturate(200%) brightness(1.08);
  -webkit-backdrop-filter: blur(2rem) saturate(200%) brightness(1.08);
  border: 0.0625rem solid rgba(255, 255, 255, 0.45);
  box-shadow:
    inset 0 0.09375rem 0 rgba(255, 255, 255, 0.90),
    inset 0 -0.0625rem 0 rgba(0, 0, 0, 0.08),
    0 0.125rem 0.5rem rgba(0, 0, 0, 0.06),
    0 0.5rem 2rem rgba(0, 0, 0, 0.08),
    0 1.5rem 3rem rgba(0, 0, 0, 0.04);
  overflow: hidden;
}

.glass-panel::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 100% 45% at 50% 0%,
      rgba(255, 255, 255, 0.45) 0%,
      rgba(255, 255, 255, 0.12) 45%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.glass-panel::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 70% 30% at 50% 100%,
      rgba(255, 255, 255, 0.15) 0%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.glass-panel.on-light {
  background: rgba(255, 255, 255, 0.68);
  border-color: rgba(255, 255, 255, 0.80);
}

.ios26-liquid-pill {
  position: relative;
  background: rgba(255, 255, 255, 0.01);
  backdrop-filter: blur(1.25rem) saturate(180%);
  -webkit-backdrop-filter: blur(1.25rem) saturate(180%);
  border: 0.0625rem solid rgba(255, 255, 255, 0.1);
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.1),
    0 0.125rem 0.25rem rgba(0, 0, 0, 0.2);
  overflow: hidden;
}

.ios26-liquid-pill::marker {
  content: '';
}

.ios26-liquid-pill .ios26-liquid-pill__ring {
  position: absolute;
  top: 0.0625rem;
  left: 0.0625rem;
  right: 0.0625rem;
  bottom: 0.0625rem;
  border-radius: inherit;
  border: 0.0625rem solid rgba(255, 255, 255, 0.1);
  pointer-events: none;
  z-index: 2;
}

.ios26-liquid-pill::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 100% 45% at 50% 0%,
      rgba(255, 255, 255, 0.45) 0%,
      rgba(255, 255, 255, 0.12) 45%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.ios26-liquid-pill::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 70% 30% at 50% 100%,
      rgba(255, 255, 255, 0.15) 0%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.ios26-liquid-pill>* {
  position: relative;
  z-index: 2;
}

/* ── NAVBAR PILL: allow nav links to be visible (not clipped) on desktop ── */
#smart-navbar .ios26-liquid-pill {
  overflow: visible;
}

/* ── Restore the visual glass effect using a pseudo-clipping wrapper ── */
#smart-navbar .nav-pill-bg {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
}

#smart-navbar .nav-pill-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 100% 45% at 50% 0%,
      rgba(255, 255, 255, 0.45) 0%,
      rgba(255, 255, 255, 0.12) 45%,
      transparent 70%);
}

#smart-navbar .nav-pill-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 70% 30% at 50% 100%,
      rgba(255, 255, 0, 0.15) 0%,
      transparent 70%);
}

.glass-pill {
  position: relative;
  background: rgba(255, 255, 255, 0.01);
  backdrop-filter: blur(1.25rem) saturate(180%);
  -webkit-backdrop-filter: blur(1.25rem) saturate(180%);
  border: 0.0625rem solid rgba(255, 255, 255, 0.1);
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.1),
    0 0.125rem 0.25rem rgba(0, 0, 0, 0.2);
  overflow: hidden;
}

.glass-pill::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 100% 45% at 50% 0%,
      rgba(255, 255, 255, 0.45) 0%,
      rgba(255, 255, 255, 0.12) 45%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.glass-pill::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 70% 30% at 50% 100%,
      rgba(255, 255, 255, 0.15) 0%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.glass-pill>* {
  position: relative;
  z-index: 2;
}

.liquid-glass {
  position: relative;
  --lg-border-radius: 0.75rem;
  --lg-border-alpha: 0.28;
  --lg-fill-alpha: 0.08;
  --lg-blur: 1.125rem;
  --lg-sat: 145%;
  --lg-brightness: 1.05;
  --lg-contrast: 1.02;
  --lg-shadow: 0 0.625rem 1.75rem rgba(0, 0, 0, 0.22), 0 1.625rem 4rem rgba(0, 0, 0, 0.14);
  --lg-glow: 0 0 0 rgba(79, 70, 229, 0);
  border-radius: var(--lg-border-radius);
  background: rgba(255, 255, 255, var(--lg-fill-alpha));
  backdrop-filter: blur(var(--lg-blur)) saturate(var(--lg-sat)) brightness(var(--lg-brightness)) contrast(var(--lg-contrast));
  -webkit-backdrop-filter: blur(var(--lg-blur)) saturate(var(--lg-sat)) brightness(var(--lg-brightness)) contrast(var(--lg-contrast));
  border: 0.0625rem solid rgba(255, 255, 255, var(--lg-border-alpha));
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.55),
    inset 0 -0.0625rem 0 rgba(0, 0, 0, 0.10),
    var(--lg-shadow),
    var(--lg-glow);
  overflow: hidden;
}

.liquid-glass::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 120% 70% at 50% -10%,
      rgba(255, 255, 255, 0.40) 0%,
      rgba(255, 255, 255, 0.12) 32%,
      rgba(255, 255, 255, 0.06) 48%,
      transparent 72%);
  pointer-events: none;
  z-index: 2;
}

.liquid-glass::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    radial-gradient(ellipse 70% 26% at 50% 110%,
      rgba(255, 255, 255, 0.12) 0%,
      transparent 68%),
    repeating-linear-gradient(45deg,
      rgba(255, 255, 255, 0.035) 0px,
      rgba(255, 255, 255, 0.035) 1px,
      rgba(255, 255, 255, 0.00) 2px,
      rgba(255, 255, 255, 0.00) 4px);
  opacity: 0.55;
  mix-blend-mode: overlay;
  pointer-events: none;
  z-index: 2;
}

.liquid-glass>* {
  position: relative;
  z-index: 3;
}

.liquid-glass {
  transform: translateZ(0);
  will-change: transform;
}

.liquid-glass.rim-sheen {
  border-color: rgba(255, 255, 255, 0.32);
}

.liquid-glass.rim-sheen:focus-within,
.liquid-glass.rim-sheen:hover {
  --lg-fill-alpha: 0.09;
  --lg-glow: 0 0.875rem 2.75rem rgba(79, 70, 229, 0.12);
}

.liquid-glass.lg-shadow-sm {
  --lg-shadow: 0 0.5rem 1.375rem rgba(0, 0, 0, 0.20), 0 1.375rem 3.625rem rgba(0, 0, 0, 0.12);
}

.liquid-glass.lg-glow-sm {
  --lg-glow: 0 0.875rem 2.75rem rgba(79, 70, 229, 0.10);
}

.crystal-glass {
  position: relative;
  background: rgba(255, 255, 255, 0.35);
  backdrop-filter: blur(1rem) saturate(160%) brightness(1.02);
  -webkit-backdrop-filter: blur(1rem) saturate(160%) brightness(1.02);
  border: 0.0625rem solid rgba(255, 255, 255, 0.65);
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.90),
    inset 0 -0.0625rem 0 rgba(0, 0, 0, 0.04),
    0 0.125rem 0.5rem rgba(0, 0, 0, 0.05),
    0 0.5rem 1.5rem rgba(0, 0, 0, 0.07);
  overflow: hidden;
  transform: translateZ(0);
  -webkit-transform: translateZ(0);
  -webkit-mask-image: -webkit-radial-gradient(white, black);

  /* ═══════════════════ ADD THESE CODES TO RESOLVE THE ARTIFACT ═══════════════════ */
  outline: 0.0625rem solid transparent;
  /* Forces Chrome to antialias the outer border-box smoothly */
  backface-visibility: hidden;
  /* Promote to GPU rasterization to eliminate subpixel shift */
  -webkit-backface-visibility: hidden;
  background-clip: padding-box;
  /* Clips background colors precisely within the border boundary */
  -webkit-background-clip: padding-box;
}

.crystal-glass img {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  outline: 0.0625rem solid transparent;
}

.crystal-glass::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 100% 35% at 50% 0%,
      rgba(255, 255, 255, 0.40) 0%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.glass-panel,
.liquid-glass,
.crystal-glass {
  transition: background 0.15s ease-out, border-color 0.15s ease-out, box-shadow 0.15s ease-out;
}

.glass-panel input {
  background: transparent;
}

.section-container {
  max-width: 75rem;
  /* 1200px */
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.5rem;
  /* 24px */
  padding-right: 1.5rem;
  /* 24px */
}

.hero-container-wide {
  width: 100%;
  max-width: 90rem;
  /* 1440px */
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.5rem;
  /* 24px */
  padding-right: 1.5rem;
  /* 24px */
}

@media (min-width: 48rem) {
  .hero-container-wide {
    padding-left: 2rem;
    /* 32px */
    padding-right: 2rem;
    /* 32px */
  }
}

@media (min-width: 80rem) {
  .hero-container-wide {
    padding-left: 3rem;
    /* 48px */
    padding-right: 3rem;
    /* 48px */
  }
}

/* ═════ RESPONSIVE BANNER SIZE & PADDING UPDATES ═════ */
.hero-banner {
  position: relative;
  width: 100%;
  border-radius: 1.25rem;
  /* 20px */
  overflow: hidden;
  height: calc(100vh - 5.5rem);
  /* 88px */
  min-height: 26.25rem;
  /* 420px */
}

@media (max-width: 47.9375rem) {
  .hero-banner {
    height: 85vh;
    height: 85svh;
    min-height: auto;
    max-height: none;
    border-radius: 1.5rem;
    /* 24px */
  }

  .hero-container-wide {
    padding-left: 0.75rem;
    /* 12px */
    padding-right: 0.75rem;
    /* 12px */
  }
}

@media (min-width: 64rem) {
  .hero-banner {
    height: calc(100vh - 6.25rem);
    /* 100px */
    border-radius: 1.5rem;
    /* 24px */
    min-height: 32.5rem;
    /* 520px */
  }
}

/* ── Mobile Deck & Soft Page Lock System Ruleset  ── */
@media (max-width: 63.9375rem) {
  .mobile-deck-wrapper {
    position: relative;
    height: 26rem;
    width: 100%;
    max-width: 23.75rem;
    /* 380px */
    margin: 0 auto;
    perspective: 75rem;
    /* 1200px */
  }
}

/* Fades out text/buttons on inactive stacked background cards to prevent glass transparency overlap */
.mobile-deck-wrapper .deck-back-card>* {
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity 0.35s ease;
}

.hero-gradient-text {
  background: linear-gradient(135deg, #4f46e5 0%, #a855f7 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

::-webkit-scrollbar {
  width: 0.25rem;
  /* 4px */
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: #e2e8f0;
  border-radius: 6.1875rem;
  /* 99px */
}

.hover-lift {
  transition: transform .25s ease, box-shadow .25s ease;
}

.hover-lift:hover {
  transform: translateY(-0.1875rem);
  /* -3px */
}

.deck-card-item,
.deck-card-item * {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(1.25rem);
    /* 20px */
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.fade-up {
  animation: fadeUp .5s ease both;
}

.d1 {
  animation-delay: .1s;
}

.d2 {
  animation-delay: .2s;
}

.d3 {
  animation-delay: .3s;
}

/* ── Nav height compensation ── */
.nav-offset {
  padding-top: 5rem;
  /* 80px */
}

@media (max-width: 47.9375rem) {
  .nav-offset {
    padding-top: 4.75rem;
    /* 76px */
  }
}

@media (min-width: 64rem) {
  .nav-offset {
    padding-top: 5.25rem;
    /* 84px */
  }
}

[data-staggered-item] {
  opacity: 0;
  transform: translateY(2.5rem);
  /* 40px */
  transition: opacity 1s cubic-bezier(0.25, 0.1, 0.25, 1), transform 1s cubic-bezier(0.25, 0.1, 0.25, 1);
  will-change: opacity, transform;
}

[data-staggered-item].is-visible {
  opacity: 1;
  transform: translateY(0);
}

#smart-cta.text-light-mode .cta-title {
  color: #ffffff;
}

#smart-cta.text-light-mode .cta-sub {
  color: rgba(255, 255, 255, 0.85);
}

#smart-cta.text-light-mode .cta-divider {
  border-color: rgba(255, 255, 255, 0.25);
}

#smart-cta.text-dark-mode .cta-title {
  color: #000000;
}

#smart-cta.text-dark-mode .cta-sub {
  color: #334155;
}

#smart-cta.text-dark-mode .cta-divider {
  border-color: rgba(100, 116, 139, 0.20);
}

/* ── MODERN PAGINATION DOTS ── */
.hero-dot {
  width: 0.4375rem;
  /* 7px */
  height: 0.4375rem;
  /* 7px */
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.04);
  border: 0.0625rem solid rgba(230, 200, 255, 0.72);
  /* 1px */
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.20),
    0 0.0625rem 0.1875rem rgba(0, 0, 0, 0.20);
  /* 1px 3px */
  cursor: pointer;
  transition:
    width 0.28s cubic-bezier(0.25, 1, 0.5, 1),
    background-color 0.28s ease,
    border-color 0.28s ease,
    box-shadow 0.28s ease,
    transform 0.28s ease;
  position: relative;
  flex: 0 0 auto;
  outline: none;
  overflow: hidden;
  padding: 0;
  backdrop-filter: blur(0.5rem);
  -webkit-backdrop-filter: blur(0.5rem);
}

.hero-dot:hover {
  background: rgba(255, 255, 255, 0.10);
  border-color: rgba(238, 214, 255, 0.85);
  transform: translateY(-0.03125rem);
}

.hero-dot.active {
  width: 1.875rem;
  /* 30px */
  background: linear-gradient(180deg, rgba(222, 179, 255, 0.42), rgba(131, 74, 141, 0.20));
  border: 0.0625rem solid rgba(238, 214, 255, 0.58);
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.28),
    0 0.125rem 0.375rem rgba(0, 0, 0, 0.24);
}

.hero-dot.active::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 100% 55% at 50% 0%,
      rgba(255, 255, 255, 0.52) 0%,
      rgba(255, 255, 255, 0.10) 45%,
      transparent 72%);
  pointer-events: none;
  z-index: 1;
}

.hero-dot.active::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 72% 35% at 50% 100%,
      rgba(255, 255, 255, 0.22) 0%,
      transparent 74%);
  pointer-events: none;
  z-index: 1;
}

@media (max-width: 48rem) {
  .hero-dot {
    width: 0.375rem;
    /* 6px */
    height: 0.375rem;
    /* 6px */
    border-width: 0.0625rem;
    /* 1px */
  }

  .hero-dot.active {
    width: 1.625rem;
    /* 26px */
  }
}

/* ── Mobile menu drawer (liquid glass) ── */
#mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 200;
  pointer-events: none;
  visibility: hidden;
  transition: visibility 0s linear 0.40s;
}

#mobile-menu.open {
  pointer-events: all;
  visibility: visible;
  transition-delay: 0s;
}

#mobile-menu.closing {
  pointer-events: none;
  visibility: visible;
  transition-delay: 0s;
}

#mobile-menu-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(0.25rem);
  /* 4px */
  -webkit-backdrop-filter: blur(0.25rem);
  opacity: 0;
  transition: opacity 0.40s cubic-bezier(0.25, 1, 0.3, 1);
}

#mobile-menu.open #mobile-menu-backdrop {
  opacity: 1;
}

#mobile-menu.closing #mobile-menu-backdrop {
  opacity: 0;
}

#mobile-menu-panel {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 80%;
  max-width: 20rem;
  /* 320px */
  transform: translateX(100%);
  transition: transform 0.40s cubic-bezier(0.25, 1, 0.3, 1);
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(1.25rem) saturate(180%);
  -webkit-backdrop-filter: blur(1.25rem) saturate(180%);
  border-left: 0.0625rem solid rgba(255, 255, 255, 0.1);
  box-shadow:
    inset 0.0625rem 1px 0 rgba(255, 255, 255, 0.1),
    -0.25rem 0 2rem rgba(0, 0, 0, 0.25);
  overflow: hidden;
}

#mobile-menu-panel::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 100% 45% at 50% 0%,
      rgba(255, 255, 255, 0.45) 0%,
      rgba(255, 255, 255, 0.12) 45%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

#mobile-menu-panel::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 30% at 50% 100%,
      rgba(255, 255, 255, 0.15) 0%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

#mobile-menu-panel>* {
  position: relative;
  z-index: 2;
}

#mobile-menu.open #mobile-menu-panel {
  transform: translateX(0);
}

#mobile-menu.closing #mobile-menu-panel {
  transform: translateX(100%);
}

/* ══════════════════════════════════════════════════
   BRAND GLOW SEARCH BAR — Desktop Nav
   ══════════════════════════════════════════════════ */

.glow-search-wrap {
  position: relative;
  border-radius: 6.1875rem;
  /* 99px */
}

.glow-search-wrap .glow-search-inner {
  position: relative;
  z-index: 1;
  border-radius: inherit;
}

.glow-search-wrap input {
  transition: box-shadow 0.35s cubic-bezier(0.25, 1, 0.5, 1), border-color 0.35s ease;
}

.glow-search-wrap:focus-within input {
  border-color: transparent !important;
  box-shadow:
    0 0 0 0.0625rem rgba(255, 255, 255, 0.5),
    0 0 0.625rem 0.125rem rgba(255, 255, 255, 0.4),
    0 0 1.125rem 0.25rem rgba(70, 70, 175, 0.4);
  outline: none;
}

/* ══════════════════════════════════════════════════
   BRAND GLOW SEARCH BAR — Mobile Sidebar
   ══════════════════════════════════════════════════ */

.mobile-glow-search-wrap {
  position: relative;
  border-radius: 6.1875rem;
  /* 99px */
}

.mobile-glow-search-wrap .mobile-glow-inner {
  position: relative;
  z-index: 1;
  border-radius: inherit;
}

#mobile-menu-search {
  background: rgba(255, 255, 255, 0.12);
  border: 0.0625rem solid rgba(255, 255, 255, 0.2);
  border-radius: 6.1875rem;
  /* 99px */
  padding: 0.625rem 1rem 0.625rem 2.5rem;
  /* 10px 16px 10px 40px */
  color: #fff;
  font-size: 0.875rem;
  /* 14px */
  width: 100%;
  outline: none;
  transition: box-shadow 0.35s cubic-bezier(0.25, 1, 0.5, 1), border-color 0.35s ease;
}

#mobile-menu-search::placeholder {
  color: rgba(255, 255, 255, 0.5);
}

#mobile-menu-search:focus {
  border-color: transparent !important;
  box-shadow:
    0 0 0 0.0625rem rgba(255, 255, 255, 0.3),
    0 0 0.625rem 0.1875rem rgba(255, 255, 255, 0.25),
    0 0 1.375rem 0.375rem rgba(70, 70, 175, 0.5);
}

/* ══════════════════════════════════════════════════
   BRAND GLOW SEARCH BAR — Hero Section
   ══════════════════════════════════════════════════ */

.hero-search-wrap {
  position: relative;
  border-radius: 6.1875rem;
  /* 99px */
  transition: box-shadow 0.35s cubic-bezier(0.25, 1, 0.5, 1), border-color 0.35s ease !important;

  box-shadow:
    0 0 0 0.0625rem rgba(255, 255, 255, 0),
    0 0 0.625rem 0.125rem rgba(255, 255, 255, 0),
    0 0 1.125rem 0.25rem rgba(70, 70, 175, 0),
    inset 0 0.09375rem 0 rgba(255, 255, 255, 0.70),
    inset 0 -0.0625rem 0 rgba(0, 0, 0, 0.0),
    0 0.125rem 0.375rem rgba(0, 0, 0, 0.03),
    0 0.375rem 1.25rem rgba(0, 0, 0, 0.04),
    0 1.25rem 2.5rem rgba(0, 0, 0, 0.02) !important;
}

.hero-search-wrap:focus-within {
  border-color: transparent !important;
  box-shadow:
    0 0 0 0.0625rem rgba(255, 255, 255, 0.5),
    0 0 0.625rem 0.125rem rgba(255, 255, 255, 0.4),
    0 0 1.125rem 0.25rem rgba(70, 70, 175, 0.4),
    inset 0 0.09375rem 0 rgba(255, 255, 255, 0.70),
    inset 0 -0.0625rem 0 rgba(0, 0, 0, 0.0),
    0 0.125rem 0.375rem rgba(0, 0, 0, 0.03),
    0 0.375rem 1.25rem rgba(0, 0, 0, 0.04),
    0 1.25rem 2.5rem rgba(0, 0, 0, 0.02) !important;
}

.hero-search-wrap.glass-panel {
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.70),
    inset 0 -0.0625rem 0 rgba(0, 0, 0, 0),
    0 0.25rem 1rem rgba(0, 0, 0, 0.04),
    0 0.75rem 2rem rgba(0, 0, 0, 0.03);
  border: 0.0625rem solid rgba(255, 255, 255, 0.35);
}

.mobile-nav-link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  /* 12px */
  padding: 0.875rem 0;
  /* 14px */
  font-size: 1rem;
  /* 16px */
  font-weight: 600;
  color: rgba(255, 255, 255, 0.92);
  border-bottom: 0.0625rem solid rgba(255, 255, 255, 0.08);
  /* 1px */
  transition: color 0.2s;
  text-decoration: none;
}

.mobile-nav-link:last-child {
  border-bottom: none;
}

.mobile-nav-link:active {
  color: #fff;
}

.mobile-nav-link .mat-icon {
  font-size: 1.25rem;
  /* 20px */
  opacity: 0.7;
  font-family: 'Material Symbols Outlined';
  font-weight: 300;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  font-feature-settings: 'liga';
}

/* Section container mobile padding */
@media (max-width: 47.9375rem) {
  .section-container {
    padding-left: 1rem;
    /* 16px */
    padding-right: 1rem;
    /* 16px */
  }
}

/* ── SIZE SELECTOR SCROLL ── */
.size-scroll-row {
  display: flex;
  gap: 0.1875rem;
  /* 3px */
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  flex-wrap: nowrap;
  padding-bottom: 0.0625rem;
  /* 1px */
}

.size-scroll-row::-webkit-scrollbar {
  display: none;
}

/* Size button base */
.size-btn {
  flex-shrink: 0;
  height: 1.625rem;
  /* 26px */
  padding: 0 0.375rem;
  /* 6px */
  min-width: 1.75rem;
  /* 28px */
  background: #fff;
  border: 0.0625rem solid rgba(203, 213, 225, 0.8);
  /* 1px */
  color: #64748b;
  border-radius: 0.4375rem;
  /* 7px */
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  transition: all 0.18s ease;
  box-shadow: 0 0.0625rem 0.125rem rgba(0, 0, 0, 0.015);
  /* 1px 2px */
  outline: none;
}

.size-btn:hover {
  border-color: rgba(79, 70, 229, 0.35);
  color: #4f46e5;
  background: rgba(79, 70, 229, 0.04);
}

.size-btn.active {
  background: rgba(79, 70, 229, 0.1);
  border-color: #4f46e5;
  color: #4f46e5;
  box-shadow: 0 0.0625rem 0.25rem rgba(79, 70, 229, 0.12);
  /* 1px 4px */
}

.size-btn .size-label {
  font-size: 0.53125rem;
  /* 8.5px */
  line-height: 1;
  margin-bottom: 0.0625rem;
  /* 1px */
  display: block;
  letter-spacing: -0.01em;
}

.size-btn .size-cat {
  font-size: 0.25rem;
  /* 4px */
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  opacity: 0.6;
  border-top: 0.0625rem solid rgba(203, 213, 225, 0.8);
  /* 1px */
  display: block;
  padding-top: 0.0625rem;
  /* 1px */
  line-height: 0.5;
  width: 100%;
  text-align: center;
}

.size-btn.active .size-cat {
  border-color: rgba(79, 70, 229, 0.2);
  opacity: 0.8;
}

/* ══════════════════════════════════════════════════
   SPEC SELECTOR — selectable pill buttons for specs
   ══════════════════════════════════════════════════ */
.spec-selector-row {
  display: flex;
  gap: 0.5rem;
  /* 8px */
  align-items: center;
  justify-content: flex-start;
  flex-wrap: nowrap;
  padding-bottom: 0.0625rem;
  /* 1px */
  overflow: visible;
}

.spec-selector-row::-webkit-scrollbar {
  display: none;
}

.spec-sel-btn {
  min-width: 0;
  flex: 1 1 0%;
  height: 1.8125rem !important;
  /* 29px */
  padding: 0 0.625rem !important;
  /* 10px */
  background: #fff;
  border: 0.09375rem solid rgba(203, 213, 225, 0.8);
  /* 1.5px */
  color: #64748b;
  border-radius: 6.1875rem;
  /* 99px */
  font-family: 'Outfit', sans-serif;
  font-size: 0.5rem !important;
  /* 8px */
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.18s ease;
  outline: none;
  white-space: nowrap;
  position: relative;
}

.spec-sel-btn:hover {
  border-color: rgba(79, 70, 229, 0.35);
  background: rgba(79, 70, 229, 0.04);
  transform: translateY(-0.03125rem);
  /* -0.5px */
}

.spec-sel-btn.active {
  background: rgba(79, 70, 229, 0.08);
  border-color: #4f46e5;
  box-shadow: 0 0.0625rem 0.375rem rgba(79, 70, 229, 0.15);
  /* 1px 6px */
}

.spec-sel-btn .series-icon-img {
  height: 0.78125rem;
  /* 12.5px */
  width: auto;
  max-width: 100%;
  display: block;
  object-fit: contain;
  margin: 0 auto;
  pointer-events: none;
  transition: transform 0.2s ease;
}

.spec-sel-btn[data-value="mgweave"] .series-icon-img {
  height: 0.59375rem;
  /* 9.5px */
  transform: scale(1.1);
}

.spec-sel-btn[data-value="mgglide"] .series-icon-img {
  height: 1.0625rem;
  /* 17px */
  margin-bottom: 0.0625rem;
  /* 1px */
  transform: scale(0.98);
}

.spec-sel-btn .series-new-badge {
  position: absolute;
  top: -1rem;
  /* -16px */
  right: -0.3125rem;
  /* -5px */
  width: 1.75rem;
  /* 28px */
  height: 1.75rem;
  /* 28px */
  display: block;
  pointer-events: none;
  z-index: 10;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.25s ease;
  transform: translateY(0);
  opacity: 0.75;
}

.spec-sel-btn.active .series-new-badge {
  transform: translateY(-0.375rem) translateX(0.125rem);
  /* -6px 2px */
  opacity: 1;
}

/* ═══════════════════════════════════════════════════════
   TOOLTIP SYSTEM
   ═══════════════════════════════════════════════════════ */

.spec-info-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 0.6875rem;
  /* 11px */
  height: 0.6875rem;
  /* 11px */
  border-radius: 50%;
  background: rgba(100, 116, 139, 0.12);
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  flex-shrink: 0;
  transition: background 0.15s ease;
  pointer-events: auto;
  position: relative;
  z-index: 10;
}

.spec-info-btn:hover,
.spec-info-btn.active-tip {
  background: rgba(79, 70, 229, 0.15);
}

.spec-info-btn .spec-info-icon {
  font-size: 0.5rem;
  /* 8px */
  color: #64748b;
  line-height: 1;
  font-family: 'Material Symbols Outlined';
  font-weight: 400;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  font-feature-settings: 'liga';
  user-select: none;
}

.spec-info-btn.active-tip .spec-info-icon {
  color: #4f46e5;
}

.spec-tooltip {
  position: absolute;
  bottom: calc(100% + 0.5rem);
  /* 8px */
  left: 50%;
  transform: translateX(-50%) translateY(0.25rem);
  /* 4px */
  min-width: 8.75rem;
  /* 140px */
  max-width: 12.5rem;
  /* 200px */
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(1.25rem) saturate(180%);
  /* 20px */
  -webkit-backdrop-filter: blur(1.25rem) saturate(180%);
  border: 0.0625rem solid rgba(255, 255, 255, 0.80);
  /* 1px */
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.90),
    0 0.25rem 1rem rgba(0, 0, 0, 0.10),
    0 0.75rem 2rem rgba(0, 0, 0, 0.08);
  border-radius: 0.75rem;
  /* 12px */
  padding: 0.5rem 0.625rem;
  /* 8px 10px */
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.18s ease, transform 0.18s ease;
  z-index: 100;
  white-space: normal;
}

.spec-tooltip.tip-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: none;
}

.spec-tooltip::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 0.3125rem solid transparent;
  /* 5px */
  border-top-color: rgba(255, 255, 255, 0.92);
}

.spec-tooltip-title {
  font-family: 'Outfit', sans-serif;
  font-size: 0.5625rem;
  /* 9px */
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #4f46e5;
  margin-bottom: 0.1875rem;
  /* 3px */
  display: block;
}

.spec-tooltip-body {
  font-family: 'Outfit', sans-serif;
  font-size: 0.625rem;
  /* 10px */
  font-weight: 500;
  color: #475569;
  line-height: 1.4;
  display: block;
}

.spec-tag-wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.125rem;
  /* 2px */
}

/* ── SPEC GROUP ── */
.spec-group {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  /* 2px */
  flex-shrink: 0;
  padding-right: 0.5rem;
  /* 8px */
  margin-right: 0.5rem;
  /* 8px */
  border-right: 0.0625rem solid rgba(226, 232, 240, 0.7);
  /* 1px */
}

.spec-group:last-child {
  border-right: none;
  padding-right: 0;
  margin-right: 0;
}

.spec-group-label {
  display: flex;
  align-items: center;
  gap: 0.125rem;
  /* 2px */
  color: #64748b;
}

/* Series badge */
.series-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.1875rem;
  /* 3px */
  padding: 0.125rem 0.4375rem 0.125rem 0.3125rem;
  /* 2px 7px 2px 5px */
  border-radius: 6.1875rem;
  /* 99px */
  font-family: 'Outfit', sans-serif;
  font-size: 0.5rem;
  /* 8px */
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  cursor: pointer;
  border: none;
  outline: none;
  transition: all 0.15s ease;
  pointer-events: auto;
  position: relative;
  z-index: 10;
  line-height: 1;
}

.series-badge.mgweave {
  background: rgba(245, 158, 11, 0.10);
  color: #b45309;
  border: 0.0625rem solid rgba(245, 158, 11, 0.20);
  /* 1px */
}

.series-badge.mgweave:hover,
.series-badge.mgweave.active-tip {
  background: rgba(245, 158, 11, 0.18);
}

.series-badge.mgglide {
  background: rgba(79, 70, 229, 0.10);
  color: #4f46e5;
  border: 0.0625rem solid rgba(79, 70, 229, 0.20);
  /* 1px */
}

.series-badge.mgglide:hover,
.series-badge.mgglide.active-tip {
  background: rgba(79, 70, 229, 0.18);
}

.series-badge .series-dot {
  width: 0.25rem;
  /* 4px */
  height: 0.25rem;
  /* 4px */
  border-radius: 50%;
  flex-shrink: 0;
}

.series-badge.mgweave .series-dot {
  background: #b45309;
}

.series-badge.mgglide .series-dot {
  background: #4f46e5;
}

/* Series tooltip */
.series-tooltip {
  position: absolute;
  bottom: calc(100% + 0.5rem);
  /* 8px */
  left: 0;
  min-width: 10rem;
  /* 160px */
  max-width: 12.5rem;
  /* 200px */
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(1.25rem) saturate(180%);
  /* 20px */
  -webkit-backdrop-filter: blur(1.25rem) saturate(180%);
  border: 0.0625rem solid rgba(255, 255, 255, 0.85);
  /* 1px */
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.90),
    0 0.25rem 1rem rgba(0, 0, 0, 0.10),
    0 0.75rem 2rem rgba(0, 0, 0, 0.08);
  border-radius: 0.75rem;
  /* 12px */
  padding: 0.5625rem 0.6875rem;
  /* 9px 11px */
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.18s ease, transform 0.18s ease;
  transform: translateY(0.25rem);
  /* 4px */
  z-index: 100;
}

.series-tooltip.tip-visible {
  opacity: 1;
  transform: translateY(0);
}

.series-tooltip::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 0.875rem;
  /* 14px */
  border: 0.3125rem solid transparent;
  /* 5px */
  border-top-color: rgba(255, 255, 255, 0.95);
}

.series-tooltip-name {
  font-family: 'Outfit', sans-serif;
  font-size: 0.5625rem;
  /* 9px */
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 0.1875rem;
  /* 3px */
  display: block;
}

.series-tooltip-name.mgweave {
  color: #b45309;
}

.series-tooltip-name.mgglide {
  color: #4f46e5;
}

.series-tooltip-desc {
  font-family: 'Outfit', sans-serif;
  font-size: 0.625rem;
  /* 10px */
  font-weight: 500;
  color: #475569;
  line-height: 1.4;
  display: block;
}

/* Size info tooltip */
.size-info-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.125rem;
  /* 2px */
  font-family: 'Outfit', sans-serif;
  font-size: 0.5rem;
  /* 8px */
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: #64748b;
  opacity: 0.80;
  cursor: pointer;
  border: none;
  background: none;
  outline: none;
  padding: 0;
  flex-shrink: 0;
  width: 1.625rem;
  /* 26px */
  pointer-events: auto;
  transition: color 0.15s;
  position: relative;
  z-index: 10;
}

.size-info-btn:hover {
  color: #4f46e5;
  opacity: 1;
}

.size-info-btn.active-tip {
  color: #4f46e5;
  opacity: 1;
}

.size-tooltip {
  position: absolute;
  bottom: calc(100% + 0.5rem);
  /* 8px */
  left: -0.25rem;
  /* -4px */
  min-width: 10.625rem;
  /* 170px */
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(1.25rem) saturate(180%);
  -webkit-backdrop-filter: blur(1.25rem) saturate(180%);
  border: 0.0625rem solid rgba(255, 255, 255, 0.85);
  /* 1px */
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.90),
    0 0.25rem 1rem rgba(0, 0, 0, 0.10),
    0 0.75rem 2rem rgba(0, 0, 0, 0.08);
  border-radius: 0.75rem;
  /* 12px */
  padding: 0.5625rem 0.625rem;
  /* 9px 10px */
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.18s ease, transform 0.18s ease;
  transform: translateY(0.25rem);
  /* 4px */
  z-index: 100;
}

.size-tooltip.tip-visible {
  opacity: 1;
  transform: translateY(0);
}

.size-tooltip::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 0.75rem;
  /* 12px */
  border: 0.3125rem solid transparent;
  /* 5px */
  border-top-color: rgba(255, 255, 255, 0.95);
}

.size-tooltip-title {
  font-family: 'Outfit', sans-serif;
  font-size: 0.5rem;
  /* 8px */
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #4f46e5;
  margin-bottom: 0.3125rem;
  /* 5px */
  display: block;
}

.size-tooltip table {
  width: 100%;
  border-collapse: collapse;
}

.size-tooltip td {
  font-family: 'Outfit', sans-serif;
  font-size: 0.59375rem;
  /* 9.5px */
  font-weight: 600;
  color: #334155;
  padding: 0.125rem 0;
  /* 2px */
  line-height: 1.3;
}

.size-tooltip td:first-child {
  color: #64748b;
  font-weight: 700;
  padding-right: 0.5rem;
  /* 8px */
  white-space: nowrap;
}

/* Generic spec tooltip */
.spec-tip {
  position: absolute;
  bottom: calc(100% + 0.5rem);
  /* 8px */
  left: 50%;
  transform: translateX(-50%) translateY(0.25rem);
  /* 4px */
  min-width: 8.75rem;
  /* 140px */
  max-width: 12.5rem;
  /* 200px */
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(1.25rem) saturate(180%);
  -webkit-backdrop-filter: blur(1.25rem) saturate(180%);
  border: 0.0625rem solid rgba(255, 255, 255, 0.85);
  /* 1px */
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.90),
    0 0.25rem 1rem rgba(0, 0, 0, 0.10),
    0 0.75rem 2rem rgba(0, 0, 0, 0.08);
  border-radius: 0.75rem;
  /* 12px */
  padding: 0.5rem 0.625rem;
  /* 8px 10px */
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.18s ease, transform 0.18s ease;
  z-index: 200;
  white-space: normal;
}

.spec-tip.tip-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.spec-tip::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 0.3125rem solid transparent;
  /* 5px */
  border-top-color: rgba(255, 255, 255, 0.95);
}

.spec-tip-title {
  font-family: 'Outfit', sans-serif;
  font-size: 0.5625rem;
  /* 9px */
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #4f46e5;
  margin-bottom: 0.1875rem;
  /* 3px */
  display: block;
}

.spec-tip-body {
  font-family: 'Outfit', sans-serif;
  font-size: 0.625rem;
  /* 10px */
  font-weight: 500;
  color: #475569;
  line-height: 1.4;
  display: block;
}

/* Button tooltips (Customize / Preview) */
.btn-tooltip-wrap {
  position: relative;
  display: flex;
  flex: 1;
}

.btn-tooltip-wrap .btn-tooltip {
  position: absolute;
  bottom: calc(100% + 0.375rem);
  /* 6px */
  left: 50%;
  transform: translateX(-50%) translateY(0.1875rem);
  /* 3px */
  background: rgba(15, 23, 42, 0.88);
  backdrop-filter: blur(0.75rem);
  /* 12px */
  -webkit-backdrop-filter: blur(0.75rem);
  border-radius: 0.5rem;
  /* 8px */
  padding: 0.3125rem 0.5625rem;
  /* 5px 9px */
  font-family: 'Outfit', sans-serif;
  font-size: 0.625rem;
  /* 10px */
  font-weight: 600;
  color: #fff;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.15s ease, transform 0.15s ease;
  z-index: 100;
}

.btn-tooltip-wrap .btn-tooltip::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 0.25rem solid transparent;
  /* 4px */
  border-top-color: rgba(15, 23, 42, 0.88);
}

@media (hover: hover) {
  .btn-tooltip-wrap:hover .btn-tooltip {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}

/* ── Suggest for Me modal ── */
#suggest-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 300;
  background: rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(0.375rem);
  /* 6px */
  -webkit-backdrop-filter: blur(0.375rem);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

@media (min-width: 40rem) {
  #suggest-modal-backdrop {
    align-items: center;
    padding: 1.5rem;
    /* 24px */
  }
}

#suggest-modal-backdrop.open {
  opacity: 1;
  pointer-events: all;
}

#suggest-modal {
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(2rem) saturate(200%);
  /* 32px */
  -webkit-backdrop-filter: blur(2rem) saturate(200%);
  border: 0.0625rem solid rgba(255, 255, 255, 0.85);
  /* 1px */
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.90),
    0 0.5rem 2.5rem rgba(0, 0, 0, 0.14),
    0 2rem 5rem rgba(0, 0, 0, 0.10);
  border-radius: 1.75rem 1.75rem 0 0;
  /* 28px */
  width: 100%;
  max-width: 30rem;
  /* 480px */
  padding: 1.75rem 1.5rem 2rem;
  /* 28px 24px 32px */
  transform: translateY(1.5rem);
  /* 24px */
  transition: transform 0.35s cubic-bezier(0.25, 1, 0.3, 1);
  position: relative;
  overflow: hidden;
}

@media (min-width: 40rem) {
  #suggest-modal {
    border-radius: 1.75rem;
    /* 28px */
    transform: translateY(0) scale(0.96);
  }
}

#suggest-modal-backdrop.open #suggest-modal {
  transform: translateY(0) scale(1);
}

#suggest-modal::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 100% 40% at 50% 0%, rgba(255, 255, 255, 0.50) 0%, transparent 70%);
  pointer-events: none;
}

.suggest-dot {
  width: 0.375rem;
  /* 6px */
  height: 0.375rem;
  /* 6px */
  border-radius: 50%;
  background: #e2e8f0;
  transition: all 0.25s ease;
}

.suggest-dot.active {
  background: #4f46e5;
  width: 1.125rem;
  /* 18px */
  border-radius: 6.1875rem;
  /* 99px */
}

.suggest-opt {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  /* 10px */
  width: 100%;
  padding: 0.6875rem 0.875rem;
  /* 11px 14px */
  border-radius: 0.875rem;
  /* 14px */
  border: 0.09375rem solid rgba(226, 232, 240, 0.8);
  /* 1.5px */
  background: #fff;
  cursor: pointer;
  transition: all 0.18s ease;
  font-family: 'Outfit', sans-serif;
  text-align: left;
  outline: none;
}

.suggest-opt:hover {
  border-color: rgba(79, 70, 229, 0.35);
  background: rgba(79, 70, 229, 0.03);
}

.suggest-opt.selected {
  border-color: #4f46e5;
  background: rgba(79, 70, 229, 0.06);
  box-shadow: 0 0 0 0.1875rem rgba(79, 70, 229, 0.08);
  /* 3px */
}

.suggest-opt-icon {
  width: 2rem;
  /* 32px */
  height: 2rem;
  /* 32px */
  border-radius: 0.625rem;
  /* 10px */
  background: rgba(79, 70, 229, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.suggest-opt-icon .material-symbols-outlined {
  font-size: 1rem;
  /* 16px */
  color: #4f46e5;
}

.suggest-opt-label {
  font-size: 0.8125rem;
  /* 13px */
  font-weight: 700;
  color: #0f172a;
  line-height: 1.2;
}

.suggest-opt-sub {
  font-size: 0.625rem;
  /* 10px */
  font-weight: 500;
  color: #64748b;
  margin-top: 0.0625rem;
  /* 1px */
}

.suggest-result-card {
  border-radius: 1rem;
  /* 16px */
  border: 0.09375rem solid rgba(79, 70, 229, 0.20);
  /* 1.5px */
  background: rgba(79, 70, 229, 0.04);
  padding: 0.875rem 1rem;
  /* 14px 16px */
}

@keyframes pulseGlowSuggest {
  0% {
    box-shadow: 0 0.375rem 1rem rgba(79, 70, 229, 0.3), 0 0 0 0 rgba(79, 70, 229, 0.4);
  }

  70% {
    box-shadow: 0 0.375rem 1rem rgba(79, 70, 229, 0.3), 0 0 0 1rem rgba(79, 70, 229, 0);
  }

  100% {
    box-shadow: 0 0.375rem 1rem rgba(79, 70, 229, 0.3), 0 0 0 0 rgba(79, 70, 229, 0);
  }
}

.suggest-trigger-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem !important;
  /* 8px */
  padding: 0.875rem 2rem !important;
  /* 14px 32px */
  border-radius: 6.1875rem !important;
  /* 99px */
  border: none;
  background: linear-gradient(135deg, #4f46e5 0%, #6366f1 100%);
  font-family: 'Outfit', sans-serif;
  font-size: 0.9375rem !important;
  /* 15px */
  font-weight: 800;
  color: #ffffff;
  cursor: pointer;
  transition: all 0.30s cubic-bezier(0.25, 1, 0.5, 1);
  outline: none;
  animation: pulseGlowSuggest 2.5s infinite;
  box-shadow: 0 0.375rem 1rem rgba(79, 70, 229, 0.3) !important;
}

.suggest-trigger-btn:hover {
  background: linear-gradient(135deg, #4338ca 0%, #4f46e5 100%);
  transform: translateY(-0.1875rem) scale(1.03);
  /* -3px */
  box-shadow: 0 0.75rem 1.75rem rgba(79, 70, 229, 0.5);
  animation: none;
}

.suggest-trigger-btn:active {
  transform: translateY(0.0625rem) scale(0.98);
  /* 1px */
  box-shadow: 0 0.25rem 0.75rem rgba(79, 70, 229, 0.4);
}

.suggest-trigger-btn .material-symbols-outlined {
  font-size: 1.25rem;
  /* 20px */
}

/* ── Spec specs grid within card ── */
.specs-panel {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.375rem 0.5rem;
  /* 6px 8px */
  margin-bottom: 0.5rem;
  /* 8px */
  padding-bottom: 0.5rem;
  /* 8px */
  border-bottom: 0.0625rem solid rgba(226, 232, 240, 0.6);
  /* 1px */
}

/* Icon sizing for spec labels */
.spec-icon {
  font-size: 0.5625rem !important;
  /* 9px */
  opacity: 0.75;
  font-family: 'Material Symbols Outlined';
  font-weight: 400;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  font-feature-settings: 'liga';
  line-height: 1;
  display: inline-block;
}

/* ══════════════════════════════════════════════════
   NAVBAR — Centered nav links, no overlap at any width
   ══════════════════════════════════════════════════ */
#smart-navbar .ios26-liquid-pill {
  min-width: 0;
}

.nav-links-center {
  display: none;
}

@media (min-width: 75rem) {

  /* 1200px */
  .nav-links-center {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    /* 12px */
    flex: 0 1 auto;
    white-space: nowrap;
    pointer-events: auto;
    z-index: 3;
  }
}

@media (min-width: 80rem) {

  /* 1280px */
  .nav-links-center {
    gap: 1rem;
    /* 16px */
  }
}

@media (min-width: 90rem) {

  /* 1440px */
  .nav-links-center {
    gap: 1.5rem;
    /* 24px */
  }
}

/* Scale font at breakpoints */
.nav-links-center a {
  font-size: 0.6875rem !important;
  /* 11px */
  white-space: nowrap;
  flex-shrink: 0;
  transition: color 0.2s ease;
}

@media (min-width: 75rem) {
  .nav-links-center a {
    font-size: 0.71875rem !important;
    /* 11.5px */
  }
}

@media (min-width: 80rem) {
  .nav-links-center a {
    font-size: 0.78125rem !important;
    /* 12.5px */
  }
}

@media (min-width: 90rem) {
  .nav-links-center a {
    font-size: 0.84375rem !important;
    /* 13.5px */
  }
}

/* Flex boundaries enforce true center without overlap */
.nav-logo-wrap {
  display: flex;
  align-items: center;
  margin-top: 0.0625rem;
  /* 1px */
  justify-content: flex-start;
  flex: 1 1 0%;
  min-width: max-content;
  z-index: 3;
}

.nav-actions-wrap {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
  /* 8px */
  flex: 1 1 0%;
  min-width: max-content;
  z-index: 3;
}

/* ── ADD TO CART — Liquid Glass Button ── */
.cart-btn-glass {
  position: relative;
  background: #4f46e5;
  backdrop-filter: blur(1.25rem) saturate(180%);
  /* 20px */
  -webkit-backdrop-filter: blur(1.25rem) saturate(180%);
  border: 0.0625rem solid rgba(255, 255, 255, 0.10);
  /* 1px */
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.10),
    inset 0 -0.0625rem 0 rgba(0, 0, 0, 0.15),
    0 0.125rem 0.25rem rgba(0, 0, 0, 0.18),
    0 0.375rem 0.875rem rgba(79, 70, 229, 0.35);
  color: #ffffff;
  overflow: hidden;
  transition: transform 0.25s cubic-bezier(0.25, 1, 0.5, 1), box-shadow 0.25s ease, background 0.25s ease;
}

.cart-btn-glass::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 100% 45% at 50% 0%,
      rgba(255, 255, 255, 0.15) 0%,
      rgba(255, 255, 255, 0.05) 45%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.cart-btn-glass::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 70% 30% at 50% 100%,
      rgba(255, 255, 255, 0.18) 0%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.cart-btn-glass>* {
  position: relative;
  z-index: 2;
}

.cart-btn-glass:hover {
  background: #4f46e5;
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.15),
    inset 0 -0.0625rem 0 rgba(0, 0, 0, 0.18),
    0 0.25rem 0.5rem rgba(0, 0, 0, 0.22),
    0 0.625rem 1.5rem rgba(79, 70, 229, 0.50);
  transform: translateY(-0.0625rem);
  /* -1px */
}

/* ══════════════════════════════════════════════════
   FROSTED GLASS — Spec Selector Pills & Action Buttons
   ══════════════════════════════════════════════════ */

.spec-sel-btn {
  position: relative;
  background: rgba(255, 255, 255, 0.10);
  backdrop-filter: blur(1.25rem) saturate(180%);
  /* 20px */
  -webkit-backdrop-filter: blur(1.25rem) saturate(180%);
  border: 0.0625rem solid rgba(255, 255, 255, 0.18);
  /* 1px */
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.25),
    0 0.125rem 0.25rem rgba(0, 0, 0, 0.18),
    0 0.25rem 0.75rem rgba(0, 0, 0, 0.14);
  color: #64748b;
  overflow: visible;
  transition: all 0.22s cubic-bezier(0.25, 1, 0.5, 1);
}

.spec-sel-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 100% 45% at 50% 0%,
      rgba(255, 255, 255, 0.45) 0%,
      rgba(255, 255, 255, 0.12) 45%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.spec-sel-btn::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 70% 30% at 50% 100%,
      rgba(255, 255, 255, 0.15) 0%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.spec-sel-btn>* {
  position: relative;
  z-index: 2;
}

.spec-sel-btn:hover {
  background: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 255, 255, 0.30);
  color: #4f46e5;
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.35),
    0 0.25rem 0.5rem rgba(0, 0, 0, 0.20),
    0 0.5rem 1.25rem rgba(79, 70, 229, 0.18);
  transform: translateY(-0.03125rem);
}

.spec-sel-btn.active {
  background: rgba(255, 255, 255, 0.16);
  border: 0.15625rem solid rgba(79, 70, 229, 0.70);
  /* 2.5px */
  color: #4f46e5;
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.30),
    0 0.125rem 0.375rem rgba(0, 0, 0, 0.16),
    0 0.375rem 1rem rgba(79, 70, 229, 0.28);
}

/* ── Customize / Preview action buttons ── */
.deck-card-item .btn-tooltip-wrap button {
  position: relative;
  background: rgba(255, 255, 255, 0.10) !important;
  backdrop-filter: blur(1.25rem) saturate(180%) !important;
  /* 20px */
  -webkit-backdrop-filter: blur(1.25rem) saturate(180%) !important;
  border: 0.0625rem solid rgba(255, 255, 255, 0.18) !important;
  /* 1px */
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.25),
    0 0.125rem 0.25rem rgba(0, 0, 0, 0.18),
    0 0.25rem 0.75rem rgba(0, 0, 0, 0.14) !important;
  color: #64748b !important;
  overflow: visible !important;
  transition: all 0.22s cubic-bezier(0.25, 1, 0.5, 1) !important;
  font-size: 0.6875rem !important;
  /* 11px baseline */
  padding-left: 1rem !important;
  padding-right: 1rem !important;
  border-radius: 6.1875rem !important;
}

.deck-card-item .btn-tooltip-wrap button::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 100% 45% at 50% 0%,
      rgba(255, 255, 255, 0.45) 0%,
      rgba(255, 255, 255, 0.12) 45%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.deck-card-item .btn-tooltip-wrap button::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 70% 30% at 50% 100%,
      rgba(255, 255, 255, 0.15) 0%,
      transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.deck-card-item .btn-tooltip-wrap button>* {
  position: relative;
  z-index: 2;
}

.deck-card-item .btn-tooltip-wrap button:hover {
  background: rgba(255, 255, 255, 0.18) !important;
  border-color: rgba(255, 255, 255, 0.30) !important;
  color: #4f46e5 !important;
  box-shadow:
    inset 0 0.0625rem 0 rgba(255, 255, 255, 0.35),
    0 0.25rem 0.5rem rgba(0, 0, 0, 0.20),
    0 0.5rem 1.25rem rgba(79, 70, 229, 0.22) !important;
  transform: translateY(-0.0625rem);
}

/* ── PRODUCT CARD — Carved Glass Effect ── */
.product-card-glass {
  position: relative;
  --card-glow: 0 1.25rem 3rem rgba(0, 0, 0, 0.06);
  /* 20px 48px */
  backdrop-filter: blur(1.25rem) saturate(180%);
  -webkit-backdrop-filter: blur(1.25rem) saturate(180%);
  border: 0.0625rem solid rgba(255, 255, 255, 0.55) !important;
  /* 1px */
  box-shadow:
    inset 0 0.09375rem 0 rgba(255, 255, 255, 0.80),
    inset 0 -0.0625rem 0 rgba(0, 0, 0, 0.06),
    inset 0.0625rem 0 0 rgba(255, 255, 255, 0.40),
    inset -0.0625rem 0 0 rgba(255, 255, 255, 0.30),
    0 0.125rem 0.25rem rgba(0, 0, 0, 0.10),
    0 0.5rem 1.5rem rgba(0, 0, 0, 0.10),
    var(--card-glow) !important;
  overflow: visible !important;
  transform: translateZ(0);
  will-change: transform;
  border-radius: 1.5rem !important;
}

.product-card-glass::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 110% 42% at 50% 0%,
      rgba(255, 255, 255, 0.62) 0%,
      rgba(255, 255, 255, 0.18) 40%,
      transparent 68%);
  pointer-events: none;
  z-index: 0;
}

.product-card-glass::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 72% 28% at 50% 102%,
      rgba(255, 255, 255, 0.30) 0%,
      transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.product-card-glass>* {
  position: relative;
  z-index: 1;
}

/* ================================================================
   CONTINUOUS FLUID SCALING DESIGN (Baseline: 1366px screen width)
   ================================================================ */
@media (min-width: 48rem) {
  html {
    /* 1.1713vw evaluates to exactly 16px base font size when screen is 1366px wide.
       Clamped between 0.75rem (12px) and 2.8125rem (45px on 4K) to protect layout usability. */
    font-size: clamp(0.75rem, 1.1713vw, 2.8125rem);
  }
}

/* ── Dynamic fluid container mapping ── */
nav#smart-navbar>div[class*="max-w-"] {
  max-width: 90rem !important;
}

/* ================================================================
   COMPONENT HARDCODED OVERRIDES
   ================================================================ */

/* 1. Nav-bar Pill & Logo */
#smart-navbar .ios26-liquid-pill {
  height: 3.5rem !important;
  /* 56px baseline */
}

@media (min-width: 48rem) {
  #smart-navbar img {
    height: 1.5rem !important;
    /* 24px baseline */
  }
}

@media (max-width: 47.9375rem) {
  #smart-navbar img {
    height: 1.125rem !important;
    /* 18px baseline */
  }
}

/* 2. Smart Fixed CTA Pill */
#smart-cta .ios26-liquid-pill {
  height: 3rem !important;
}

@media (min-width: 48rem) {
  #smart-cta .ios26-liquid-pill {
    height: 3.75rem !important;
  }
}

/* 3. Mousepad Catalog Card Spacings & Borders */
.deck-card-item .aspect-\[12\/6\.5\] {
  border-radius: 1.25rem !important;
  /* 20px baseline */
  margin-bottom: 0.75rem !important;
  /* 12px baseline */
}

.deck-card-item button:not(.spec-sel-btn):not(.spec-info-btn) {
  height: 2.375rem !important;
  /* 38px baseline */
}

.deck-card-item .cart-btn-glass {
  height: 2.5rem !important;
  /* 40px baseline */
}

/* ═══════════════════════════════════════════════════════
   4. COMPONENT INTERACTIVE SCALE REFINEMENTS
   ═══════════════════════════════════════════════════════ */

.suggest-trigger-btn {
  font-size: 0.9375rem !important;
  padding: 0.875rem 2rem !important;
}

.deck-card-item button:not(.spec-sel-btn):not(.spec-info-btn) {
  font-size: 0.6875rem !important;
  /* 11px baseline */
}

.deck-card-item .cart-btn-glass {
  font-size: 0.75rem !important;
  /* 12px baseline */
  padding-left: 1rem !important;
  padding-right: 1rem !important;
}

#smart-navbar .nav-actions-wrap a:not(:has(svg)),
#smart-navbar .nav-actions-wrap button:not(:has(svg)) {
  font-size: 0.8125rem !important;
  /* 13px baseline */
  padding: 0.5rem 1.25rem !important;
  border-radius: 6.1875rem !important;
}

/* ═══════════════════════════════════════════════════════
   FLUID MATERIAL ICONS OVERRIDE
   Overwrites Google's static 24px default stylesheet value 
   to scale relative to your root clamp() font size.
   ═══════════════════════════════════════════════════════ */
.material-symbols-outlined {
  font-size: 1.5rem;
  /* Converts static 24px to a relative, scaling 1.5rem */
}
