*,
:before,
:after {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x: ;
  --tw-pan-y: ;
  --tw-pinch-zoom: ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position: ;
  --tw-gradient-via-position: ;
  --tw-gradient-to-position: ;
  --tw-ordinal: ;
  --tw-slashed-zero: ;
  --tw-numeric-figure: ;
  --tw-numeric-spacing: ;
  --tw-numeric-fraction: ;
  --tw-ring-inset: ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246/.5);
  --tw-ring-offset-shadow: 0 0#0000;
  --tw-ring-shadow: 0 0#0000;
  --tw-shadow: 0 0#0000;
  --tw-shadow-colored: 0 0#0000;
  --tw-blur: ;
  --tw-brightness: ;
  --tw-contrast: ;
  --tw-grayscale: ;
  --tw-hue-rotate: ;
  --tw-invert: ;
  --tw-saturate: ;
  --tw-sepia: ;
  --tw-drop-shadow: ;
  --tw-backdrop-blur: ;
  --tw-backdrop-brightness: ;
  --tw-backdrop-contrast: ;
  --tw-backdrop-grayscale: ;
  --tw-backdrop-hue-rotate: ;
  --tw-backdrop-invert: ;
  --tw-backdrop-opacity: ;
  --tw-backdrop-saturate: ;
  --tw-backdrop-sepia: ;
  --tw-contain-size: ;
  --tw-contain-layout: ;
  --tw-contain-paint: ;
  --tw-contain-style:
}

::backdrop {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x: ;
  --tw-pan-y: ;
  --tw-pinch-zoom: ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position: ;
  --tw-gradient-via-position: ;
  --tw-gradient-to-position: ;
  --tw-ordinal: ;
  --tw-slashed-zero: ;
  --tw-numeric-figure: ;
  --tw-numeric-spacing: ;
  --tw-numeric-fraction: ;
  --tw-ring-inset: ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246/.5);
  --tw-ring-offset-shadow: 0 0#0000;
  --tw-ring-shadow: 0 0#0000;
  --tw-shadow: 0 0#0000;
  --tw-shadow-colored: 0 0#0000;
  --tw-blur: ;
  --tw-brightness: ;
  --tw-contrast: ;
  --tw-grayscale: ;
  --tw-hue-rotate: ;
  --tw-invert: ;
  --tw-saturate: ;
  --tw-sepia: ;
  --tw-drop-shadow: ;
  --tw-backdrop-blur: ;
  --tw-backdrop-brightness: ;
  --tw-backdrop-contrast: ;
  --tw-backdrop-grayscale: ;
  --tw-backdrop-hue-rotate: ;
  --tw-backdrop-invert: ;
  --tw-backdrop-opacity: ;
  --tw-backdrop-saturate: ;
  --tw-backdrop-sepia: ;
  --tw-contain-size: ;
  --tw-contain-layout: ;
  --tw-contain-paint: ;
  --tw-contain-style:
}

*,
:before,
:after {
  box-sizing: border-box;
  border-width: 0;
  border-style: solid;
  border-color: #e5e7eb
}

:before,
:after {
  --tw-content: ""
}

html,
:host {
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  -moz-tab-size: 4;
  -o-tab-size: 4;
  tab-size: 4;
  font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", Segoe UI Symbol, "Noto Color Emoji";
  font-feature-settings: normal;
  font-variation-settings: normal;
  -webkit-tap-highlight-color: transparent
}

body {
  margin: 0;
  line-height: inherit
}

h1,
h2,
h3,
h4 {
  font-size: inherit
}

a {
  color: inherit;
  text-decoration: inherit
}

button {
  font-family: inherit;
  font-feature-settings: inherit;
  font-variation-settings: inherit;
  font-size: 100%;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: inherit;
  color: inherit;
  margin: 0
}

button {
  text-transform: none
}

button {
  -webkit-appearance: button;
  background-color: transparent;
  background-image: none
}

:-moz-focusring {
  outline: auto
}

:-moz-ui-invalid {
  box-shadow: none
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto
}

::-webkit-search-decoration {
  -webkit-appearance: none
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit
}

h1,
h2,
h3,
h4,
p {
  margin: 0
}

ol {
  list-style: none;
  margin: 0
}

input::-moz-placeholder,
textarea::-moz-placeholder {
  opacity: 1;
  color: #9ca3af
}

input::placeholder,
textarea::placeholder {
  opacity: 1;
  color: #9ca3af
}

button {
  cursor: pointer
}

:disabled {
  cursor: default
}

img,
svg {
  display: block;
  vertical-align: middle
}

img {
  max-width: 100%
}

:root {
  --background: 220 20% 6%;
  --foreground: 210 20% 92%;
  --card: 220 15% 10%;
  --card-foreground: 210 20% 92%;
  --popover: 220 15% 10%;
  --popover-foreground: 210 20% 92%;
  --primary: 195 100% 44%;
  --primary-foreground: 220 20% 6%;
  --secondary: 220 15% 14%;
  --secondary-foreground: 210 20% 92%;
  --muted: 220 15% 14%;
  --muted-foreground: 215 15% 55%;
  --accent: 195 80% 50%;
  --accent-foreground: 220 20% 6%;
  --destructive: 0 72% 51%;
  --destructive-foreground: 210 20% 92%;
  --success: 142 71% 45%;
  --success-foreground: 220 20% 6%;
  --warning: 38 92% 50%;
  --warning-foreground: 220 20% 6%;
  --border: 220 15% 18%;
  --input: 220 15% 18%;
  --ring: 195 100% 44%;
  --radius: .75rem;
  --glass-bg: 220 20% 100%/.06;
  --glass-bg-hover: 220 20% 100%/.1;
  --glass-border: 220 20% 100%/.1;
  --glass-border-bright: 195 100% 44%/.3;
  --glass-shadow: 195 100% 44%/.08;
  --glass-blur: 20px;
  --glass-blur-heavy: 40px;
  --gradient-primary: linear-gradient(135deg, hsl(195 100% 44%), hsl(210 100% 60%));
  --gradient-glow: radial-gradient(ellipse at center, hsl(195 100% 44%/.15), transparent 70%);
  --gradient-surface: linear-gradient(180deg, hsl(220 15% 12%), hsl(220 20% 8%));
  --sidebar-background: 220 20% 8%;
  --sidebar-foreground: 210 20% 92%;
  --sidebar-primary: 195 100% 44%;
  --sidebar-primary-foreground: 220 20% 6%;
  --sidebar-accent: 220 15% 14%;
  --sidebar-accent-foreground: 210 20% 92%;
  --sidebar-border: 220 15% 18%;
  --sidebar-ring: 195 100% 44%
}

* {
  border-color: hsl(var(--border))
}

