/*
 * Variáveis semânticas (formato shadcn / Tailwind: H S% L% sem envolver em hsl()).
 * O CSS do tema da CentralCart costuma sobrescrever isto depois; estes valores só
 * servem de fallback quando --border / --background / etc. não existem — evita
 * `border-border`, `bg-background` e afins gerarem cores inválidas em todo o site.
 */
:root {
  --background: 222 47% 5.9%;
  --foreground: 210 40% 98%;
  --muted: 217 33% 14%;
  --muted-foreground: 215 20% 65%;
  --primary: 199 89% 48%;
  --primary-foreground: 210 40% 98%;
  --secondary: 217 33% 17.5%;
  --border: 217 33% 22%;
  --card: 222 47% 7%;
}

/* Garante .container centrado mesmo se o CSS da CentralCart ou a ordem de carregamento
   não aplicarem o plugin container do Tailwind (evita conteúdo “colado” à esquerda). */
.container {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}

/* CentralCart: se o tema não carregar .rounded-cc, o Tailwind CDN não gera esta classe — cantos ficam 90° */
.rounded-cc {
  border-radius: 0.75rem;
}

/*
 * Página do produto: o Tailwind `border` sem cor + tema CentralCart = borda branca forte.
 * Estas superfícies usam borda transparente / quase invisível (como pretendido no design).
 */
.package-wrapper .pkg-surface {
  border: 1px solid transparent !important;
  box-sizing: border-box;
}

.package-wrapper .pkg-surface-subtle {
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
  box-sizing: border-box;
}

/* Preço + botões do produto: /styles/package-after-theme.css (depois do CSS da CentralCart no layout). */

/* Descrição HTML: só ajusta elementos que já têm classe Tailwind `border` (evita borda branca do tema) */
.package-wrapper #package-description.centralcart-content [class~='border'] {
  border-color: rgba(255, 255, 255, 0.08) !important;
}

/* FAQ — visual limpo: #050a12, glow azul nos cantos, botão escuro + aura ciano, sem verde */
.faq-showcase-shell.faq-glass-root {
  border-color: rgba(148, 163, 184, 0.14) !important;
  background:
    radial-gradient(ellipse 70% 55% at 0% 0%, rgba(56, 189, 248, 0.14) 0%, transparent 55%),
    radial-gradient(ellipse 65% 50% at 100% 0%, rgba(59, 130, 246, 0.12) 0%, transparent 50%),
    linear-gradient(180deg, rgba(5, 10, 18, 0.72) 0%, rgba(3, 6, 12, 0.88) 100%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(1.12);
  backdrop-filter: blur(20px) saturate(1.12);
  box-shadow:
    0 0 0 1px rgba(30, 58, 95, 0.35) inset,
    0 20px 50px rgba(0, 0, 0, 0.45);
}

.faq-showcase-shell .faq-acc-border {
  border-color: rgba(100, 116, 139, 0.22) !important;
}

.faq-showcase-shell .faq-cyan-ring {
  border-color: rgba(34, 211, 238, 0.35) !important;
}

/* Botão “Ver todas…”: fundo escuro + brilho ciano (como referência) */
.faq-cta-glow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1.75rem;
  border-radius: 9999px;
  font-size: 0.875rem;
  font-weight: 600;
  color: #e2e8f0 !important;
  text-decoration: none !important;
  background: rgba(15, 23, 42, 0.95) !important;
  border: 1px solid rgba(34, 211, 238, 0.28) !important;
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.4),
    0 0 28px rgba(34, 211, 238, 0.22),
    0 0 56px rgba(34, 211, 238, 0.08);
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.faq-cta-glow:hover {
  color: #f8fafc !important;
  background: rgba(15, 23, 42, 1) !important;
  border-color: rgba(34, 211, 238, 0.45) !important;
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.5),
    0 0 36px rgba(34, 211, 238, 0.32),
    0 0 72px rgba(34, 211, 238, 0.12);
}

/* Acordeão: quase preto, mais escuro que o cartão */
.faq-showcase-shell details.faq-item.faq-glass-item {
  background: rgba(2, 4, 10, 0.88) !important;
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border-color: rgba(71, 85, 105, 0.35) !important;
}

.faq-showcase-shell details.faq-item.faq-glass-item:hover {
  background: rgba(2, 4, 10, 0.94) !important;
  border-color: rgba(100, 116, 139, 0.4) !important;
}

.faq-showcase-shell details.faq-item.faq-glass-item[open] {
  background: rgba(2, 4, 10, 0.92) !important;
  border-color: rgba(34, 211, 238, 0.2) !important;
}

.faq-showcase-shell details.faq-item .faq-content .border-t,
.faq-showcase-shell details.faq-item .border-t {
  border-top-color: rgba(71, 85, 105, 0.35) !important;
}

.faq-showcase-shell .faq-icon-glass {
  background: rgba(0, 0, 0, 0.35) !important;
  box-shadow: 0 0 12px rgba(34, 211, 238, 0.1);
}

.faq-showcase-shell .faq-feature-icon-glass {
  background: rgba(2, 6, 14, 0.65) !important;
  box-shadow: 0 0 24px rgba(34, 211, 238, 0.15);
}

.faq-showcase-shell .faq-feature-glow {
  background: radial-gradient(circle, rgba(34, 211, 238, 0.35) 0%, transparent 70%);
  opacity: 0.5;
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type=number] {
  -moz-appearance: textfield;
}

/*
 * Separadores globais (referência Megabuxx): 1px, branco muito suave — sem “linha branca” forte.
 * Usar .site-divider-t / .site-divider-b em vez de border-t + tema CC.
 */
.site-divider-t {
  border-top-width: 1px !important;
  border-top-style: solid !important;
  border-top-color: rgba(255, 255, 255, 0.08) !important;
}

.site-divider-b {
  border-bottom-width: 1px !important;
  border-bottom-style: solid !important;
  border-bottom-color: rgba(255, 255, 255, 0.08) !important;
}

/* Ícones sociais no rodapé — círculo fino discreto (referência) */
.site-footer-socials > a {
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  border-radius: 9999px !important;
  box-sizing: border-box !important;
}

.site-footer-socials > a:hover {
  border-color: rgba(255, 255, 255, 0.2) !important;
}

/* Barra do topo – fundo escuro, logo em destaque (estilo referência) */
.navbar-top {
  background: rgba(18, 20, 28, 0.97);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
/* Botão headset Suporte (navbar) — sem borda branca do tema */
#support-button.support-nav-trigger,
button#support-button {
  border: none !important;
  box-shadow: none !important;
}

.navbar-logo-wrap {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.25) 0%, rgba(34, 211, 238, 0.2) 100%);
  padding: 4px;
  min-width: 2.5rem;
  min-height: 2.5rem;
  width: 2.5rem;
  height: 2.5rem;
}
@media (min-width: 640px) {
  .navbar-logo-wrap {
    min-width: 2.75rem;
    min-height: 2.75rem;
    width: 2.75rem;
    height: 2.75rem;
  }
}

@keyframes fade-in {
  from {
      background-color: rgba(0, 0, 0, 0);
  }
  to {
      background-color: rgba(0, 0, 0, 0.8);
  }
}

@keyframes fade-out {
  from {
      background-color: rgba(0, 0, 0, 0.8);
  }
  to {
      background-color: rgba(0, 0, 0, 0);
  }
}

@keyframes slide-in {
  from {
      transform: translateX(500px);
  }
  to {
      transform: translateX(0px);
  }
}

@keyframes slide-out {
  from {
      transform: translateX(0px);
  }
  to {
      transform: translateX(500px);
  }
}


#cart-drawer[data-state="open"] {
  animation: fade-in 0.4s forwards;
}

body.cart-open {
  overflow: hidden;
  padding-right: var(--scrollbar-width, 0px);
}

#cart-drawer[data-state="closed"] {
  animation: fade-out 0.4s forwards;
}

#cart-drawer[data-state="open"] > div {
  animation: slide-in 0.4s forwards;
}

#cart-drawer[data-state="closed"] > div {
  animation: slide-out 0.4s forwards;
}

.dialog[data-state="open"] {
  animation: fade-in 0.4s forwards;
}

.dialog[data-state="closed"] {
  animation: fade-out 0.4s forwards;
}

