/* DarkVerse — base reset + tokens
   Volgt de Backstage-conventie: --color-* / --spacing-* / --radius-* / --transition-*
   als aliassen op de centrale --dp-* variabelen uit /api/public/theme.css. */

:root {
  /* Color aliases (zelfde patroon als backstage/src/styles/main.css) */
  --color-gradient-top:    var(--dp-bg, #000000);
  --color-gradient-bottom: var(--dp-bg-end, #020140);
  --color-primary:         var(--dp-primary, #FF0080);
  --color-secondary:       var(--dp-secondary, #585E7A);
  --color-text:            var(--dp-text, #FFFFFF);
  --color-text-secondary:  var(--dp-text-secondary, rgba(255, 255, 255, 0.7));
  --color-text-muted:      var(--dp-text-muted, rgba(255, 255, 255, 0.5));
  --color-button-text:     var(--dp-button-text, #FFFFFF);
  --color-surface:         var(--dp-surface, rgba(255, 255, 255, 0.04));
  --color-surface-alt:     var(--dp-surface-alt, rgba(255, 255, 255, 0.06));
  --color-border:          var(--dp-border, rgba(255, 255, 255, 0.1));
  --color-border-light:    var(--dp-border-light, rgba(255, 255, 255, 0.06));
  --color-success:         var(--dp-success, #22c55e);
  --color-warning:         var(--dp-warning, #fbbf24);
  --color-error:           var(--dp-error, #ef4444);

  /* Fonts: Oswald (heading) + Questrial (body), conform Backstage. Geen extra fonts. */
  --font-body:    'Questrial', sans-serif;
  --font-heading: 'Oswald', sans-serif;

  /* Spacing (8px-based, zelfde scale als Backstage) */
  --spacing-xs:  0.25rem;   /*  4px */
  --spacing-sm:  0.5rem;    /*  8px */
  --spacing-md:  1rem;      /* 16px */
  --spacing-lg:  1.5rem;    /* 24px */
  --spacing-xl:  2rem;      /* 32px */
  --spacing-xxl: 3rem;      /* 48px */

  /* Border radius (Backstage default = scherp; hier toch wat afronding voor cards) */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;

  /* Transitions */
  --transition-fast:   150ms ease;
  --transition-normal: 250ms ease;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html, body {
  margin: 0;
  padding: 0;
  min-height: 100vh;
  background: var(--color-gradient-top);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  background-image:
    radial-gradient(1200px 600px at 10% -10%, rgba(255, 0, 128, 0.08), transparent 60%),
    radial-gradient(1000px 600px at 110% 110%, rgba(2, 1, 64, 0.7), transparent 60%),
    linear-gradient(160deg, var(--color-gradient-top) 0%, var(--color-gradient-bottom) 100%);
  background-attachment: fixed;
  background-size: cover;
}

/* Backstage-conforme heading-defaults (Oswald 700 uppercase) */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  line-height: 1.2;
  margin: 0;
}

a {
  color: var(--color-primary);
  text-decoration: none;
  transition: opacity var(--transition-fast);
}
a:hover { opacity: 0.85; }

button {
  font-family: var(--font-heading);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  cursor: pointer;
  border: none;
  background: none;
  color: inherit;
  transition: opacity var(--transition-fast), transform var(--transition-fast);
}

input, textarea, select {
  font-family: var(--font-body);
  color: var(--color-text);
}

img { max-width: 100%; display: block; }

::selection {
  background: var(--color-primary);
  color: var(--color-button-text);
}

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--dp-scrollbar-track, transparent); }
::-webkit-scrollbar-thumb {
  background: var(--dp-scrollbar-thumb, rgba(255, 255, 255, 0.2));
  border-radius: var(--radius-md);
}
::-webkit-scrollbar-thumb:hover { background: rgba(255, 255, 255, 0.35); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
