/* Age restriction modal styles */
html.age-locked, body.age-locked { overflow: hidden; }

.age-modal {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  display: grid;
  place-items: center;
}
.age-overlay {
  position: absolute;
  inset: 0;
  background: radial-gradient(1200px 800px at 50% 50%, rgba(178,75,243,0.25), rgba(10,10,15,0.95) 60%);
  backdrop-filter: blur(2px);
}
.age-dialog {
  position: relative;
  max-width: 640px;
  width: calc(100% - 2rem);
  background: linear-gradient(135deg, rgba(26,26,36,0.98) 0%, rgba(19,19,26,0.98) 100%);
  border: 1px solid var(--color-border-primary);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  box-shadow: var(--glow-purple), var(--shadow-2xl);
}
.age-header h2 { margin-bottom: var(--space-4); }
.age-body p { color: var(--color-text-secondary); }
.age-actions { display: flex; gap: var(--space-4); margin-top: var(--space-6); justify-content: flex-end; flex-wrap: wrap; }

@media (prefers-reduced-motion: no-preference) {
  .age-dialog { animation: ageIn var(--transition-slower) ease-out; }
  @keyframes ageIn { from { transform: translateY(10px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
}

/* Ensure modal content is above overlay */
.age-dialog, .age-dialog * { position: relative; }