body {
  background-color: hsl(var(--background));
  font-family: DM Sans, system-ui, sans-serif;
  color: hsl(var(--foreground));
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale
}

/* Full-viewport gradient to fill side margins on wide screens */
.page-hero-bg {
  position: absolute;
  inset: 0;
  min-height: 100vh;
  background: linear-gradient(165deg, hsl(var(--primary) / 0.06) 0%, transparent 35%, hsl(var(--background)) 100%);
  pointer-events: none;
}
/* Contain page-hero-bg to main so it never overlays the footer */
main.relative {
  overflow: hidden;
}

.container {
  width: 100%
}

@media (min-width:1400px) {
  .container {
    max-width: 1400px
  }
}

.glass {
  background: hsl(var(--glass-bg));
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid hsl(var(--glass-border))
}

.glass-heavy {
  background: hsl(var(--glass-bg));
  backdrop-filter: blur(var(--glass-blur-heavy));
  -webkit-backdrop-filter: blur(var(--glass-blur-heavy));
  border: 1px solid hsl(var(--glass-border))
}

.glass-hover:hover {
  background: hsl(var(--glass-bg-hover));
  border-color: hsl(var(--glass-border-bright));
  box-shadow: 0 0 30px hsl(var(--glass-shadow))
}

.glass-glow {
  box-shadow: 0 0 40px hsl(var(--glass-shadow)), 0 0 80px #00a8e00a, inset 0 1px #ffffff14
}

.glass-card {
  background: hsl(var(--glass-bg));
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid hsl(var(--glass-border));
  box-shadow: 0 8px 32px #0000004d, inset 0 1px #ffffff0f;
  transition: all .3s cubic-bezier(.4, 0, .2, 1)
}

.glass-card:hover {
  background: hsl(var(--glass-bg-hover));
  border-color: hsl(var(--glass-border-bright));
  box-shadow: 0 8px 32px #0000004d, 0 0 30px hsl(var(--glass-shadow)), inset 0 1px #ffffff1a;
  transform: translateY(-2px)
}

/* Order Summary / Product Details Card – shared styling */
.order-summary-card {
  border-radius: 1rem;
  padding: 1.75rem 2rem;
  border: 1px solid hsl(var(--border));
  background: linear-gradient(180deg, hsl(var(--background) / 0.85) 0%, hsl(var(--background) / 0.7) 100%);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 12px 40px -16px rgba(0,0,0,0.25);
  max-width: 100%;
}
.order-summary-header {
  padding: 0 0 1rem 0;
  margin-bottom: 1rem;
  border-bottom: 1px solid hsl(var(--border) / 0.5);
}
.order-summary-header h2 {
  margin: 0;
  font-size: clamp(1.25rem, 2vw, 1.5rem);
  letter-spacing: -0.02em;
}
.order-summary-totals {
  padding: 0.5rem 0 1.25rem;
}
.order-summary-totals .total-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.5rem 0;
  border-bottom: 1px solid hsl(var(--border) / 0.4);
}
.order-summary-totals .total-row:last-of-type {
  border-bottom: none;
  padding-top: 0.75rem;
  padding-bottom: 0;
}
.order-summary-actions {
  margin-left: -2rem;
  margin-right: -2rem;
  margin-bottom: -1.75rem;
  padding: 1.5rem 2rem 1.75rem;
  border-top: 1px solid hsl(var(--primary) / 0.12);
  border-radius: 0 0 1rem 1rem;
  background: linear-gradient(180deg, hsl(var(--primary) / 0.055) 0%, hsl(var(--primary) / 0.035) 40%, hsl(var(--background) / 0.55) 100%);
  box-shadow: inset 0 1px 0 hsl(var(--primary) / 0.1), 0 0 0 1px hsl(var(--primary) / 0.04) inset, 0 -8px 24px -8px hsl(var(--primary) / 0.08);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  isolation: isolate;
}
.order-summary-actions .checkout-btn {
  margin-bottom: 0.75rem;
}
.order-summary-actions .btn-continue {
  display: block;
  width: 100%;
  padding: 0.875rem 1.5rem;
  border-radius: 0.75rem;
  border: 1px solid hsl(var(--primary) / 0.35);
  background: hsl(var(--primary) / 0.04);
  color: hsl(var(--primary));
  font-weight: 600;
  text-align: center;
  transition: all 0.25s ease;
}
.order-summary-actions .btn-continue:hover {
  background: hsl(var(--primary) / 0.1);
  border-color: hsl(var(--primary) / 0.5);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px hsl(var(--primary) / 0.15);
}

/* Cart item cards – match Order Summary / product card style */
.cart-item-card {
  display: flex;
  gap: 1rem;
  padding: 1rem 1.25rem;
  border-radius: 1rem;
  border: 1px solid hsl(var(--border));
  background: linear-gradient(180deg, hsl(var(--background) / 0.85) 0%, hsl(var(--background) / 0.7) 100%);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 8px 32px -12px rgba(0,0,0,0.2);
  transition: all 0.35s ease;
}
.cart-item-card:hover {
  border-color: hsl(var(--primary) / 0.25);
  box-shadow: 0 12px 40px -16px rgba(0,0,0,0.25);
}
.cart-item-card .cart-item-image {
  flex-shrink: 0;
  width: 4rem;
  height: 4rem;
  border-radius: 0.75rem;
  overflow: hidden;
  border: 1px solid hsl(var(--border) / 0.6);
  transition: border-color 0.25s ease;
}
.cart-item-card:hover .cart-item-image {
  border-color: hsl(var(--primary) / 0.4);
}
.cart-item-card .cart-item-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cart-item-card .cart-item-body {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.cart-item-card .cart-item-info {
  flex: 1;
  min-width: 0;
}
.cart-item-card .cart-item-name {
  font-size: 0.9375rem;
  font-weight: 600;
  color: hsl(var(--foreground));
  transition: color 0.2s ease;
}
.cart-item-card .cart-item-name:hover {
  color: hsl(var(--primary));
}
.cart-item-card .cart-item-price {
  font-size: 0.8125rem;
  font-weight: 700;
  color: hsl(var(--primary));
  margin-top: 0.25rem;
}
.cart-item-card .cart-item-qty {
  display: inline-flex;
  align-items: center;
  border: 1px solid hsl(var(--border) / 0.8);
  border-radius: 0.5rem;
  overflow: hidden;
  background: hsl(var(--background) / 0.6);
}
.cart-item-card .cart-item-qty button {
  width: 1.75rem;
  height: 1.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 600;
  color: hsl(var(--muted-foreground));
  background: transparent;
  border: none;
  cursor: pointer;
  transition: color 0.2s ease, background 0.2s ease;
}
.cart-item-card .cart-item-qty button:hover {
  color: hsl(var(--primary));
  background: hsl(var(--primary) / 0.08);
}
.cart-item-card .cart-item-qty span {
  min-width: 1.75rem;
  height: 1.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8125rem;
  font-weight: 600;
  color: hsl(var(--foreground));
  border-left: 1px solid hsl(var(--border));
  border-right: 1px solid hsl(var(--border));
}
.cart-item-card .cart-item-total {
  font-size: 0.9375rem;
  font-weight: 700;
  color: hsl(var(--primary));
  white-space: nowrap;
}
.cart-item-card .cart-item-remove {
  padding: 0.375rem;
  border-radius: 0.5rem;
  color: hsl(var(--muted-foreground));
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
}
.cart-item-card .cart-item-remove:hover {
  color: #ef4444;
  background: rgba(239, 68, 68, 0.12);
}
.cart-item-card .cart-item-remove svg {
  display: block;
  transition: transform 0.25s ease;
}
.cart-item-card .cart-item-remove:hover svg {
  transform: rotate(90deg);
}
@media (max-width: 480px) {
  .cart-item-card {
    flex-wrap: wrap;
  }
  .cart-item-card .cart-item-body {
    flex-wrap: wrap;
  }
}

/* Compact variant for side cart (narrower panel) */
#side-cart .cart-item-card {
  padding: 0.75rem 1rem;
}
#side-cart .cart-item-card .cart-item-image {
  width: 3rem;
  height: 3rem;
}
#side-cart .cart-item-card .cart-item-name {
  font-size: 0.8125rem;
}
#side-cart .cart-item-card .cart-item-price {
  font-size: 0.6875rem;
}
#side-cart .cart-item-card .cart-item-qty button,
#side-cart .cart-item-card .cart-item-qty span {
  min-width: 1.5rem;
  width: 1.5rem;
  height: 1.5rem;
  font-size: 0.75rem;
}
#side-cart .cart-item-card .cart-item-total {
  font-size: 0.8125rem;
}
#side-cart .cart-item-card .cart-item-remove svg {
  width: 14px;
  height: 14px;
}