.dialog[data-state="open"] > div {
  animation: dialog-in 0.2s forwards;
}

.dialog[data-state="closed"] > div {
  animation: dialog-out 0.2s forwards;
}

@keyframes dialog-in {
  from {
      opacity: 0;
      scale: 50%;
  }
  to {
      opacity: 1;
      scale: 100%;
  }
}

@keyframes dialog-out {
  from {
      opacity: 1;
      scale: 100%;
  }
  to {
      opacity: 0;
      scale: 50%;
  }
}

/* Modais de resgate / entrega: sem bordas brancas do tema CC */
.dialog > div.rounded-cc.border,
.dialog > div[class*="rounded-cc"][class~="border"] {
  border-color: rgba(59, 130, 246, 0.3) !important;
  box-shadow:
    0 0 0 1px rgba(2, 6, 23, 0.45),
    0 24px 56px rgba(0, 0, 0, 0.4);
}

.dialog > div > div.border-b {
  border-bottom-color: rgba(30, 52, 92, 0.72) !important;
}

/* Caixas de entrega (chaves, HTML nome/senha, download) */
.order-delivery-panel {
  border: 1px solid rgba(59, 130, 246, 0.26) !important;
  background: rgba(15, 23, 42, 0.72) !important;
  box-shadow: inset 0 1px 0 rgba(186, 230, 253, 0.05);
}

.order-delivery-panel.divide-y > :not([hidden]) ~ :not([hidden]) {
  border-top-color: rgba(51, 65, 85, 0.65) !important;
}

/* HTML da loja dentro da entrega (campos, tabelas, bordas utilitárias) */
.dialog .centralcart-content.order-delivery-panel [class~="border"],
.dialog .centralcart-content.order-delivery-panel [class*="border-white"],
.dialog .centralcart-content.order-delivery-panel [class*="border-gray"] {
  border-color: rgba(56, 189, 248, 0.22) !important;
}

.dialog .centralcart-content.order-delivery-panel input,
.dialog .centralcart-content.order-delivery-panel textarea,
.dialog .centralcart-content.order-delivery-panel select {
  border: 1px solid rgba(56, 189, 248, 0.38) !important;
  background: rgba(2, 6, 23, 0.62) !important;
  color: #e2e8f0 !important;
  border-radius: 0.65rem !important;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.2);
}

/* Corpo do modal (.p-6): nome/senha costumam vir com borda branca do tema CC */
.dialog > div > div.p-6 input,
.dialog > div > div.p-6 textarea,
.dialog > div > div.p-6 select {
  border: 1px solid rgba(56, 189, 248, 0.38) !important;
  border-color: rgba(56, 189, 248, 0.38) !important;
  background: rgba(2, 6, 23, 0.62) !important;
  color: #e2e8f0 !important;
  border-radius: 0.65rem !important;
}

/* Linhas tipo “input + copiar” (flex) geradas pelo HTML da loja */
.dialog .centralcart-content.order-delivery-panel .flex.items-center[class*="border"],
.dialog .centralcart-content.order-delivery-panel div.flex.items-center.gap-2,
.dialog .centralcart-content.order-delivery-panel div.flex.items-center.gap-3 {
  border: 1px solid rgba(56, 189, 248, 0.3) !important;
  border-color: rgba(56, 189, 248, 0.3) !important;
  background: rgba(15, 23, 42, 0.45) !important;
  border-radius: 0.65rem !important;
}

/* Estilo inline com branco (#fff, rgb(255…)) — força borda azul inteira */
.dialog .centralcart-content.order-delivery-panel [style*="#fff"],
.dialog .centralcart-content.order-delivery-panel [style*="#FFF"],
.dialog .centralcart-content.order-delivery-panel [style*="rgb(255"],
.dialog .centralcart-content.order-delivery-panel [style*="rgba(255"] {
  border: 1px solid rgba(56, 189, 248, 0.34) !important;
}

/* Qualquer descendente com borda desenhada: troca cor (mantém espessura) */
.dialog .centralcart-content.order-delivery-panel * {
  border-color: rgba(56, 189, 248, 0.28) !important;
}

.dialog .centralcart-content.order-delivery-panel input,
.dialog .centralcart-content.order-delivery-panel textarea,
.dialog .centralcart-content.order-delivery-panel select,
.dialog .centralcart-content.order-delivery-panel button {
  border-color: rgba(56, 189, 248, 0.4) !important;
}

.dialog .centralcart-content.order-delivery-panel button {
  background: rgba(15, 23, 42, 0.75) !important;
  color: #e2e8f0 !important;
}

.dialog .centralcart-content.order-delivery-panel button:hover {
  background: rgba(30, 58, 138, 0.55) !important;
  border-color: rgba(96, 165, 250, 0.55) !important;
}

/* Sobrescreve borda branca em estilo inline (templates CC de credenciais) */
.dialog .centralcart-content.order-delivery-panel [style*="border"]:not(input):not(textarea):not(select) {
  border: 1px solid rgba(56, 189, 248, 0.3) !important;
}

.dialog .centralcart-content.order-delivery-panel hr {
  border-color: rgba(51, 65, 85, 0.55) !important;
  opacity: 1;
}

.dialog .centralcart-content.order-delivery-panel table,
.dialog .centralcart-content.order-delivery-panel th,
.dialog .centralcart-content.order-delivery-panel td {
  border-color: rgba(56, 189, 248, 0.18) !important;
}

.reveal-fade-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.3s ease, transform 0.3s ease;
  transition-delay: var(--delay, 0s);
}

.reveal-fade-up.visible {
  opacity: 1;
  transform: translateY(0);
}

.centralcart-content iframe {
  aspect-ratio: 16 / 9;
  border-radius: 0.5rem;
  width: 100%;
  height: auto;
}

