@charset "UTF-8";
/**
 * VoxDiff Phase Space SVG Styling
 * 2D trajectory plot for epistemic phase space visualization
 */
/**
 * VoxDiff Admin Design System
 * Aesthetic: Precision technical interface — Swiss typography, modular scale
 * All values derived from fundamental units for consistency and maintainability
 */
/**
 * VoxDiff Admin Mixins Library
 * Reusable patterns for consistency across all admin interfaces
 */
/**
 * VoxDiff Admin Design System
 * Aesthetic: Precision technical interface — Swiss typography, modular scale
 * All values derived from fundamental units for consistency and maintainability
 */
@keyframes fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes slide-up {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes scale-pop {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes vxd-spin {
  to {
    transform: rotate(360deg);
  }
}
@keyframes vxd-blink {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
}
@keyframes vxd-fade-up {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes vxd-shimmer {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(100%);
  }
}
/* Tile wrapper */
#phase-space-container {
  display: flex;
  flex-direction: column;
}

/* Container */
.phase-space-container {
  font-family: ui-monospace, "SF Mono", "Monaco", "Cascadia Code", "Fira Code", monospace;
  color: hsl(225, 27%, 95%);
  background: hsl(220, 21%, 7%);
  border-radius: 0;
  overflow-x: hidden;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 12px;
  border: none;
  transition: all 200ms ease;
  width: 100%;
  text-align: center;
}
.phase-space-container:focus-within {
  outline: none;
}

/* Header with mode badge and axis selectors */
.phase-space-header {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  padding: 7px 12px 6px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
  background: rgba(0, 0, 0, 0.18);
  margin: -12px -12px 0;
}

.phase-space-mode-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 1px 7px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 2px;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-family: ui-monospace, "SF Mono", "Monaco", "Cascadia Code", "Fira Code", monospace;
}
.phase-space-mode-badge .badge-label {
  color: hsl(213, 12%, 52%);
}
.phase-space-mode-badge .badge-value {
  color: hsl(163, 83%, 62%);
  font-weight: 700;
  letter-spacing: 0.08em;
}

/* Axis selectors */
.phase-space-axis-selectors {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 11.0617283951px;
}
.phase-space-axis-selectors label {
  display: block;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  opacity: 0.85;
  transition: opacity 200ms ease;
}
.phase-space-axis-selectors label:hover {
  opacity: 1;
}
.phase-space-axis-selectors span,
.phase-space-axis-selectors .wtf {
  display: none;
}
.phase-space-axis-selectors .axis-select {
  background: hsl(217, 22%, 11%);
  border: 1px solid hsla(0, 0%, 100%, 0.13);
  color: hsl(225, 27%, 95%);
  padding: 4px 8px;
  border-radius: 3px;
  font-family: inherit;
  font-size: 10px;
  cursor: pointer;
  transition: all 200ms ease;
}
.phase-space-axis-selectors .axis-select:hover {
  border-color: hsla(0, 0%, 100%, 0.26);
  background: hsl(220, 17%, 9%);
}
.phase-space-axis-selectors .axis-select:focus {
  outline: none;
  border-color: color-mix(in srgb, hsl(210, 83%, 62%) 70%, transparent);
  box-shadow: 0 0 0 2px color-mix(in srgb, hsl(210, 83%, 62%) 15%, transparent);
}
.phase-space-axis-selectors .separator {
  opacity: 0.4;
}

/* Hypothesis badge */
.phase-space-hypothesis-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 12px;
  background: color-mix(in srgb, hsl(286, 83%, 62%) 15%, transparent);
  border: 1px solid color-mix(in srgb, hsl(286, 83%, 62%) 40%, transparent);
  border-radius: 4px;
  font-size: 11.0617283951px;
  font-weight: 600;
  color: hsl(280, 100%, 84%);
  letter-spacing: 0.05em;
}

/* SVG container */
.phase-space-svg-container {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 400px;
  height: auto;
  background: rgba(20, 25, 35, 0.5);
  border-radius: 4px;
  border: 1px solid hsla(0, 0%, 100%, 0.07);
  padding: 16px;
  overflow-x: hidden;
  overflow-y: auto;
  transform: scale(75%);
}

