:root {
  /* Neon Nocturne Color Palette */
  --color-primary: #ffb0c9;
  --color-primary-container: #ff4898;
  --color-secondary: #9ccaff;
  --color-secondary-container: #2295ed;
  
  --color-background: #131313;
  --color-surface: #131313;
  --color-surface-container-lowest: #0e0e0e;
  --color-surface-container-low: #1c1b1b;
  --color-surface-container: #201f1f;
  --color-surface-container-high: #2a2a2a;
  --color-surface-container-highest: #353534;
  --color-surface-bright: #3a3939;
  
  --color-on-surface: #e5e2e1;
  --color-on-surface-variant: #e2bdc7;
  --color-outline-variant: #5a3f47;
}

html {
  -webkit-text-size-adjust: 100%;
}

body {
  background-color: var(--color-background);
  color: var(--color-on-surface);
  font-family: 'Inter', sans-serif;
  margin: 0;
  overflow-x: hidden;
}

/* Safe areas (notched phones, home indicator) */
.safe-pb {
  padding-bottom: max(0.75rem, env(safe-area-inset-bottom, 0px));
}

.safe-pt {
  padding-top: max(0px, env(safe-area-inset-top, 0px));
}

.touch-manipulation {
  touch-action: manipulation;
}

.headline-font {
  font-family: 'Plus Jakarta Sans', sans-serif;
}

/* Glassmorphism */
.glass-panel {
  background: rgba(42, 42, 42, 0.6);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.glass-nav {
  background: rgba(19, 19, 19, 0.6);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

/* Neon Effects */
.neon-glow {
  box-shadow: 0 0 20px rgba(255, 176, 201, 0.15);
}

.neon-gradient {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-container) 100%);
}

.hero-glow {
  background: radial-gradient(circle at 50% 50%, rgba(255, 176, 201, 0.1) 0%, transparent 70%);
}

/* Custom Scrollbar */
::-webkit-scrollbar {
  width: 6px;
}

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

::-webkit-scrollbar-thumb {
  background: var(--color-surface-container-high);
  border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--color-surface-bright);
}

/* Animations */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

.animate-fade-in {
  animation: fadeIn 0.6s ease-out forwards;
}
