/* Age restriction modal */

.age-gate {
  position: fixed;
  inset: 0;
  z-index: 70;
  display: none;
}

.age-gate--visible {
  display: block;
}

.age-gate__backdrop {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top, rgba(0, 0, 0, 0.8), rgba(0, 0, 0, 0.96));
  backdrop-filter: blur(6px);
}

.age-gate__dialog {
  position: relative;
  max-width: 520px;
  margin: 10vh auto;
  padding: var(--space-6);
  border-radius: var(--radius-xl);
  background: radial-gradient(circle at top left, rgba(245, 185, 69, 0.16), transparent 55%),
              linear-gradient(145deg, #151827, #05070c);
  box-shadow: var(--shadow-soft-lg);
  border: 1px solid rgba(255, 255, 255, 0.09);
}

.age-gate__header {
  margin-bottom: var(--space-5);
}

.age-gate__tag {
  margin-bottom: var(--space-3);
}

.age-gate__title {
  font-size: var(--font-size-3xl);
  margin-bottom: var(--space-3);
}

.age-gate__description {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.age-gate__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.age-gate__btn {
  flex: 1 1 48%;
  justify-content: center;
}

.age-gate__legal {
  font-size: var(--font-size-xs);
  color: var(--gray-400);
}

@media (max-width: 640px) {
  .age-gate__dialog {
    margin: 5vh var(--space-4);
    padding: var(--space-5);
  }

  .age-gate__title {
    font-size: var(--font-size-2xl);
  }

  .age-gate__actions {
    flex-direction: column;
  }

  .age-gate__btn {
    flex: 1 1 auto;
  }
}

.age-gate button:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 3px;
}
