/* ============================
   SweetMC - Global polish pack
   ============================ */

/* Remove spinner number inputs */
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;
}

/* Motion defaults (mais “premium”) */
:root {
  --ease-out-smooth: cubic-bezier(.22, 1, .36, 1);
  --ease-in-smooth: cubic-bezier(.4, 0, .2, 1);

  --anim-fast: 180ms;
  --anim-med: 420ms;
  --anim-slow: 850ms;

  --overlay-closed: rgba(0, 0, 0, 0);
  --overlay-open: rgba(0, 0, 0, 0.78);
  --drawer-offset: 520px;
}

/* ============================
   Overlay / Drawer animations
   ============================ */
@keyframes fade-in {
  from { background-color: var(--overlay-closed); backdrop-filter: blur(0px); }
  to   { background-color: var(--overlay-open);   backdrop-filter: blur(6px); }
}
@keyframes fade-out {
  from { background-color: var(--overlay-open);   backdrop-filter: blur(6px); }
  to   { background-color: var(--overlay-closed); backdrop-filter: blur(0px); }
}

@keyframes slide-in {
  from { transform: translate3d(var(--drawer-offset), 0, 0); }
  to   { transform: translate3d(0, 0, 0); }
}
@keyframes slide-out {
  from { transform: translate3d(0, 0, 0); }
  to   { transform: translate3d(var(--drawer-offset), 0, 0); }
}

/* Cart drawer */
#cart-drawer {
  will-change: background-color, backdrop-filter;
}

#cart-drawer[data-state="open"] {
  animation: fade-in var(--anim-med) var(--ease-out-smooth) forwards;
}
#cart-drawer[data-state="closed"] {
  animation: fade-out var(--anim-med) var(--ease-out-smooth) forwards;
}

#cart-drawer[data-state="open"] > div {
  will-change: transform;
  animation: slide-in var(--anim-med) var(--ease-out-smooth) forwards;
}
#cart-drawer[data-state="closed"] > div {
  will-change: transform;
  animation: slide-out var(--anim-med) var(--ease-out-smooth) forwards;
}

/* Lock scroll when cart open */
body.cart-open {
  overflow: hidden;
  padding-right: var(--scrollbar-width, 0px);
}

/* ============================
   Dialog animations (mais suave)
   ============================ */
@keyframes dialog-in {
  from { opacity: 0; transform: translate3d(0, 8px, 0) scale(0.94); }
  to   { opacity: 1; transform: translate3d(0, 0, 0) scale(1); }
}
@keyframes dialog-out {
  from { opacity: 1; transform: translate3d(0, 0, 0) scale(1); }
  to   { opacity: 0; transform: translate3d(0, 8px, 0) scale(0.94); }
}

.dialog[data-state="open"] {
  animation: fade-in var(--anim-med) var(--ease-out-smooth) forwards;
}
.dialog[data-state="closed"] {
  animation: fade-out var(--anim-med) var(--ease-out-smooth) forwards;
}

.dialog[data-state="open"] > div {
  will-change: transform, opacity;
  animation: dialog-in var(--anim-fast) var(--ease-out-smooth) forwards;
}
.dialog[data-state="closed"] > div {
  will-change: transform, opacity;
  animation: dialog-out var(--anim-fast) var(--ease-in-smooth) forwards;
}

/* ============================
   Reveal on scroll
   ============================ */
.reveal-fade-up {
  opacity: 0;
  transform: translate3d(0, 22px, 0);
  transition:
    opacity 320ms var(--ease-out-smooth),
    transform 420ms var(--ease-out-smooth);
  transition-delay: var(--delay, 0s);
  will-change: opacity, transform;
}
.reveal-fade-up.visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

/* ============================
   Iframe (CentralCart) polish
   ============================ */
.centralcart-content iframe {
  aspect-ratio: 16 / 9;
  border-radius: 0.75rem;
  width: 100%;
  height: auto;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.25);
}

/* ============================
   Background grid + FOTO + FADE
   (foto começa em cima e vai escurecendo até sumir)
   ============================ */
.grid-background {
  background-image:
    linear-gradient(
      to bottom,
      rgba(10,11,20,0.00) 0%,
      rgba(10,11,20,0.45) 52%,
      rgba(10,11,20,0.82) 78%,
      rgba(10,11,20,1) 100%
    ),
    radial-gradient(900px 420px at 50% 10%, rgba(0,0,0,0.12), rgba(10,11,20,0.72)),
    url("https://i.imgur.com/PBtbHja.png"),
    linear-gradient(to right, hsla(0,0%,100%,.035) 1px, transparent 1px),
    linear-gradient(to bottom, hsla(0,0%,100%,.035) 1px, transparent 1px);

  background-size:
    cover,
    cover,
    cover,
    40px 40px,
    40px 40px;

  background-position:
    center,
    center,
    center,
    center,
    center;

  background-repeat:
    no-repeat,
    no-repeat,
    no-repeat,
    repeat,
    repeat;

  mask-image: none;
}