/* Cart page header – left accent bar, eyebrow, title, subtitle */
.cart-page-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2.5rem;
}
.cart-page-header::before {
  content: '';
  width: 4px;
  height: 2.5rem;
  border-radius: 2px;
  background: linear-gradient(180deg, hsl(var(--primary)), hsl(var(--primary) / 0.5));
  flex-shrink: 0;
}
.cart-page-header-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.cart-page-eyebrow {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: hsl(var(--primary));
}
.cart-page-title {
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: hsl(var(--foreground));
  margin: 0;
  line-height: 1.2;
}
.cart-page-subtitle {
  font-size: 0.9375rem;
  color: hsl(var(--muted-foreground));
  margin: 0;
  line-height: 1.4;
}

/* Section header – left accent bar, eyebrow, title, subtitle (Collections, etc.) */
.section-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2.5rem;
  text-align: left;
}
.section-header.section-header-center {
  justify-content: center;
  text-align: center;
}
.section-header.section-header-center .section-header-wrap {
  align-items: center;
}
.section-header::before {
  content: '';
  width: 4px;
  height: 2.5rem;
  border-radius: 2px;
  background: linear-gradient(180deg, hsl(var(--primary)), hsl(var(--primary) / 0.5));
  flex-shrink: 0;
}
.section-header-center.section-header::before {
  display: none;
}
.section-header-center .section-header-eyebrow::after {
  content: '';
  display: block;
  width: 32px;
  height: 2px;
  background: linear-gradient(90deg, transparent, hsl(var(--primary)), transparent);
  margin: 0.5rem auto 0;
  border-radius: 1px;
}
.section-header-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.section-header-eyebrow {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: hsl(var(--primary));
}
.section-header-title {
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: hsl(var(--foreground));
  margin: 0;
  line-height: 1.2;
}
.section-header-subtitle {
  font-size: 0.9375rem;
  color: hsl(var(--muted-foreground));
  margin: 0;
  line-height: 1.4;
}

/* Featured section header – section header + View All link */
.featured-section-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 2.5rem;
}
.featured-section-header .section-header {
  margin-bottom: 0;
}
.featured-view-all {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--primary));
  text-decoration: none;
  transition: color 0.2s;
  flex-shrink: 0;
}
.featured-view-all:hover {
  color: hsl(var(--primary) / 0.8);
  text-decoration: underline;
}

/* Footer brand section – section-header style */
.footer-brand .section-header {
  margin-bottom: 0;
}
.footer-brand .section-header::before {
  height: 2rem;
}

/* Navbar nav links – active = pill, hover = rectangular, merged effects */
.nav-links .nav-link {
  text-decoration: none;
  position: relative;
  overflow: hidden;
  border-radius: 0.5rem;
  transition: color 0.2s ease, background 0.2s ease, border-radius 0.25s ease;
  color: hsl(var(--muted-foreground));
}
.nav-links .nav-link:hover {
  color: hsl(var(--foreground));
  background: hsl(var(--secondary));
}
.nav-links .nav-link:hover:not(.nav-link-active) {
  border-radius: 0;
}
.nav-links .nav-link.nav-link-active {
  color: hsl(var(--primary));
  background: hsl(var(--primary) / 0.1);
  border-radius: 9999px;
}
/* ::before = bottom underline (expands + heartbeat), ::after = top-left corner expand */
.nav-links .nav-link::before,
.nav-links .nav-link::after {
  content: "";
  position: absolute;
  display: block;
  pointer-events: none;
}
.nav-links .nav-link::before {
  left: 0;
  bottom: 0;
  width: 0;
  height: 2px;
  background: hsl(var(--primary));
  transition: width 0.35s ease;
}
.nav-links .nav-link::after {
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  border: 0 solid transparent;
  border-top: 2px solid transparent;
  border-left: 2px solid transparent;
  transition: width 0.45s ease, height 0.45s ease, border-color 0.45s ease;
}
.nav-links .nav-link:hover::before {
  width: 100%;
  animation: nav-heartbeat 1.5s ease-in-out 0.35s infinite;
}
.nav-links .nav-link:hover::after {
  width: 100%;
  height: 100%;
  border-color: hsl(var(--primary));
}
.nav-links .nav-link.nav-link-active:hover::before,
.nav-links .nav-link.nav-link-active:hover::after {
  width: 0;
  height: 0;
  border-color: transparent;
  animation: none;
}
@keyframes nav-heartbeat {
  0%, 100% { width: 100%; }
  50% { width: 60%; }
}