.grid-background {
  background-image: linear-gradient(to right,hsla(0,0%,100%,.02) 1px,transparent 1px),linear-gradient(to bottom,hsla(0,0%,100%,.02) 1px,transparent 1px);
  background-size: 40px 40px;
  mask-image: radial-gradient(ellipse 60% 85% at 40% 30%, #000 0%, #fff0 110%)
}

/* Grade no fundo do site: camada acima do fundo, abaixo do conteúdo */
.site-grid {
  position: relative;
}

.site-grid::before {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 0;
  pointer-events: none;
  background-image: linear-gradient(to right, hsla(0, 0%, 100%, 0.045) 1px, transparent 1px),
    linear-gradient(to bottom, hsla(0, 0%, 100%, 0.045) 1px, transparent 1px);
  background-size: 40px 40px;
}

/* Conteúdo do site acima da grade */
.site-grid > * {
  position: relative;
  z-index: 1;
}

.custom-bg-mask {
	mask-image: linear-gradient(hsl(var(--background)), rgba(0, 0, 0, 0.3), rgb(0, 0, 0, 0));
}

@keyframes loading {
  0% {
      left: -50%;
  }

  to {
      left: 100%;
  }
}

.detail-dash {
  background-image: linear-gradient(to right, rgba(255, 255, 255, 0.1) 50%, hsl(var(--foreground) / 0) 0%);
  background-position: center bottom;
  background-size: 16px;
  background-repeat: repeat-x;
  width: 100%;
  height: 1px;
}

.custom-scrollbar::-webkit-scrollbar {
  width: 3px;
  height: 3px;
}

.custom-scrollbar::-webkit-scrollbar-track {
  background: transparent;
}

.custom-scrollbar::-webkit-scrollbar-thumb {
  background: hsl(var(--primary));
  border-radius: 0.25rem;
}

.animate-float {
  animation: floatRandom 15s ease-in-out infinite;
}

@keyframes floatRandom {
  0% {
    transform: translate(0, 0) rotate(0deg);
  }
  20% {
    transform: translate(-6px, -10px) rotate(-1deg);
  }
  40% {
    transform: translate(4px, -5px) rotate(1deg);
  }
  60% {
    transform: translate(-4px, -12px) rotate(-1.5deg);
  }
  80% {
    transform: translate(3px, -7px) rotate(1deg);
  }
  100% {
    transform: translate(0, 0) rotate(0deg);
  }
}

@keyframes gradient-shift {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}


.gradient-text {
  background: linear-gradient(
    45deg,
    hsl(var(--primary)),
    hsl(var(--primary) / 0.8),
    hsl(var(--primary) / 0.6),
    hsl(var(--primary) / 0.9),
    hsl(var(--primary)),
    hsl(var(--primary) / 0.7),
    hsl(var(--primary) / 0.5),
    hsl(var(--primary) / 0.8)
  );
  background-size: 400% 400%;
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: gradient-shift 3s ease-in-out infinite;
}


.glass {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  z-index: 0;
}

.glass::after {
  content: "";
  transition: all 850ms cubic-bezier(.19,1,.22,1);
  background-color: white;
  opacity: .2;
  width: 50px;
  height: 200px;
  position: absolute;
  left: -85px;
  top: -80px;
  z-index: 1;
  transform: rotate(30deg);
  filter: blur(2px);
}

.glass:hover::after {
  left: 130%;
}

.glass-secondary {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  z-index: 0;
}

.glass-secondary::after {
  content: "";
  transition: all 850ms cubic-bezier(.19,1,.22,1);
  background: linear-gradient(to right, transparent, hsl(var(--secondary) / 0.15), transparent);
  width: 100%;
  height: 200%;
  position: absolute;
  left: -150%;
  top: -50%;
  z-index: 1;
  transform: rotate(30deg);
  filter: blur(10px);
}

.glass-secondary:hover::after {
  left: 150%;
}

/* Três cards (Entrega / Segurança / Pagamento) — borda azul escuro (tema CC costuma forçar branco) */
.package-wrapper .features-trust-grid .features-trust-card,
.features-trust-grid .features-trust-card {
  border-color: rgba(23, 37, 72, 0.9) !important;
  border-width: 1px !important;
  border-style: solid !important;
  box-shadow: none !important;
  outline: none !important;
}

.package-wrapper .features-trust-grid .features-trust-card:hover,
.features-trust-grid .features-trust-card:hover {
  border-color: rgba(59, 130, 246, 0.35) !important;
}

/* Área escura inferior do card — brilho azul suave (halo perto da imagem + canto) */
a.package .package-card-body {
  background:
    radial-gradient(ellipse 115% 90% at 50% -18%, rgba(59, 130, 246, 0.22) 0%, transparent 55%),
    radial-gradient(ellipse 85% 55% at 92% 88%, rgba(56, 189, 248, 0.1) 0%, transparent 48%),
    linear-gradient(180deg, rgba(12, 18, 32, 0.98) 0%, rgba(5, 8, 16, 1) 100%);
  transition: background 0.35s ease;
}

a.package.group:hover .package-card-body {
  background:
    radial-gradient(ellipse 115% 90% at 50% -18%, rgba(59, 130, 246, 0.3) 0%, transparent 55%),
    radial-gradient(ellipse 85% 55% at 92% 88%, rgba(96, 165, 250, 0.14) 0%, transparent 48%),
    linear-gradient(180deg, rgba(14, 22, 40, 1) 0%, rgba(5, 9, 18, 1) 100%);
}

/*
 * Barra "Comprar agora" nos cards — estilo sólido (ref. cartão roxo), em azul #3B82F6.
 * Ícone + texto brancos, cantos ~12px, borda escura discreta.
 */
.btn-comprar-metallic {
  position: relative;
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.5rem;
  width: 100%;
  box-sizing: border-box;
  padding: 0.625rem 0.875rem;
  font-size: 0.8125rem;
  font-weight: 700;
  color: #fff !important;
  text-transform: none;
  letter-spacing: 0.01em;
  line-height: 1.2;
  border-radius: 0.75rem;
  border: 1px solid rgba(0, 0, 0, 0.3) !important;
  background: #3b82f6 !important;
  box-shadow: 0 2px 0 rgba(0, 0, 0, 0.15), 0 6px 16px rgba(59, 130, 246, 0.35);
  transition:
    background 0.18s ease,
    transform 0.12s ease,
    box-shadow 0.18s ease;
}

.btn-comprar-metallic svg {
  color: #fff !important;
  stroke: #fff !important;
  flex-shrink: 0 !important;
}

.package.group:hover .btn-comprar-metallic,
.btn-comprar-metallic:hover {
  background: #2563eb !important;
  border-color: rgba(0, 0, 0, 0.28) !important;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.12), 0 4px 14px rgba(37, 99, 235, 0.4);
  transform: translateY(1px);
}

.btn-comprar-metallic:active {
  transform: translateY(2px);
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.2), inset 0 2px 6px rgba(0, 0, 0, 0.15);
}

/* Placeholder da barra (card minimal — só visual, dentro do <a>) */
.package-card-buy-placeholder {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.375rem;
  width: 100%;
  box-sizing: border-box;
  font-weight: 700 !important;
  text-transform: none !important;
  letter-spacing: 0.01em !important;
  color: #fff !important;
  background: #3b82f6 !important;
  border: 1px solid rgba(0, 0, 0, 0.3) !important;
  border-radius: 0.75rem !important;
  box-shadow: 0 2px 0 rgba(0, 0, 0, 0.12), 0 4px 12px rgba(59, 130, 246, 0.3) !important;
}

.package.group:hover .package-card-buy-placeholder {
  background: #2563eb !important;
}

/* Campo Roblox / nick (entrega) — borda azul, glow suave, card de resultado */
.roblox-nick-field .roblox-nick-input {
  border-radius: 0.75rem !important;
  border: 1px solid rgba(59, 130, 246, 0.32) !important;
  background: linear-gradient(180deg, rgba(12, 18, 34, 0.95) 0%, rgba(6, 10, 20, 0.98) 100%) !important;
  color: #f1f5f9 !important;
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.25),
    0 4px 18px rgba(59, 130, 246, 0.08);
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.roblox-nick-field .roblox-nick-input::placeholder {
  color: rgba(148, 163, 184, 0.88) !important;
}

.roblox-nick-field .roblox-nick-input:hover:not(:disabled) {
  border-color: rgba(59, 130, 246, 0.45) !important;
  box-shadow:
    0 0 0 1px rgba(59, 130, 246, 0.12),
    0 6px 22px rgba(59, 130, 246, 0.12);
}

.roblox-nick-field .roblox-nick-input:focus {
  outline: none !important;
  border-color: rgba(96, 165, 250, 0.65) !important;
  box-shadow:
    0 0 0 1px rgba(59, 130, 246, 0.25),
    0 0 28px rgba(59, 130, 246, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.roblox-nick-field .roblox-nick-input[data-state='error'] {
  border-color: rgba(248, 113, 113, 0.55) !important;
  box-shadow: 0 0 0 1px rgba(248, 113, 113, 0.15);
}

.roblox-nick-result {
  margin-top: 0.375rem;
  padding: 0.75rem 0.875rem !important;
  border-radius: 0.85rem !important;
  border: 1px solid rgba(59, 130, 246, 0.28) !important;
  background: linear-gradient(155deg, rgba(17, 26, 48, 0.98) 0%, rgba(6, 10, 22, 1) 55%, rgba(8, 14, 30, 1) 100%) !important;
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.2),
    0 10px 32px rgba(0, 0, 0, 0.4),
    0 0 24px rgba(59, 130, 246, 0.12);
}

.roblox-nick-select-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 2.25rem;
  padding: 0.4rem 1rem !important;
  border-radius: 9999px !important;
  font-size: 0.8125rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em;
  color: #fff !important;
  background: #3b82f6 !important;
  border: 1px solid rgba(147, 197, 253, 0.4) !important;
  box-shadow: 0 2px 0 rgba(0, 0, 0, 0.12), 0 4px 14px rgba(59, 130, 246, 0.25);
  cursor: pointer;
  transition:
    background 0.18s ease,
    transform 0.12s ease,
    box-shadow 0.18s ease;
}

.roblox-nick-select-btn:hover {
  background: #2563eb !important;
  transform: translateY(-1px);
  box-shadow: 0 3px 0 rgba(0, 0, 0, 0.1), 0 8px 20px rgba(37, 99, 235, 0.35);
}

.roblox-nick-select-btn:active {
  transform: translateY(0);
}

