/**
 * ETHRAEON AUTHENTIC COMPONENTS
 * Core UI components extracted from actual screenshots
 *
 * Requires: ethraeon-tokens.css
 * Version: 1.0 (AUTHENTIC)
 */

/* ============================================
 * CONSTITUTIONAL SYMBOL (⟁)
 * ============================================ */

.ethraeon-sigil {
  display: inline-block;
  font-size: 24px;
  color: var(--ethraeon-magenta);
  text-shadow: var(--ethraeon-text-glow-magenta);
  font-weight: var(--ethraeon-weight-normal);
  line-height: 1;
}


/* ============================================
 * BRAND NAME
 * ============================================ */

.ethraeon-brand-name {
  display: inline-block;
  font-size: var(--ethraeon-text-sm);
  font-weight: var(--ethraeon-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--ethraeon-tracking-widest);
  color: var(--ethraeon-text-secondary);
}


/* ============================================
 * TOPBAR
 * ============================================ */

.ethraeon-topbar {
  position: sticky;
  top: 0;
  z-index: var(--ethraeon-z-sticky);
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--ethraeon-topbar-height);
  padding: 0 var(--ethraeon-space-6);
  background: var(--ethraeon-topbar-bg);
  backdrop-filter: var(--ethraeon-blur-md);
  border-bottom: 1px solid var(--ethraeon-topbar-border);
}

.ethraeon-topbar-brand {
  display: flex;
  align-items: center;
  gap: var(--ethraeon-space-3);
}

.ethraeon-topbar-nav {
  display: flex;
  align-items: center;
  gap: var(--ethraeon-space-6);
}

.ethraeon-topbar-link {
  font-size: var(--ethraeon-text-sm);
  font-weight: var(--ethraeon-weight-medium);
  text-transform: uppercase;
  letter-spacing: var(--ethraeon-tracking-wide);
  color: var(--ethraeon-text-tertiary);
  transition: color var(--ethraeon-transition-fast);
}

.ethraeon-topbar-link:hover {
  color: var(--ethraeon-text-primary);
}

.ethraeon-topbar-link.active {
  color: var(--ethraeon-magenta);
  text-shadow: var(--ethraeon-text-glow-magenta);
}


/* ============================================
 * GLOWING ORBS / DOTS
 * ============================================ */

.ethraeon-orb {
  display: inline-block;
  border-radius: var(--ethraeon-radius-full);
  transition: all var(--ethraeon-transition-base);
}

.ethraeon-orb-sm {
  width: var(--ethraeon-orb-sm);
  height: var(--ethraeon-orb-sm);
}

.ethraeon-orb-md {
  width: var(--ethraeon-orb-md);
  height: var(--ethraeon-orb-md);
}

.ethraeon-orb-lg {
  width: var(--ethraeon-orb-lg);
  height: var(--ethraeon-orb-lg);
}

/* Domain-specific orbs */
.ethraeon-orb-constitution {
  background: var(--ethraeon-magenta);
  box-shadow: var(--ethraeon-glow-magenta);
}

.ethraeon-orb-mind {
  background: var(--ethraeon-cyan);
  box-shadow: var(--ethraeon-glow-cyan);
}

.ethraeon-orb-os {
  background: var(--ethraeon-purple);
  box-shadow: var(--ethraeon-glow-purple);
}

.ethraeon-orb-app {
  background: var(--ethraeon-orange);
  box-shadow: var(--ethraeon-glow-orange);
}

.ethraeon-orb-governance {
  background: var(--ethraeon-violet);
  box-shadow: 0 0 16px rgba(180, 127, 255, 0.4);
}

.ethraeon-orb-enterprise {
  background: var(--ethraeon-blue);
  box-shadow: 0 0 16px rgba(106, 159, 255, 0.4);
}

.ethraeon-orb-consciousness {
  background: var(--ethraeon-pink);
  box-shadow: 0 0 16px rgba(255, 122, 164, 0.4);
}


/* ============================================
 * PILLS / TAGS
 * ============================================ */

.ethraeon-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--ethraeon-space-2);
  padding: var(--ethraeon-pill-padding-y) var(--ethraeon-pill-padding-x);
  border-radius: var(--ethraeon-pill-radius);
  font-size: var(--ethraeon-text-xs);
  font-weight: var(--ethraeon-weight-medium);
  text-transform: uppercase;
  letter-spacing: var(--ethraeon-tracking-wider);
  border: 1px solid;
  transition: all var(--ethraeon-transition-base);
  cursor: pointer;
}

.ethraeon-pill:hover {
  opacity: var(--ethraeon-opacity-hover);
}

/* Pill variants */
.ethraeon-pill-constitution {
  background: rgba(243, 92, 255, 0.12);
  border-color: var(--ethraeon-magenta);
  color: var(--ethraeon-magenta);
}

.ethraeon-pill-mind {
  background: rgba(122, 214, 255, 0.12);
  border-color: var(--ethraeon-cyan);
  color: var(--ethraeon-cyan);
}