/* Mobile burger menu – side-cart style */
.mobile-nav-backdrop {
  position: fixed;
  inset: 0;
  z-index: 9996;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.mobile-nav-backdrop.active {
  opacity: 1;
  pointer-events: auto;
}
.mobile-nav-drawer {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: min(420px, 90vw);
  z-index: 9997;
  overflow-y: auto;
  transform: translateX(-100%);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  background: linear-gradient(165deg, rgba(255,255,255,0.04) 0%, rgba(0,0,0,0.75) 40%, rgba(0,0,0,0.92) 100%);
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  border-right: 1px solid rgba(255,255,255,0.1);
  box-shadow: 12px 0 48px rgba(0,0,0,0.6), 4px 0 24px rgba(0,0,0,0.4), 0 0 0 1px rgba(0,0,0,0.2) inset;
}
.mobile-nav-drawer.active {
  transform: translateX(0);
}
.mobile-nav-drawer .mobile-nav-header {
  background: linear-gradient(180deg, rgba(255,255,255,0.05) 0%, rgba(0,0,0,0.12) 100%);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 1px 0 rgba(255,255,255,0.02);
}
.mobile-nav-drawer .mobile-nav-body {
  background: linear-gradient(180deg, rgba(255,255,255,0.02) 0%, transparent 30%, rgba(0,0,0,0.08) 100%);
}
.mobile-nav-links {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.mobile-nav-link {
  display: block;
  padding: 0.875rem 1rem;
  border-radius: 0.75rem;
  font-size: 1rem;
  font-weight: 500;
  color: hsl(var(--muted-foreground));
  text-decoration: none;
  transition: color 0.2s, background 0.2s;
  background: linear-gradient(135deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.02) 100%);
  border: 1px solid rgba(255,255,255,0.08);
}
.mobile-nav-link:hover {
  color: hsl(var(--foreground));
  background: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0.05) 100%);
  border-color: rgba(255,255,255,0.12);
}
.mobile-nav-link.nav-link-active {
  color: hsl(var(--primary));
  background: linear-gradient(135deg, hsl(var(--primary) / 0.2) 0%, hsl(var(--primary) / 0.08) 100%);
  border-color: hsl(var(--primary) / 0.3);
}

/* Navbar site name – accent bar + consistent typography */
.navbar-site-name {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.navbar-site-name::before {
  content: '';
  width: 3px;
  height: 1.25rem;
  border-radius: 2px;
  background: linear-gradient(180deg, hsl(var(--primary)), hsl(var(--primary) / 0.5));
  flex-shrink: 0;
}

/* Footer column headers – Shop, Support, Legal */
.footer-column-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: hsl(var(--primary));
  margin: 0 0 1rem 0;
}
.footer-column-header::before {
  content: '';
  width: 3px;
  height: 1rem;
  border-radius: 2px;
  background: linear-gradient(180deg, hsl(var(--primary)), hsl(var(--primary) / 0.5));
  flex-shrink: 0;
}

/* Proceed to Checkout button – matches Add to Cart style */
.btn-checkout-proceed {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  min-height: 2.75rem;
  padding: 0.875rem 1.5rem;
  font-size: 0.9375rem;
  font-weight: 600;
  border-radius: 0.75rem;
  border: none;
  cursor: pointer;
  transition: all 0.25s ease;
  background: linear-gradient(180deg, hsl(var(--primary)) 0%, hsl(var(--primary) / 0.92) 100%);
  color: hsl(var(--primary-foreground));
  box-shadow: 0 4px 16px hsl(var(--primary) / 0.35), inset 0 1px 0 hsl(var(--primary) / 0.3);
}
.btn-checkout-proceed:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px hsl(var(--primary) / 0.4), inset 0 1px 0 hsl(var(--primary) / 0.35);
}
.btn-checkout-proceed:active {
  transform: translateY(0);
}

.text-gradient {
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text
}

/* Hero wave text effect for "Gaming Edge" */
.hero-wave-wrap {
  position: relative;
  display: inline-block;
}
.hero-wave-stroke {
  color: transparent;
  -webkit-text-stroke: 2px hsl(var(--primary));
  text-stroke: 2px hsl(var(--primary));
}
.hero-wave-fill {
  position: absolute;
  left: 0;
  top: 0;
  color: hsl(var(--primary));
  -webkit-text-stroke: 0;
  animation: hero-wave-animate 4s ease-in-out infinite;
}
@keyframes hero-wave-animate {
  0%, 100% {
    clip-path: polygon(
      0% 45%,
      16% 44%,
      33% 50%,
      54% 60%,
      70% 61%,
      84% 59%,
      100% 52%,
      100% 100%,
      0% 100%
    );
  }
  50% {
    clip-path: polygon(
      0% 60%,
      15% 65%,
      34% 66%,
      51% 62%,
      67% 50%,
      84% 45%,
      100% 46%,
      100% 100%,
      0% 100%
    );
  }
}

.glow-orb {
  position: absolute;
  border-radius: 50%;
  background: radial-gradient(circle, hsl(195 100% 44%/.15), transparent 70%);
  filter: blur(60px);
  pointer-events: none
}

.pointer-events-none {
  pointer-events: none
}

.fixed {
  position: fixed
}

.absolute {
  position: absolute
}

.relative {
  position: relative
}

.inset-0 {
  top: 0;
  right: 0;
  bottom: 0;
  left: 0
}

.-right-0\.5 {
  right: -.125rem
}

.-right-40 {
  right: -10rem
}

.-top-0\.5 {
  top: -.125rem
}

.-top-40 {
  top: -10rem
}

.bottom-0 {
  bottom: 0
}

.left-0 {
  left: 0
}

.left-3 {
  left: .75rem
}

.right-0 {
  right: 0
}

.right-3 {
  right: .75rem
}

.top-0 {
  top: 0
}

.top-3 {
  top: .75rem
}

.z-10 {
  z-index: 10
}

.z-50 {
  z-index: 50
}

.z-\[100\] {
  z-index: 100
}

.mx-auto {
  margin-left: auto;
  margin-right: auto
}

.mb-10 {
  margin-bottom: 2.5rem
}

.mb-12 {
  margin-bottom: 3rem
}

.mb-3 {
  margin-bottom: .75rem
}

.mb-6 {
  margin-bottom: 1.5rem
}

.mt-1 {
  margin-top: .25rem
}

.mt-1\.5 {
  margin-top: .375rem
}

.mt-10 {
  margin-top: 2.5rem
}

.mt-2 {
  margin-top: .5rem
}

.mt-20 {
  margin-top: 5rem
}

.mt-3 {
  margin-top: .75rem
}

.mt-4 {
  margin-top: 1rem
}

.mt-5 {
  margin-top: 1.25rem
}

.mt-8 {
  margin-top: 2rem
}