/* ============================
   HERO / BANNER: fade suave no final da imagem
   Use esta classe no container que tem a imagem do banner:
   ex: <section class="hero-bg ...">...</section>
   ============================ */
/* ============================
   HERO / BANNER: fade suave no final da imagem
   Use esta classe no container que tem a imagem do banner:
   ex: <section class="hero-bg ...">...</section>
   ============================ */
.hero-bg {
  position: relative;
  overflow: hidden;
  background-image: var(--background-image);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.hero-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(900px 480px at 50% 15%, rgba(0,0,0,0.04), rgba(10,11,20,0.38)),
    linear-gradient(
      to bottom,
      rgba(10,11,20,0.00) 0%,
      rgba(10,11,20,0.12) 45%,
      rgba(10,11,20,0.40) 68%,
      rgba(10,11,20,0.78) 84%,
      rgba(10,11,20,1) 100%
    );
}

/* Se tiver conteúdo no hero, garante que fica acima do overlay */
.hero-bg > * {
  position: relative;
  z-index: 1;
}

/* Optional mask helper */
.custom-bg-mask {
  mask-image: linear-gradient(
    hsl(var(--background)),
    rgba(0, 0, 0, 0.35),
    rgba(0, 0, 0, 0)
  );
}

/* ============================
   Loading shimmer helper
   ============================ */
@keyframes loading {
  0% { left: -60%; }
  100% { left: 120%; }
}

/* dashed divider */
.detail-dash {
  background-image: linear-gradient(
    to right,
    rgba(255, 255, 255, 0.12) 50%,
    hsl(var(--foreground) / 0) 0%
  );
  background-position: center bottom;
  background-size: 16px;
  background-repeat: repeat-x;
  width: 100%;
  height: 1px;
}

/* ============================
   Custom scrollbar (mais clean)
   ============================ */
.custom-scrollbar::-webkit-scrollbar {
  width: 4px;
  height: 4px;
}
.custom-scrollbar::-webkit-scrollbar-track {
  background: transparent;
}
.custom-scrollbar::-webkit-scrollbar-thumb {
  background: hsl(var(--primary) / 0.9);
  border-radius: 999px;
}
.custom-scrollbar::-webkit-scrollbar-thumb:hover {
  background: hsl(var(--primary));
}

/* ============================
   Float animation
   ============================ */
.animate-float {
  animation: floatRandom 14s var(--ease-out-smooth) infinite;
  will-change: transform;
}
@keyframes floatRandom {
  0%   { transform: translate3d(0, 0, 0) rotate(0deg); }
  20%  { transform: translate3d(-6px, -10px, 0) rotate(-1deg); }
  40%  { transform: translate3d( 4px,  -5px, 0) rotate( 1deg); }
  60%  { transform: translate3d(-4px, -12px, 0) rotate(-1.5deg); }
  80%  { transform: translate3d( 3px,  -7px, 0) rotate( 1deg); }
  100% { transform: translate3d(0, 0, 0) rotate(0deg); }
}

/* ============================
   Gradient text (menos “enjoativo”)
   ============================ */
@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.85)),
    hsl(var(--primary) / 0.65)),
    hsl(var(--primary)),
    hsl(var(--primary) / 0.7)),
    hsl(var(--primary))
  );
  background-size: 260% 260%;
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: gradient-shift 3.2s var(--ease-out-smooth) infinite;
}

/* ============================
   Glass hover shine (mais elegante)
   ============================ */
.glass,
.glass-secondary {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  z-index: 0;
}

.glass::after {
  content: "";
  transition: transform var(--anim-slow) var(--ease-out-smooth), opacity var(--anim-slow) var(--ease-out-smooth);
  background: linear-gradient(
    to right,
    transparent,
    rgba(255, 255, 255, 0.28),
    transparent
  );
  opacity: 0;
  width: 140%;
  height: 140%;
  position: absolute;
  left: -160%;
  top: -20%;
  z-index: 1;
  transform: rotate(25deg);
  filter: blur(10px);
  pointer-events: none;
}

.glass:hover::after {
  opacity: 1;
  transform: translate3d(240%, 0, 0) rotate(25deg);
}

.glass-secondary::after {
  content: "";
  transition: transform var(--anim-slow) var(--ease-out-smooth), opacity var(--anim-slow) var(--ease-out-smooth);
  background: linear-gradient(
    to right,
    transparent,
    hsl(var(--secondary) / 0.22),
    transparent
  );
  opacity: 0;
  width: 170%;
  height: 170%;
  position: absolute;
  left: -190%;
  top: -35%;
  z-index: 1;
  transform: rotate(25deg);
  filter: blur(14px);
  pointer-events: none;
}

.glass-secondary:hover::after {
  opacity: 1;
  transform: translate3d(260%, 0, 0) rotate(25deg);
}

/* ============================
   FAQ (details/summary)
   ============================ */
.faq-item .faq-content {
  overflow: hidden;
  transition: height 300ms var(--ease-out-smooth);
  will-change: height;
}
.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: '';
}

/* ============================
   Reduced motion (acessibilidade)
   ============================ */
@media (prefers-reduced-motion: reduce) {
  * {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important;
  }
}