.faq-item .faq-content {
  overflow: hidden;
  transition: height 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.faq-item:not([open]) .faq-content {
  height: 0;
}

.faq-item summary {
  list-style: none;
}

.faq-item summary::-webkit-details-marker {
  display: none;
}

.faq-item summary::marker {
  display: none;
  content: '';
}

/* Brilho metálico nos cards de produto: bordas nítidas + varredura dinâmica */
.package-metal-shine-top {
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.15) 15%,
    rgba(255, 255, 255, 0.55) 50%,
    rgba(255, 255, 255, 0.15) 85%,
    transparent 100%
  );
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.4);
}

.package-metal-shine-bottom {
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.08) 15%,
    rgba(255, 255, 255, 0.35) 50%,
    rgba(255, 255, 255, 0.08) 85%,
    transparent 100%
  );
  box-shadow: 0 -1px 0 rgba(255, 255, 255, 0.25);
}

/* Varredura de luz dinâmica no hover */
.package-metal-shine-sweep {
  position: absolute;
  top: -50%;
  left: -80%;
  width: 60%;
  height: 200%;
  pointer-events: none;
  z-index: 5;
  transform: rotate(-22deg);
  background: linear-gradient(
    105deg,
    transparent 0%,
    transparent 35%,
    rgba(255, 255, 255, 0.08) 45%,
    rgba(255, 255, 255, 0.18) 50%,
    rgba(255, 255, 255, 0.08) 55%,
    transparent 65%,
    transparent 100%
  );
  transition: left 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.package.group:hover .package-metal-shine-sweep {
  left: 120%;
}

/* Cards só-banner (product finder): varredura de luz + leve “zoom” na imagem no hover */
.pf-banner-only-inner {
  isolation: isolate;
}
.pf-banner-only-inner .pf-banner-shine.package-metal-shine-sweep {
  z-index: 8;
  border-radius: 0.65rem;
}
.pf-banner-only-inner .pf-banner-only-img {
  position: relative;
  z-index: 0;
  transition: transform 0.42s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}
.pf-banner-only.group:hover .pf-banner-only-inner .pf-banner-only-img {
  transform: scale(1.075) translateZ(0);
}
.pf-banner-only.group:hover {
  box-shadow:
    0 0 0 1px rgba(56, 189, 248, 0.2),
    0 14px 36px rgba(0, 0, 0, 0.4);
}

/* Luz em volta dos produtos */
.package-glow {
  box-shadow:
    0 0 24px hsl(var(--primary) / 0.1),
    0 0 48px hsl(var(--primary) / 0.06);
}

.package-glow:hover {
  box-shadow:
    0 0 32px hsl(var(--primary) / 0.14),
    0 0 64px hsl(var(--primary) / 0.08);
}

/* Estamos online – animação suave na bolinha */
@keyframes online-pulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(52, 211, 153, 0.5); }
  50% { opacity: 0.85; box-shadow: 0 0 0 4px rgba(52, 211, 153, 0); }
}
.online-badge-dot {
  box-shadow: 0 0 8px rgba(52, 211, 153, 0.6);
  animation: online-pulse 2s ease-in-out infinite;
}

/* Cards de estatísticas – quadrado escuro com efeito glass */
.stats-showcase {
  position: relative;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background:
    linear-gradient(180deg, rgba(14, 18, 32, 0.88), rgba(8, 10, 18, 0.96)),
    radial-gradient(circle at top, rgba(59, 130, 246, 0.08), transparent 45%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 18px 60px rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.stats-showcase::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    linear-gradient(90deg, transparent 0%, rgba(96, 165, 250, 0.12) 50%, transparent 100%);
  opacity: 0.5;
  pointer-events: none;
}

.stats-showcase-orb {
  position: absolute;
  width: 16rem;
  height: 16rem;
  border-radius: 9999px;
  filter: blur(56px);
  opacity: 0.65;
  pointer-events: none;
}

.stats-showcase-orb-left {
  top: -5rem;
  left: -3rem;
  background: radial-gradient(circle, rgba(37, 99, 235, 0.42) 0%, transparent 68%);
}

.stats-showcase-orb-right {
  right: -4rem;
  bottom: -6rem;
  background: radial-gradient(circle, rgba(96, 165, 250, 0.34) 0%, transparent 70%);
}

.stats-section-heading h2 {
  letter-spacing: -0.02em;
  text-wrap: balance;
}

.stats-section-heading p {
  text-wrap: balance;
}

.stats-cards-grid .stats-card-wrapper {
  border-radius: 1rem;
  position: relative;
  transition: transform 180ms ease, filter 180ms ease;
}
.stats-cards-grid .stats-card-inner {
  position: relative;
  border-radius: 1rem;
  background: rgba(12, 14, 24, 0.92) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4) !important;
  overflow: hidden;
}

.stats-cards-grid-compact .stats-card-wrapper {
  max-width: 30rem;
  width: 100%;
}

.stats-cards-grid-compact .stats-card-inner {
  min-height: 5.5rem;
  padding: 1.1rem 1.35rem;
}

@media (min-width: 768px) {
  .stats-cards-grid-compact .stats-card-wrapper:first-child {
    justify-self: end;
  }

  .stats-cards-grid-compact .stats-card-wrapper:last-child {
    justify-self: start;
  }
}

.stats-cards-grid .stats-card-inner::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(96, 165, 250, 0.75), transparent);
  opacity: 0.85;
}

.stats-cards-grid .stats-card-inner::after {
  content: "";
  position: absolute;
  inset: auto -20% -45% auto;
  width: 8rem;
  height: 8rem;
  border-radius: 9999px;
  background: radial-gradient(circle, rgba(59, 130, 246, 0.14) 0%, transparent 68%);
  pointer-events: none;
}

.stats-cards-grid .stats-card-wrapper:hover {
  transform: translateY(-3px);
  filter: drop-shadow(0 12px 24px rgba(37, 99, 235, 0.16));
}

/* Seção Seleção Premium */
.premium-glass-container {
  position: relative;
  z-index: 10;
  max-width: min(1280px, calc(100vw - 2rem));
  margin-left: auto;
  margin-right: auto;
  padding: 2rem 1rem;
  border-radius: 1.5rem;
}

.premium-showcase-shell {
  overflow: hidden;
  background:
    radial-gradient(ellipse 90% 70% at 50% 0%, rgba(56, 189, 248, 0.14), transparent 42%),
    radial-gradient(circle at 15% 40%, rgba(37, 99, 235, 0.12), transparent 38%),
    radial-gradient(circle at 85% 55%, rgba(59, 130, 246, 0.1), transparent 36%),
    linear-gradient(180deg, rgba(8, 20, 40, 0.98), rgba(6, 11, 22, 0.99));
  border: 1px solid rgba(59, 130, 246, 0.28);
  box-shadow:
    inset 0 1px 0 rgba(147, 197, 253, 0.08),
    0 24px 60px rgba(0, 0, 0, 0.35),
    0 0 80px rgba(37, 99, 235, 0.08);
}

.premium-showcase-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(96, 165, 250, 0.07) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(96, 165, 250, 0.07) 1px, transparent 1px);
  background-size: 44px 44px;
  opacity: 0.35;
  pointer-events: none;
}

.premium-showcase-shell::after {
  content: "";
  position: absolute;
  inset: auto 10% -6rem 10%;
  height: 11rem;
  background: radial-gradient(circle, rgba(59, 130, 246, 0.38), transparent 65%);
  filter: blur(36px);
  pointer-events: none;
}

/* Área “Destaques da loja” – fundo azul suave atrás do cardápio */
#selecao-premium {
  background:
    radial-gradient(ellipse 100% 80% at 50% 20%, rgba(37, 99, 235, 0.12), transparent 55%),
    radial-gradient(circle at 80% 60%, rgba(14, 165, 233, 0.06), transparent 40%),
    transparent;
}

.premium-showcase-header {
  position: relative;
}

/* Cabeçalho estático – hierarquia como na referência */
.premium-showcase-line1 {
  margin: 0 0 0.35rem;
  font-family: "Kanit", sans-serif;
  font-size: clamp(1.75rem, 4.2vw, 2.5rem);
  font-weight: 700;
  line-height: 1.05;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: #fff;
  text-shadow:
    0 2px 20px rgba(0, 0, 0, 0.35),
    0 0 40px rgba(59, 130, 246, 0.25);
}