.line-clamp-2 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2
}

.block {
  display: block
}

.flex {
  display: flex
}

.inline-flex {
  display: inline-flex
}

.grid {
  display: grid
}

/* Hero two-column layout (loaded dynamically, so not in Tailwind scan) */
.hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  align-items: center;
  gap: 2rem;
}
@media (min-width: 768px) {
  .hero-grid {
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
  }
}
.hero-logo-area {
  display: none;
  align-items: center;
  justify-content: center;
  min-width: 0;
  min-height: 160px;
}
@media (min-width: 1024px) {
  .hero-logo-area {
    display: flex;
    justify-content: flex-end;
    min-height: 0;
  }
}
.hero-logo-img {
  height: auto;
  width: auto;
  object-fit: contain;
  /* Size controlled by admin slider via inline style */
}
.hero-content {
  max-width: 48rem;
}
.hero-tilt {
  transition: transform 0.3s ease-out;
  will-change: transform;
}
@media (min-width: 768px) {
  .hero-content {
    max-width: 56rem;
  }
}
.hero-content .hero-title {
  font-size: calc(2.5rem * var(--hero-text-size, 1));
  line-height: 1.1;
}
@media (min-width: 768px) {
  .hero-content .hero-title {
    font-size: calc(4rem * var(--hero-text-size, 1));
  }
}
@media (min-width: 1024px) {
  .hero-content .hero-title {
    font-size: calc(4.5rem * var(--hero-text-size, 1));
  }
}
.hero-content .hero-desc {
  font-size: calc(1.125rem * var(--hero-text-size, 1));
}
@media (min-width: 768px) {
  .hero-content .hero-desc {
    font-size: calc(1.25rem * var(--hero-text-size, 1));
  }
}

.hidden {
  display: none
}

.aspect-video {
  aspect-ratio: 16/9
}

.h-1\.5 {
  height: .375rem
}

.h-10 {
  height: 2.5rem
}

.h-12 {
  height: 3rem
}

.h-8 {
  height: 2rem
}

.h-\[18px\] {
  height: 18px
}

.h-\[400px\] {
  height: 400px
}

.h-\[600px\] {
  height: 600px
}

.h-full {
  height: 100%
}

.max-h-screen {
  max-height: 100vh
}

.min-h-\[85vh\] {
  min-height: 85vh
}

.min-h-screen {
  min-height: 100vh
}

.w-1\.5 {
  width: .375rem
}

.w-10 {
  width: 2.5rem
}

.w-12 {
  width: 3rem
}

.w-8 {
  width: 2rem
}

.w-\[400px\] {
  width: 400px
}

.w-\[600px\] {
  width: 600px
}

.w-full {
  width: 100%
}

.min-w-\[18px\] {
  min-width: 18px
}

.max-w-2xl {
  max-width: 42rem
}

.max-w-lg {
  max-width: 32rem
}

.flex-1 {
  flex: 1 1 0%
}

.translate-y-2 {
  --tw-translate-y: .5rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

@keyframes glow-pulse {

  0%,
  to {
    opacity: .4
  }

  50% {
    opacity: .8
  }
}

.animate-glow-pulse {
  animation: glow-pulse 3s ease-in-out infinite
}

@keyframes pulse {
  50% {
    opacity: .5
  }
}

.grid-cols-1 {
  grid-template-columns: repeat(1, minmax(0, 1fr))
}

.grid-cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr))
}

.flex-col {
  flex-direction: column
}

.flex-col-reverse {
  flex-direction: column-reverse
}

.flex-wrap {
  flex-wrap: wrap
}

.items-center {
  align-items: center
}

.justify-center {
  justify-content: center
}

.justify-between {
  justify-content: space-between
}

.gap-1 {
  gap: .25rem
}

.gap-1\.5 {
  gap: .375rem
}

.gap-2 {
  gap: .5rem
}

.gap-3 {
  gap: .75rem
}

.gap-4 {
  gap: 1rem
}

.gap-5 {
  gap: 1.25rem
}

.gap-6 {
  gap: 1.5rem
}

.gap-8 {
  gap: 2rem
}

.overflow-hidden {
  overflow: hidden
}

.rounded-2xl {
  border-radius: 1rem
}

.rounded-full {
  border-radius: 9999px
}

.rounded-lg {
  border-radius: var(--radius)
}

.rounded-md {
  border-radius: calc(var(--radius) - 2px)
}

.rounded-xl {
  border-radius: .75rem
}

.border {
  border-width: 1px
}

.border-y {
  border-top-width: 1px;
  border-bottom-width: 1px
}

.border-t {
  border-top-width: 1px
}

.border-border {
  border-color: hsl(var(--border))
}

.border-border\/50 {
  border-color: hsl(var(--border)/.5)
}

.border-primary\/40 {
  border-color: hsl(var(--primary)/.4)
}

.bg-background\/60 {
  background-color: hsl(var(--background)/.6)
}

.bg-green-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(34 197 94/var(--tw-bg-opacity, 1))
}

.bg-orange-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(249 115 22/var(--tw-bg-opacity, 1))
}

.bg-primary {
  background-color: hsl(var(--primary))
}

.bg-primary\/10 {
  background-color: hsl(var(--primary)/.1)
}

.bg-primary\/20 {
  background-color: hsl(var(--primary)/.2)
}

.bg-primary\/5 {
  background-color: hsl(var(--primary)/.05)
}

.bg-primary\/90 {
  background-color: hsl(var(--primary)/.9)
}

.bg-gradient-to-br {
  background-image: linear-gradient(to bottom right, var(--tw-gradient-stops))
}

.bg-gradient-to-t {
  background-image: linear-gradient(to top, var(--tw-gradient-stops))
}

.from-background\/90 {
  --tw-gradient-from: hsl(var(--background)/.9) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--background)/0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-primary\/5 {
  --tw-gradient-from: hsl(var(--primary)/.05) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--primary)/0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.via-background\/20 {
  --tw-gradient-to: hsl(var(--background)/0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), hsl(var(--background)/.2) var(--tw-gradient-via-position), var(--tw-gradient-to)
}

.to-transparent {
  --tw-gradient-to: transparent var(--tw-gradient-to-position)
}

.object-cover {
  -o-object-fit: cover;
  object-fit: cover
}

.p-2 {
  padding: .5rem
}

.p-2\.5 {
  padding: .625rem
}

.p-4 {
  padding: 1rem
}

.p-5 {
  padding: 1.25rem
}

.p-6 {
  padding: 1.5rem
}

.px-2 {
  padding-left: .5rem;
  padding-right: .5rem
}

.px-2\.5 {
  padding-left: .625rem;
  padding-right: .625rem
}