.ethraeon-pill-os {
  background: rgba(164, 164, 255, 0.12);
  border-color: var(--ethraeon-purple);
  color: var(--ethraeon-purple);
}

.ethraeon-pill-app {
  background: rgba(255, 180, 106, 0.12);
  border-color: var(--ethraeon-orange);
  color: var(--ethraeon-orange);
}

.ethraeon-pill-governance {
  background: rgba(180, 127, 255, 0.12);
  border-color: var(--ethraeon-violet);
  color: var(--ethraeon-violet);
}

.ethraeon-pill-ghost {
  background: transparent;
  border-color: var(--ethraeon-border-default);
  color: var(--ethraeon-text-secondary);
}


/* ============================================
 * PANELS / CARDS
 * ============================================ */

.ethraeon-panel {
  background: var(--ethraeon-panel-bg);
  border: 1px solid var(--ethraeon-panel-border);
  border-radius: var(--ethraeon-panel-radius);
  padding: var(--ethraeon-panel-padding);
}

.ethraeon-panel-glass {
  background: var(--ethraeon-glass-surface);
  backdrop-filter: var(--ethraeon-blur-md);
  border: 1px solid var(--ethraeon-border-subtle);
  border-radius: var(--ethraeon-panel-radius);
  padding: var(--ethraeon-panel-padding);
}

.ethraeon-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--ethraeon-space-4);
  padding-bottom: var(--ethraeon-space-4);
  border-bottom: 1px solid var(--ethraeon-border-subtle);
}

.ethraeon-panel-title {
  font-size: var(--ethraeon-text-sm);
  font-weight: var(--ethraeon-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--ethraeon-tracking-wider);
  color: var(--ethraeon-text-primary);
}

.ethraeon-panel-eyebrow {
  font-size: var(--ethraeon-text-xs);
  font-weight: var(--ethraeon-weight-medium);
  text-transform: uppercase;
  letter-spacing: var(--ethraeon-tracking-widest);
  color: var(--ethraeon-text-tertiary);
  margin-bottom: var(--ethraeon-space-2);
}


/* ============================================
 * BUTTONS
 * ============================================ */

.ethraeon-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--ethraeon-space-2);
  padding: var(--ethraeon-space-3) var(--ethraeon-space-5);
  border-radius: var(--ethraeon-radius-md);
  font-size: var(--ethraeon-text-sm);
  font-weight: var(--ethraeon-weight-medium);
  text-transform: uppercase;
  letter-spacing: var(--ethraeon-tracking-wide);
  border: 1px solid;
  transition: all var(--ethraeon-transition-base);
  cursor: pointer;
}

.ethraeon-button-primary {
  background: var(--ethraeon-magenta);
  border-color: var(--ethraeon-magenta);
  color: white;
  box-shadow: var(--ethraeon-glow-magenta);
}

.ethraeon-button-primary:hover {
  box-shadow: var(--ethraeon-glow-magenta-strong);
}

.ethraeon-button-secondary {
  background: transparent;
  border-color: var(--ethraeon-border-strong);
  color: var(--ethraeon-text-primary);
}

.ethraeon-button-secondary:hover {
  border-color: var(--ethraeon-magenta);
  color: var(--ethraeon-magenta);
}

.ethraeon-button-ghost {
  background: transparent;
  border-color: transparent;
  color: var(--ethraeon-text-secondary);
}

.ethraeon-button-ghost:hover {
  background: rgba(255, 255, 255, 0.05);
  color: var(--ethraeon-text-primary);
}


/* ============================================
 * SECTION HEADERS
 * ============================================ */

.ethraeon-section-header {
  font-size: var(--ethraeon-text-xs);
  font-weight: var(--ethraeon-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--ethraeon-tracking-widest);
  color: var(--ethraeon-text-tertiary);
  margin-bottom: var(--ethraeon-space-3);
}

.ethraeon-section-title {
  font-size: var(--ethraeon-text-2xl);
  font-weight: var(--ethraeon-weight-semibold);
  color: var(--ethraeon-text-primary);
  margin-bottom: var(--ethraeon-space-4);
}


/* ============================================
 * SIDE PANEL (Controls)
 * ============================================ */

.ethraeon-side-panel {
  width: var(--ethraeon-sidebar-width);
  height: 100%;
  background: var(--ethraeon-sidebar-bg);
  border-right: 1px solid var(--ethraeon-border-default);
  padding: var(--ethraeon-space-5);
  overflow-y: auto;
}

.ethraeon-control-group {
  margin-bottom: var(--ethraeon-space-5);
}

.ethraeon-control-label {
  display: block;
  font-size: var(--ethraeon-text-xs);
  font-weight: var(--ethraeon-weight-medium);
  text-transform: uppercase;
  letter-spacing: var(--ethraeon-tracking-wide);
  color: var(--ethraeon-text-tertiary);
  margin-bottom: var(--ethraeon-space-2);
}

.ethraeon-slider {
  width: 100%;
  height: 4px;
  background: var(--ethraeon-border-default);
  border-radius: var(--ethraeon-radius-full);
  position: relative;
  cursor: pointer;
}