.premium-showcase-line2 {
  margin: 0 0 0.5rem;
  font-size: clamp(1rem, 2.4vw, 1.25rem);
  font-weight: 600;
  line-height: 1.25;
  color: rgba(255, 255, 255, 0.88);
}

.premium-showcase-line3 {
  margin: 0;
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(147, 197, 253, 0.65);
}

.premium-showcase-kicker {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.28em;
  color: rgba(255, 255, 255, 0.38);
  margin-bottom: 0.65rem;
}

.premium-showcase-title {
  font-family: "Kanit", sans-serif;
  font-size: clamp(2.2rem, 5vw, 3.35rem);
  line-height: 0.95;
  font-weight: 700;
  text-transform: uppercase;
  color: #3b82f6;
  letter-spacing: 0.01em;
  text-shadow: 0 0 24px rgba(59, 130, 246, 0.25);
}

.premium-showcase-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin-top: 1rem;
  padding: 0.8rem 1rem;
  border-radius: 9999px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.premium-showcase-slider {
  padding-bottom: 0.5rem;
}

/* Seção Seleção Premium */
#selecao-premium .premium-selection-grid .reveal-fade-up {
  max-width: 100%;
}
#selecao-premium .premium-selection-grid .package {
  max-width: none;
}

/* Catálogo premium – cards no estilo showcase */
.premium-catalog-card:not(.premium-catalog-card-showcase) {
  min-height: 280px;
}

/* Cantos arredondados visíveis mesmo com imagem em absolute + transforms */
#selecao-premium a.premium-catalog-card.premium-catalog-card-showcase {
  border-radius: 20px !important;
  overflow: hidden !important;
  -webkit-mask-image: radial-gradient(#fff 0 0);
  mask-image: radial-gradient(#fff 0 0);
  transform: translateZ(0);
}

.premium-catalog-card.premium-catalog-card-showcase {
  display: block;
  flex: 0 0 auto;
  position: relative;
  width: min(320px, 88vw) !important;
  max-width: min(320px, 88vw) !important;
  aspect-ratio: 300 / 170;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  border-radius: 20px !important;
  overflow: hidden !important;
  border: 1px solid rgba(59, 130, 246, 0.12);
  background: #0d1020;
  box-shadow:
    0 16px 36px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.premium-catalog-card.premium-catalog-card-showcase:hover {
  transform: translateY(-4px) translateZ(0);
  border-color: rgba(59, 130, 246, 0.45);
  box-shadow:
    0 20px 42px rgba(0, 0, 0, 0.34),
    0 0 0 1px rgba(59, 130, 246, 0.12);
}

.premium-catalog-card-showcase .premium-card-media,
.premium-catalog-card-showcase .premium-card-image,
.premium-catalog-card-showcase .premium-card-overlay {
  position: absolute;
  inset: 0;
  border-radius: 20px !important;
}

.premium-catalog-card-showcase .premium-card-media {
  overflow: hidden;
}

.premium-catalog-card-showcase .premium-card-image {
  display: block;
  width: 100% !important;
  max-width: 100% !important;
  height: 100% !important;
  max-height: 100% !important;
  object-fit: cover;
  object-position: center;
  transform: scale(1.01);
  transition: transform 0.45s ease;
}

.premium-catalog-card.premium-catalog-card-showcase:hover .premium-card-image {
  transform: scale(1.06);
}

.premium-card-overlay {
  background:
    linear-gradient(180deg, rgba(8, 10, 20, 0.18) 0%, rgba(8, 10, 20, 0.58) 52%, rgba(8, 10, 20, 0.94) 100%),
    linear-gradient(90deg, rgba(37, 99, 235, 0.14), transparent 45%);
}

.premium-card-top {
  position: absolute;
  top: 0.85rem;
  left: 0.85rem;
  right: 0.85rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  z-index: 2;
}

.premium-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.42rem 0.7rem;
  border-radius: 9999px;
  background: rgba(7, 8, 15, 0.72);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: #fff;
  font-size: 0.67rem;
  font-weight: 700;
  line-height: 1;
}

.premium-chip-dot {
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 9999px;
  background: #3b82f6;
  box-shadow: 0 0 10px rgba(59, 130, 246, 0.85);
}

.premium-discount {
  padding: 0.38rem 0.62rem;
  border-radius: 9999px;
  background: linear-gradient(180deg, #ff6f6f, #ff4d4d);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 800;
  line-height: 1;
}

.premium-card-content {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 2;
}

.premium-card-subline {
  margin: 0 0 0.35rem;
  font-size: 0.62rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.2;
}

.premium-catalog-card-showcase h3 {
  margin: 0 0 0.65rem;
  color: #fff;
  font-size: 0.76rem;
  font-weight: 800;
  line-height: 1.2;
  text-transform: uppercase;
  max-width: none;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.45);
}

.premium-card-bottom {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
}

.premium-price-box {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}

.premium-price-old {
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.78rem;
  text-decoration: line-through;
}

/* Destaques da home: nunca mostrar preço “riscado” nem segunda linha de preço */
#selecao-premium .premium-catalog-card-showcase .premium-price-old {
  display: none !important;
}

.premium-price-new {
  color: #fff;
  font-size: 1.15rem;
  font-weight: 900;
  line-height: 1;
}

.premium-card-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 6.2rem;
  padding: 0.78rem 1rem;
  border-radius: 1rem;
  background: linear-gradient(180deg, #38bdf8, #2563eb) !important;
  color: #fff !important;
  font-size: 0.82rem;
  font-weight: 800;
  line-height: 1;
  border: 1px solid rgba(147, 197, 253, 0.25);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    0 10px 22px rgba(37, 99, 235, 0.4);
}

#selecao-premium .premium-card-cta {
  background: linear-gradient(180deg, #38bdf8, #2563eb) !important;
}

#selecao-premium .premium-chip-dot {
  background: #38bdf8 !important;
  box-shadow: 0 0 12px rgba(56, 189, 248, 0.95) !important;
}

#selecao-premium .premium-catalog-card-showcase .premium-card-cta:hover {
  filter: brightness(1.08);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.28),
    0 12px 28px rgba(14, 165, 233, 0.45);
}

@media (min-width: 640px) {
  .premium-glass-container {
    padding: 2.5rem 1.5rem;
    border-radius: 1.75rem;
  }

  .premium-catalog-card-showcase h3 {
    font-size: 0.82rem;
  }
}

@media (min-width: 768px) {
  .premium-glass-container {
    padding: 3rem 2rem;
    border-radius: 2rem;
  }

  .premium-catalog-card-showcase {
    width: 320px !important;
    max-width: 320px !important;
  }
}

@media (max-width: 639px) {
  .premium-showcase-line1 {
    font-size: 1.55rem;
  }

  .premium-catalog-card-showcase h3 {
    font-size: 0.68rem;
    -webkit-line-clamp: 4;
  }

  .premium-card-top {
    top: 0.45rem;
    left: 0.45rem;
    right: 0.45rem;
    gap: 0.35rem;
  }

  .premium-chip,
  .premium-discount {
    transform: scale(0.78);
    transform-origin: center;
  }

  .premium-card-content {
    left: 0.55rem;
    right: 0.55rem;
    bottom: 0.55rem;
  }

  .premium-price-old {
    font-size: 0.58rem;
  }

  .premium-price-new {
    font-size: 0.8rem;
  }

  .premium-card-bottom {
    align-items: stretch;
    gap: 0.45rem;
  }

  .premium-card-cta {
    min-width: auto;
    padding: 0.45rem 0.58rem;
    font-size: 0.62rem;
    border-radius: 0.7rem;
  }
}

/* Scroll contínuo das contas (igual avaliações) – passando para a esquerda */
@keyframes premium-scroll {
  0% { transform: translate3d(0, 0, 0); }
  100% { transform: translate3d(-50%, 0, 0); }
}
#premium-catalog-cards.premium-scroll-track {
  animation: premium-scroll 40s linear infinite;
  will-change: transform;
}
#premium-catalog-cards.premium-scroll-track:hover {
  animation-play-state: paused;
}