.px-3 {
  padding-left: .75rem;
  padding-right: .75rem
}

.px-4 {
  padding-left: 1rem;
  padding-right: 1rem
}

.px-6 {
  padding-left: 1.5rem;
  padding-right: 1.5rem
}

.py-1 {
  padding-top: .25rem;
  padding-bottom: .25rem
}

.py-1\.5 {
  padding-top: .375rem;
  padding-bottom: .375rem
}

.py-12 {
  padding-top: 3rem;
  padding-bottom: 3rem
}

.py-2 {
  padding-top: .5rem;
  padding-bottom: .5rem
}

.py-20 {
  padding-top: 5rem;
  padding-bottom: 5rem
}

.py-3 {
  padding-top: .75rem;
  padding-bottom: .75rem
}

.pt-20 {
  padding-top: 5rem
}

.pt-4 {
  padding-top: 1rem
}

.pt-6 {
  padding-top: 1.5rem
}

.text-center {
  text-align: center
}

.font-heading {
  font-family: Space Grotesk, system-ui, sans-serif
}

.text-3xl {
  font-size: 1.875rem;
  line-height: 2.25rem
}

.text-5xl {
  font-size: 3rem
}

.text-\[10px\] {
  font-size: 10px
}

.text-\[11px\] {
  font-size: 11px
}

.text-base {
  font-size: 1rem;
  line-height: 1.5rem
}

.text-lg {
  font-size: 1.125rem;
  line-height: 1.75rem
}

.text-sm {
  font-size: .875rem;
  line-height: 1.25rem
}

.text-xs {
  font-size: .75rem;
  line-height: 1rem
}

.font-bold {
  font-weight: 700
}

.font-medium {
  font-weight: 500
}

.font-semibold {
  font-weight: 600
}

.uppercase {
  text-transform: uppercase
}

.capitalize {
  text-transform: capitalize
}

.leading-\[1\.05\] {
  line-height: 1.05
}

.leading-relaxed {
  line-height: 1.625
}

.tracking-tight {
  letter-spacing: -.025em
}

.tracking-wider {
  letter-spacing: .05em
}

.text-foreground {
  color: hsl(var(--foreground))
}

.text-foreground\/70 {
  color: hsl(var(--foreground)/.7)
}

.text-muted-foreground {
  color: hsl(var(--muted-foreground))
}

.text-primary {
  color: hsl(var(--primary))
}

.text-primary-foreground {
  color: hsl(var(--primary-foreground))
}

.text-primary\/70 {
  color: hsl(var(--primary)/.7)
}

.opacity-0 {
  opacity: 0
}

.shadow-lg {
  --tw-shadow: 0 10px 15px -3px rgb(0 0 0/.1), 0 4px 6px -4px rgb(0 0 0/.1);
  --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0#0000), var(--tw-ring-shadow, 0 0#0000), var(--tw-shadow)
}

.shadow-primary\/20 {
  --tw-shadow-color: hsl(var(--primary)/.2);
  --tw-shadow: var(--tw-shadow-colored)
}

.ring-1 {
  --tw-ring-offset-shadow: var(--tw-ring-inset)0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset)0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0#0000)
}

.ring-primary\/20 {
  --tw-ring-color: hsl(var(--primary)/.2)
}

.backdrop-blur-md {
  --tw-backdrop-blur: blur(12px);
  -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)
}

.backdrop-blur-sm {
  --tw-backdrop-blur: blur(4px);
  -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)
}

.transition-all {
  transition-property: all;
  transition-timing-function: cubic-bezier(.4, 0, .2, 1);
  transition-duration: .15s
}

.transition-colors {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-timing-function: cubic-bezier(.4, 0, .2, 1);
  transition-duration: .15s
}

.transition-opacity {
  transition-property: opacity;
  transition-timing-function: cubic-bezier(.4, 0, .2, 1)
}

.transition-transform {
  transition-property: transform;
  transition-timing-function: cubic-bezier(.4, 0, .2, 1)
}

.duration-200 {
  transition-duration: .2s
}

.duration-300 {
  transition-duration: .3s
}

.duration-500 {
  transition-duration: .5s
}

.duration-700 {
  transition-duration: .7s
}

@keyframes enter {
  0% {
    opacity: var(--tw-enter-opacity, 1);
    transform: translate3d(var(--tw-enter-translate-x, 0), var(--tw-enter-translate-y, 0), 0) scale3d(var(--tw-enter-scale, 1), var(--tw-enter-scale, 1), var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))
  }
}

@keyframes exit {
  to {
    opacity: var(--tw-exit-opacity, 1);
    transform: translate3d(var(--tw-exit-translate-x, 0), var(--tw-exit-translate-y, 0), 0) scale3d(var(--tw-exit-scale, 1), var(--tw-exit-scale, 1), var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))
  }
}

.duration-200 {
  animation-duration: .2s
}

.duration-300 {
  animation-duration: .3s
}

.duration-500 {
  animation-duration: .5s
}

.duration-700 {
  animation-duration: .7s
}

::-webkit-scrollbar {
  width: 6px
}

::-webkit-scrollbar-track {
  background: hsl(var(--background))
}

::-webkit-scrollbar-thumb {
  background: hsl(var(--border));
  border-radius: 3px
}

::-webkit-scrollbar-thumb:hover {
  background: hsl(var(--muted-foreground))
}

.file\:border-0::file-selector-button {
  border-width: 0px
}

.file\:bg-transparent::file-selector-button {
  background-color: transparent
}

.file\:text-sm::file-selector-button {
  font-size: .875rem;
  line-height: 1.25rem
}

.file\:font-medium::file-selector-button {
  font-weight: 500
}

.file\:text-foreground::file-selector-button {
  color: hsl(var(--foreground))
}

.placeholder\:text-muted-foreground::-moz-placeholder {
  color: hsl(var(--muted-foreground))
}

.placeholder\:text-muted-foreground::placeholder {
  color: hsl(var(--muted-foreground))
}

.after\:absolute:after {
  content: var(--tw-content);
  position: absolute
}

.after\:-inset-2:after {
  content: var(--tw-content);
  top: -.5rem;
  right: -.5rem;
  bottom: -.5rem;
  left: -.5rem
}

.after\:inset-y-0:after {
  content: var(--tw-content);
  top: 0;
  bottom: 0
}

.after\:left-1\/2:after {
  content: var(--tw-content);
  left: 50%
}

.after\:w-1:after {
  content: var(--tw-content);
  width: .25rem
}

.after\:w-\[2px\]:after {
  content: var(--tw-content);
  width: 2px
}

