/* =============================================================================
   Sombrio Storefront — Animation Layer
   Import this AFTER luxury.css.
   Targets only transform/opacity for 60fps GPU compositing.
   ============================================================================= */

/* ─── Custom Cursor ─────────────────────────────────────────────────────────── */

.has-custom-cursor,
.has-custom-cursor * { cursor: none !important; }

.scursor-outer {
  position: fixed;
  top: 0; left: 0;
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 2px solid var(--cursor-default, var(--gold, #c9a961));
  background: rgba(201, 169, 97, 0.06);  /* tint stays subtle */
  pointer-events: none;
  z-index: 9998;
  will-change: transform;
  transition:
    width 0.18s ease,
    height 0.18s ease,
    border-color 0.18s ease,
    background-color 0.18s ease;
}

.scursor-outer.scursor-hover {
  width: 52px; height: 52px;
  border-color: var(--cursor-hover, #2dd4bf);
  background: rgba(45, 212, 191, 0.1);
}

.scursor-outer.scursor-product {
  width: 42px; height: 42px;
  border-color: var(--cursor-default, var(--gold, #c9a961));
  background: transparent;
  border-style: dashed;
}

.scursor-inner {
  position: fixed;
  top: 0; left: 0;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--cursor-default, var(--gold, #c9a961));
  pointer-events: none;
  z-index: 9999;
  will-change: transform;
  transition: background-color 0.15s, transform 0.1s;
}

.scursor-inner.scursor-inner-hover { background: var(--cursor-hover, #2dd4bf); }
.scursor-inner.scursor-inner-product { transform: translate(-50%, -50%) scale(0) !important; }


/* ─── Scroll Reveals ─────────────────────────────────────────────────────────── */

.s-reveal,
.s-stagger-child {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform;
}

.s-reveal.s-revealed,
.s-stagger-child.s-revealed {
  opacity: 1;
  transform: translateY(0);
}

/* Delay variants */
.s-reveal-delay-1 { transition-delay: 0.08s; }
.s-reveal-delay-2 { transition-delay: 0.16s; }
.s-reveal-delay-3 { transition-delay: 0.24s; }
.s-reveal-delay-4 { transition-delay: 0.32s; }
.s-reveal-delay-5 { transition-delay: 0.40s; }

/* Fade-from-left variant */
.s-reveal-left {
  opacity: 0;
  transform: translateX(-24px);
  transition:
    opacity 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}
.s-reveal-left.s-revealed {
  opacity: 1;
  transform: translateX(0);
}

/* Scale-up variant */
.s-reveal-scale {
  opacity: 0;
  transform: scale(0.92);
  transition:
    opacity 0.5s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.s-reveal-scale.s-revealed {
  opacity: 1;
  transform: scale(1);
}


/* ─── Button Hover Glow + Tap ─────────────────────────────────────────────────── */

.btn, .btn-gold {
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    opacity 0.18s;
  will-change: transform, box-shadow;
}

.btn:hover, .btn-gold:hover {
  transform: scale(1.05);
  box-shadow: 0 0 24px 4px rgba(201, 169, 97, 0.35);
}

.btn.btn-tapped, .btn-gold.btn-tapped {
  transform: scale(0.97);
  transition: transform 0.08s ease;
}

.btn-secondary {
  transition: transform 0.18s ease, box-shadow 0.18s ease;
  will-change: transform, box-shadow;
}
.btn-secondary:hover {
  transform: scale(1.04);
  box-shadow: 0 0 20px 3px rgba(201, 169, 97, 0.2);
}


/* ─── Glassmorphism ───────────────────────────────────────────────────────────── */

.s-glass {
  background: rgba(10, 22, 40, 0.7);
  border: 1px solid rgba(201, 169, 97, 0.15);
  border-radius: 16px;
  /* backdrop-filter added after .s-glass-loaded to avoid CLS */
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  transition: backdrop-filter 0.4s ease, background 0.3s ease;
}

.s-glass.s-glass-loaded {
  backdrop-filter: blur(18px) saturate(1.4);
  -webkit-backdrop-filter: blur(18px) saturate(1.4);
}

/* Frosted overlay (hero sections) */
.frosted-overlay {
  background: rgba(10, 22, 40, 0.55);
  backdrop-filter: blur(8px) saturate(1.2);
  -webkit-backdrop-filter: blur(8px) saturate(1.2);
}


/* ─── Typography Letter Reveal ───────────────────────────────────────────────── */

.s-letter-reveal .s-letter {
  display: inline-block;
  opacity: 0;
  transform: translateY(12px);
  transition:
    opacity 0.35s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: calc(var(--i) * 0.028s);
  will-change: opacity, transform;
}

.s-letter-reveal.s-letter-revealed .s-letter {
  opacity: 1;
  transform: translateY(0);
}


/* ─── Gold Spinner ────────────────────────────────────────────────────────────── */

@keyframes gold-spin {
  to { transform: rotate(360deg); }
}

.gold-spinner {
  display: inline-block;
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 3px solid rgba(201, 169, 97, 0.2);
  border-top-color: var(--gold, #c9a961);
  animation: gold-spin 0.9s linear infinite;
  will-change: transform;
}

.gold-spinner.gold-spinner-sm { width: 20px; height: 20px; border-width: 2px; }
.gold-spinner.gold-spinner-lg { width: 48px; height: 48px; border-width: 4px; }


/* ─── Form Animations ─────────────────────────────────────────────────────────── */

/* Shake on invalid */
@keyframes s-shake {
  0%, 100% { transform: translateX(0); }
  15%       { transform: translateX(-8px); }
  30%       { transform: translateX(8px); }
  45%       { transform: translateX(-6px); }
  60%       { transform: translateX(6px); }
  75%       { transform: translateX(-3px); }
  90%       { transform: translateX(3px); }
}

.s-shake { animation: s-shake 0.5s ease-in-out; }

/* Success pulse */
@keyframes s-success-pulse {
  0%   { transform: scale(1); box-shadow: 0 0 0 0 rgba(52, 211, 153, 0.4); }
  40%  { transform: scale(1.06); box-shadow: 0 0 0 8px rgba(52, 211, 153, 0); }
  100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(52, 211, 153, 0); }
}

.s-success-pulse { animation: s-success-pulse 0.6s ease-out; }

/* Input focus glow (CSS version for non-React forms) */
input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--gold, #c9a961);
  box-shadow: 0 0 0 3px rgba(201, 169, 97, 0.3);
  transform: scale(1.01);
  transition: border-color 0.18s, box-shadow 0.18s, transform 0.18s;
}

/* Error state */
input.is-error,
select.is-error,
textarea.is-error {
  border-color: #f87171;
  box-shadow: 0 0 0 3px rgba(248, 113, 113, 0.25);
}

/* Success state */
input.is-success,
select.is-success,
textarea.is-success {
  border-color: #34d399;
  box-shadow: 0 0 0 3px rgba(52, 211, 153, 0.2);
}


/* ─── Page Transition ─────────────────────────────────────────────────────────── */

.page-fade-overlay {
  position: fixed;
  inset: 0;
  background: var(--navy, #0a1628);
  pointer-events: none;
  z-index: 9000;
  opacity: 0;
  transition: opacity 0.1s ease;
}

.page-fade-overlay.page-fade-out { opacity: 1; }

.page-fade-overlay.page-fade-in {
  opacity: 1;
  transition: opacity 0.12s ease;
}


/* ─── Hero Parallax ──────────────────────────────────────────────────────────── */

.hero { overflow: hidden; }

.hero-bg,
[data-parallax-layer] {
  will-change: transform;
  /* transform set by animations.js via inline style */
}


/* ─── Member Badges (storefront product cards) ───────────────────────────────── */

.badge-member {
  position: absolute;
  top: 10px; right: 10px;
  background: linear-gradient(135deg, rgba(201,169,97,0.9), rgba(168,139,72,0.9));
  color: #0a1628;
  font-size: 10px;
  font-weight: 800;
  padding: 3px 8px;
  border-radius: 4px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  backdrop-filter: blur(4px);
  z-index: 2;
}

.badge-kit {
  position: absolute;
  top: 10px; left: 10px;
  background: linear-gradient(135deg, rgba(45,212,191,0.85), rgba(13,148,136,0.85));
  color: #0a1628;
  font-size: 10px;
  font-weight: 800;
  padding: 3px 8px;
  border-radius: 4px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  backdrop-filter: blur(4px);
  z-index: 2;
}

/* Member price display */
.member-price-block {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.price-original {
  font-size: 13px;
  color: rgba(26,26,26,0.45);
  text-decoration: line-through;
}
.price-member {
  font-size: 16px;
  font-weight: 700;
  color: var(--gold, #c9a961);
}
.price-savings {
  font-size: 12px;
  color: #34d399;
  font-weight: 600;
}

/* Member-exclusive lock overlay on cards */
.product-card.member-exclusive-locked .photo::after {
  content: '🔒 Member Only';
  position: absolute;
  inset: 0;
  background: rgba(10, 22, 40, 0.65);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold, #c9a961);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
}
.product-card.member-exclusive-locked .photo { position: relative; }


/* ─── Micro-interactions ──────────────────────────────────────────────────────── */

/* Product card hover: subtle lift */
.product-card {
  transition: transform 0.22s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.22s ease;
  will-change: transform, box-shadow;
}
.product-card:hover {
  transform: translateY(-4px) scale(1.01);
  box-shadow: 0 16px 40px rgba(10, 22, 40, 0.2);
}

/* Category pill hover */
.cat-pill {
  transition: transform 0.18s ease, background-color 0.18s ease, color 0.18s ease;
}
.cat-pill:hover {
  transform: translateY(-1px);
}

/* Cart link pulse when item added */
@keyframes cart-pulse {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.3); }
  100% { transform: scale(1); }
}
.cart-count.cart-pulse { animation: cart-pulse 0.3s ease; }


/* Dashboard kill-switch: hide custom cursor + restore native */
.cursor-disabled .scursor-outer,
.cursor-disabled .scursor-inner { display: none !important; }
.cursor-disabled.has-custom-cursor * { cursor: auto !important; }

/* ── Accessibility: respect prefers-reduced-motion ─────────────────────────── */
/* When user has reduced motion enabled, kill transitions & reveal scroll content immediately. */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .s-reveal { opacity: 1 !important; transform: none !important; }
  .scursor-outer, .scursor-inner { display: none !important; }
  .has-custom-cursor * { cursor: auto !important; }
}