/* Carrossel premium – 1 slide por vez, centralizado, em todas as telas (legado) */
#premium-catalog-cards.keen-slider {
  overflow: hidden;
  width: 100%;
  margin: 0 auto;
}
#premium-catalog-cards.keen-slider .keen-slider__viewport {
  overflow: hidden;
  width: 100%;
}
#premium-catalog-cards.keen-slider .keen-slider__track {
  transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  display: flex;
  align-items: stretch;
}
#premium-catalog-cards.keen-slider .keen-slider__slide {
  min-width: 100%;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  align-items: stretch;
}
#premium-catalog-cards.keen-slider .keen-slider__slide > a {
  width: 100%;
  max-width: 100%;
}
.premium-slider-mobile .premium-card-inner {
  transition: opacity 0.35s ease;
  width: 100%;
}
.premium-slider-mobile .premium-catalog-card:not(.premium-slide-center) .premium-card-inner {
  opacity: 0.82;
}
.premium-slider-mobile .premium-catalog-card.premium-slide-center .premium-card-inner {
  opacity: 1;
}

/* Mobile: esconde scrollbar nativa do carrossel de destaques (usa barra customizada) */
@media (max-width: 767.98px) {
  #premium-catalog-cards.premium-catalog-static {
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  #premium-catalog-cards.premium-catalog-static::-webkit-scrollbar {
    width: 0;
    height: 0;
    display: none;
  }
}

/* Barra horizontal customizada (tema azul — trilho escuro, thumb ciano/azul, setas) */
.premium-hscroll-bar {
  user-select: none;
  -webkit-user-select: none;
}

.premium-hscroll-rail {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  min-height: 12px;
  padding: 3px 8px;
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.98) 0%, rgba(8, 17, 35, 0.99) 100%);
  border: 1px solid rgba(56, 189, 248, 0.38);
  border-radius: 9999px;
  box-shadow:
    0 0 0 1px rgba(2, 6, 23, 0.6),
    0 4px 14px rgba(2, 132, 199, 0.18),
    inset 0 1px 0 rgba(186, 230, 253, 0.08);
}

.premium-hscroll-gutter {
  flex: 1;
  position: relative;
  height: 7px;
  border-radius: 9999px;
  min-width: 0;
  background: rgba(2, 6, 23, 0.55);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.35);
}

.premium-hscroll-thumb {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  min-width: 36px;
  border-radius: 9999px;
  background: linear-gradient(180deg, #7dd3fc 0%, #38bdf8 45%, #0ea5e9 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.35),
    0 1px 4px rgba(14, 165, 233, 0.45);
  cursor: grab;
  touch-action: none;
  transition: background 0.15s ease, box-shadow 0.15s ease;
}

.premium-hscroll-thumb:active {
  cursor: grabbing;
  background: linear-gradient(180deg, #bae6fd 0%, #0ea5e9 50%, #0284c7 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.25),
    0 0 12px rgba(56, 189, 248, 0.5);
}

.premium-hscroll-arrow {
  flex-shrink: 0;
  width: 0;
  height: 0;
  padding: 0;
  margin: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  opacity: 0.92;
}

.premium-hscroll-arrow--left {
  border-style: solid;
  border-width: 5px 7px 5px 0;
  border-color: transparent #38bdf8 transparent transparent;
  filter: drop-shadow(0 0 4px rgba(56, 189, 248, 0.45));
}

.premium-hscroll-arrow--right {
  border-style: solid;
  border-width: 5px 0 5px 7px;
  border-color: transparent transparent transparent #38bdf8;
  filter: drop-shadow(0 0 4px rgba(56, 189, 248, 0.45));
}

.premium-hscroll-arrow:active {
  opacity: 1;
  filter: brightness(1.1) drop-shadow(0 0 6px rgba(56, 189, 248, 0.55));
}

.premium-hscroll-bar.is-collapsed {
  display: none !important;
}

/*
 * Assistente "Achar o produto perfeito": perguntas no HTML; estilos fixos aqui
 * (Tailwind CDN não cobre bem conteúdo só em JS).
 */
/* Raiz do modal: tudo em core.css (não usar Tailwind hidden/flex — evita conflito com CDN) */
.product-finder-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  box-sizing: border-box;
  padding: 1rem;
  display: none;
  align-items: center;
  justify-content: center;
  isolation: isolate;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
}
.product-finder-modal.is-open {
  display: flex !important;
}
#product-finder-modal.product-finder-modal {
  /* mantém compatibilidade com seletor por id */
  isolation: isolate;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
}
.product-finder-modal .product-finder-backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
  background: rgba(0, 0, 0, 0.82);
  pointer-events: auto;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
}
.product-finder-modal .product-finder-panel {
  z-index: 1;
  position: relative;
  width: 100%;
  max-width: 28rem;
  margin: 0 auto;
  border-radius: 1rem;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.15);
  pointer-events: auto;
  background-color: #13141f !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.06),
    0 25px 80px rgba(0, 0, 0, 0.75);
}
#product-finder-modal #product-finder-title {
  color: #fafafa;
}
#product-finder-modal #product-finder-subtitle {
  color: rgba(161, 161, 170, 0.95);
}
#product-finder-modal #product-finder-body {
  color: #fafafa;
  min-height: 160px;
}
/* Assistente: telas só dentro do modal legado ou da página /product-finder */
#product-finder-modal .pf-view:not(.is-active),
#pf-quiz-page .pf-view:not(.is-active) {
  display: none !important;
}
#product-finder-modal .pf-view.is-active,
#pf-quiz-page .pf-view.is-active {
  display: block !important;
}
.pf-lead {
  margin: 0 0 1rem;
  font-size: 0.9375rem;
  font-weight: 600;
  color: #e4e4e7;
  line-height: 1.4;
}
#product-finder-back.pf-back-hidden,
#pf-quiz-back.pf-back-hidden {
  display: none !important;
}
.pf-modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 1.25rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.pf-modal-close {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.5rem;
  border: none;
  cursor: pointer;
  background: transparent;
  color: #a1a1aa;
}
.pf-modal-close:hover {
  color: #fafafa;
  background: rgba(255, 255, 255, 0.08);
}
.pf-modal-footer {
  padding: 0 1.25rem 1.25rem;
}
#product-finder-back {
  width: 100%;
  min-height: 2.75rem;
  border-radius: 0.75rem;
  font-weight: 600;
  font-size: 0.875rem;
  cursor: pointer;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: transparent;
  color: #fafafa;
}
#product-finder-back:hover {
  background: rgba(255, 255, 255, 0.06);
}
.pf-steps {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pf-option {
  width: 100%;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.75rem;
  padding: 1rem 1.1rem;
  border-radius: 0.75rem;
  font-weight: 600;
  font-size: 0.9375rem;
  text-align: left;
  cursor: pointer;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(59, 130, 246, 0.14);
  color: #fafafa;
  transition: background 0.15s ease, border-color 0.15s ease, transform 0.12s ease;
}
.pf-option:hover {
  background: rgba(59, 130, 246, 0.26);
  border-color: rgba(96, 165, 250, 0.4);
}
.pf-option:active {
  transform: scale(0.99);
}
.pf-option-icon {
  flex-shrink: 0;
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pf-option-icon svg {
  width: 1.25rem;
  height: 1.25rem;
}
.pf-icon-cyan {
  background: rgba(6, 182, 212, 0.22);
  color: #22d3ee;
}
.pf-icon-violet {
  background: rgba(139, 92, 246, 0.22);
  color: #a78bfa;
}
.pf-icon-orange {
  background: rgba(249, 115, 22, 0.22);
  color: #fb923c;
}
.pf-icon-pink {
  background: rgba(236, 72, 153, 0.22);
  color: #f472b6;
}
.pf-icon-green {
  background: rgba(34, 197, 94, 0.22);
  color: #4ade80;
}
.pf-icon-amber {
  background: rgba(245, 158, 11, 0.22);
  color: #fbbf24;
}
.pf-fallback {
  font-size: 1.15rem;
  line-height: 1;
}
.pf-muted-text {
  font-size: 0.875rem;
  line-height: 1.5;
  color: rgba(161, 161, 170, 0.95);
  margin: 0 0 1rem;
}
.pf-link-categories {
  display: inline-flex;
  width: 100%;
  box-sizing: border-box;
  justify-content: center;
  align-items: center;
  min-height: 2.75rem;
  border-radius: 0.75rem;
  font-weight: 600;
  font-size: 0.875rem;
  background: linear-gradient(180deg, #38bdf8, #0284c7);
  color: #fff !important;
  text-decoration: none;
  border: 1px solid rgba(255, 255, 255, 0.22);
}
.pf-link-categories:hover {
  filter: brightness(1.06);
}

/* ========== Checkout minimalista (bordas azul-ardósia — sem “branco” no contorno) ========== */
#checkout.checkout-page .checkout-card {
  border-color: rgba(24, 42, 78, 0.92) !important;
  background: rgba(12, 22, 42, 0.45) !important;
  box-shadow: none !important;
}

#checkout.checkout-page .checkout-card > .border-b {
  border-color: rgba(30, 52, 92, 0.55) !important;
}

#checkout.checkout-page .checkout-gateway-btn {
  border-color: rgba(28, 48, 88, 0.88) !important;
  background: rgba(8, 16, 36, 0.35) !important;
  box-shadow: none !important;
}