.after\:-translate-x-1\/2:after {
  content: var(--tw-content);
  --tw-translate-x: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.focus-within\:relative:focus-within {
  position: relative
}

.focus-within\:z-20:focus-within {
  z-index: 20
}

.hover\:bg-accent:hover {
  background-color: hsl(var(--accent))
}

.hover\:bg-destructive\/10:hover {
  background-color: hsl(var(--destructive)/.1)
}

.hover\:bg-destructive\/80:hover {
  background-color: hsl(var(--destructive)/.8)
}

.hover\:bg-destructive\/90:hover {
  background-color: hsl(var(--destructive)/.9)
}

.hover\:bg-muted:hover {
  background-color: hsl(var(--muted))
}

.hover\:bg-muted\/50:hover {
  background-color: hsl(var(--muted)/.5)
}

.hover\:bg-primary:hover {
  background-color: hsl(var(--primary))
}

.hover\:bg-primary\/20:hover {
  background-color: hsl(var(--primary)/.2)
}

.hover\:bg-primary\/80:hover {
  background-color: hsl(var(--primary)/.8)
}

.hover\:bg-primary\/90:hover {
  background-color: hsl(var(--primary)/.9)
}

.hover\:bg-secondary:hover {
  background-color: hsl(var(--secondary))
}

.hover\:bg-secondary\/80:hover {
  background-color: hsl(var(--secondary)/.8)
}

.hover\:bg-sidebar-accent:hover {
  background-color: hsl(var(--sidebar-accent))
}

.hover\:text-accent-foreground:hover {
  color: hsl(var(--accent-foreground))
}

.hover\:text-destructive:hover {
  color: hsl(var(--destructive))
}

.hover\:text-foreground:hover {
  color: hsl(var(--foreground))
}

.hover\:text-muted-foreground:hover {
  color: hsl(var(--muted-foreground))
}

.hover\:text-primary:hover {
  color: hsl(var(--primary))
}

.hover\:text-primary-foreground:hover {
  color: hsl(var(--primary-foreground))
}

.hover\:text-primary\/90:hover {
  color: hsl(var(--primary)/.9)
}

.hover\:text-sidebar-accent-foreground:hover {
  color: hsl(var(--sidebar-accent-foreground))
}

.hover\:underline:hover {
  text-decoration-line: underline
}

.hover\:opacity-100:hover {
  opacity: 1
}

.hover\:shadow-\[0_0_0_1px_hsl\(var\(--sidebar-accent\)\)\]:hover {
  --tw-shadow: 0 0 0 1px hsl(var(--sidebar-accent));
  --tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0#0000), var(--tw-ring-shadow, 0 0#0000), var(--tw-shadow)
}

.hover\:after\:bg-sidebar-border:hover:after {
  content: var(--tw-content);
  background-color: hsl(var(--sidebar-border))
}

.focus\:border-primary\/50:focus {
  border-color: hsl(var(--primary)/.5)
}

.focus\:bg-accent:focus {
  background-color: hsl(var(--accent))
}

.focus\:bg-primary:focus {
  background-color: hsl(var(--primary))
}

.focus\:text-accent-foreground:focus {
  color: hsl(var(--accent-foreground))
}

.focus\:text-primary-foreground:focus {
  color: hsl(var(--primary-foreground))
}

.focus\:opacity-100:focus {
  opacity: 1
}

.focus\:outline-none:focus {
  outline: 2px solid transparent;
  outline-offset: 2px
}

.focus\:ring-1:focus {
  --tw-ring-offset-shadow: var(--tw-ring-inset)0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset)0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0#0000)
}

.focus\:ring-2:focus {
  --tw-ring-offset-shadow: var(--tw-ring-inset)0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset)0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0#0000)
}

.focus\:ring-primary\/20:focus {
  --tw-ring-color: hsl(var(--primary)/.2)
}

.focus\:ring-ring:focus {
  --tw-ring-color: hsl(var(--ring))
}

.focus\:ring-offset-2:focus {
  --tw-ring-offset-width: 2px
}

.focus-visible\:outline-none:focus-visible {
  outline: 2px solid transparent;
  outline-offset: 2px
}

.focus-visible\:ring-1:focus-visible {
  --tw-ring-offset-shadow: var(--tw-ring-inset)0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset)0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0#0000)
}

.focus-visible\:ring-2:focus-visible {
  --tw-ring-offset-shadow: var(--tw-ring-inset)0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset)0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0#0000)
}

.focus-visible\:ring-ring:focus-visible {
  --tw-ring-color: hsl(var(--ring))
}

.focus-visible\:ring-sidebar-ring:focus-visible {
  --tw-ring-color: hsl(var(--sidebar-ring))
}

.focus-visible\:ring-offset-1:focus-visible {
  --tw-ring-offset-width: 1px
}

.focus-visible\:ring-offset-2:focus-visible {
  --tw-ring-offset-width: 2px
}

.focus-visible\:ring-offset-background:focus-visible {
  --tw-ring-offset-color: hsl(var(--background))
}

.active\:bg-sidebar-accent:active {
  background-color: hsl(var(--sidebar-accent))
}

.active\:text-sidebar-accent-foreground:active {
  color: hsl(var(--sidebar-accent-foreground))
}

.disabled\:pointer-events-none:disabled {
  pointer-events: none
}

.disabled\:cursor-not-allowed:disabled {
  cursor: not-allowed
}

.disabled\:opacity-50:disabled {
  opacity: .5
}

.group\/menu-item:focus-within .group-focus-within\/menu-item\:opacity-100 {
  opacity: 1
}