.phase-space-plot {
  width: 500px;
  height: auto;
  max-width: 500px;
  max-height: 500px;
}

/* SVG styling */
.phase-space-grid line {
  shape-rendering: geometricPrecision;
}

.phase-space-axes {
  font-family: ui-monospace, "SF Mono", "Monaco", "Cascadia Code", "Fira Code", monospace;
}

.phase-space-trajectory {
  fill: none;
  transition: opacity, stroke-width 200ms ease;
  filter: drop-shadow(0 0 2px rgba(0, 0, 0, 0.5));
}
.phase-space-trajectory:hover {
  stroke-width: 3.5;
  filter: drop-shadow(0 0 4px rgba(0, 0, 0, 0.8));
}
.phase-space-trajectory.isolated {
  opacity: 1 !important;
  stroke-width: 3;
}

.phase-space-point {
  transition: all 200ms ease;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.6));
}
.phase-space-point:hover {
  r: 6;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.8));
}

.phase-space-point-label {
  pointer-events: none;
  user-select: none;
  transition: opacity 200ms ease;
}

.phase-space-legend {
  font-family: ui-monospace, "SF Mono", "Monaco", "Cascadia Code", "Fira Code", monospace;
}
.phase-space-legend text {
  user-select: none;
  pointer-events: none;
}

/* Lane toggle menu */
.phase-space-toggle-menu {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  padding: 12px;
  background: rgba(30, 35, 50, 0.6);
  border: 1px solid hsla(0, 0%, 100%, 0.07);
  border-radius: 4px;
  font-size: 11.0617283951px;
}
.phase-space-toggle-menu .toggle-label {
  font-weight: 600;
  opacity: 0.8;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.phase-space-toggle-menu .toggle-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 3px;
  transition: all 200ms ease;
  opacity: 0.85;
}
.phase-space-toggle-menu .toggle-item:hover {
  opacity: 1;
  background: color-mix(in srgb, hsl(210, 83%, 62%) 10%, transparent);
}
.phase-space-toggle-menu .toggle-item input[type=checkbox] {
  cursor: pointer;
  width: 14px;
  height: 14px;
  accent-color: hsl(163, 83%, 62%);
}
.phase-space-toggle-menu .toggle-text {
  font-family: ui-monospace, "SF Mono", "Monaco", "Cascadia Code", "Fira Code", monospace;
  font-size: 10px;
}

/* Animation for initial render */
@keyframes phase-space-fade-in {
  from {
    opacity: 0;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.phase-space-container {
  animation: phase-space-fade-in 700ms cubic-bezier(0.25, 1, 0.5, 1);
}

/* Responsive behavior */
@media (max-width: 768px) {
  .phase-space-container {
    padding: 12px;
    gap: 10px;
  }
  .phase-space-header {
    gap: 10px;
    padding-bottom: 6px;
  }
  .phase-space-axis-selectors {
    gap: 8px;
    font-size: 10px;
  }
  .phase-space-axis-selectors .axis-select {
    font-size: 9px;
    padding: 3px 6px;
  }
  .phase-space-svg-container {
    min-height: 300px;
    padding: 12px;
  }
  .phase-space-plot {
    max-width: 100%;
    max-height: 400px;
  }
  .phase-space-toggle-menu {
    font-size: 10px;
    gap: 8px;
    padding: 10px;
  }
  .phase-space-toggle-menu .toggle-item {
    padding: 3px 6px;
    gap: 4px;
  }
}
/* Dark theme adjustments */
@media (prefers-color-scheme: dark) {
  .phase-space-container {
    background: hsl(220, 22%, 4%);
  }
  .phase-space-svg-container {
    background: rgba(15, 18, 28, 0.7);
  }
  .phase-space-trajectory {
    filter: drop-shadow(0 0 1px rgba(0, 0, 0, 0.8));
  }
  .phase-space-trajectory:hover {
    filter: drop-shadow(0 0 3px rgba(0, 0, 0, 0.9));
  }
}

/*# sourceMappingURL=phase-space.css.map */