#checkout.checkout-page .checkout-gateway-btn:hover {
  border-color: rgba(59, 130, 246, 0.22) !important;
  background: rgba(255, 255, 255, 0.04) !important;
}

#checkout.checkout-page .checkout-gateway-btn[data-selected='true'] {
  border-color: rgba(59, 130, 246, 0.45) !important;
  background: rgba(59, 130, 246, 0.08) !important;
}

#checkout.checkout-page .checkout-gateway-btn .size-10.border {
  border-color: rgba(32, 55, 98, 0.75) !important;
}

/* Badges unificados (azul suave) */
#checkout.checkout-page .checkout-pill-badge {
  background: rgba(59, 130, 246, 0.12) !important;
  color: #93c5fd !important;
  border: 1px solid rgba(59, 130, 246, 0.22) !important;
}

#checkout.checkout-page .checkout-pill-badge--muted {
  background: rgba(148, 163, 184, 0.08) !important;
  color: #cbd5e1 !important;
  border-color: rgba(148, 163, 184, 0.18) !important;
}

#checkout.checkout-page .checkout-tag {
  display: inline-flex;
  align-items: center;
  padding: 0.125rem 0.5rem;
  border-radius: 0.375rem;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  background: rgba(59, 130, 246, 0.12);
  color: #93c5fd;
  border: 1px solid rgba(59, 130, 246, 0.22);
}

#checkout.checkout-page .checkout-tag--ghost {
  text-transform: none;
  font-weight: 500;
  background: rgba(15, 28, 52, 0.5);
  color: #94a3b8;
  border-color: rgba(28, 48, 88, 0.65);
}

#checkout.checkout-page .checkout-promo-shell {
  border-color: rgba(24, 42, 78, 0.9) !important;
  background: rgba(8, 16, 36, 0.4) !important;
}

#checkout.checkout-page .checkout-promo-shell > .border-b {
  border-color: rgba(30, 52, 92, 0.5) !important;
}

#checkout.checkout-page .checkout-promo-card {
  border-color: rgba(26, 45, 82, 0.85) !important;
  background: rgba(12, 22, 42, 0.4) !important;
  box-shadow: none !important;
}

#checkout.checkout-page .checkout-promo-card:hover {
  border-color: rgba(59, 130, 246, 0.22) !important;
  background: rgba(59, 130, 246, 0.04) !important;
}

#checkout.checkout-page .checkout-promo-pct {
  background: rgba(59, 130, 246, 0.9) !important;
  color: #fff !important;
  font-weight: 700;
  box-shadow: none !important;
}

#checkout.checkout-page .checkout-promo-price {
  color: #93c5fd !important;
}

#checkout.checkout-page .checkout-promo-add {
  border-radius: 9999px !important;
  font-weight: 600 !important;
}

#checkout.checkout-page .checkout-coupon-input {
  border-color: rgba(32, 55, 98, 0.78) !important;
  background: rgba(8, 16, 36, 0.45) !important;
}

#checkout.checkout-page .checkout-coupon-input:focus {
  outline: none !important;
  border-color: rgba(59, 130, 246, 0.4) !important;
  box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.12) !important;
}

#checkout.checkout-page .checkout-coupon-btn {
  border-radius: 0.5rem !important;
}

#checkout.checkout-page .checkout-pricing-summary {
  border-color: rgba(255, 255, 255, 0.08) !important;
  background: rgba(255, 255, 255, 0.02) !important;
}

#checkout.checkout-page #pay-button.checkout-pay-btn {
  border-radius: 9999px !important;
  background: #3b82f6 !important;
  border: 1px solid rgba(147, 197, 253, 0.35) !important;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.1) inset !important;
}

#checkout.checkout-page #pay-button.checkout-pay-btn:hover:not(:disabled) {
  background: #2563eb !important;
  filter: none !important;
}

/* Itens do carrinho no resumo */
#checkout.checkout-page .checkout-line-item {
  border-color: rgba(26, 45, 82, 0.88) !important;
  background: rgba(10, 20, 40, 0.4) !important;
}

#checkout.checkout-page .checkout-line-item [data-cart-action] {
  border-color: rgba(32, 55, 98, 0.72) !important;
  pointer-events: auto !important;
  cursor: pointer;
  position: relative;
  z-index: 1;
}

#checkout.checkout-page .checkout-line-item [data-cart-action='remove'] {
  border-color: rgba(148, 163, 184, 0.25) !important;
  background: rgba(148, 163, 184, 0.08) !important;
  color: #94a3b8 !important;
}

#checkout.checkout-page .checkout-line-item [data-cart-action='remove']:hover {
  border-color: rgba(248, 113, 113, 0.35) !important;
  background: rgba(248, 113, 113, 0.1) !important;
  color: #fca5a5 !important;
}

#checkout.checkout-page .checkout-line-item .size-12.rounded-lg.border {
  border-color: rgba(28, 48, 88, 0.75) !important;
}

#checkout.checkout-page .checkout-line-item input[data-cart-action='input'] {
  border-color: rgba(32, 55, 98, 0.72) !important;
  background: rgba(8, 16, 36, 0.4) !important;
}

/* Separadores internos do resumo */
#checkout.checkout-page [role='none'].bg-border.h-px,
#checkout.checkout-page .shrink-0.bg-border.h-px {
  background-color: rgba(36, 58, 102, 0.45) !important;
}

/* Checkout – inputs (borda azul-ardósia; foco azul) */
#checkout #personal-info input[type='text']:not([hidden]),
#checkout #creditcard-form input[type='text'],
#checkout #personal-info input[type='tel'],
#checkout #phone-field-wrapper input[type='tel'],
#checkout #creditcard-form select {
  border-radius: 0.5rem !important;
  border: 1px solid rgba(32, 55, 98, 0.78) !important;
  background-color: rgba(8, 16, 36, 0.45) !important;
  padding-left: 0.75rem !important;
  padding-right: 0.75rem !important;
}

#checkout #personal-info input:focus,
#checkout #creditcard-form input:focus,
#checkout #creditcard-form select:focus,
#checkout #phone-field-wrapper input:focus {
  outline: none !important;
  border-color: rgba(59, 130, 246, 0.45) !important;
  box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.12) !important;
}

/* Checkout – Oferta Especial (layout ícone) */
.checkout-promo-section .checkout-promo-card .relative.w-16 {
  display: flex;
  align-items: center;
  justify-content: center;
}

.checkout-promo-section .checkout-promo-add:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

/* ========== Página PIX / pagamento (bordas azul-ardósia) ========== */
section.payment-page {
  --border: 217 38% 14%;
}

section.payment-page .payment-card.border {
  border-color: rgba(24, 42, 78, 0.92) !important;
  background: rgba(12, 22, 42, 0.45) !important;
  box-shadow: none !important;
}

/* Moldura do QR: cantos arredondados (calc(var(--radius)+16px) quebra se --radius não existir) */
section.payment-page .payment-qr-frame {
  border-radius: 1.25rem !important;
  overflow: hidden !important;
}

section.payment-page .payment-qr-frame.border {
  border-color: rgba(32, 55, 98, 0.78) !important;
  background: rgba(8, 16, 36, 0.4) !important;
}

section.payment-page .payment-qr-img,
section.payment-page .payment-qr-frame img {
  border-radius: 0.75rem !important;
  display: block !important;
}