.ethraeon-slider-fill {
  height: 100%;
  background: var(--ethraeon-cyan);
  border-radius: var(--ethraeon-radius-full);
  box-shadow: var(--ethraeon-glow-cyan);
}

.ethraeon-slider-thumb {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 12px;
  height: 12px;
  background: white;
  border-radius: var(--ethraeon-radius-full);
  box-shadow: 0 0 8px rgba(255, 255, 255, 0.4);
}

.ethraeon-metric {
  display: flex;
  align-items: baseline;
  gap: var(--ethraeon-space-2);
}

.ethraeon-metric-label {
  font-size: var(--ethraeon-text-xs);
  color: var(--ethraeon-text-tertiary);
}

.ethraeon-metric-value {
  font-size: var(--ethraeon-text-base);
  font-weight: var(--ethraeon-weight-semibold);
  color: var(--ethraeon-text-primary);
}


/* ============================================
 * NETWORK / CONSTELLATION DIAGRAM
 * ============================================ */

.ethraeon-constellation {
  position: relative;
  width: 100%;
  height: 600px;
  background: var(--ethraeon-void);
  border-radius: var(--ethraeon-radius-lg);
  overflow: hidden;
}

.ethraeon-constellation-node {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ethraeon-space-2);
}

.ethraeon-constellation-node-dot {
  width: 16px;
  height: 16px;
  border-radius: var(--ethraeon-radius-full);
  border: 2px solid;
}

.ethraeon-constellation-node-label {
  font-size: var(--ethraeon-text-xs);
  font-weight: var(--ethraeon-weight-medium);
  text-transform: uppercase;
  letter-spacing: var(--ethraeon-tracking-wide);
  color: var(--ethraeon-text-secondary);
  white-space: nowrap;
}

.ethraeon-constellation-line {
  position: absolute;
  border-top: 1px dashed rgba(255, 255, 255, 0.2);
  transform-origin: left center;
}

.ethraeon-constellation-category {
  position: absolute;
  top: var(--ethraeon-space-4);
  font-size: var(--ethraeon-text-xs);
  font-weight: var(--ethraeon-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--ethraeon-tracking-widest);
  color: var(--ethraeon-text-quaternary);
}


/* ============================================
 * PARTICLE FIELD
 * ============================================ */

.ethraeon-particle-field {
  position: relative;
  width: 100%;
  height: 100%;
  background: var(--ethraeon-void);
  overflow: hidden;
}

.ethraeon-particle {
  position: absolute;
  border-radius: var(--ethraeon-radius-full);
  background: var(--ethraeon-magenta);
  box-shadow: var(--ethraeon-glow-magenta);
  pointer-events: none;
}

/* Particle animation */
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

.ethraeon-particle {
  animation: float 4s ease-in-out infinite;
}


/* ============================================
 * GRID LAYOUTS
 * ============================================ */

.ethraeon-grid {
  display: grid;
  gap: var(--ethraeon-space-5);
}

.ethraeon-grid-2 {
  grid-template-columns: repeat(2, 1fr);
}

.ethraeon-grid-3 {
  grid-template-columns: repeat(3, 1fr);
}

.ethraeon-grid-4 {
  grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 1024px) {
  .ethraeon-grid-3,
  .ethraeon-grid-4 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .ethraeon-grid-2,
  .ethraeon-grid-3,
  .ethraeon-grid-4 {
    grid-template-columns: 1fr;
  }
}


/* ============================================
 * SYSTEM CARD (for Nexus browser)
 * ============================================ */

.ethraeon-system-card {
  background: var(--ethraeon-elevated);
  border: 1px solid var(--ethraeon-border-default);
  border-radius: var(--ethraeon-radius-lg);
  padding: var(--ethraeon-space-5);
  transition: all var(--ethraeon-transition-base);
  cursor: pointer;
}

.ethraeon-system-card:hover {
  border-color: var(--ethraeon-border-strong);
  box-shadow: var(--ethraeon-shadow-md);
}

.ethraeon-system-card-header {
  display: flex;
  align-items: center;
  gap: var(--ethraeon-space-3);
  margin-bottom: var(--ethraeon-space-3);
}

.ethraeon-system-card-icon {
  width: 32px;
  height: 32px;
  border-radius: var(--ethraeon-radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
}

.ethraeon-system-card-title {
  font-size: var(--ethraeon-text-base);
  font-weight: var(--ethraeon-weight-semibold);
  color: var(--ethraeon-text-primary);
}

.ethraeon-system-card-subtitle {
  font-size: var(--ethraeon-text-xs);
  color: var(--ethraeon-text-tertiary);
  text-transform: uppercase;
  letter-spacing: var(--ethraeon-tracking-wide);
}

.ethraeon-system-card-description {
  font-size: var(--ethraeon-text-sm);
  line-height: var(--ethraeon-leading-relaxed);
  color: var(--ethraeon-text-secondary);
  margin-bottom: var(--ethraeon-space-4);
}

.ethraeon-system-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ethraeon-space-2);
}
