/* Victory Design System — 2026 */
@import url("/assets/victory-ds-components.css");

/* Dark theme only */
:root {
  color-scheme: dark;

  --vds-space-1: 4px;
  --vds-space-2: 8px;
  --vds-space-3: 12px;
  --vds-space-4: 16px;
  --vds-space-5: 20px;
  --vds-space-6: 24px;
  --vds-space-8: 32px;
  --vds-space-10: 40px;
  --vds-space-12: 48px;

  --vds-radius-sm: 8px;
  --vds-radius-md: 12px;
  --vds-radius-lg: 16px;
  --vds-radius-xl: 20px;
  --vds-radius-full: 999px;

  --vds-font-body: "Plus Jakarta Sans", "DM Sans", system-ui, -apple-system, sans-serif;
  --vds-font-display: "Rajdhani", "Exo 2", system-ui, sans-serif;
  --vds-font-mono: ui-monospace, "Cascadia Mono", "Segoe UI Mono", Consolas, monospace;

  --vds-text-xs: clamp(0.68rem, 0.65rem + 0.1vw, 0.72rem);
  --vds-text-sm: clamp(0.8rem, 0.78rem + 0.12vw, 0.875rem);
  --vds-text-base: clamp(0.9rem, 0.88rem + 0.15vw, 0.95rem);
  --vds-text-lg: clamp(1.05rem, 1rem + 0.25vw, 1.15rem);
  --vds-text-xl: clamp(1.35rem, 1.2rem + 0.5vw, 1.65rem);
  --vds-text-2xl: clamp(1.75rem, 1.5rem + 0.9vw, 2.35rem);

  --vds-bg: #050a14;
  --vds-bg-elevated: #0a1224;
  --vds-surface: rgba(12, 22, 44, 0.72);
  --vds-surface-solid: #0f1a30;
  --vds-glass: rgba(14, 24, 48, 0.55);
  --vds-border: rgba(148, 163, 184, 0.14);
  --vds-border-strong: rgba(125, 211, 252, 0.28);
  --vds-text: #f1f5f9;
  --vds-text-muted: #94a3b8;
  --vds-text-subtle: #64748b;

  --vds-accent: #0ea5e9;
  --vds-accent-hover: #38bdf8;
  --vds-accent-muted: rgba(14, 165, 233, 0.14);
  --vds-accent-2: #2563eb;
  --vds-gradient-brand: linear-gradient(135deg, #2563eb 0%, #0ea5e9 52%, #22d3ee 100%);
  --vds-gradient-surface: linear-gradient(165deg, rgba(255, 255, 255, 0.06), transparent 42%);

  --vds-success: #34d399;
  --vds-success-muted: rgba(52, 211, 153, 0.14);
  --vds-danger: #f87171;
  --vds-danger-muted: rgba(248, 113, 113, 0.14);
  --vds-warn: #fbbf24;
  --vds-premium: #fbbf24;
  --vds-premium-muted: rgba(251, 191, 36, 0.14);
  --vds-discord: #5865f2;
  --vds-status-live: #34d399;
  --vds-container-lg: 1120px;

  --vds-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.35);
  --vds-shadow-md: 0 8px 24px rgba(0, 0, 0, 0.35);
  --vds-shadow-lg: 0 20px 48px rgba(0, 0, 0, 0.45);
  --vds-shadow-glow: 0 0 0 1px rgba(125, 211, 252, 0.12), 0 12px 40px rgba(14, 165, 233, 0.12);

  --vds-blur: 16px;
  --vds-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --vds-ease-spring: cubic-bezier(0.22, 1, 0.36, 1);
  --vds-duration-fast: 140ms;
  --vds-duration: 220ms;
  --vds-duration-slow: 380ms;

  --vds-focus-ring: 0 0 0 3px rgba(14, 165, 233, 0.35);

  /* Legacy aliases */
  --vt-bg: var(--vds-bg);
  --vt-bg-soft: var(--vds-bg-elevated);
  --vt-surface: var(--vds-surface);
  --vt-surface-strong: var(--vds-surface-solid);
  --vt-border: var(--vds-border-strong);
  --vt-border-strong: rgba(125, 211, 252, 0.38);
  --vt-text: var(--vds-text);
  --vt-muted: var(--vds-text-muted);
  --vt-accent: var(--vds-accent);
  --vt-accent-2: var(--vds-accent-2);
  --vt-accent-soft: var(--vds-accent-muted);
  --vt-success: var(--vds-success);
  --vt-warn: var(--vds-warn);
  --vt-danger: var(--vds-danger);
  --vt-radius: var(--vds-radius-lg);
  --vt-radius-sm: var(--vds-radius-sm);
  --vt-shadow: var(--vds-shadow-lg);
  --vt-glow: var(--vds-shadow-glow);
  --vt-font-body: var(--vds-font-body);
  --vt-font-display: var(--vds-font-display);
  --vt-font-mono: var(--vds-font-mono);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  color-scheme: dark;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

body {
  margin: 0;
  min-height: 100dvh;
  font-family: var(--vds-font-body);
  font-size: var(--vds-text-base);
  font-weight: 400;
  line-height: 1.55;
  letter-spacing: -0.01em;
  color: var(--vds-text);
  background-color: var(--vds-bg);
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -10%, rgba(14, 165, 233, 0.12), transparent 55%),
    radial-gradient(ellipse 60% 40% at 100% 100%, rgba(37, 99, 235, 0.08), transparent 50%),
    radial-gradient(ellipse 50% 35% at 0% 80%, rgba(34, 211, 238, 0.06), transparent 45%);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* Skip link */
.vds-skip {
  position: absolute;
  left: var(--vds-space-4);
  top: var(--vds-space-4);
  z-index: 10000;
  padding: var(--vds-space-2) var(--vds-space-4);
  border-radius: var(--vds-radius-sm);
  background: var(--vds-accent);
  color: #fff;
  font-weight: 600;
  text-decoration: none;
  transform: translateY(-140%);
  transition: transform var(--vds-duration) var(--vds-ease-out);
}

.vds-skip:focus {
  transform: translateY(0);
  outline: none;
  box-shadow: var(--vds-focus-ring);
}

/* Glass surface */
.vds-glass {
  background: var(--vds-glass);
  border: 1px solid var(--vds-border);
  border-radius: var(--vds-radius-lg);
  box-shadow: var(--vds-shadow-md);
  backdrop-filter: blur(var(--vds-blur));
  -webkit-backdrop-filter: blur(var(--vds-blur));
}

.vds-shell {
  background: var(--vds-surface);
  border: 1px solid var(--vds-border);
  border-radius: var(--vds-radius-xl);
  box-shadow: var(--vds-shadow-lg);
  backdrop-filter: blur(var(--vds-blur));
}

/* Typography */
.vds-eyebrow {
  margin: 0 0 var(--vds-space-2);
  font-family: var(--vds-font-display);
  font-size: var(--vds-text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: none;
  color: var(--vds-accent);
}

.vds-h1 {
  margin: 0;
  font-family: var(--vds-font-display);
  font-size: var(--vds-text-2xl);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: 0.02em;
}

.vds-lead {
  margin: var(--vds-space-2) 0 0;
  max-width: 38rem;
  color: var(--vds-text-muted);
  font-size: var(--vds-text-base);
  line-height: 1.6;
}

/* Buttons */
.vds-btn {
  -webkit-appearance: none;
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--vds-space-2);
  min-height: 40px;
  padding: 0 var(--vds-space-4);
  border: 1px solid var(--vds-border);
  border-radius: var(--vds-radius-md);
  background: var(--vds-surface-solid);
  color: var(--vds-text);
  font-family: var(--vds-font-display);
  font-size: var(--vds-text-sm);
  font-weight: 600;
  letter-spacing: 0.03em;
  line-height: 1;
  cursor: pointer;
  user-select: none;
  transition:
    transform var(--vds-duration-fast) var(--vds-ease-spring),
    background var(--vds-duration) ease,
    border-color var(--vds-duration) ease,
    box-shadow var(--vds-duration) ease,
    opacity var(--vds-duration) ease;
}

.vds-btn:hover:not(:disabled) {
  transform: translateY(-1px);
  border-color: var(--vds-border-strong);
  box-shadow: var(--vds-shadow-sm);
}

.vds-btn:active:not(:disabled) {
  transform: translateY(0) scale(0.98);
}

.vds-btn:focus-visible {
  outline: none;
  box-shadow: var(--vds-focus-ring);
}

.vds-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.vds-btn--primary {
  border-color: transparent;
  background: var(--vds-gradient-brand);
  color: #fff;
  box-shadow: var(--vds-shadow-glow);
}

.vds-btn--primary:hover:not(:disabled) {
  filter: brightness(1.06);
}

.vds-btn--ghost {
  background: transparent;
}

.vds-btn--sm {
  min-height: 36px;
  padding: 0 var(--vds-space-3);
  font-size: var(--vds-text-xs);
}

.vds-btn.is-loading {
  pointer-events: none;
  position: relative;
  color: transparent;
}

.vds-btn.is-loading::after {
  content: "";
  position: absolute;
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255, 255, 255, 0.35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: vdsSpin 0.65s linear infinite;
}

@keyframes vdsSpin {
  to { transform: rotate(360deg); }
}

/* Segmented control */
.vds-segment {
  display: inline-flex;
  gap: var(--vds-space-1);
  padding: var(--vds-space-1);
  border: 1px solid var(--vds-border);
  border-radius: var(--vds-radius-md);
  background: rgba(0, 0, 0, 0.2);
}

.vds-segment__btn {
  -webkit-appearance: none;
  appearance: none;
  margin: 0;
  padding: var(--vds-space-2) var(--vds-space-4);
  border: 1px solid transparent;
  border-radius: var(--vds-radius-sm);
  background: transparent;
  color: var(--vds-text-muted);
  font-family: var(--vds-font-display);
  font-size: var(--vds-text-sm);
  font-weight: 600;
  cursor: pointer;
  transition: background var(--vds-duration), color var(--vds-duration), box-shadow var(--vds-duration);
}

.vds-segment__btn:hover {
  color: var(--vds-text);
  background: rgba(255, 255, 255, 0.05);
}

.vds-segment__btn[aria-pressed="true"],
.vds-segment__btn.active {
  color: #fff;
  background: var(--vds-gradient-brand);
  border-color: rgba(186, 230, 253, 0.35);
  box-shadow: var(--vds-shadow-sm);
}

/* Spring "pop" when a tab/filter becomes active (class is toggled by JS). */
.vds-segment__btn.active {
  animation: vdsSegPop 0.34s var(--vds-ease-spring);
}

@keyframes vdsSegPop {
  0% { transform: scale(0.95); }
  55% { transform: scale(1.03); }
  100% { transform: scale(1); }
}

@media (prefers-reduced-motion: reduce) {
  .vds-segment__btn.active {
    animation: none;
  }
}

.vds-segment__btn:focus-visible {
  outline: none;
  box-shadow: var(--vds-focus-ring);
}

/* Input */
.vds-input-wrap {
  position: relative;
  flex: 1 1 200px;
  min-width: min(100%, 220px);
}

.vds-input-wrap svg {
  position: absolute;
  left: var(--vds-space-4);
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  color: var(--vds-text-subtle);
  pointer-events: none;
}

.vds-input {
  width: 100%;
  min-height: 42px;
  padding: var(--vds-space-2) var(--vds-space-4);
  border: 1px solid var(--vds-border);
  border-radius: var(--vds-radius-md);
  background: rgba(0, 0, 0, 0.2);
  color: var(--vds-text);
  font-family: var(--vds-font-body);
  font-size: var(--vds-text-base);
  font-weight: 500;
  transition: border-color var(--vds-duration), box-shadow var(--vds-duration), background var(--vds-duration);
}

.vds-input--icon {
  padding-left: calc(var(--vds-space-4) + 28px);
}

.vds-input::placeholder {
  color: var(--vds-text-subtle);
}

.vds-input:hover {
  border-color: var(--vds-border-strong);
}

.vds-input:focus {
  outline: none;
  border-color: var(--vds-accent);
  box-shadow: var(--vds-focus-ring);
  background: rgba(0, 0, 0, 0.28);
}

/* Badge */
.vds-badge {
  display: inline-flex;
  align-items: center;
  padding: var(--vds-space-1) var(--vds-space-2);
  border-radius: var(--vds-radius-full);
  font-family: var(--vds-font-display);
  font-size: var(--vds-text-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid transparent;
}

.vds-badge--success {
  color: #6ee7b7;
  background: var(--vds-success-muted);
  border-color: rgba(52, 211, 153, 0.35);
}

.vds-badge--danger {
  color: #fca5a5;
  background: var(--vds-danger-muted);
  border-color: rgba(248, 113, 113, 0.35);
}

.vds-badge--premium {
  color: #fde68a;
  background: var(--vds-premium-muted);
  border-color: rgba(251, 191, 36, 0.45);
}

.vds-badge--muted {
  color: var(--vds-text-muted);
  background: rgba(148, 163, 184, 0.1);
  border-color: var(--vds-border);
}

/* State panel */
.vds-state {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--vds-space-12) var(--vds-space-6);
  border: 1px dashed var(--vds-border);
  border-radius: var(--vds-radius-lg);
  background: var(--vds-gradient-surface);
}

.vds-state__title {
  margin: 0 0 var(--vds-space-2);
  font-family: var(--vds-font-display);
  font-size: var(--vds-text-lg);
  font-weight: 700;
}

.vds-state__text {
  margin: 0;
  color: var(--vds-text-muted);
  font-size: var(--vds-text-sm);
  line-height: 1.55;
}

.vds-state--error {
  border-color: rgba(248, 113, 113, 0.35);
  background: var(--vds-danger-muted);
}

.vds-state--error .vds-state__text {
  color: var(--vds-danger);
}

/* Skeleton */
.vds-skeleton {
  border-radius: var(--vds-radius-lg);
  border: 1px solid var(--vds-border);
  background: linear-gradient(
    110deg,
    rgba(255, 255, 255, 0.03) 25%,
    rgba(255, 255, 255, 0.08) 50%,
    rgba(255, 255, 255, 0.03) 75%
  );
  background-size: 200% 100%;
  animation: vdsShimmer 1.2s ease-in-out infinite;
  min-height: 148px;
}

@keyframes vdsShimmer {
  0% { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}

/* Page ready — html.vds-ready (VictoryUI) or body.vt-ready (VictoryMotion) */
html:not(.vds-ready) body.vt-page:not(.vt-ready) {
  visibility: hidden;
}

html.vds-ready body.vt-page,
body.vt-page.vt-ready {
  visibility: visible;
}

@media (prefers-reduced-motion: reduce) {
  .vds-btn:hover:not(:disabled) {
    transform: none;
  }

  .vds-skeleton {
    animation: none;
  }

  html.vds-ready body.vt-page,
  body.vt-page.vt-ready {
    transition: none;
  }
}