.group:hover .group-hover\:translate-y-0 {
  --tw-translate-y: 0px;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.group:hover .group-hover\:scale-110 {
  --tw-scale-x: 1.1;
  --tw-scale-y: 1.1;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.group:hover .group-hover\:bg-primary\/20 {
  background-color: hsl(var(--primary)/.2)
}

.group:hover .group-hover\:text-primary {
  color: hsl(var(--primary))
}

.group\/menu-item:hover .group-hover\/menu-item\:opacity-100,
.group:hover .group-hover\:opacity-100 {
  opacity: 1
}

.group.destructive .group-\[\.destructive\]\:hover\:border-destructive\/30:hover {
  border-color: hsl(var(--destructive)/.3)
}

.group.destructive .group-\[\.destructive\]\:hover\:bg-destructive:hover {
  background-color: hsl(var(--destructive))
}

.group.destructive .group-\[\.destructive\]\:hover\:text-destructive-foreground:hover {
  color: hsl(var(--destructive-foreground))
}

.group.destructive .group-\[\.destructive\]\:hover\:text-red-50:hover {
  --tw-text-opacity: 1;
  color: rgb(254 242 242/var(--tw-text-opacity, 1))
}

.group.destructive .group-\[\.destructive\]\:focus\:ring-destructive:focus {
  --tw-ring-color: hsl(var(--destructive))
}

.group.destructive .group-\[\.destructive\]\:focus\:ring-red-400:focus {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(248 113 113/var(--tw-ring-opacity, 1))
}

.group.destructive .group-\[\.destructive\]\:focus\:ring-offset-red-600:focus {
  --tw-ring-offset-color: #dc2626
}

.peer\/menu-button:hover~.peer-hover\/menu-button\:text-sidebar-accent-foreground {
  color: hsl(var(--sidebar-accent-foreground))
}

.peer:disabled~.peer-disabled\:cursor-not-allowed {
  cursor: not-allowed
}

.peer:disabled~.peer-disabled\:opacity-70 {
  opacity: .7
}

.has-\[\:disabled\]\:opacity-50:has(:disabled) {
  opacity: .5
}

@keyframes accordion-up {
  0% {
    height: var(--radix-accordion-content-height)
  }

  to {
    height: 0
  }
}

@keyframes accordion-down {
  0% {
    height: 0
  }

  to {
    height: var(--radix-accordion-content-height)
  }
}

.data-\[panel-group-direction\=vertical\]\:after\:left-0[data-panel-group-direction=vertical]:after {
  content: var(--tw-content);
  left: 0
}

.data-\[panel-group-direction\=vertical\]\:after\:h-1[data-panel-group-direction=vertical]:after {
  content: var(--tw-content);
  height: .25rem
}

.data-\[panel-group-direction\=vertical\]\:after\:w-full[data-panel-group-direction=vertical]:after {
  content: var(--tw-content);
  width: 100%
}

.data-\[panel-group-direction\=vertical\]\:after\:-translate-y-1\/2[data-panel-group-direction=vertical]:after {
  content: var(--tw-content);
  --tw-translate-y: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.data-\[panel-group-direction\=vertical\]\:after\:translate-x-0[data-panel-group-direction=vertical]:after {
  content: var(--tw-content);
  --tw-translate-x: 0px;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.data-\[state\=open\]\:hover\:bg-sidebar-accent:hover[data-state=open] {
  background-color: hsl(var(--sidebar-accent))
}

.data-\[state\=open\]\:hover\:text-sidebar-accent-foreground:hover[data-state=open] {
  color: hsl(var(--sidebar-accent-foreground))
}

.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:after\:left-full:after {
  content: var(--tw-content);
  left: 100%
}

.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:hover\:bg-sidebar:hover {
  background-color: hsl(var(--sidebar-background))
}

@media (min-width:640px) {
  .sm\:bottom-0 {
    bottom: 0
  }

  .sm\:right-0 {
    right: 0
  }

  .sm\:top-auto {
    top: auto
  }

  .sm\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr))
  }

  .sm\:flex-col {
    flex-direction: column
  }
}

@media (min-width:768px) {
  .md\:max-w-\[420px\] {
    max-width: 420px
  }

  .md\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr))
  }

  .md\:text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem
  }

  .md\:text-7xl {
    font-size: 4.5rem;
    line-height: 1
  }

  .after\:md\:hidden:after {
    content: var(--tw-content);
    display: none
  }
}

@media (min-width:1024px) {
  .lg\:flex {
    display: flex
  }

  .lg\:hidden {
    display: none
  }

  .lg\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr))
  }

  .lg\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr))
  }
}
:where([data-sonner-toast]:focus-visible) {
  box-shadow: 0 4px 12px #0000001a, 0 0 0 2px #0003
}

:where([data-sonner-toast]) :where([data-button]):focus-visible {
  box-shadow: 0 0 0 2px #0006
}

:where([data-sonner-toast]) :where([data-close-button]):focus-visible {
  box-shadow: 0 4px 12px #0000001a, 0 0 0 2px #0003
}

:where([data-sonner-toast]):hover :where([data-close-button]):hover {
  background: var(--gray2);
  border-color: var(--gray5)
}

:where([data-sonner-toast][data-swiping="true"]):before {
  content: "";
  position: absolute;
  left: -50%;
  right: -50%;
  height: 100%;
  z-index: -1
}

:where([data-sonner-toast][data-y-position="top"][data-swiping="true"]):before {
  bottom: 50%;
  transform: scaleY(3) translateY(50%)
}

:where([data-sonner-toast][data-y-position="bottom"][data-swiping="true"]):before {
  top: 50%;
  transform: scaleY(3) translateY(-50%)
}

:where([data-sonner-toast][data-swiping="false"][data-removed="true"]):before {
  content: "";
  position: absolute;
  inset: 0;
  transform: scaleY(2)
}

:where([data-sonner-toast]):after {
  content: "";
  position: absolute;
  left: 0;
  height: calc(var(--gap) + 1px);
  bottom: 100%;
  width: 100%
}

:where([data-sonner-toast][data-removed="true"][data-front="false"]):before {
  height: calc(var(--initial-height) + 20%)
}

@keyframes swipe-out-left {
  0% {
    transform: var(--y) translate(var(--swipe-amount-x));
    opacity: 1
  }

  to {
    transform: var(--y) translate(calc(var(--swipe-amount-x) - 100%));
    opacity: 0
  }
}

@keyframes swipe-out-right {
  0% {
    transform: var(--y) translate(var(--swipe-amount-x));
    opacity: 1
  }

  to {
    transform: var(--y) translate(calc(var(--swipe-amount-x) + 100%));
    opacity: 0
  }
}

@keyframes swipe-out-up {
  0% {
    transform: var(--y) translateY(var(--swipe-amount-y));
    opacity: 1
  }

  to {
    transform: var(--y) translateY(calc(var(--swipe-amount-y) - 100%));
    opacity: 0
  }
}

@keyframes swipe-out-down {
  0% {
    transform: var(--y) translateY(var(--swipe-amount-y));
    opacity: 1
  }

  to {
    transform: var(--y) translateY(calc(var(--swipe-amount-y) + 100%));
    opacity: 0
  }
}

[data-sonner-toaster][data-theme=dark] [data-sonner-toast] [data-close-button]:hover {
  background: var(--normal-bg-hover);
  border-color: var(--normal-border-hover)
}

@keyframes sonner-fade-in {
  0% {
    opacity: 0;
    transform: scale(.8)
  }

  to {
    opacity: 1;
    transform: scale(1)
  }
}

@keyframes sonner-fade-out {
  0% {
    opacity: 1;
    transform: scale(1)
  }

  to {
    opacity: 0;
    transform: scale(.8)
  }
}

@keyframes sonner-spin {
  0% {
    opacity: 1
  }

  to {
    opacity: .15
  }
}

/* Hide all numbers when admin setting is enabled */
body.hide-numbers .site-number {
  display: none !important;
}