section.payment-page .payment-pix-divider.border-t,
section.payment-page .payment-card .border-t {
  border-top-color: rgba(30, 52, 92, 0.55) !important;
}

section.payment-page .payment-pix-input.border,
section.payment-page .payment-card input[type='text'][readonly] {
  border-color: rgba(32, 55, 98, 0.78) !important;
  background: rgba(8, 16, 36, 0.45) !important;
  color: #e2e8f0 !important;
}

section.payment-page .payment-pix-input.border:focus,
section.payment-page .payment-card input[type='text'][readonly]:focus {
  outline: none !important;
  border-color: rgba(59, 130, 246, 0.45) !important;
  box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.12) !important;
}

/* Botão Copiar — azul + linha (ícone + texto); CC costuma forçar flex-col em .btn-primary */
section.payment-page .payment-copy-btn {
  display: inline-flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0 !important;
  box-sizing: border-box !important;
  height: 2.5rem !important;
  min-height: 2.5rem !important;
  max-height: 2.5rem !important;
  background: #3b82f6 !important;
  color: #fff !important;
  border: 1px solid rgba(147, 197, 253, 0.4) !important;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.08) inset !important;
}

section.payment-page .payment-copy-btn-inner {
  display: inline-flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.375rem !important;
  line-height: 1 !important;
}

section.payment-page .payment-copy-btn:hover:not(:disabled) {
  background: #2563eb !important;
  border-color: rgba(191, 219, 254, 0.45) !important;
  color: #fff !important;
}

section.payment-page .payment-copy-btn svg {
  display: block !important;
  flex-shrink: 0 !important;
  color: #fff !important;
  stroke: #fff !important;
}

section.payment-page .payment-copy-label {
  font-weight: 600 !important;
  font-size: 0.875rem !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

/* Faixa de progresso no topo do card PIX */
section.payment-page .payment-top-progress {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Card “Como pagar”: contorno escuro + faixa azul à esquerda */
section.payment-page .payment-help-card.border {
  border-color: rgba(24, 42, 78, 0.92) !important;
  background: rgba(12, 22, 42, 0.45) !important;
  border-left-color: rgba(59, 130, 246, 0.72) !important;
  border-left-width: 4px !important;
}

/* ===== Barras de rolagem (tema escuro + azul) — Chrome / Edge / Safari / Firefox ===== */
html {
  color-scheme: dark;
  scrollbar-width: thin;
  scrollbar-color: #38bdf8 #0c1220;
}

html::-webkit-scrollbar,
body::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

html::-webkit-scrollbar-track,
body::-webkit-scrollbar-track {
  background: linear-gradient(180deg, #0a0f18 0%, #0f172a 100%);
  border-radius: 999px;
}

html::-webkit-scrollbar-thumb,
body::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #38bdf8 0%, #0ea5e9 50%, #2563eb 100%);
  border-radius: 999px;
  border: 2px solid rgba(10, 15, 24, 0.9);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 0 16px rgba(56, 189, 248, 0.22);
}

html::-webkit-scrollbar-thumb:hover,
body::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, #7dd3fc 0%, #38bdf8 55%, #0ea5e9 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.25),
    0 0 20px rgba(56, 189, 248, 0.38);
}

/* Lista de produtos no assistente (product-finder) */
#pf-results-mount {
  scrollbar-width: thin;
  scrollbar-color: #38bdf8 rgba(15, 23, 42, 0.85);
}

#pf-results-mount::-webkit-scrollbar {
  width: 9px;
  height: 9px;
}

#pf-results-mount::-webkit-scrollbar-track {
  background: rgba(8, 14, 26, 0.9);
  border-radius: 999px;
  margin: 4px 0;
}

#pf-results-mount::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #38bdf8 0%, #2563eb 100%);
  border-radius: 999px;
  border: 2px solid rgba(8, 14, 26, 0.95);
  box-shadow: 0 0 10px rgba(14, 165, 233, 0.35);
}

#pf-results-mount::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, #7dd3fc 0%, #38bdf8 100%);
  box-shadow: 0 0 14px rgba(56, 189, 248, 0.45);
}

/* Caixa de presente flutuante (cupom) — fixo na lateral direita, balanço + abre ao clicar */
@keyframes gift-cupom-wiggle {
  0%,
  100% {
    transform: rotate(-5deg);
  }
  50% {
    transform: rotate(5deg);
  }
}

.gift-cupom-fab {
  position: fixed;
  left: auto;
  right: max(0.35rem, env(safe-area-inset-right, 0px));
  transform: none;
  top: auto;
  /* Ancorado embaixo: fica mais baixo e consistente em qualquer altura de header */
  bottom: max(6.5rem, calc(env(safe-area-inset-bottom, 0px) + 5.25rem));
  z-index: 45;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  padding: 0.25rem;
  margin: 0;
  background: transparent;
  cursor: pointer;
  border-radius: 0.75rem;
  -webkit-tap-highlight-color: transparent;
}

/* Maior no mobile e ainda maior no desktop */
.gift-cupom-fab .gift-cupom-svg {
  width: clamp(3.35rem, 14vw, 4.25rem);
  height: clamp(3.35rem, 14vw, 4.25rem);
  display: block;
  transform-origin: 50% 88%;
  animation: gift-cupom-wiggle 2.4s ease-in-out infinite;
  filter: drop-shadow(0 4px 14px rgba(220, 38, 38, 0.4));
}

@media (min-width: 640px) {
  .gift-cupom-fab .gift-cupom-svg {
    width: 4.75rem;
    height: 4.75rem;
  }
  .gift-cupom-fab {
    bottom: max(5.5rem, calc(env(safe-area-inset-bottom, 0px) + 4.25rem));
    right: max(0.75rem, env(safe-area-inset-right, 0px));
  }
}

@media (min-width: 1024px) {
  .gift-cupom-fab .gift-cupom-svg {
    width: 5.25rem;
    height: 5.25rem;
  }
}

/* Ao abrir: para o balanço e levanta a tampa */
.gift-cupom-fab.is-open .gift-cupom-svg {
  animation: none;
  transform: rotate(0deg);
}

.gift-cupom-lid {
  transform-origin: 32px 32px;
  transform-box: view-box;
  transition:
    transform 0.55s cubic-bezier(0.33, 1.24, 0.64, 1),
    filter 0.35s ease;
}

.gift-cupom-fab.is-open .gift-cupom-lid {
  transform: rotate(-42deg) translateY(-5px);
  filter: drop-shadow(-2px 4px 6px rgba(0, 0, 0, 0.25));
}

.gift-cupom-glow {
  opacity: 0;
  transition: opacity 0.4s ease 0.08s;
  pointer-events: none;
}

.gift-cupom-fab.is-open .gift-cupom-glow {
  opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
  .gift-cupom-fab .gift-cupom-svg {
    animation: none;
  }

  .gift-cupom-lid {
    transition-duration: 0.12s;
  }

  .gift-cupom-fab.is-open .gift-cupom-lid {
    transform: rotate(-36deg) translateY(-3px);
  }
}

.gift-cupom-fab:hover .gift-cupom-svg,
.gift-cupom-fab:focus-visible .gift-cupom-svg {
  filter: drop-shadow(0 5px 18px rgba(251, 191, 36, 0.5));
}

.gift-cupom-fab:focus-visible {
  outline: 2px solid rgba(59, 130, 246, 0.8);
  outline-offset: 3px;
}

/* Tooltip à esquerda do botão (lateral direita da tela — não estoura pra fora) */
.gift-cupom-tooltip {
  position: absolute;
  right: 100%;
  left: auto;
  top: 50%;
  bottom: auto;
  transform: translateY(-50%);
  margin-right: 0.5rem;
  padding: 0.45rem 0.75rem;
  border-radius: 0.75rem;
  border: 1px solid rgba(96, 165, 250, 0.45);
  background: rgba(2, 6, 23, 0.96);
  color: #e0f2fe;
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  white-space: nowrap;
  box-shadow:
    0 12px 28px rgba(15, 23, 42, 0.55),
    0 0 0 1px rgba(30, 58, 138, 0.25);
  transition: opacity 0.2s ease;
  z-index: 2;
}