/**
 * MIGESTI OS — Core UI Styles
 * Sovereign Operating System Component Library — Cosmic Edition
 *
 * Architect: Matthew F. Inglima
 * CONFIDENTIAL — All Rights Reserved
 */

/* ═══════════════════════════════════════════════════════════
   RESET & BASE — enhanced cosmic depth
   ═══════════════════════════════════════════════════════════ */

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

html {
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-primary);
  background: var(--bg-primary);
  color: var(--text-primary);
  line-height: var(--line-height-normal);
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a { 
  color: var(--accent-cyan); 
  text-decoration: none; 
  transition: all var(--transition-fast); 
  text-shadow: 0 0 8px rgba(0, 229, 255, 0.3); 
}
a:hover {
  color: var(--accent-cyan, #80f4ff);
  text-shadow: 0 0 16px rgba(0, 229, 255, 0.7);
}

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

button {
  font-family: var(--font-primary);
  cursor: pointer;
  border: none;
  background: none;
  color: inherit;
}

/* ── Inputs with inner depth & glow ── */
input, textarea, select {
  font-family: var(--font-primary);
  color: var(--text-primary);
  background: var(--bg-input, linear-gradient(145deg, #0a1628, #050e1c));
  border: 1px solid var(--border-input, rgba(0, 180, 216, 0.28));
  border-radius: var(--radius-input);
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-base);
  line-height: var(--leading-normal);
  transition: all 0.22s cubic-bezier(0.4, 0, 0.2, 1);
  outline: none;
  width: 100%;
  box-shadow: inset 0 3px 8px rgba(0,0,0,0.55), 0 0 12px rgba(0,180,216,0.15);
}

input:focus, textarea:focus, select:focus {
  border-color: var(--accent-cyan);
  box-shadow: inset 0 3px 10px rgba(0,0,0,0.6), 0 0 0 2px rgba(0, 229, 255, 0.28), var(--glow-cyan);
}

input::placeholder, textarea::placeholder {
  color: var(--text-muted);
  opacity: 0.7;
}

::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--text-muted, rgba(0, 229, 255, 0.18)); border-radius: var(--radius-full); }

/* ═══════════════════════════════════════════════════════════════
   ATMOSPHERIC PANEL ENFORCEMENT (Phase 106B)
   Every surface is solid — never transparent over sky.
   CSS variables are set by the Atmospheric Theme Manager or
   fall back to design_tokens.css theme definitions.
   ═══════════════════════════════════════════════════════════════ */

.panel,
.card,
.workspace-panel,
.crystal-panel,
.dashboard-panel,
.dashboard-widget,
.dashboard-card,
.nav,
.sidebar,
.sidebar-nav,
.left-panel,
.right-panel,
.center-panel,
.chat-container,
.chat-panel,
.chat-box,
.chat-window,
.eomi-card,
.eomi-hub-card,
.eomi-chat-header,
.modal,
.modal-content,
.drawer,
.drawer-content,
.dropdown-menu,
.dropdown-content,
.estimating-panel,
.bom-panel,
.bom-container,
.field-sync-panel,
.report-panel,
.crystal-vault,
.vault-card,
.settings-panel,
.settings-section,
.settings-card,
.project-card,
.project-panel,
.toolbar,
.topbar,
.header,
.workspace,
.workspace-content,
.tab-content,
.tab-panel,
.blueprint-panel,
.takeoff-panel,
.assembly-panel,
.design-panel,
[class*="-panel"],
[class*="-card"],
[class*="-container"],
[class*="-widget"],
[class*="-drawer"],
[class*="-modal"],
[class*="-workspace"],
.fed-card,
.fed-dash,
.conflict-panel,
.morph-suggestions,
.council-main,
.council-feed,
.council-sidebar,
.council-input-area,
.council-action-bar,
.eomi-drawer,
.eomi-drawer__body {
  background: var(--panel-bg) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color, var(--panel-border)) !important;
}

/* Navigation surfaces */
nav,
.nav,
.sidebar,
.left-nav,
.top-nav,
.mig-sidebar {
  background: var(--nav-bg) !important;
  color: var(--nav-text, var(--text-primary)) !important;
}

nav a,
.nav a,
.nav-link,
.sidebar a,
.mig-nav-item {
  color: var(--nav-text, var(--text-secondary)) !important;
}

/* All inputs — always readable */
input,
textarea,
select,
.select,
.input {
  background: var(--input-bg, var(--bg-input)) !important;
  color: var(--text-primary) !important;
  border: 1px solid var(--border-color, var(--panel-border)) !important;
}

/* Dropdown options — always readable */
select option,
option {
  background: var(--panel-bg) !important;
  color: var(--text-primary) !important;
}

/* Placeholder text — always visible */
::placeholder {
  color: var(--text-muted) !important;
  opacity: 1 !important;
}

/* All text — always readable */
p, h1, h2, h3, h4, h5, h6,
span, label, td, th, li,
.label, .title, .subtitle,
.description, .caption {
  color: var(--text-primary) !important;
}

/* Secondary text */
.text-muted,
.text-secondary,
.subtitle,
.caption,
small {
  color: var(--text-secondary) !important;
}

/* Buttons — respect text color */
button:not(.btn-primary):not(.btn-gold):not(.mig-btn--primary):not(.mig-onboarding__btn) {
  color: var(--text-primary) !important;
}

/* ═══════════════════════════════════════════════════════════════
   END ATMOSPHERIC PANEL ENFORCEMENT
   ═══════════════════════════════════════════════════════════════ */
::-webkit-scrollbar-thumb:hover { background: var(--scrollbar-thumb-hover, rgba(0, 229, 255, 0.45)); }


/* ═══════════════════════════════════════════════════════════
   LAYOUT — APP SHELL with floating / holographic depth
   ═══════════════════════════════════════════════════════════ */

.mig-app {
  display: flex;
  min-height: 100vh;
  background: radial-gradient(circle at 20% 30%, rgba(212,168,67,0.06) 0%, transparent 60%);
}

.mig-sidebar {
  width: var(--sidebar-width);
  background: var(--bg-sidebar, var(--sidebar-bg, linear-gradient(180deg, rgba(8,14,28,0.94), rgba(4,8,18,0.92))));
  border-right: 1px solid var(--border-subtle, rgba(212,168,67,0.16));
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0; left: 0; bottom: 0;
  z-index: var(--z-sidebar);
  backdrop-filter: var(--glass-blur-heavy);
  box-shadow: 12px 0 60px rgba(0,0,0,0.75), inset -3px 0 20px rgba(212,168,67,0.12);
  transition: width 0.4s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.4s ease;
  overflow-y: auto;
  overflow-x: hidden;
  transform: perspective(1400px) translateZ(0);
}

.mig-main {
  flex: 1;
  margin-left: var(--sidebar-width);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  background: var(--bg-primary);
}

.mig-topbar {
  height: var(--topbar-height);
  background: var(--nav-bg, rgba(6, 8, 24, 0.95));
  border-bottom: 1px solid var(--border-subtle, rgba(212, 168, 67, 0.3));
  box-shadow: 0 8px 32px rgba(0,0,0,0.6);
  display: flex;
  align-items: center;
  padding: 0 var(--space-xl);
  position: sticky;
  top: 0;
  z-index: var(--z-topbar);
  backdrop-filter: var(--glass-blur);
  gap: var(--space-lg);
  transform: perspective(1200px) translateZ(4px);
}

/* ═══════════════════════════════════════════════════════════
   SIDEBAR — glowing metallic / raised elements
   ═══════════════════════════════════════════════════════════ */

.mig-sidebar__logo {
  padding: var(--space-xl) var(--space-lg);
  display: flex;
  align-items: center;
  gap: var(--space-md);
  border-bottom: 1px solid rgba(212,168,67,0.14);
  box-shadow: inset 0 -8px 20px rgba(0,0,0,0.5);
}

.mig-sidebar__logo-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #ffeb3b, var(--accent-gold) 50%, #b8922f 100%);
  box-shadow: 0 0 32px rgba(212,168,67,0.6), inset 0 3px 10px rgba(255,240,180,0.5), inset 0 -4px 12px rgba(0,0,0,0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-sm);
  color: #0a0f1c;
  flex-shrink: 0;
  transform: perspective(500px) translateZ(8px) rotateX(6deg);
}

.mig-nav-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md) var(--space-lg);
  color: var(--text-secondary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  border-left: 4px solid transparent;
  transition: all 0.28s cubic-bezier(0.34,1.56,0.64,1);
}

.mig-nav-item:hover {
  background: linear-gradient(90deg, rgba(212,168,67,0.12), transparent);
  color: var(--text-primary);
  transform: translateX(6px) perspective(800px) translateZ(6px);
  box-shadow: inset 6px 0 20px rgba(212,168,67,0.22);
}

.mig-nav-item--active {
  border-left-color: var(--accent-gold);
  background: linear-gradient(90deg, rgba(212,168,67,0.22), rgba(212,168,67,0.08));
  color: var(--text-primary);
  box-shadow: 0 0 32px rgba(212,168,67,0.5), inset 5px 0 24px rgba(212,168,67,0.28);
  transform: translateX(4px) perspective(800px) translateZ(10px);
}

/* ═══════════════════════════════════════════════════════════
   CARDS — strong floating holographic look
   ═══════════════════════════════════════════════════════════ */

.mig-card {
  background: var(--bg-card, var(--panel-bg, linear-gradient(145deg, #0c172c, #060f20)));
  border: 1px solid var(--border-card, rgba(212,168,67,0.22));
  border-radius: var(--radius-card);
  padding: var(--space-xl);
  backdrop-filter: var(--glass-blur);
  box-shadow: 
    0 12px 40px rgba(0,0,0,0.7),
    inset 0 2px 8px rgba(255,255,255,0.05),
    inset 0 -4px 12px rgba(0,0,0,0.55);
  transition: all 0.32s cubic-bezier(0.34,1.56,0.64,1);
  transform: perspective(1100px) translateZ(0) rotateX(1.5deg);
}

.mig-card:hover {
  transform: perspective(1100px) translateZ(22px) translateY(-10px) rotateX(3deg);
  box-shadow: 
    0 30px 80px rgba(0,0,0,0.85),
    inset 0 3px 12px rgba(255,255,255,0.08),
    0 0 0 1.5px rgba(212,168,67,0.3);
  border-color: rgba(212,168,67,0.45);
}

/* ═══════════════════════════════════════════════════════════
   TOPBAR
   ═══════════════════════════════════════════════════════════ */

.mig-topbar__title { flex: 1; }

.mig-topbar__title h1 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  line-height: var(--line-height-tight);
}

.mig-topbar__title p {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  margin-top: 2px;
}

.mig-topbar__search {
  position: relative;
  width: 280px;
}

.mig-topbar__search input {
  padding-left: 36px;
  background: var(--bg-frosted);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-pill);
  height: 38px;
  font-size: var(--font-size-sm);
}

.mig-topbar__search-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  font-size: 0.9rem;
}

.mig-topbar__actions {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.mig-topbar__icon-btn {
  width: 38px;
  height: 38px;
  border-radius: var(--radius-circle);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-frosted);
  color: var(--text-secondary);
  transition: var(--transition-fast);
  position: relative;
  font-size: 1.1rem;
}

.mig-topbar__icon-btn:hover {
  background: rgba(255,255,255,0.1);
  color: var(--text-primary);
}

.mig-topbar__badge {
  position: absolute;
  top: -2px;
  right: -2px;
  width: 18px;
  height: 18px;
  border-radius: var(--radius-circle);
  background: var(--accent-red);
  color: white;
  font-size: 0.6rem;
  font-weight: var(--font-weight-bold);
  display: flex;
  align-items: center;
  justify-content: center;
}

.mig-topbar__avatar {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-circle);
  background: linear-gradient(135deg, var(--accent-gold), var(--accent-blue));
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-xs);
  color: var(--bg-primary);
  cursor: pointer;
}

.mig-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-lg);
}

.mig-card__title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
}

.mig-card__action {
  color: var(--text-muted);
  font-size: 1.1rem;
  cursor: pointer;
  transition: var(--transition-fast);
}

.mig-card__action:hover { color: var(--text-primary); }
/* ═══════════════════════════════════════════════════════════
   GRID LAYOUTS
   ═══════════════════════════════════════════════════════════ */

.mig-grid {
  display: grid;
  gap: var(--space-xl);
}

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

.mig-grid--auto {
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
}

.mig-grid--dashboard {
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
}

/* ═══════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════ */

.mig-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: var(--touch-min);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
  white-space: nowrap;
  text-decoration: none;
}

.mig-btn--primary {
  background: linear-gradient(135deg, var(--accent-blue), #0090A8);
  color: white;
}

.mig-btn--primary:hover {
  box-shadow: var(--glow-blue);
  transform: translateY(-1px);
  color: white;
}

.mig-btn--gold {
  background: linear-gradient(135deg, var(--accent-gold), #B8922F);
  color: var(--bg-primary);
}

.mig-btn--gold:hover {
  box-shadow: var(--glow-gold);
  transform: translateY(-1px);
  color: var(--bg-primary);
}

.mig-btn--outline {
  background: transparent;
  border: 1px solid var(--accent-blue);
  color: var(--accent-blue);
}

.mig-btn--outline:hover {
  background: rgba(0, 180, 216, 0.1);
  color: var(--accent-cyan);
}

.mig-btn--outline-white {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.3);
  color: var(--text-primary);
}

.mig-btn--outline-white:hover {
  border-color: var(--text-primary);
  background: rgba(255,255,255,0.05);
}

.mig-btn--ghost {
  background: var(--bg-frosted);
  color: var(--text-secondary);
}

.mig-btn--ghost:hover {
  background: rgba(255,255,255,0.1);
  color: var(--text-primary);
}

.mig-btn--sm {
  min-height: 32px;
  padding: 6px 14px;
  font-size: var(--font-size-sm);
}

.mig-btn--lg {
  min-height: 52px;
  padding: 14px 28px;
  font-size: var(--font-size-md);
}

.mig-btn--full { width: 100%; }

.mig-btn--danger {
  background: linear-gradient(135deg, var(--accent-red), #CC3333);
  color: white;
}

.mig-btn--danger:hover { box-shadow: var(--glow-red); }

.mig-btn--icon {
  width: 40px;
  height: 40px;
  padding: 0;
  border-radius: var(--radius-circle);
  min-height: unset;
}

/* ═══════════════════════════════════════════════════════════
   BADGES
   ═══════════════════════════════════════════════════════════ */

.mig-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: var(--radius-pill);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.mig-badge--blue { background: rgba(0,180,216,0.15); color: var(--accent-blue); }
.mig-badge--gold { background: rgba(212,168,67,0.15); color: var(--accent-gold); }
.mig-badge--green { background: rgba(0,230,118,0.15); color: var(--accent-green); }
.mig-badge--red { background: rgba(255,82,82,0.15); color: var(--accent-red); }
.mig-badge--orange { background: rgba(255,152,0,0.15); color: var(--accent-orange); }
.mig-badge--gray { background: rgba(255,255,255,0.08); color: var(--text-muted); }
.mig-badge--cyan { background: rgba(0,229,255,0.15); color: var(--accent-cyan); }

/* ═══════════════════════════════════════════════════════════
   STAT CARDS
   ═══════════════════════════════════════════════════════════ */

.mig-stat {
  text-align: center;
  padding: var(--space-lg);
}

.mig-stat__value {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  line-height: 1;
  margin-bottom: var(--space-xs);
}

.mig-stat__label {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.mig-stat--gold .mig-stat__value { color: var(--accent-gold); }
.mig-stat--blue .mig-stat__value { color: var(--accent-blue); }
.mig-stat--green .mig-stat__value { color: var(--accent-green); }
.mig-stat--red .mig-stat__value { color: var(--accent-red); }

/* ═══════════════════════════════════════════════════════════
   PROGRESS RING
   ═══════════════════════════════════════════════════════════ */

.mig-progress-ring {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.mig-progress-ring__svg { transform: rotate(-90deg); }

.mig-progress-ring__bg {
  fill: none;
  stroke: var(--border-subtle);
  stroke-width: 6;
}

.mig-progress-ring__fill {
  fill: none;
  stroke: var(--accent-blue);
  stroke-width: 6;
  stroke-linecap: round;
  transition: stroke-dashoffset 1s ease;
}

.mig-progress-ring__text {
  position: absolute;
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
}

/* ═══════════════════════════════════════════════════════════
   TABLES
   ═══════════════════════════════════════════════════════════ */

.mig-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
}

.mig-table th {
  text-align: left;
  padding: var(--space-md) var(--space-lg);
  color: var(--text-muted);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 1px solid var(--border-divider);
  cursor: pointer;
  user-select: none;
}

.mig-table th:hover { color: var(--text-secondary); }

.mig-table td {
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--border-subtle);
  color: var(--text-secondary);
}

.mig-table tr:hover td { background: var(--bg-frosted); }

/* ═══════════════════════════════════════════════════════════
   TABS
   ═══════════════════════════════════════════════════════════ */

.mig-tabs {
  display: flex;
  gap: var(--space-xs);
  border-bottom: 1px solid var(--border-subtle);
  padding: 0 var(--space-lg);
  overflow-x: auto;
}

.mig-tab {
  padding: var(--space-md) var(--space-lg);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-muted);
  border-bottom: 2px solid transparent;
  transition: var(--transition-fast);
  white-space: nowrap;
  cursor: pointer;
  background: none;
}

.mig-tab:hover { color: var(--text-secondary); }

.mig-tab--active {
  color: var(--text-primary);
  border-bottom-color: var(--accent-gold);
}

/* ═══════════════════════════════════════════════════════════
   FORM ELEMENTS
   ═══════════════════════════════════════════════════════════ */

.mig-input-group {
  position: relative;
  margin-bottom: var(--space-lg);
}

.mig-input-group__icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  font-size: 0.95rem;
  pointer-events: none;
}

.mig-input-group input {
  padding-left: 42px;
}

.mig-input-group__toggle {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  cursor: pointer;
  font-size: 0.95rem;
  transition: var(--transition-fast);
}

.mig-input-group__toggle:hover { color: var(--text-secondary); }

.mig-checkbox {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  cursor: pointer;
}

.mig-checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--accent-blue);
  cursor: pointer;
}

.mig-error {
  color: var(--text-error);
  font-size: var(--font-size-sm);
  margin-top: var(--space-sm);
  display: none;
}

.mig-error--visible {
  display: block;
  animation: mig-shake 0.4s ease;
}

/* ═══════════════════════════════════════════════════════════
   EMET CHAT ORB
   ═══════════════════════════════════════════════════════════ */

.mig-orb {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 56px;
  height: 56px;
  border-radius: var(--radius-circle);
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-cyan));
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: var(--z-orb);
  box-shadow: var(--glow-blue-strong);
  transition: var(--transition-smooth);
  animation: mig-orb-pulse 3s infinite;
  font-size: 1.3rem;
  color: white;
}

.mig-orb:hover {
  transform: scale(1.1);
  box-shadow: 0 0 50px rgba(0, 180, 216, 0.5);
}

.mig-orb__label {
  position: absolute;
  bottom: -18px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.6rem;
  font-weight: var(--font-weight-semibold);
  color: var(--text-secondary);
  white-space: nowrap;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.mig-orb--hidden { display: none; }

/* ── Chat Panel ── */
.mig-chat-panel {
  position: fixed;
  bottom: 90px;
  right: 24px;
  width: 400px;
  height: 600px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-card);
  display: none;
  flex-direction: column;
  z-index: var(--z-orb);
  box-shadow: var(--shadow-elevated);
  overflow: hidden;
  animation: mig-slide-up 0.3s ease;
}

.mig-chat-panel--open { display: flex; }

.mig-chat-panel__header {
  padding: var(--space-lg);
  border-bottom: 1px solid var(--border-subtle);
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.mig-chat-panel__avatar {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-circle);
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-cyan));
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: var(--font-size-sm);
  color: white;
  flex-shrink: 0;
}

.mig-chat-panel__info { flex: 1; }
.mig-chat-panel__name { font-weight: var(--font-weight-semibold); font-size: var(--font-size-base); color: var(--text-primary); }
.mig-chat-panel__status { font-size: var(--font-size-xs); color: var(--accent-green); }

.mig-chat-panel__close {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-circle);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  transition: var(--transition-fast);
  font-size: 1.2rem;
}

.mig-chat-panel__close:hover { background: var(--bg-frosted); color: var(--text-primary); }

.mig-chat-panel__messages {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.mig-chat-msg {
  max-width: 85%;
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-card);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
  color: var(--text-primary);
}

.mig-chat-msg--eomi {
  align-self: flex-start;
  background: var(--bg-card);
  border-left: 3px solid var(--accent-blue);
  color: var(--text-primary);
}

.mig-chat-msg--user {
  align-self: flex-end;
  background: rgba(0, 180, 216, 0.12);
  color: var(--text-primary);
}

.mig-chat-msg__time {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  margin-top: var(--space-xs);
}

.mig-chat-panel__input {
  padding: var(--space-md) var(--space-lg);
  border-top: 1px solid var(--border-subtle);
  display: flex;
  gap: var(--space-sm);
}

.mig-chat-panel__input input {
  flex: 1;
  border-radius: var(--radius-pill);
  padding: 10px 16px;
  font-size: var(--font-size-sm);
}

.mig-chat-panel__send {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-circle);
  background: var(--accent-gold);
  color: var(--bg-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  transition: var(--transition-fast);
  flex-shrink: 0;
}

.mig-chat-panel__send:hover { box-shadow: var(--glow-gold); }

.mig-typing {
  display: flex;
  gap: 4px;
  padding: 8px 0;
}

.mig-typing span {
  width: 6px;
  height: 6px;
  background: var(--text-muted);
  border-radius: var(--radius-circle);
  animation: mig-typing-dot 1.4s infinite;
}

.mig-typing span:nth-child(2) { animation-delay: 0.2s; }
.mig-typing span:nth-child(3) { animation-delay: 0.4s; }

/* ═══════════════════════════════════════════════════════════
   EOMI CARDS
   ═══════════════════════════════════════════════════════════ */

.mig-eomi-card {
  background: var(--bg-card);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-card);
  padding: var(--space-xl);
  text-align: center;
  transition: var(--transition-smooth);
  cursor: pointer;
  backdrop-filter: var(--glass-blur);
}

.mig-eomi-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-elevated);
}

.mig-eomi-card__avatar {
  width: 100px;
  height: 100px;
  border-radius: var(--radius-circle);
  margin: 0 auto var(--space-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: white;
  transition: var(--transition-smooth);
}

.mig-eomi-card:hover .mig-eomi-card__avatar { transform: scale(1.08); }

.mig-eomi-card__name {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  margin-bottom: var(--space-xs);
}

.mig-eomi-card__role {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  margin-bottom: var(--space-lg);
}

/* ═══════════════════════════════════════════════════════════
   PRICING CARDS
   ═══════════════════════════════════════════════════════════ */

.mig-pricing-card {
  background: var(--bg-card);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-card);
  padding: var(--space-2xl);
  text-align: center;
  position: relative;
  backdrop-filter: var(--glass-blur);
  transition: var(--transition-smooth);
}

.mig-pricing-card:hover {
  border-color: var(--border-card-hover);
  transform: translateY(-4px);
}

.mig-pricing-card--popular {
  border-color: var(--accent-gold);
}

.mig-pricing-card__banner {
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--accent-gold);
  color: var(--bg-primary);
  padding: 4px 20px;
  border-radius: 0 0 var(--radius-button) var(--radius-button);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.mig-pricing-card__price {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  margin: var(--space-lg) 0;
}

.mig-pricing-card__period {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  font-weight: var(--font-weight-normal);
}

.mig-pricing-card__features {
  list-style: none;
  text-align: left;
  margin: var(--space-xl) 0;
}

.mig-pricing-card__features li {
  padding: var(--space-sm) 0;
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
}

.mig-pricing-card__features li::before {
  content: '\2713';
  color: var(--accent-green);
  font-weight: bold;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════
   TWO-COLUMN WORKSPACE
   ═══════════════════════════════════════════════════════════ */

.mig-workspace {
  display: flex;
  gap: 0;
  height: calc(100vh - var(--topbar-height));
  overflow: hidden;
}

.mig-workspace__center {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.mig-workspace__right {
  width: var(--right-panel-width);
  border-left: 1px solid var(--border-subtle);
  display: flex;
  flex-direction: column;
  background: var(--bg-secondary);
  overflow: hidden;
}

/* ── Blueprint Canvas ── */
.mig-canvas-area {
  flex: 1;
  background: var(--bg-secondary, #0D1520);
  position: relative;
  overflow: hidden;
  min-height: 400px;
}

.mig-canvas-area__empty {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-lg);
  color: var(--text-muted);
}

.mig-canvas-area__empty-icon { font-size: 3rem; opacity: 0.3; }

.mig-canvas-controls {
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: var(--space-xs);
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-pill);
  padding: var(--space-xs);
}

.mig-canvas-controls button {
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-pill);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--text-secondary);
  transition: var(--transition-fast);
}

.mig-canvas-controls button:hover { background: var(--bg-frosted); color: var(--text-primary); }
.mig-canvas-controls button.active { background: var(--accent-blue); color: white; }

/* ── Upload Zone ── */
.mig-upload-zone {
  border: 2px dashed var(--border-card);
  border-radius: var(--radius-card);
  padding: var(--space-3xl);
  text-align: center;
  transition: var(--transition-smooth);
  cursor: pointer;
}

.mig-upload-zone:hover, .mig-upload-zone--dragover {
  border-color: var(--accent-blue);
  background: rgba(0, 180, 216, 0.05);
}

.mig-upload-zone__icon {
  font-size: 2.5rem;
  color: var(--text-muted);
  margin-bottom: var(--space-md);
}

.mig-upload-zone__text {
  font-size: var(--font-size-base);
  color: var(--text-secondary);
  margin-bottom: var(--space-sm);
}

.mig-upload-zone__hint {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
}

/* ═══════════════════════════════════════════════════════════
   PIPELINE / AUTONOMOUS STAGES
   ═══════════════════════════════════════════════════════════ */

.mig-pipeline { padding: var(--space-xl); }

.mig-pipeline__stage {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-lg) 0;
  border-bottom: 1px solid var(--border-subtle);
}

.mig-pipeline__dot {
  width: 28px;
  height: 28px;
  border-radius: var(--radius-circle);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 0.8rem;
}

.mig-pipeline__dot--pending { background: var(--bg-frosted); color: var(--text-muted); }
.mig-pipeline__dot--running { background: rgba(0,180,216,0.2); color: var(--accent-blue); animation: mig-spin 1s linear infinite; }
.mig-pipeline__dot--done { background: rgba(0,230,118,0.2); color: var(--accent-green); }
.mig-pipeline__dot--failed { background: rgba(255,82,82,0.2); color: var(--accent-red); }

.mig-pipeline__label { flex: 1; font-size: var(--font-size-base); color: var(--text-secondary); }
.mig-pipeline__artifact { font-size: var(--font-size-sm); color: var(--accent-gold); }

/* ═══════════════════════════════════════════════════════════
   LOGIN PAGE
   ═══════════════════════════════════════════════════════════ */

/* ── LOGIN PAGE (cosmic sovereign — styles in login.html <style> block) ─── */
/* Base layout kept here for shared-file compatibility */
.mig-login {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  background: var(--bg-primary);
}
.mig-login__stars { position: fixed; inset: 0; z-index: 0; }
.mig-login__container {
  position: relative; z-index: 10; width: 100%; max-width: 440px;
  padding: 20px 20px 32px; text-align: center;
}

/* ═══════════════════════════════════════════════════════════
   PUBLIC NAV (Pricing/Features)
   ═══════════════════════════════════════════════════════════ */

.mig-public-nav {
  position: sticky;
  top: 0;
  z-index: var(--z-topbar);
  background: var(--bg-topbar);
  backdrop-filter: var(--glass-blur);
  border-bottom: 1px solid var(--border-subtle);
  padding: 0 var(--space-2xl);
  display: flex;
  align-items: center;
  height: var(--topbar-height);
  gap: var(--space-2xl);
}

.mig-public-nav__logo {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--accent-gold);
  letter-spacing: 1px;
  margin-right: auto;
}

.mig-public-nav__links {
  display: flex;
  gap: var(--space-xl);
}

.mig-public-nav__link {
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  transition: var(--transition-fast);
}

.mig-public-nav__link:hover, .mig-public-nav__link--active { color: var(--text-primary); }

.mig-public-nav__actions {
  display: flex;
  gap: var(--space-md);
}

/* ═══════════════════════════════════════════════════════════
   FEATURE CARDS
   ═══════════════════════════════════════════════════════════ */

.mig-feature-card {
  background: var(--bg-card);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-card);
  padding: var(--space-2xl);
  backdrop-filter: var(--glass-blur);
  transition: var(--transition-smooth);
}

.mig-feature-card:hover { border-color: var(--border-card-hover); }

.mig-feature-card__icon {
  width: 60px;
  height: 60px;
  border-radius: var(--radius-card);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin-bottom: var(--space-lg);
  background: var(--bg-frosted);
}

.mig-feature-card__title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  margin-bottom: var(--space-sm);
}

.mig-feature-card__desc {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--space-lg);
}

/* ═══════════════════════════════════════════════════════════
   CRYSTAL LIST
   ═══════════════════════════════════════════════════════════ */

.mig-crystal-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-lg);
  border-bottom: 1px solid var(--border-subtle);
  transition: var(--transition-fast);
  cursor: pointer;
}

.mig-crystal-item:hover { background: var(--bg-frosted); }

.mig-crystal-item__dot {
  width: 12px;
  height: 12px;
  border-radius: var(--radius-circle);
  flex-shrink: 0;
}

.mig-crystal-item__body { flex: 1; min-width: 0; }

.mig-crystal-item__title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mig-crystal-item__meta {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  margin-top: 2px;
}

/* ═══════════════════════════════════════════════════════════
   LOADING & ANIMATIONS
   ═══════════════════════════════════════════════════════════ */

.mig-spinner {
  width: 24px;
  height: 24px;
  border: 2px solid var(--border-subtle);
  border-top-color: var(--accent-gold);
  border-radius: var(--radius-circle);
  animation: mig-spin 0.8s linear infinite;
}

.mig-spinner--lg { width: 40px; height: 40px; border-width: 3px; }

@keyframes mig-spin { to { transform: rotate(360deg); } }

@keyframes mig-shake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-6px); }
  75% { transform: translateX(6px); }
}

@keyframes mig-globe-pulse {
  0%, 100% { box-shadow: 0 0 40px rgba(212,168,67,0.2); }
  50% { box-shadow: 0 0 80px rgba(212,168,67,0.4); }
}

@keyframes mig-orb-pulse {
  0%, 100% { box-shadow: 0 0 20px rgba(0,180,216,0.3); }
  50% { box-shadow: 0 0 40px rgba(0,180,216,0.5); }
}

@keyframes mig-slide-up {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes mig-fade-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes mig-typing-dot {
  0%, 60%, 100% { opacity: 0.3; transform: translateY(0); }
  30% { opacity: 1; transform: translateY(-4px); }
}

/* ═══════════════════════════════════════════════════════════
   EOMI THINKING INDICATOR (Phase 38 Hotfix)
   ═══════════════════════════════════════════════════════════ */

.mig-thinking {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 0;
}

.mig-thinking__text {
  color: var(--text-muted);
  font-size: var(--font-size-sm);
  font-style: italic;
}

.mig-thinking__dots {
  display: inline-flex;
  gap: 3px;
  align-items: center;
}

.mig-thinking__dot {
  width: 5px;
  height: 5px;
  background: var(--accent-gold);
  border-radius: var(--radius-circle);
  animation: mig-thinking-pulse 1.6s infinite;
}

.mig-thinking__dot:nth-child(2) { animation-delay: 0.15s; }
.mig-thinking__dot:nth-child(3) { animation-delay: 0.30s; }
.mig-thinking__dot:nth-child(4) { animation-delay: 0.45s; }
.mig-thinking__dot:nth-child(5) { animation-delay: 0.60s; }

@keyframes mig-thinking-pulse {
  0%, 70%, 100% { opacity: 0.25; transform: scale(0.8); }
  35% { opacity: 1; transform: scale(1.2); }
}

.mig-chat-msg--thinking {
  background: transparent !important;
  border: none !important;
}

/* ═══════════════════════════════════════════════════════════
   NOTIFICATION CENTER (Phase 38 Hotfix)
   ═══════════════════════════════════════════════════════════ */

.mig-notif-panel {
  position: fixed;
  top: 0;
  right: -380px;
  width: 380px;
  height: 100vh;
  background: var(--bg-secondary);
  border-left: 1px solid var(--border-primary);
  z-index: 1000;
  transition: right 0.25s ease;
  display: flex;
  flex-direction: column;
}

.mig-notif-panel--open {
  right: 0;
}

.mig-notif-panel__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--border-primary);
}

.mig-notif-panel__title {
  font-weight: 700;
  font-size: var(--font-size-lg);
  color: var(--text-primary);
}

.mig-notif-panel__actions {
  display: flex;
  gap: var(--space-sm);
}

.mig-notif-panel__btn {
  padding: 4px 10px;
  font-size: var(--font-size-xs);
  background: var(--bg-tertiary);
  border: 1px solid var(--border-primary);
  border-radius: var(--radius-button);
  color: var(--text-secondary);
  cursor: pointer;
}

.mig-notif-panel__btn:hover {
  background: var(--accent-gold);
  color: #000;
}

.mig-notif-panel__list {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-sm);
}

.mig-notif-item {
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--border-primary);
  cursor: pointer;
  transition: background 0.15s;
}

.mig-notif-item:hover {
  background: var(--bg-tertiary);
}

.mig-notif-item--unread {
  border-left: 3px solid var(--accent-gold);
}

.mig-notif-item__title {
  font-weight: 600;
  font-size: var(--font-size-sm);
  color: var(--text-primary);
  margin-bottom: 2px;
}

.mig-notif-item__body {
  font-size: var(--font-size-xs);
  color: var(--text-secondary);
  line-height: 1.4;
}

.mig-notif-item__time {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  margin-top: 4px;
}

.mig-notif-empty {
  text-align: center;
  padding: var(--space-xl) var(--space-md);
  color: var(--text-muted);
  font-size: var(--font-size-sm);
}

.mig-notif-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.3);
  z-index: 999;
  display: none;
}

.mig-notif-overlay--open {
  display: block;
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════ */

@media (max-width: 1200px) {
  .mig-sidebar { width: var(--sidebar-collapsed); }
  .mig-sidebar__logo-text, .mig-nav-item span:not(.mig-nav-item__icon),
  .mig-sidebar__user-info, .mig-sidebar__footer > *:not(.mig-sidebar__user) { display: none; }
  .mig-nav-item { justify-content: center; padding: var(--space-md); border-left: none; }
  .mig-nav-item--active { background: rgba(212,168,67,0.12); border-radius: var(--radius-button); }
  .mig-main { margin-left: var(--sidebar-collapsed); }
  .mig-workspace__right { width: 320px; }
}

@media (max-width: 768px) {
  .mig-sidebar { display: none; }
  .mig-main { margin-left: 0; }
  .mig-grid--3, .mig-grid--4, .mig-grid--2 { grid-template-columns: 1fr; }
  .mig-workspace { flex-direction: column; }
  .mig-workspace__right { width: 100%; height: 50vh; border-left: none; border-top: 1px solid var(--border-subtle); }
  .mig-topbar__search { display: none; }
  .mig-chat-panel { width: calc(100% - 32px); left: 16px; right: 16px; bottom: 80px; height: 60vh; }
}

/* ═══════════════════════════════════════════════════════════
   UTILITY CLASSES
   ═══════════════════════════════════════════════════════════ */

.text-gold { color: var(--accent-gold); }
.text-blue { color: var(--accent-blue); }
.text-green { color: var(--accent-green); }
.text-red { color: var(--accent-red); }
.text-muted { color: var(--text-muted); }
.text-center { text-align: center; }
.text-right { text-align: right; }
.flex { display: flex; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.flex-between { display: flex; align-items: center; justify-content: space-between; }
.gap-sm { gap: var(--space-sm); }
.gap-md { gap: var(--space-md); }
.gap-lg { gap: var(--space-lg); }
.gap-xl { gap: var(--space-xl); }
.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mt-xl { margin-top: var(--space-xl); }
.mb-sm { margin-bottom: var(--space-sm); }
.mb-md { margin-bottom: var(--space-md); }
.mb-lg { margin-bottom: var(--space-lg); }
.mb-xl { margin-bottom: var(--space-xl); }
.hidden { display: none !important; }

/* ═══════════════════════════════════════════════════════════
   CALENDAR GRID (Phase 36 — Fix 5)
   ═══════════════════════════════════════════════════════════ */

.mig-calendar {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  text-align: center;
}
.mig-calendar__header {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  font-weight: var(--font-weight-semibold);
  padding: 4px 0;
}
.mig-calendar__day {
  padding: 6px 4px;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  cursor: pointer;
  transition: var(--transition-fast);
  color: var(--text-secondary);
}
.mig-calendar__day:hover { background: var(--surface-hover); }
.mig-calendar__day--today { background: var(--accent-primary, var(--accent-blue)); color: #fff; font-weight: bold; }
.mig-calendar__day--event { position: relative; }
.mig-calendar__day--event::after {
  content: '';
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--accent-gold);
  position: absolute;
  bottom: 2px;
  left: 50%;
  transform: translateX(-50%);
}
.mig-calendar__day--empty { visibility: hidden; }

/* ═══════════════════════════════════════════════════════════
   COMPACT CARD VARIANT (Phase 36 — Fix 6)
   ═══════════════════════════════════════════════════════════ */

.mig-card--compact {
  padding: var(--space-lg);
}
.mig-card--compact .mig-card__header {
  margin-bottom: var(--space-md);
}
.mig-card--compact .mig-progress-ring__svg {
  width: 100px;
  height: 100px;
}
.mig-card--compact .mig-progress-ring__svg circle {
  r: 42;
  cx: 50;
  cy: 50;
}

/* ═══════════════════════════════════════════════════════════
   EMPTY STATE (Phase 36 — Fix 12)
   ═══════════════════════════════════════════════════════════ */

.mig-empty-state {
  text-align: center;
  padding: var(--space-3xl) var(--space-xl);
  color: var(--text-muted);
}
.mig-empty-state__icon { font-size: 2.5rem; opacity: 0.3; margin-bottom: var(--space-lg); }
.mig-empty-state__text { font-size: var(--font-size-base); margin-bottom: var(--space-md); }
.mig-empty-state__sub { font-size: var(--font-size-sm); }

/* ═══════════════════════════════════════════════════════════
   TOAST NOTIFICATIONS (Phase 36 — Fix 12)
   ═══════════════════════════════════════════════════════════ */

.mig-toast {
  position: fixed;
  top: 24px;
  right: 24px;
  min-width: 280px;
  max-width: 420px;
  padding: var(--space-lg) var(--space-xl);
  border-radius: var(--radius-card);
  background: var(--bg-card);
  border: 1px solid var(--border-card);
  backdrop-filter: var(--glass-blur);
  box-shadow: var(--shadow-elevated);
  z-index: var(--z-toast);
  animation: mig-slide-down 0.3s ease, mig-fade-out 0.3s ease 2.7s forwards;
  font-size: var(--font-size-sm);
  color: var(--text-primary);
}
.mig-toast--success { border-left: 3px solid var(--accent-green); }
.mig-toast--error { border-left: 3px solid var(--accent-red); }
.mig-toast--info { border-left: 3px solid var(--accent-blue); }

@keyframes mig-slide-down {
  from { opacity: 0; transform: translateY(-20px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes mig-fade-out {
  from { opacity: 1; }
  to { opacity: 0; pointer-events: none; }
}

/* ═══════════════════════════════════════════════════════════
   MODAL (Phase 36 — Fix 4)
   ═══════════════════════════════════════════════════════════ */

.mig-modal-overlay {
  position: fixed;
  inset: 0;
  background: var(--bg-overlay);
  backdrop-filter: var(--blur-sm);
  -webkit-backdrop-filter: var(--blur-sm);
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  animation: mig-fade-in 0.2s ease;
}
.mig-modal-overlay.hidden { display: none !important; }

.mig-modal {
  background: var(--bg-secondary);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-xl);
  width: 90%;
  max-width: 600px;
  max-height: 85vh;
  overflow-y: auto;
  box-shadow: var(--shadow-2xl);
  animation: mig-modal-in 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes mig-modal-in {
  from { opacity: 0; transform: scale(0.94) translateY(8px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

.mig-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5);
  border-bottom: 1px solid var(--border-subtle);
}
.mig-modal__title {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--text-primary);
}
.mig-modal__close {
  width: 32px; height: 32px;
  border-radius: var(--radius-circle);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-muted);
  font-size: 1.2rem;
  transition: var(--transition-fast);
}
.mig-modal__close:hover { background: var(--bg-frosted); color: var(--text-primary); }

.mig-modal__body { padding: var(--space-5); }
.mig-modal__footer {
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid var(--border-subtle);
  display: flex;
  justify-content: flex-end;
  gap: var(--space-3);
}

/* ── Modal Form Layout ── */
.mig-form-group { margin-bottom: var(--space-lg); }
.mig-form-group label {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--text-secondary);
  margin-bottom: var(--space-1);
}
.mig-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
}

/* ═══════════════════════════════════════════════════════════
   SIDEBAR CHAT HISTORY (Phase 36 — Fix 9)
   ═══════════════════════════════════════════════════════════ */

.mig-sidebar__section {
  padding: var(--space-md) var(--space-lg);
  border-top: 1px solid var(--border-subtle);
}
.mig-sidebar__section-title {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: var(--space-sm);
  font-weight: var(--font-weight-semibold);
}
.mig-chat-session-item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-xs);
  border-radius: var(--radius-button);
  cursor: pointer;
  transition: var(--transition-fast);
  font-size: var(--font-size-xs);
  color: var(--text-secondary);
}
.mig-chat-session-item:hover { background: var(--bg-frosted); color: var(--text-primary); }
.mig-chat-session-item__dot {
  width: 8px; height: 8px;
  border-radius: var(--radius-circle);
  flex-shrink: 0;
}
.mig-chat-session-item__text {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ═══════════════════════════════════════════════════════════
   LOADING SKELETON (Phase 36 — Fix 12)
   ═══════════════════════════════════════════════════════════ */

.mig-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-xl);
  color: var(--text-muted);
  gap: var(--space-md);
  font-size: var(--font-size-sm);
}

/* ═══════════════════════════════════════════════════════════
   SIDEBAR LOGO LINK (Phase 36 — Fix 2)
   ═══════════════════════════════════════════════════════════ */

a.mig-sidebar__logo-link {
  text-decoration: none;
  color: inherit;
  display: block;
}
a.mig-sidebar__logo-link:hover { color: inherit; }

/* ═══════════════════════════════════════════════════════════
   ACTIVITY ITEM (Phase 36 — Dashboard EOMI Activity Feed)
   ═══════════════════════════════════════════════════════════ */

.mig-activity-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--border);
  font-size: var(--font-size-sm);
}
.mig-activity-item:last-child { border-bottom: none; }
.mig-activity-item__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-top: 5px;
  flex-shrink: 0;
}
.mig-activity-item__content { flex: 1; min-width: 0; }
.mig-activity-item__text { color: var(--text-secondary); line-height: 1.4; }
.mig-activity-item__text strong { color: var(--text-primary); }
.mig-activity-item__time { color: var(--text-muted); font-size: var(--font-size-xs); margin-top: 2px; }

/* ═══════════════════════════════════════════════════════════
   TASK ITEM (Phase 36 — Dashboard Task List)
   ═══════════════════════════════════════════════════════════ */

.mig-task-item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--border);
  font-size: var(--font-size-sm);
}
.mig-task-item:last-child { border-bottom: none; }
.mig-task-item--done .mig-task-item__text {
  text-decoration: line-through;
  color: var(--text-muted);
}
.mig-task-item__text {
  flex: 1;
  color: var(--text-secondary);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ═══════════════════════════════════════════════════════════
   UPLOAD ITEM (Phase 36 — Estimating upload list)
   ═══════════════════════════════════════════════════════════ */

.mig-upload-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-sm) var(--space-md);
  background: var(--surface-2);
  border-radius: var(--radius);
  margin-bottom: var(--space-xs);
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
}


/* ═══════════════════════════════════════════════════════════
   COSMIC OVERRIDES — enhanced depth & energy (Phase 75i)
   ═══════════════════════════════════════════════════════════ */

.mig-activity-item,
.mig-task-item,
.mig-upload-item {
  background: rgba(10,18,35,0.4);
  border: 1px solid rgba(0,180,216,0.14);
  border-radius: 10px;
  box-shadow: 0 6px 24px rgba(0,0,0,0.45);
  transition: all 0.24s ease;
}

.mig-activity-item:hover,
.mig-task-item:hover,
.mig-upload-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,180,216,0.35);
  border-color: rgba(0,180,216,0.35);
}

/* Loading / subtle glow */
.mig-loading {
  color: var(--accent-cyan);
  text-shadow: 0 0 12px rgba(0,229,255,0.4);
}

/* Progress ring gets cyan-gold pulse feel */
.mig-progress-ring__fill {
  transition: stroke-dashoffset 1.2s ease-out;
  stroke: var(--accent-cyan);
}

/* Badge variants with glow */
.mig-badge--orange { background: rgba(255,152,0,0.22); color: #ffaa00; box-shadow: 0 0 12px rgba(255,152,0,0.3); }
.mig-badge--red    { background: rgba(231,76,60,0.22);  color: #ff6b6b;  box-shadow: 0 0 12px rgba(231,76,60,0.3); }
.mig-badge--gray   { background: rgba(255,255,255,0.1); color: var(--text-muted); }

/* Sidebar bottom section */
.mig-sidebar__section {
  border-top: 1px solid rgba(212,168,67,0.12);
  background: rgba(8,14,28,0.6);
  backdrop-filter: blur(8px);
}

/* ── Phase 76: EOMI Action Card ──────────────────────────────── */
.eomi-action-card {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin: 8px 0 4px 0;
  padding: 10px 14px;
  border: 1px solid rgba(212,168,67,0.35);
  border-radius: 10px;
  background: rgba(20,28,50,0.7);
  backdrop-filter: blur(6px);
  font-size: 0.92rem;
  color: var(--text-primary, #e8e6e3);
}
.eomi-action-card__icon {
  font-size: 1.2rem;
}
.eomi-action-card__label {
  font-weight: 600;
  color: var(--gold, #d4a843);
}
.eomi-action-card__links {
  display: flex;
  gap: 8px;
  margin-left: auto;
}
.eomi-action-link {
  display: inline-block;
  padding: 3px 12px;
  border: 1px solid rgba(212,168,67,0.4);
  border-radius: 14px;
  font-size: 0.82rem;
  color: var(--gold, #d4a843);
  text-decoration: none;
  transition: background 0.2s, box-shadow 0.2s;
  cursor: pointer;
}
.eomi-action-link:hover {
  background: rgba(212,168,67,0.15);
  box-shadow: 0 0 8px rgba(212,168,67,0.25);
}

/* ── Phase 77: News Panel & Web Viewer ───────────────────────── */

/* News article card */
.mig-news-article {
  display: flex;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border-subtle, rgba(255,255,255,0.06));
  align-items: flex-start;
}
.mig-news-article:last-child {
  border-bottom: none;
}
.mig-news-article__title {
  font-size: var(--font-size-sm, 0.82rem);
  font-weight: var(--font-weight-semibold, 600);
  color: var(--text-primary, #f8fafc);
  line-height: 1.3;
  margin-bottom: 3px;
}
.mig-news-article__meta {
  font-size: var(--font-size-xs, 0.72rem);
  color: var(--text-muted, #64748b);
  margin-bottom: 3px;
}
.mig-news-article__desc {
  font-size: var(--font-size-xs, 0.72rem);
  color: var(--text-secondary, #c7d2fe);
  line-height: 1.35;
  margin-bottom: 4px;
}
.mig-news-article__actions {
  display: flex;
  gap: 6px;
  margin-top: 2px;
}

/* Web Viewer panel — position: relative for absolutely-positioned resize handle */
.mig-webviewer-panel {
  position: relative;
}

/* Web Viewer drag handle */
.mig-webviewer-drag-handle {
  cursor: grab;
  user-select: none;
  -webkit-user-select: none;
}
.mig-webviewer-drag-handle:active {
  cursor: grabbing;
}

/* Web Viewer resize handle — always visible */
.mig-webviewer-resize-handle {
  position: absolute;
  right: 6px;
  bottom: 6px;
  width: 20px;
  height: 20px;
  line-height: 20px;
  text-align: center;
  font-size: 13px;
  color: var(--text-muted, #64748b);
  cursor: nwse-resize;
  user-select: none;
  -webkit-user-select: none;
  border-radius: 4px;
  transition: color 0.15s, background 0.15s;
  z-index: 2;
}
.mig-webviewer-resize-handle:hover {
  color: var(--accent-gold, #e0c04a);
  background: rgba(212,168,67,0.12);
}

/* Web Viewer fullscreen mode */
.mig-webviewer--fullscreen {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0;
  bottom: 0;
  width: 100% !important;
  height: 100% !important;
  z-index: 9999;
  margin: 0 !important;
  border-radius: 0 !important;
  grid-column: unset !important;
  overflow-y: auto;
}

/* Responsive: single-column panels on mobile */
@media (max-width: 768px) {
  .mig-news-panel,
  .mig-webviewer-panel {
    grid-column: span 1 !important;
  }
}

/* ═══════════════════════════════════════════════════════
   Phase 78 — Personal Dashboard Builder
   ═══════════════════════════════════════════════════════ */

/* ── Custom Panel ─────────────────────────────────────── */
.mig-custom-panel {
  position: relative;
  border: 1px solid #00d4ff;
  border-radius: 14px;
  background: var(--bg-primary);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 4px 24px rgba(0,0,0,0.4);
  transition: box-shadow 0.2s;
}
.mig-custom-panel:hover {
  box-shadow: 0 6px 32px rgba(0,212,255,0.15);
}
.mig-custom-panel--minimized .mig-custom-panel__body,
.mig-custom-panel--minimized .mig-panel-eomi-bar,
.mig-custom-panel--minimized .mig-custom-panel__resize {
  display: none;
}

/* ── Panel Header ─────────────────────────────────────── */
.mig-custom-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  background: rgba(0,0,0,0.3);
  cursor: grab;
  user-select: none;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.mig-custom-panel__header:active { cursor: grabbing; }
.mig-custom-panel__title {
  font-weight: 600;
  font-size: 0.85rem;
  letter-spacing: 0.03em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.mig-custom-panel__actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}
.mig-panel-action-btn {
  background: rgba(255,255,255,0.08);
  border: none;
  color: rgba(255,255,255,0.6);
  width: 24px;
  height: 24px;
  border-radius: 6px;
  font-size: 0.75rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s;
}
.mig-panel-action-btn:hover {
  background: var(--surface-hover);
  color: var(--text-primary);
}
.mig-panel-action-btn--delete:hover {
  background: rgba(229,69,96,0.3);
  color: #e94560;
}

/* ── Panel Body ───────────────────────────────────────── */
.mig-custom-panel__body {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  min-height: 60px;
}

/* ── Panel EOMI Bar ───────────────────────────────────── */
.mig-panel-eomi-bar {
  padding: 6px 8px;
  border-top: 1px solid rgba(255,255,255,0.06);
  background: rgba(0,0,0,0.2);
}
.mig-panel-eomi-input {
  width: 100%;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  color: inherit;
  padding: 5px 10px;
  font-size: 0.75rem;
  outline: none;
  box-sizing: border-box;
}
.mig-panel-eomi-input:focus {
  border-color: rgba(0,212,255,0.4);
}
.mig-panel-eomi-input::placeholder {
  color: rgba(255,255,255,0.3);
}

/* ── Resize Handle ────────────────────────────────────── */
.mig-custom-panel__resize {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 16px;
  height: 16px;
  cursor: nwse-resize;
  background: linear-gradient(135deg, transparent 50%, rgba(0,212,255,0.4) 50%);
  border-radius: 0 0 14px 0;
}

/* ── Clock Panel ──────────────────────────────────────── */
.mig-panel-clock {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 20px 12px;
  height: 100%;
}
.mig-panel-clock__time {
  font-size: 2.2rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
}
.mig-panel-clock__date {
  font-size: 0.85rem;
  opacity: 0.7;
  margin-top: 4px;
}
.mig-panel-clock__tz {
  font-size: 0.7rem;
  opacity: 0.4;
  margin-top: 8px;
}

/* ── Notes Panel ──────────────────────────────────────── */
.mig-panel-notes {
  width: 100%;
  height: 100%;
  min-height: 120px;
  background: transparent;
  border: none;
  color: inherit;
  padding: 12px;
  font-size: 0.85rem;
  font-family: inherit;
  resize: none;
  outline: none;
  box-sizing: border-box;
}
.mig-panel-notes::placeholder {
  color: rgba(255,255,255,0.3);
}

/* ── Tasks Panel ──────────────────────────────────────── */
.mig-panel-tasks {
  padding: 8px;
}
.mig-panel-task-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 6px;
  font-size: 0.82rem;
  transition: background 0.15s;
}
.mig-panel-task-item:hover {
  background: rgba(255,255,255,0.04);
}
.mig-panel-task-item--done span {
  text-decoration: line-through;
  opacity: 0.4;
}
.mig-panel-task-item input[type="checkbox"] {
  accent-color: #00d4ff;
  flex-shrink: 0;
}
.mig-panel-task-item span {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.mig-panel-task-del {
  background: none;
  border: none;
  color: rgba(255,255,255,0.3);
  cursor: pointer;
  font-size: 1rem;
  padding: 0 4px;
}
.mig-panel-task-del:hover { color: #e94560; }
.mig-panel-task-add {
  padding: 4px 0;
}
.mig-panel-task-add input {
  width: 100%;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 6px;
  color: inherit;
  padding: 6px 10px;
  font-size: 0.8rem;
  outline: none;
  box-sizing: border-box;
}
.mig-panel-task-add input:focus {
  border-color: rgba(0,212,255,0.4);
}

/* ── Calendar Panel ───────────────────────────────────── */
.mig-panel-calendar {
  padding: 10px;
}
.mig-panel-calendar__header {
  text-align: center;
  font-weight: 600;
  font-size: 0.9rem;
  margin-bottom: 8px;
}
.mig-panel-calendar__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  text-align: center;
  font-size: 0.75rem;
}
.mig-panel-calendar__day-header {
  font-weight: 700;
  opacity: 0.5;
  padding: 4px 0;
}
.mig-panel-calendar__cell {
  padding: 4px 0;
  border-radius: 6px;
  cursor: default;
}
.mig-panel-calendar__cell--today {
  background: rgba(0,212,255,0.25);
  font-weight: 700;
  color: #00d4ff;
}

/* ── News Panel (compact) ─────────────────────────────── */
.mig-panel-news {
  padding: 4px 0;
}
.mig-panel-news__item {
  padding: 8px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.mig-panel-news__item a {
  color: inherit;
  text-decoration: none;
  font-size: 0.82rem;
  line-height: 1.3;
  display: block;
}
.mig-panel-news__item a:hover { color: #00d4ff; }
.mig-panel-news__source {
  font-size: 0.7rem;
  opacity: 0.4;
  display: block;
  margin-top: 2px;
}

/* ── Web Viewer (panel embed) ─────────────────────────── */
.mig-panel-webviewer {
  width: 100%;
  height: 100%;
  min-height: 200px;
  border: none;
}

/* ── Custom HTML ──────────────────────────────────────── */
.mig-panel-custom {
  padding: 12px;
  font-size: 0.85rem;
  line-height: 1.5;
}

/* ── Add Panel Button (Topbar) ────────────────────────── */
.mig-add-panel-btn {
  background: linear-gradient(135deg, rgba(0,212,255,0.15), rgba(0,212,255,0.05));
  border: 1px solid rgba(0,212,255,0.3);
  color: #00d4ff;
  padding: 6px 14px;
  border-radius: 8px;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}
.mig-add-panel-btn:hover {
  background: linear-gradient(135deg, rgba(0,212,255,0.25), rgba(0,212,255,0.1));
  border-color: #00d4ff;
  box-shadow: 0 0 12px rgba(0,212,255,0.2);
}

/* ── Modal Overlay ────────────────────────────────────── */
.mig-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9000;
}
.mig-modal {
  background: var(--panel-bg);
  border: 1px solid rgba(0,212,255,0.25);
  border-radius: 16px;
  width: 90%;
  max-width: 520px;
  max-height: 85vh;
  overflow-y: auto;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}
.mig-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border-subtle);
}
.mig-modal__header h3 {
  margin: 0;
  font-size: 1.05rem;
  color: var(--text-primary);
}
.mig-modal__close {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 1.4rem;
  cursor: pointer;
}
.mig-modal__close:hover { color: var(--text-primary); }
.mig-modal__body {
  padding: 20px;
}
.mig-modal__footer {
  padding: 12px 20px;
  border-top: 1px solid var(--border-subtle);
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
.mig-modal__field {
  margin-bottom: 16px;
}
.mig-modal__field label {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 6px;
}
.mig-modal__input {
  width: 100%;
  background: var(--input-bg);
  border: 1px solid var(--border-input);
  border-radius: 8px;
  color: var(--text-primary);
  padding: 8px 12px;
  font-size: 0.85rem;
  outline: none;
  box-sizing: border-box;
}
.mig-modal__input:focus {
  border-color: rgba(0,212,255,0.4);
}
.mig-modal__color-input {
  width: 48px;
  height: 32px;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 6px;
  background: transparent;
  cursor: pointer;
}
.mig-modal__slider {
  width: 100%;
  accent-color: #00d4ff;
}
.mig-modal__btn {
  padding: 8px 20px;
  border-radius: 8px;
  border: 1px solid var(--border-input);
  background: var(--surface-hover);
  color: var(--text-primary);
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
}
.mig-modal__btn--primary {
  background: linear-gradient(135deg, rgba(0,212,255,0.2), rgba(0,212,255,0.08));
  border-color: rgba(0,212,255,0.4);
  color: #00d4ff;
}
.mig-modal__btn--primary:hover {
  background: linear-gradient(135deg, rgba(0,212,255,0.3), rgba(0,212,255,0.15));
  box-shadow: 0 0 12px rgba(0,212,255,0.2);
}

/* ── Type Selection Grid ──────────────────────────────── */
.mig-modal__type-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 10px;
}
.mig-panel-type-card {
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  padding: 14px 10px;
  text-align: center;
  cursor: pointer;
  transition: all 0.15s;
  background: rgba(255,255,255,0.03);
}
.mig-panel-type-card:hover {
  border-color: rgba(0,212,255,0.3);
  background: rgba(0,212,255,0.05);
}
.mig-panel-type-card--selected {
  border-color: #00d4ff;
  background: rgba(0,212,255,0.1);
  box-shadow: 0 0 12px rgba(0,212,255,0.15);
}
.mig-panel-type-card__icon {
  display: block;
  font-size: 1.6rem;
  margin-bottom: 6px;
}
.mig-panel-type-card__label {
  display: block;
  font-weight: 600;
  font-size: 0.8rem;
  margin-bottom: 3px;
}
.mig-panel-type-card__desc {
  display: block;
  font-size: 0.68rem;
  opacity: 0.5;
}

/* ── Color Swatch Grid ────────────────────────────────── */
.mig-swatch-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.mig-color-swatch {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  border: 2px solid transparent;
  cursor: pointer;
  transition: border-color 0.15s, transform 0.15s;
}
.mig-color-swatch:hover {
  transform: scale(1.15);
}
.mig-color-swatch--selected {
  border-color: #fff;
  box-shadow: 0 0 8px rgba(255,255,255,0.3);
}

/* ═══════════════════════════════════════════════════════════
   PHASE 79: Crystal Panels — EOMI-Attached Chat Panels
   ═══════════════════════════════════════════════════════════ */

/* ── Crystal Panel Container ───────────────────────────── */
.crystal-panel {
  position: fixed;
  display: flex;
  flex-direction: column;
  min-width: 300px;
  min-height: 400px;
  background: var(--panel-bg, linear-gradient(145deg, rgba(26,26,46,0.95), rgba(10,15,30,0.98)));
  border: 1px solid var(--border-card, rgba(0,212,255,0.25));
  border-radius: 14px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5), 0 0 1px rgba(0,212,255,0.3);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  z-index: 8000;
  overflow: hidden;
  transition: box-shadow 0.2s, border-color 0.2s;
}
.crystal-panel:hover {
  box-shadow: 0 12px 40px rgba(0,0,0,0.6), 0 0 2px rgba(0,212,255,0.4);
}
.crystal-panel--minimized .crystal-panel__body,
.crystal-panel--minimized .crystal-panel__config,
.crystal-panel--minimized .crystal-panel__input,
.crystal-panel--minimized .crystal-panel__resize,
.crystal-panel--minimized .crystal-tool-tray,
.crystal-panel--minimized .crystal-tool-panel {
  display: none;
}
.crystal-panel--minimized {
  min-height: auto;
  height: auto !important;
  width: auto !important;
  min-width: 260px;
}
/* Expand button: hidden by default, shown when minimized */
.crystal-panel__expand-btn {
  display: none;
  width: 28px;
  height: 24px;
  border: 1px solid rgba(0,212,255,0.35);
  border-radius: 6px;
  background: rgba(0,212,255,0.12);
  color: #00d4ff;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  flex-shrink: 0;
  line-height: 1;
  transition: background 0.15s, border-color 0.15s;
}
.crystal-panel__expand-btn:hover {
  background: rgba(0,212,255,0.25);
  border-color: rgba(0,212,255,0.6);
}
.crystal-panel--minimized .crystal-panel__expand-btn {
  display: flex;
  align-items: center;
  justify-content: center;
}
.crystal-panel--minimized .crystal-panel__title {
  cursor: pointer;
}
.crystal-panel--minimized .crystal-panel__title:hover {
  color: #00d4ff;
}
[data-theme="sunrise"] .crystal-panel__expand-btn {
  border-color: rgba(232,160,32,0.35);
  background: rgba(232,160,32,0.12);
  color: #E8A020;
}
[data-theme="sunrise"] .crystal-panel__expand-btn:hover {
  background: rgba(232,160,32,0.25);
  border-color: rgba(232,160,32,0.6);
}
.crystal-panel--pinned {
  border-color: rgba(212,168,67,0.6) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5), 0 0 16px rgba(212,168,67,0.15) !important;
}

/* ── Header ────────────────────────────────────────────── */
.crystal-panel__header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border-bottom: 1px solid rgba(255,255,255,0.06);
  cursor: grab;
  user-select: none;
  flex-shrink: 0;
}
.crystal-panel__header:active { cursor: grabbing; }
.crystal-panel__eomi-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #D4A843;
  flex-shrink: 0;
  box-shadow: 0 0 6px rgba(212,168,67,0.4);
}
.crystal-panel__title {
  flex: 1;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.crystal-panel__header-actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}
.crystal-panel__header-btn {
  width: 28px;
  height: 28px;
  border: none;
  background: rgba(255,255,255,0.05);
  color: var(--text-muted);
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s;
}
.crystal-panel__header-btn:hover {
  background: rgba(255,255,255,0.1);
  color: var(--text-primary);
}
.crystal-panel__header-btn--pin-active {
  color: #D4A843;
  background: rgba(212,168,67,0.15);
}
.crystal-panel__delete-btn {
  opacity: 0;
  transition: opacity 0.2s, color 0.15s, transform 0.15s;
  color: rgba(255,80,80,0.8);
}
.crystal-panel__header:hover .crystal-panel__delete-btn {
  opacity: 1;
}
.crystal-panel__delete-btn:hover {
  color: #ff4444;
  transform: scale(1.1);
  background: rgba(255,68,68,0.15);
}

/* ── Config Bar ────────────────────────────────────────── */
.crystal-panel__config {
  display: flex;
  gap: 8px;
  padding: 8px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  flex-shrink: 0;
}
.crystal-panel__config select {
  flex: 1;
  padding: 5px 8px;
  font-size: 0.75rem;
  background: rgba(255,255,255,0.06);
  color: var(--text-secondary);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 6px;
  cursor: pointer;
}
.crystal-panel__config select:focus {
  outline: none;
  border-color: rgba(0,212,255,0.4);
}

/* ── Messages Body ─────────────────────────────────────── */
.crystal-panel__body {
  flex: 1;
  overflow-y: auto;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.1) transparent;
}
.crystal-panel__body::-webkit-scrollbar { width: 5px; }
.crystal-panel__body::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 3px; }

/* ── Message Bubbles ───────────────────────────────────── */
.crystal-msg {
  max-width: 85%;
  padding: 10px 14px;
  border-radius: 12px;
  font-size: 0.82rem;
  line-height: 1.5;
  word-wrap: break-word;
}
.crystal-msg--user {
  align-self: flex-end;
  background: linear-gradient(135deg, rgba(0,212,255,0.2), rgba(0,212,255,0.08));
  color: var(--text-primary);
  border: 1px solid rgba(0,212,255,0.15);
  border-bottom-right-radius: 4px;
}
.crystal-msg--assistant {
  align-self: flex-start;
  background: rgba(255,255,255,0.04);
  color: var(--text-primary);
  border: 1px solid rgba(255,255,255,0.06);
  border-bottom-left-radius: 4px;
}
.crystal-msg--assistant pre {
  background: rgba(0,0,0,0.3);
  padding: 8px 10px;
  border-radius: 6px;
  overflow-x: auto;
  font-size: 0.78rem;
  margin: 6px 0;
}
.crystal-msg--assistant code {
  font-family: 'Courier New', monospace;
  font-size: 0.78rem;
}
.crystal-msg--assistant p { margin-bottom: 6px; }
.crystal-msg--assistant p:last-child { margin-bottom: 0; }
.crystal-msg--assistant ul, .crystal-msg--assistant ol { padding-left: 18px; margin-bottom: 6px; }
.crystal-msg__copy-btn {
  margin-top: 6px;
  padding: 2px 8px;
  font-size: 0.65rem;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--text-muted);
  border-radius: 4px;
  cursor: pointer;
}
.crystal-msg__copy-btn:hover { background: rgba(255,255,255,0.1); }

/* ── Thinking Indicator ────────────────────────────────── */
.crystal-thinking {
  align-self: flex-start;
  display: flex;
  gap: 4px;
  padding: 10px 14px;
}
.crystal-thinking__dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(0,212,255,0.5);
  animation: crystalPulse 1.2s ease-in-out infinite;
}
.crystal-thinking__dot:nth-child(2) { animation-delay: 0.2s; }
.crystal-thinking__dot:nth-child(3) { animation-delay: 0.4s; }
@keyframes crystalPulse {
  0%, 100% { opacity: 0.3; transform: scale(0.8); }
  50% { opacity: 1; transform: scale(1.1); }
}

/* ── Input Bar ─────────────────────────────────────────── */
.crystal-panel__input {
  display: flex;
  align-items: flex-end;
  gap: 6px;
  padding: 10px 14px;
  border-top: 1px solid rgba(255,255,255,0.06);
  flex-shrink: 0;
}
.crystal-panel__input-actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
  padding-bottom: 2px;
}
.crystal-panel__input-btn {
  width: 32px;
  height: 32px;
  border: none;
  background: rgba(255,255,255,0.05);
  color: var(--text-muted);
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.85rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
}
.crystal-panel__input-btn:hover {
  background: rgba(255,255,255,0.1);
  color: var(--text-primary);
}
.crystal-panel__textarea {
  flex: 1;
  min-height: 36px;
  max-height: 100px;
  padding: 8px 10px;
  font-size: 0.82rem;
  font-family: var(--font-primary);
  background: rgba(255,255,255,0.04);
  color: var(--text-primary);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  resize: none;
  overflow-y: auto;
}
.crystal-panel__textarea:focus {
  outline: none;
  border-color: rgba(0,212,255,0.4);
}
.crystal-panel__textarea::placeholder { color: rgba(255,255,255,0.25); }
.crystal-panel__send-btn {
  width: 36px;
  height: 36px;
  border: none;
  background: linear-gradient(135deg, rgba(0,212,255,0.25), rgba(0,212,255,0.1));
  color: #00d4ff;
  border-radius: 8px;
  cursor: pointer;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
  flex-shrink: 0;
}
.crystal-panel__send-btn:hover {
  background: linear-gradient(135deg, rgba(0,212,255,0.35), rgba(0,212,255,0.18));
}
.crystal-panel__send-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* ── Attachment Pills ──────────────────────────────────── */
.crystal-attach-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 6px 14px;
  border-top: 1px solid rgba(255,255,255,0.04);
  flex-shrink: 0;
}
.crystal-attach-pill {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  font-size: 0.7rem;
  background: rgba(0,212,255,0.08);
  border: 1px solid rgba(0,212,255,0.15);
  border-radius: 12px;
  color: var(--text-secondary);
}
.crystal-attach-pill__remove {
  cursor: pointer;
  color: var(--text-muted);
  font-size: 0.6rem;
}
.crystal-attach-pill__remove:hover { color: #ef4444; }

/* ── Resize Handle ─────────────────────────────────────── */
.crystal-panel__resize {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 18px;
  height: 18px;
  cursor: nwse-resize;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.6rem;
  color: rgba(255,255,255,0.15);
}
.crystal-panel__resize:hover { color: rgba(255,255,255,0.35); }

/* ── Create Modal ──────────────────────────────────────── */
.crystal-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(4px);
}
.crystal-modal {
  background: linear-gradient(145deg, rgba(26,26,46,0.98), rgba(10,15,30,0.99));
  border: 1px solid rgba(0,212,255,0.25);
  border-radius: 16px;
  padding: 28px;
  width: 440px;
  max-width: 90vw;
  max-height: 80vh;
  overflow-y: auto;
  box-shadow: 0 16px 48px rgba(0,0,0,0.6);
}
.crystal-modal__title {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 20px;
}
.crystal-modal__field {
  margin-bottom: 16px;
}
.crystal-modal__label {
  display: block;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 6px;
}
.crystal-modal__input {
  width: 100%;
  padding: 8px 12px;
  font-size: 0.85rem;
  font-family: var(--font-primary);
  background: var(--input-bg);
  color: var(--text-primary);
  border: 1px solid rgba(0,212,255,0.4);
  border-radius: 8px;
}
.crystal-modal__input:focus {
  outline: none;
  border-color: rgba(0,212,255,0.7);
}
.crystal-modal__select {
  width: 100%;
  padding: 8px 12px;
  padding-right: 32px;
  font-size: 0.85rem;
  background: var(--input-bg);
  color: var(--text-primary);
  border: 1px solid rgba(0,212,255,0.4);
  border-radius: 8px;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%2300d4ff' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
}
.crystal-modal__select:focus {
  outline: none;
  border-color: rgba(0,212,255,0.7);
}
.crystal-modal__select option {
  background: var(--panel-bg);
  color: var(--text-primary);
}
.crystal-modal__actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 24px;
}
.crystal-modal__btn {
  padding: 8px 20px;
  border-radius: 8px;
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.05);
  color: var(--text-secondary);
  transition: all 0.15s;
}
.crystal-modal__btn:hover { background: rgba(255,255,255,0.1); }
.crystal-modal__btn--primary {
  background: linear-gradient(135deg, rgba(0,212,255,0.2), rgba(0,212,255,0.08));
  border-color: rgba(0,212,255,0.4);
  color: #00d4ff;
}
.crystal-modal__btn--primary:hover {
  background: linear-gradient(135deg, rgba(0,212,255,0.3), rgba(0,212,255,0.15));
}

/* ── Color Theme Presets ───────────────────────────────── */
.crystal-theme-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.crystal-theme-swatch {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  border: 2px solid transparent;
  cursor: pointer;
  transition: border-color 0.15s, transform 0.15s;
  position: relative;
}
.crystal-theme-swatch:hover { transform: scale(1.1); }
.crystal-theme-swatch--selected {
  border-color: #fff;
  box-shadow: 0 0 8px rgba(255,255,255,0.3);
}
.crystal-theme-swatch--default { background: linear-gradient(135deg, #1a1a2e, #0a0f1e); border-color: rgba(0,212,255,0.3); }
.crystal-theme-swatch--gold { background: linear-gradient(135deg, #2e2a1a, #1e1a0a); border-color: rgba(212,168,67,0.3); }
.crystal-theme-swatch--blue { background: linear-gradient(135deg, #1a1e2e, #0a0f1e); border-color: rgba(99,102,241,0.3); }
.crystal-theme-swatch--cyan { background: linear-gradient(135deg, #1a2e2e, #0a1e1e); border-color: rgba(0,212,255,0.3); }
.crystal-theme-swatch--green { background: linear-gradient(135deg, #1a2e1e, #0a1e0f); border-color: rgba(34,197,94,0.3); }
.crystal-theme-swatch--red { background: linear-gradient(135deg, #2e1a1a, #1e0a0a); border-color: rgba(239,68,68,0.3); }
.crystal-theme-swatch--purple { background: linear-gradient(135deg, #251a2e, #180a1e); border-color: rgba(168,85,247,0.3); }

/* ── Empty State ───────────────────────────────────────── */
.crystal-panel__empty {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  font-size: 0.8rem;
  text-align: center;
  padding: 20px;
}

/* ═══════════════════════════════════════════════════════════
   PHASE 80: Crystal Panel Tool Suite
   ═══════════════════════════════════════════════════════════ */

/* ── Tool Tray Bar ─────────────────────────────────────── */
.crystal-tool-tray {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  flex-shrink: 0;
  overflow-x: auto;
}
.crystal-tool-tray__btn {
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  border-radius: 6px;
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.6);
  font-size: 14px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, box-shadow 0.15s;
  flex-shrink: 0;
}
.crystal-tool-tray__btn:hover {
  background: rgba(0,212,255,0.15);
  color: #00d4ff;
}
.crystal-tool-tray__btn:active {
  transform: scale(0.93);
}
.crystal-tool-tray__btn.is-active {
  background: rgba(0,212,255,0.2);
  color: #00d4ff;
  box-shadow: 0 0 8px rgba(0,212,255,0.3);
}

/* ── Tool Panel Container ──────────────────────────────── */
.crystal-tool-panel {
  flex-shrink: 0;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.25s ease;
  border-bottom: none;
}
.crystal-tool-panel.is-open {
  max-height: 55%;
  overflow-y: auto;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

/* ── Calculator ────────────────────────────────────────── */
.crystal-calc { padding: 8px; }
.crystal-calc__display {
  background: rgba(0,0,0,0.3);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 6px;
  padding: 8px 10px;
  font-family: 'Courier New', monospace;
  font-size: 1.1rem;
  color: #00d4ff;
  text-align: right;
  margin-bottom: 8px;
  min-height: 24px;
  word-break: break-all;
}
.crystal-calc__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
}
.crystal-calc__key {
  padding: 8px 4px;
  border: none;
  border-radius: 5px;
  background: var(--surface-hover, rgba(255,255,255,0.08));
  color: var(--text-primary);
  font-size: 0.85rem;
  cursor: pointer;
  transition: background 0.12s;
}
.crystal-calc__key:hover { background: rgba(255,255,255,0.15); }
.crystal-calc__key--op { background: rgba(0,212,255,0.15); color: #00d4ff; }
.crystal-calc__key--op:hover { background: rgba(0,212,255,0.25); }
.crystal-calc__key--eq { background: rgba(0,212,255,0.3); color: var(--text-primary); }
.crystal-calc__key--eq:hover { background: rgba(0,212,255,0.45); }
.crystal-calc__key--wide { grid-column: span 2; }
.crystal-calc__ask {
  margin-top: 6px;
  width: 100%;
  padding: 6px;
  border: none;
  border-radius: 5px;
  background: rgba(168,85,247,0.15);
  color: #a855f7;
  font-size: 0.75rem;
  cursor: pointer;
}
.crystal-calc__ask:hover { background: rgba(168,85,247,0.25); }

/* ── Unit Converter ────────────────────────────────────── */
.crystal-convert { padding: 8px; }
.crystal-convert__row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 6px;
}
.crystal-convert__select,
.crystal-convert__input {
  flex: 1;
  padding: 6px 8px;
  border: 1px solid var(--border-input, rgba(255,255,255,0.1));
  border-radius: 5px;
  background: var(--input-bg, rgba(0,0,0,0.3));
  color: var(--text-primary);
  font-size: 0.8rem;
}
.crystal-convert__result {
  background: rgba(0,212,255,0.08);
  border: 1px solid rgba(0,212,255,0.15);
  border-radius: 6px;
  padding: 8px 10px;
  font-family: 'Courier New', monospace;
  font-size: 0.95rem;
  color: #00d4ff;
  text-align: center;
  min-height: 20px;
}
.crystal-convert__swap {
  width: 28px;
  height: 28px;
  border: none;
  border-radius: 50%;
  background: var(--surface-hover, rgba(255,255,255,0.08));
  color: var(--text-primary);
  font-size: 0.9rem;
  cursor: pointer;
  flex-shrink: 0;
}
.crystal-convert__swap:hover { background: rgba(255,255,255,0.15); }
.crystal-convert__ask {
  margin-top: 6px;
  width: 100%;
  padding: 6px;
  border: none;
  border-radius: 5px;
  background: rgba(168,85,247,0.15);
  color: #a855f7;
  font-size: 0.75rem;
  cursor: pointer;
}
.crystal-convert__ask:hover { background: rgba(168,85,247,0.25); }

/* ── Web Search ────────────────────────────────────────── */
.crystal-search { padding: 8px; }
.crystal-search__bar {
  display: flex;
  gap: 4px;
  margin-bottom: 8px;
}
.crystal-search__input {
  flex: 1;
  padding: 6px 10px;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 5px;
  background: rgba(0,0,0,0.3);
  color: #fff;
  font-size: 0.8rem;
}
.crystal-search__go {
  padding: 6px 12px;
  border: none;
  border-radius: 5px;
  background: rgba(0,212,255,0.2);
  color: #00d4ff;
  font-size: 0.8rem;
  cursor: pointer;
}
.crystal-search__go:hover { background: rgba(0,212,255,0.35); }
.crystal-search__results { display: flex; flex-direction: column; gap: 6px; }
.crystal-search__card {
  padding: 8px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 6px;
  background: rgba(255,255,255,0.03);
  cursor: pointer;
  transition: background 0.12s;
}
.crystal-search__card:hover { background: rgba(255,255,255,0.07); }
.crystal-search__card-title {
  font-size: 0.8rem;
  color: #00d4ff;
  margin-bottom: 2px;
}
.crystal-search__card-snippet {
  font-size: 0.7rem;
  color: rgba(255,255,255,0.5);
  line-height: 1.3;
}

/* ── Deep Dive ─────────────────────────────────────────── */
.crystal-deepdive { padding: 8px; }
.crystal-deepdive__input-row {
  display: flex;
  gap: 4px;
  margin-bottom: 8px;
}
.crystal-deepdive__input {
  flex: 1;
  padding: 6px 10px;
  border: 1px solid rgba(168,85,247,0.2);
  border-radius: 5px;
  background: rgba(0,0,0,0.3);
  color: #fff;
  font-size: 0.8rem;
}
.crystal-deepdive__launch {
  padding: 6px 12px;
  border: none;
  border-radius: 5px;
  background: rgba(168,85,247,0.25);
  color: #a855f7;
  font-size: 0.8rem;
  cursor: pointer;
  white-space: nowrap;
}
.crystal-deepdive__launch:hover { background: rgba(168,85,247,0.4); }
.crystal-deepdive__launch:disabled { opacity: 0.4; cursor: not-allowed; }
.crystal-deepdive__stages { list-style: none; padding: 0; margin: 0 0 8px 0; }
.crystal-deepdive__stage {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 0;
  font-size: 0.75rem;
  color: rgba(255,255,255,0.35);
}
.crystal-deepdive__stage.is-active { color: #a855f7; font-weight: 600; }
.crystal-deepdive__stage.is-done { color: rgba(255,255,255,0.5); }
.crystal-deepdive__stage-icon {
  width: 16px;
  text-align: center;
  font-size: 0.7rem;
}
.crystal-deepdive__output {
  background: rgba(0,0,0,0.25);
  border: 1px solid rgba(168,85,247,0.12);
  border-radius: 6px;
  padding: 10px;
  font-size: 0.78rem;
  color: rgba(255,255,255,0.8);
  line-height: 1.5;
  max-height: 300px;
  overflow-y: auto;
}
.crystal-deepdive__output h1,
.crystal-deepdive__output h2,
.crystal-deepdive__output h3 {
  color: #a855f7;
  margin: 8px 0 4px;
}
.crystal-deepdive__output p { margin: 4px 0; }

/* ── Timer / Stopwatch ─────────────────────────────────── */
.crystal-timer { padding: 8px; }
.crystal-timer__tabs {
  display: flex;
  gap: 2px;
  margin-bottom: 8px;
}
.crystal-timer__tab {
  flex: 1;
  padding: 5px;
  border: none;
  border-radius: 5px 5px 0 0;
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.5);
  font-size: 0.75rem;
  cursor: pointer;
}
.crystal-timer__tab.is-active {
  background: rgba(0,212,255,0.15);
  color: #00d4ff;
}
.crystal-timer__display {
  font-family: 'Courier New', monospace;
  font-size: 2rem;
  text-align: center;
  color: #00d4ff;
  padding: 12px 0;
  letter-spacing: 2px;
}
.crystal-timer__controls {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-bottom: 6px;
}
.crystal-timer__btn {
  padding: 6px 14px;
  border: none;
  border-radius: 5px;
  font-size: 0.75rem;
  cursor: pointer;
}
.crystal-timer__btn--start { background: rgba(34,197,94,0.2); color: #22c55e; }
.crystal-timer__btn--start:hover { background: rgba(34,197,94,0.35); }
.crystal-timer__btn--stop { background: rgba(239,68,68,0.2); color: #ef4444; }
.crystal-timer__btn--stop:hover { background: rgba(239,68,68,0.35); }
.crystal-timer__btn--lap { background: rgba(0,212,255,0.15); color: #00d4ff; }
.crystal-timer__btn--lap:hover { background: rgba(0,212,255,0.25); }
.crystal-timer__btn--reset { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.6); }
.crystal-timer__btn--reset:hover { background: rgba(255,255,255,0.15); }
.crystal-timer__set-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  margin-bottom: 8px;
}
.crystal-timer__set-input {
  width: 42px;
  padding: 4px;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 4px;
  background: rgba(0,0,0,0.3);
  color: #fff;
  font-size: 0.8rem;
  text-align: center;
}
.crystal-timer__laps {
  max-height: 80px;
  overflow-y: auto;
  font-size: 0.7rem;
  color: rgba(255,255,255,0.5);
}
.crystal-timer__lap-item {
  padding: 2px 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}

/* ── Voice Memo ────────────────────────────────────────── */
.crystal-voice { padding: 8px; text-align: center; }
.crystal-voice__rec-btn {
  width: 50px;
  height: 50px;
  border: none;
  border-radius: 50%;
  background: rgba(239,68,68,0.25);
  color: #ef4444;
  font-size: 1.2rem;
  cursor: pointer;
  transition: background 0.15s, box-shadow 0.15s;
  margin-bottom: 8px;
}
.crystal-voice__rec-btn:hover { background: rgba(239,68,68,0.4); }
.crystal-voice__rec-btn.is-recording {
  background: rgba(239,68,68,0.5);
  box-shadow: 0 0 0 4px rgba(239,68,68,0.15);
  animation: crystal-voice-pulse 1.2s ease-in-out infinite;
}
@keyframes crystal-voice-pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(239,68,68,0.15); }
  50% { box-shadow: 0 0 0 10px rgba(239,68,68,0.05); }
}
.crystal-voice__status {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.5);
  margin-bottom: 8px;
}
.crystal-voice__audio {
  width: 100%;
  height: 32px;
  margin-bottom: 6px;
}
.crystal-voice__transcribe {
  padding: 6px 14px;
  border: none;
  border-radius: 5px;
  background: rgba(168,85,247,0.2);
  color: #a855f7;
  font-size: 0.75rem;
  cursor: pointer;
}
.crystal-voice__transcribe:hover { background: rgba(168,85,247,0.35); }
.crystal-voice__transcribe:disabled { opacity: 0.4; cursor: not-allowed; }
.crystal-voice__transcript {
  margin-top: 6px;
  padding: 8px;
  border-radius: 5px;
  background: rgba(0,0,0,0.2);
  font-size: 0.75rem;
  color: rgba(255,255,255,0.7);
  text-align: left;
}

/* ── Code Editor ───────────────────────────────────────── */
.crystal-code { padding: 8px; }
.crystal-code__header {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 6px;
}
.crystal-code__lang {
  padding: 4px 8px;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 4px;
  background: rgba(0,0,0,0.3);
  color: #fff;
  font-size: 0.75rem;
}
.crystal-code__textarea {
  width: 100%;
  min-height: 100px;
  padding: 8px;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 6px;
  background: rgba(0,0,0,0.35);
  color: #00d4ff;
  font-family: 'Courier New', monospace;
  font-size: 0.8rem;
  resize: vertical;
  tab-size: 2;
}
.crystal-code__actions {
  display: flex;
  gap: 4px;
  margin-top: 6px;
}
.crystal-code__btn {
  padding: 5px 10px;
  border: none;
  border-radius: 4px;
  font-size: 0.75rem;
  cursor: pointer;
}
.crystal-code__btn--run { background: rgba(34,197,94,0.2); color: #22c55e; }
.crystal-code__btn--run:hover { background: rgba(34,197,94,0.35); }
.crystal-code__btn--ask { background: rgba(168,85,247,0.15); color: #a855f7; }
.crystal-code__btn--ask:hover { background: rgba(168,85,247,0.25); }
.crystal-code__output {
  margin-top: 6px;
  padding: 8px;
  border-radius: 5px;
  background: rgba(0,0,0,0.3);
  border: 1px solid rgba(255,255,255,0.06);
  font-family: 'Courier New', monospace;
  font-size: 0.75rem;
  color: rgba(255,255,255,0.7);
  max-height: 120px;
  overflow-y: auto;
  white-space: pre-wrap;
}

/* ═══════════════════════════════════════════════════════════
   PHASE 79: Crystal Panels — Light Mode Overrides
   ═══════════════════════════════════════════════════════════ */

[data-theme="sunrise"] .crystal-panel {
  background: #F5F0E8;
  border-color: #E8A020;
  box-shadow: 0 8px 32px rgba(232,160,32,0.15), 0 0 1px rgba(232,160,32,0.3);
}
[data-theme="sunrise"] .crystal-panel:hover {
  box-shadow: 0 12px 40px rgba(232,160,32,0.25), 0 0 2px rgba(232,160,32,0.4);
}
[data-theme="sunrise"] .crystal-panel--pinned {
  border-color: #E8A020 !important;
  box-shadow: 0 8px 32px rgba(232,160,32,0.2), 0 0 12px rgba(232,160,32,0.3) !important;
}
[data-theme="sunrise"] .crystal-panel__header {
  background: rgba(232,160,32,0.05);
  border-bottom-color: rgba(232,160,32,0.2);
}
[data-theme="sunrise"] .crystal-panel__config select {
  background: #EDE8DC;
  color: #191970;
  border-color: rgba(232,160,32,0.3);
}
[data-theme="sunrise"] .crystal-msg--user {
  background: rgba(232,160,32,0.1);
  border-color: rgba(232,160,32,0.2);
}
[data-theme="sunrise"] .crystal-msg--assistant {
  background: rgba(25,25,112,0.04);
  border-color: rgba(232,160,32,0.15);
}
[data-theme="sunrise"] .crystal-msg--assistant pre {
  background: #EDE8DC;
}
[data-theme="sunrise"] .crystal-panel__textarea {
  background: #EDE8DC;
  color: #191970;
  border-color: rgba(232,160,32,0.35);
}
[data-theme="sunrise"] .crystal-panel__textarea::placeholder { color: rgba(25,25,112,0.4); }
[data-theme="sunrise"] .crystal-panel__header-btn {
  background: rgba(232,160,32,0.1);
  color: #191970;
}
[data-theme="sunrise"] .crystal-panel__header-btn:hover {
  background: rgba(232,160,32,0.2);
}
[data-theme="sunrise"] .crystal-panel__delete-btn {
  color: rgba(200,50,50,0.7);
}
[data-theme="sunrise"] .crystal-panel__delete-btn:hover {
  color: #cc2222;
  background: rgba(200,50,50,0.1);
}
[data-theme="sunrise"] .crystal-panel__input-btn {
  background: rgba(232,160,32,0.1);
}
[data-theme="sunrise"] .crystal-panel__input-btn:hover {
  background: rgba(232,160,32,0.2);
}
[data-theme="sunrise"] .crystal-panel__send-btn {
  background: #E8A020;
  color: #191970;
}
[data-theme="sunrise"] .crystal-modal {
  background: #F5F0E8;
  border-color: rgba(232,160,32,0.4);
}
[data-theme="sunrise"] .crystal-modal__input,
[data-theme="sunrise"] .crystal-modal__select {
  background: #EDE8DC;
  border-color: rgba(232,160,32,0.35);
  color: #191970;
}
[data-theme="sunrise"] .crystal-attach-pill {
  background: rgba(232,160,32,0.08);
  border-color: rgba(232,160,32,0.2);
}
[data-theme="sunrise"] .crystal-thinking__dot {
  background: rgba(232,160,32,0.6);
}
/* ── Phase 80: Tool Suite Light Mode ───────────────────── */
[data-theme="sunrise"] .crystal-tool-tray {
  border-bottom-color: rgba(232,160,32,0.2);
}
[data-theme="sunrise"] .crystal-tool-tray__btn {
  background: rgba(232,160,32,0.08);
  color: #191970;
}
[data-theme="sunrise"] .crystal-tool-tray__btn:hover {
  background: rgba(232,160,32,0.2);
  color: #191970;
}
[data-theme="sunrise"] .crystal-tool-tray__btn.is-active {
  background: rgba(232,160,32,0.25);
  color: #191970;
  box-shadow: 0 0 6px rgba(232,160,32,0.3);
}
[data-theme="sunrise"] .crystal-tool-panel {
  border-bottom-color: rgba(232,160,32,0.2);
}
[data-theme="sunrise"] .crystal-calc__display {
  background: #EDE8DC;
  border-color: rgba(232,160,32,0.3);
  color: #191970;
}
[data-theme="sunrise"] .crystal-calc__key {
  background: rgba(232,160,32,0.08);
  color: #191970;
}
[data-theme="sunrise"] .crystal-calc__key--op { background: rgba(232,160,32,0.15); color: #191970; }
[data-theme="sunrise"] .crystal-calc__key--eq { background: #E8A020; color: #191970; }
[data-theme="sunrise"] .crystal-convert__select,
[data-theme="sunrise"] .crystal-convert__input,
[data-theme="sunrise"] .crystal-search__input,
[data-theme="sunrise"] .crystal-deepdive__input,
[data-theme="sunrise"] .crystal-timer__set-input,
[data-theme="sunrise"] .crystal-code__lang {
  background: #EDE8DC;
  border-color: rgba(232,160,32,0.35);
  color: #191970;
}
[data-theme="sunrise"] .crystal-convert__result {
  background: rgba(232,160,32,0.08);
  border-color: rgba(232,160,32,0.2);
  color: #191970;
}
[data-theme="sunrise"] .crystal-code__textarea {
  background: #EDE8DC;
  border-color: rgba(232,160,32,0.35);
  color: #191970;
}
[data-theme="sunrise"] .crystal-code__output {
  background: #EDE8DC;
  border-color: rgba(232,160,32,0.2);
  color: #191970;
}
[data-theme="sunrise"] .crystal-timer__display { color: #E8A020; }
[data-theme="sunrise"] .crystal-deepdive__output {
  background: rgba(232,160,32,0.04);
  border-color: rgba(232,160,32,0.15);
  color: #191970;
}
[data-theme="sunrise"] .crystal-deepdive__output h1,
[data-theme="sunrise"] .crystal-deepdive__output h2,
[data-theme="sunrise"] .crystal-deepdive__output h3 { color: #E8A020; }
[data-theme="sunrise"] .crystal-search__card {
  border-color: rgba(232,160,32,0.2);
  background: rgba(232,160,32,0.04);
}
[data-theme="sunrise"] .crystal-search__card-title { color: #E8A020; }
[data-theme="sunrise"] .crystal-search__card-snippet { color: rgba(25,25,112,0.5); }
[data-theme="sunrise"] .crystal-voice__rec-btn {
  background: rgba(239,68,68,0.1);
}
[data-theme="sunrise"] .crystal-voice__transcript {
  background: #EDE8DC;
  color: #191970;
}

/* ═══════════════════════════════════════════════════════════
   PHASE 81: Code Workspace
   ═══════════════════════════════════════════════════════════ */

.code-workspace {
  display: grid;
  grid-template-rows: 40px 1fr 180px;
  grid-template-columns: 180px 1fr 260px;
  height: 100%;
  background: #0a0a14;
  color: #e0e0e0;
  font-family: 'Courier New', monospace;
  font-size: 13px;
  border-radius: 0 0 14px 14px;
  overflow: hidden;
}
.code-workspace.panel-mode {
  grid-template-columns: 1fr;
}
.code-workspace.panel-mode .code-file-tree,
.code-workspace.panel-mode .code-eomi-panel { display: none; }
.code-workspace.fullscreen {
  position: fixed;
  inset: 0;
  z-index: 9999;
  border-radius: 0;
  grid-template-columns: 180px 1fr 280px;
}

/* ── Toolbar ───────────────────────────────────────────── */
.code-toolbar {
  background: #06060f;
  border-bottom: 1px solid rgba(0,212,255,0.15);
  padding: 0 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  height: 40px;
  grid-column: 1 / -1;
}
.code-toolbar__title {
  font-size: 13px;
  font-weight: 700;
  color: #00d4ff;
  margin-right: 4px;
  white-space: nowrap;
}
.code-toolbar select {
  padding: 3px 6px;
  border: 1px solid rgba(0,212,255,0.2);
  border-radius: 4px;
  background: rgba(0,0,0,0.4);
  color: #e0e0e0;
  font-size: 12px;
  max-width: 140px;
}
.code-toolbar__spacer { flex: 1; }

/* ── Engine Selector ──────────────────────────────────── */
.code-engine-select {
  background: rgba(0, 0, 0, 0.4);
  color: var(--text-primary, #e0e0e0);
  border: 1px solid rgba(0, 212, 255, 0.3);
  border-radius: 4px;
  padding: 3px 8px;
  font-size: 12px;
  font-family: var(--font-primary, 'Inter', sans-serif);
  cursor: pointer;
  outline: none;
  max-width: 170px;
}
.code-engine-select:hover { border-color: rgba(0, 212, 255, 0.6); }
.code-engine-select:focus { border-color: #00d4ff; box-shadow: 0 0 0 1px rgba(0,212,255,0.2); }
.code-engine-cost {
  background: rgba(0, 212, 255, 0.1);
  color: #00d4ff;
  border-radius: 4px;
  padding: 2px 8px;
  font-size: 11px;
  font-weight: 500;
  white-space: nowrap;
}

/* ── Buttons ───────────────────────────────────────────── */
.code-btn {
  padding: 4px 12px;
  border-radius: 6px;
  font-size: 12px;
  border: 1px solid rgba(0,212,255,0.3);
  background: rgba(0,212,255,0.08);
  color: #00d4ff;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.12s;
}
.code-btn:hover { background: rgba(0,212,255,0.2); }
.code-btn--run {
  border-color: rgba(0,255,136,0.4);
  background: rgba(0,255,136,0.08);
  color: #00ff88;
}
.code-btn--run:hover { background: rgba(0,255,136,0.2); }
.code-btn--danger {
  border-color: rgba(255,80,80,0.3);
  background: rgba(255,80,80,0.08);
  color: #ff6b6b;
}
.code-btn--sm { padding: 2px 8px; font-size: 11px; }

/* ── File Tree ─────────────────────────────────────────── */
.code-file-tree {
  background: #080810;
  border-right: 1px solid rgba(0,212,255,0.15);
  padding: 8px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.code-file-tree__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 4px 0 8px;
  font-size: 11px;
  color: rgba(255,255,255,0.4);
  text-transform: uppercase;
  letter-spacing: 1px;
}
.code-file-item {
  padding: 6px 8px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 6px;
  color: rgba(255,255,255,0.6);
  transition: background 0.1s;
}
.code-file-item:hover { background: rgba(255,255,255,0.05); }
.code-file-item.active {
  background: rgba(0,212,255,0.12);
  color: #00d4ff;
}
.code-file-item__icon { font-size: 14px; flex-shrink: 0; }
.code-file-item__name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.code-file-item__del {
  margin-left: auto;
  opacity: 0;
  font-size: 11px;
  cursor: pointer;
  color: #ff6b6b;
}
.code-file-item:hover .code-file-item__del { opacity: 0.6; }
.code-file-item__del:hover { opacity: 1 !important; }

/* ── Editor ────────────────────────────────────────────── */
.code-editor-wrapper {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.code-editor-scroll {
  position: relative;
  overflow: auto;
  display: flex;
}
.code-line-numbers {
  position: sticky;
  left: 0;
  width: 44px;
  min-width: 44px;
  padding: 12px 8px 12px 0;
  color: rgba(255,255,255,0.2);
  font-size: 13px;
  line-height: 1.6;
  text-align: right;
  user-select: none;
  background: #0a0a14;
  z-index: 1;
}
.code-editor-textarea {
  width: 100%;
  min-height: 100%;
  background: transparent;
  color: #e0e0e0;
  border: none;
  outline: none;
  resize: none;
  font-family: 'Courier New', monospace;
  font-size: 14px;
  line-height: 1.6;
  padding: 12px 12px 12px 8px;
  tab-size: 2;
  caret-color: #00d4ff;
  white-space: pre;
  overflow-wrap: normal;
}
.code-status-bar {
  background: #060610;
  border-top: 1px solid rgba(255,255,255,0.06);
  padding: 0 12px;
  font-size: 11px;
  color: rgba(255,255,255,0.4);
  display: flex;
  align-items: center;
  gap: 16px;
}
.code-status-bar__saved { color: #00ff88; }

/* ── EOMI Panel ────────────────────────────────────────── */
.code-eomi-panel {
  border-left: 1px solid rgba(0,212,255,0.15);
  display: flex;
  flex-direction: column;
  background: #08081a;
  overflow: hidden;
}
.code-eomi-panel__header {
  padding: 8px 10px;
  font-size: 12px;
  font-weight: 600;
  color: #a855f7;
  border-bottom: 1px solid rgba(168,85,247,0.15);
}
.code-eomi-panel__actions {
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.code-eomi-btn {
  padding: 6px 10px;
  border: 1px solid rgba(168,85,247,0.2);
  border-radius: 6px;
  background: rgba(168,85,247,0.06);
  color: #c084fc;
  font-size: 12px;
  cursor: pointer;
  text-align: left;
  transition: background 0.12s;
}
.code-eomi-btn:hover { background: rgba(168,85,247,0.15); }
.code-eomi-panel__prompt {
  padding: 8px;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.code-eomi-panel__prompt textarea {
  width: 100%;
  min-height: 50px;
  padding: 6px 8px;
  border: 1px solid rgba(168,85,247,0.2);
  border-radius: 5px;
  background: rgba(0,0,0,0.3);
  color: #e0e0e0;
  font-family: inherit;
  font-size: 12px;
  resize: vertical;
}
.code-eomi-panel__output {
  flex: 1;
  overflow-y: auto;
  padding: 8px 10px;
  font-size: 12px;
  color: rgba(255,255,255,0.7);
  line-height: 1.5;
}
.code-eomi-insert-btn {
  margin-top: 6px;
  padding: 4px 10px;
  border: 1px solid rgba(0,212,255,0.3);
  border-radius: 4px;
  background: rgba(0,212,255,0.1);
  color: #00d4ff;
  font-size: 11px;
  cursor: pointer;
}
.code-eomi-insert-btn:hover { background: rgba(0,212,255,0.2); }

/* ── Bottom Panel ──────────────────────────────────────── */
.code-bottom-panel {
  border-top: 1px solid rgba(0,212,255,0.15);
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.code-bottom-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  flex-shrink: 0;
}
.code-bottom-tab {
  padding: 5px 14px;
  border: none;
  background: transparent;
  color: rgba(255,255,255,0.4);
  font-size: 12px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
}
.code-bottom-tab.active {
  color: #00d4ff;
  border-bottom-color: #00d4ff;
}
.code-bottom-content { flex: 1; overflow: hidden; position: relative; }
.code-terminal {
  position: absolute;
  inset: 0;
  overflow-y: auto;
  padding: 10px 14px;
  font-size: 13px;
  line-height: 1.5;
  display: none;
}
.code-terminal.active { display: block; }
.code-terminal .stdout { color: #e0e0e0; }
.code-terminal .stderr { color: #ff6b6b; }
.code-terminal .runtime { color: rgba(255,255,255,0.3); font-size: 11px; }
.code-preview {
  position: absolute;
  inset: 0;
  display: none;
}
.code-preview.active { display: block; }
.code-preview iframe { width: 100%; height: 100%; border: none; background: var(--mig-bg-primary, #f5f0e8); }
.code-versions {
  position: absolute;
  inset: 0;
  overflow-y: auto;
  padding: 10px;
  display: none;
}
.code-versions.active { display: block; }
.code-version-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  font-size: 12px;
}
.code-version-item__time { color: rgba(255,255,255,0.35); font-size: 11px; }
.code-version-item__msg { color: rgba(255,255,255,0.6); flex: 1; }

/* ── Light Mode Overrides ──────────────────────────────── */
[data-theme="sunrise"] .code-engine-select {
  background: #EDE8DC;
  color: #191970;
  border-color: rgba(232,160,32,0.35);
}
[data-theme="sunrise"] .code-engine-cost {
  background: rgba(232,160,32,0.1);
  color: #E8A020;
}

/* ═══════════════════════════════════════════════════════════
   PHASE 82: EOMI Voice System
   ═══════════════════════════════════════════════════════════ */

/* ── Orb speaking animation ─────────────────────────────── */
@keyframes eomi-orb-speak {
  0%   { box-shadow: 0 4px 20px rgba(108,99,255,.3); }
  50%  { box-shadow: 0 4px 30px rgba(108,99,255,.7), 0 0 40px rgba(108,99,255,.3); }
  100% { box-shadow: 0 4px 20px rgba(108,99,255,.3); }
}
.eomi-orb.speaking {
  animation: eomi-orb-speak 1.2s ease-in-out infinite;
  border-color: #6c63ff;
}

/* ── Voice toggle button in toolbar ─────────────────────── */
.eomi-voice-toggle {
  background: none;
  border: none;
  color: #8888a0;
  font-size: 16px;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 4px;
  position: relative;
}
.eomi-voice-toggle:hover {
  background: rgba(108,99,255,.15);
  color: #e0e0e8;
}
.eomi-voice-toggle.active {
  color: #6c63ff;
}
.eomi-voice-toggle .eomi-tool-tip {
  display: none;
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  background: #0a0a0f;
  color: #e0e0e8;
  font-size: 10px;
  padding: 3px 6px;
  border-radius: 4px;
  white-space: nowrap;
  border: 1px solid #2a2a3a;
}
.eomi-voice-toggle:hover .eomi-tool-tip {
  display: block;
}

/* ── Speak button on messages ───────────────────────────── */
.eomi-speak-btn {
  position: absolute;
  bottom: 4px;
  right: 32px;
  background: none;
  border: none;
  color: #6668;
  font-size: 11px;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 4px;
  opacity: 0;
  transition: opacity .2s;
}
.eomi-msg--eomi:hover .eomi-speak-btn {
  opacity: 1;
}
.eomi-speak-btn:hover {
  background: rgba(108,99,255,.2);
  color: #e0e0e8;
}
.eomi-speak-btn.speaking {
  color: #6c63ff;
  opacity: 1;
}

/* ── Crystal panel speak button ─────────────────────────── */
.crystal-panel__speak-btn {
  background: none;
  border: none;
  color: #888;
  font-size: 13px;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 4px;
  opacity: 0.6;
  transition: opacity .2s, color .2s;
  margin-left: 4px;
  vertical-align: middle;
}
.crystal-panel__speak-btn:hover {
  background: rgba(0, 212, 255, 0.2);
  color: #e0e0e8;
  opacity: 1;
}
.crystal-panel__speak-btn.speaking {
  color: #00d4ff;
  opacity: 1;
}

/* ── Voice toggle in crystal panel config bar ───────────── */
.crystal-voice-toggle-btn {
  background: none;
  border: 1px solid rgba(255,255,255,0.1);
  color: #8888a0;
  border-radius: 4px;
  padding: 2px 6px;
  font-size: 14px;
  cursor: pointer;
  line-height: 1;
  flex-shrink: 0;
}
.crystal-voice-toggle-btn:hover {
  border-color: rgba(0,212,255,0.3);
  color: #e0e0e8;
}
.crystal-voice-toggle-btn.active {
  color: #00d4ff;
  border-color: #00d4ff;
}

/* ── Light-mode overrides ───────────────────────────────── */
[data-theme="sunrise"] .eomi-voice-toggle {
  color: #191970;
}
[data-theme="sunrise"] .eomi-voice-toggle:hover {
  background: rgba(232,160,32,0.15);
  color: #191970;
}
[data-theme="sunrise"] .eomi-voice-toggle.active {
  color: #E8A020;
}
[data-theme="sunrise"] .eomi-speak-btn {
  color: rgba(25,25,112,0.5);
}
[data-theme="sunrise"] .eomi-speak-btn:hover {
  background: rgba(232,160,32,0.15);
  color: #191970;
}
[data-theme="sunrise"] .crystal-panel__speak-btn {
  color: rgba(25,25,112,0.5);
}
[data-theme="sunrise"] .crystal-panel__speak-btn:hover {
  background: rgba(232,160,32,0.15);
  color: #191970;
}
[data-theme="sunrise"] .crystal-voice-toggle-btn {
  border-color: rgba(232,160,32,0.3);
  color: #191970;
}
[data-theme="sunrise"] .crystal-voice-toggle-btn.active {
  color: #E8A020;
  border-color: #E8A020;
}

/* ── EOMI Orb Light Mode ──────────────────────────────────── */
[data-theme="sunrise"] .eomi-orb {
  background: radial-gradient(circle at 35% 35%, #E8A020, #d4911a, #F5F0E8);
  box-shadow: 0 0 30px rgba(232,160,32,0.4), inset 0 0 15px rgba(232,160,32,0.15);
}
[data-theme="sunrise"] .eomi-orb--gold {
  background: radial-gradient(circle at 35% 35%, #E8A020, #c98a15, #F5F0E8);
  box-shadow: 0 0 30px rgba(232,160,32,0.5), inset 0 0 15px rgba(232,160,32,0.2);
}
[data-theme="sunrise"] .eomi-orb.speaking {
  border-color: #E8A020;
  animation-name: eomi-orb-speak-light;
}
@keyframes eomi-orb-speak-light {
  0%   { box-shadow: 0 4px 20px rgba(232,160,32,0.3); }
  50%  { box-shadow: 0 4px 30px rgba(232,160,32,0.7), 0 0 40px rgba(232,160,32,0.3); }
  100% { box-shadow: 0 4px 20px rgba(232,160,32,0.3); }
}

/* ═══════════════════════════════════════════════════════════
   PHASE 83: Crystal Vaults — Governed Folder System
   ═══════════════════════════════════════════════════════════ */

/* ── Topbar Vault Actions ─────────────────────────────────── */
.mig-topbar__vault-actions {
  display: flex; gap: 8px; align-items: center;
}

/* ── Vault Grid Section ─────────────────────────────────── */
.vault-grid-section {
  padding: 20px 0;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.vault-canvas {
  position: relative;
  width: 100%;
  min-height: calc(100vh - 60px);
  background-image:
    linear-gradient(rgba(0,212,255,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,212,255,0.06) 1px, transparent 1px);
  background-size: 130px 130px;
  overflow: auto;
}
.vault-grid-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 4px 12px;
}
.vault-grid-header h3 {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary, #e0e0e8);
  margin: 0;
}
.vault-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  padding: 12px 0;
  min-height: 60px;
}
.vault-canvas .vault-grid {
  display: block;
  position: relative;
  width: 100%;
  min-height: calc(100vh - 120px);
  padding: 0;
}

/* ── Vault Cube ─────────────────────────────────────────── */
.vault-cube {
  width: 120px;
  height: 120px;
  border-radius: 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  cursor: pointer;
  position: relative;
  transition: transform 0.3s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.3s;
  user-select: none;
  backdrop-filter: blur(12px);
}
.vault-cube:hover {
  transform: scale(1.05);
}
.vault-cube.is-selected {
  box-shadow: 0 0 20px rgba(255,255,255,0.15) !important;
}
.vault-cube.is-dragging {
  opacity: 0.5;
  transform: scale(0.95);
}
.vault-cube.drag-over {
  transform: scale(1.1);
}
.vault-canvas .vault-cube {
  position: absolute;
  transition: left 0.25s ease, top 0.25s ease, transform 0.3s, box-shadow 0.3s;
}
.vault-canvas .vault-cube.is-dragging {
  transition: none;
  z-index: 100;
  opacity: 0.8;
}
.vault-cube__icon {
  font-size: var(--icon-lg);
  line-height: 1;
}
.vault-cube__name {
  font-size: 11px;
  text-align: center;
  max-width: 100px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text-primary, #e0e0e8);
}
.vault-cube__count {
  position: absolute;
  top: 6px;
  right: 6px;
  background: rgba(0,0,0,0.5);
  border-radius: 10px;
  font-size: 10px;
  padding: 1px 5px;
  color: #fff;
  min-width: 16px;
  text-align: center;
}
.vault-cube__storage-bar {
  position: absolute;
  bottom: 8px;
  left: 10px;
  right: 10px;
  height: 3px;
  border-radius: 2px;
  background: rgba(255,255,255,0.1);
  overflow: hidden;
}
.vault-cube__storage-fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.5s;
}
.vault-cube__storage-fill.warn {
  background: #ffd700 !important;
}
.vault-cube__storage-fill.critical {
  background: #ff4444 !important;
  animation: vault-pulse 1s ease-in-out infinite;
}
@keyframes vault-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

/* ── Vault Expanded Panel ───────────────────────────────── */
.vault-expanded {
  position: fixed;
  z-index: 5000;
  border-radius: 20px;
  backdrop-filter: blur(20px);
  box-shadow: 0 20px 60px rgba(0,0,0,0.6);
  animation: vault-expand 0.3s cubic-bezier(0.34,1.56,0.64,1);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-width: 480px;
  min-height: 360px;
  max-width: 90vw;
  max-height: 80vh;
}
@keyframes vault-expand {
  from { transform: scale(0.3); opacity: 0; }
  to   { transform: scale(1);   opacity: 1; }
}
@keyframes vault-collapse {
  from { transform: scale(1);   opacity: 1; }
  to   { transform: scale(0.3); opacity: 0; }
}
.vault-expanded.collapsing {
  animation: vault-collapse 0.25s ease-in forwards;
}
.vault-expanded__header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.1);
  flex-shrink: 0;
}
.vault-expanded__icon {
  font-size: 24px;
}
.vault-expanded__name {
  flex: 1;
  font-size: 15px;
  font-weight: 600;
  color: #fff;
}
.vault-expanded__actions {
  display: flex;
  gap: 6px;
}
.vault-expanded__btn {
  background: rgba(255,255,255,0.08);
  border: none;
  color: #ccc;
  border-radius: 6px;
  padding: 4px 8px;
  font-size: 13px;
  cursor: pointer;
}
.vault-expanded__btn:hover {
  background: rgba(255,255,255,0.15);
  color: #fff;
}
.vault-expanded__storage {
  padding: 6px 16px;
  font-size: 11px;
  color: rgba(255,255,255,0.6);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  flex-shrink: 0;
}
.vault-expanded__content {
  flex: 1;
  overflow-y: auto;
  padding: 12px 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-content: flex-start;
}
.vault-expanded__toolbar {
  display: flex;
  gap: 8px;
  padding: 10px 16px;
  border-top: 1px solid rgba(255,255,255,0.08);
  flex-shrink: 0;
}
.vault-expanded__toolbar button {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  color: #ccc;
  border-radius: 8px;
  padding: 6px 12px;
  font-size: 12px;
  cursor: pointer;
}
.vault-expanded__toolbar button:hover {
  background: rgba(255,255,255,0.12);
  color: #fff;
}

/* ── Storage Bar (expanded header) ──────────────────────── */
.vault-storage-bar {
  height: 6px;
  border-radius: 3px;
  background: rgba(255,255,255,0.1);
  overflow: hidden;
  margin-top: 4px;
}
.vault-storage-bar__fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.5s;
}

/* ── Vault Fullscreen ───────────────────────────────────── */
.vault-fullscreen {
  position: fixed;
  inset: 0;
  z-index: 9000;
  display: grid;
  grid-template-columns: 240px 1fr 280px;
  grid-template-rows: 50px 1fr;
  animation: vault-expand 0.3s ease;
}
.vault-fullscreen__topbar {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 16px;
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.vault-fullscreen__breadcrumb {
  flex: 1;
  font-size: 13px;
  color: rgba(255,255,255,0.7);
}
.vault-fullscreen__breadcrumb span {
  cursor: pointer;
}
.vault-fullscreen__breadcrumb span:hover {
  color: #fff;
}
.vault-fullscreen__sidebar {
  border-right: 1px solid rgba(255,255,255,0.08);
  overflow-y: auto;
  padding: 12px;
}
.vault-fullscreen__main {
  overflow-y: auto;
  padding: 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-content: flex-start;
}
.vault-fullscreen__detail {
  border-left: 1px solid rgba(255,255,255,0.08);
  overflow-y: auto;
  padding: 12px;
}
.vault-fullscreen__detail-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary, #e0e0e8);
  margin-bottom: 8px;
}
.vault-fullscreen__detail-summary {
  font-size: 12px;
  color: var(--text-secondary, #8888a0);
  line-height: 1.5;
}

/* ── Item Cards (inside expanded/fullscreen) ────────────── */
.vault-item-card {
  border-radius: 12px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04);
  cursor: pointer;
  transition: all 0.2s;
  width: 140px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  text-align: center;
  position: relative;
}
.vault-item-card:hover {
  background: rgba(255,255,255,0.08);
  transform: translateY(-2px);
}
.vault-item-card__icon {
  font-size: var(--icon-lg);
  line-height: 1;
}
.vault-item-card__name {
  font-size: 11px;
  color: var(--text-primary, #e0e0e8);
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.vault-item-card__meta {
  font-size: 10px;
  color: var(--text-muted, #8888a0);
}
.vault-item-card__actions {
  display: none;
  position: absolute;
  top: 4px;
  right: 4px;
  gap: 2px;
}
.vault-item-card:hover .vault-item-card__actions {
  display: flex;
}
.vault-item-card__action-btn {
  background: rgba(0,0,0,0.4);
  border: none;
  color: #ccc;
  border-radius: 4px;
  padding: 2px 5px;
  font-size: 10px;
  cursor: pointer;
}
.vault-item-card__action-btn:hover {
  background: rgba(255,255,255,0.2);
  color: #fff;
}

/* ── Panel Item Card (inside vault) ──────────────────────── */
.vault-item-card--panel {
  width: 180px;
  border-left: 3px solid #00d4ff;
}
.vault-item-card--panel .vault-item-card__eomi-badge {
  display: inline-block;
  font-size: 9px;
  background: rgba(212,168,67,0.25);
  color: #ffd700;
  border-radius: 4px;
  padding: 1px 5px;
  margin-top: 2px;
}
.vault-item-card--panel .vault-item-card__open-btn {
  background: rgba(0,212,255,0.15);
  border: 1px solid rgba(0,212,255,0.3);
  color: #00d4ff;
  border-radius: 6px;
  padding: 3px 10px;
  font-size: 10px;
  cursor: pointer;
  margin-top: 4px;
}
.vault-item-card--panel .vault-item-card__open-btn:hover {
  background: rgba(0,212,255,0.3);
  color: #fff;
}

/* ── Panel expand-from-vault animation ────────────────────── */
@keyframes panel-expand-from-card {
  from { transform: scale(0.3) translateY(20px); opacity: 0; }
  to   { transform: scale(1)   translateY(0);    opacity: 1; }
}
.crystal-panel.is-expanded-from-vault {
  position: fixed;
  z-index: 8000;
  animation: panel-expand-from-card 0.3s ease;
}
@keyframes panel-collapse-to-card {
  from { transform: scale(1)   translateY(0);    opacity: 1; }
  to   { transform: scale(0.3) translateY(20px); opacity: 0; }
}
.crystal-panel.is-collapsing-to-vault {
  animation: panel-collapse-to-card 0.25s ease forwards;
}

/* ── Vault tether line (SVG connecting panel to vault) ─────── */
.vault-tether-line {
  position: fixed;
  pointer-events: none;
  z-index: 7999;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* ── Vault EOMI Chat Bar (inside expanded vault) ─────────── */
.vault-eomi-chat-bar {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex-shrink: 0;
}
.vault-eomi-chat-bar__messages {
  max-height: 200px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 12px;
}
.vault-eomi-chat-bar__msg {
  padding: 6px 10px;
  border-radius: 8px;
  max-width: 90%;
  line-height: 1.4;
}
.vault-eomi-chat-bar__msg--user {
  background: rgba(255,255,255,0.08);
  color: var(--text-primary, #e0e0e8);
  align-self: flex-end;
}
.vault-eomi-chat-bar__msg--assistant {
  background: rgba(0,212,255,0.08);
  color: var(--text-primary, #e0e0e8);
  align-self: flex-start;
  border-left: 2px solid rgba(0,212,255,0.4);
}
.vault-eomi-chat-bar__input-row {
  display: flex;
  gap: 6px;
  align-items: center;
}
.vault-eomi-chat-bar__input {
  flex: 1;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 12px;
  color: var(--text-primary, #e0e0e8);
  outline: none;
}
.vault-eomi-chat-bar__input:focus {
  border-color: rgba(0,212,255,0.4);
}
.vault-eomi-chat-bar__send {
  background: rgba(0,212,255,0.15);
  border: 1px solid rgba(0,212,255,0.3);
  color: #00d4ff;
  border-radius: 8px;
  padding: 8px 14px;
  font-size: 12px;
  cursor: pointer;
}
.vault-eomi-chat-bar__send:hover {
  background: rgba(0,212,255,0.3);
  color: #fff;
}

/* ── Vault Quick Prompts ─────────────────────────────────── */
.vault-quick-prompts {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.vault-quick-prompts button {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(0,212,255,0.15);
  color: rgba(0,212,255,0.7);
  border-radius: 12px;
  padding: 4px 10px;
  font-size: 10px;
  cursor: pointer;
  transition: all 0.2s;
}
.vault-quick-prompts button:hover {
  background: rgba(0,212,255,0.1);
  border-color: rgba(0,212,255,0.4);
  color: #00d4ff;
}

/* ── Phase 84 Light-mode: Vault EOMI + Panel Tether ──────── */
[data-theme="sunrise"] .vault-eomi-chat-bar {
  border-top-color: rgba(232,160,32,0.2);
}
[data-theme="sunrise"] .vault-eomi-chat-bar__msg--user {
  background: rgba(232,160,32,0.1);
}
[data-theme="sunrise"] .vault-eomi-chat-bar__msg--assistant {
  background: rgba(25,25,112,0.04);
  border-left-color: rgba(232,160,32,0.5);
  color: #191970;
}
[data-theme="sunrise"] .vault-eomi-chat-bar__input {
  background: #EDE8DC;
  border-color: rgba(232,160,32,0.3);
  color: #191970;
}
[data-theme="sunrise"] .vault-eomi-chat-bar__send {
  background: #E8A020;
  border-color: #E8A020;
  color: #191970;
}
[data-theme="sunrise"] .vault-quick-prompts button {
  background: rgba(232,160,32,0.06);
  border-color: rgba(232,160,32,0.2);
  color: rgba(25,25,112,0.7);
}
[data-theme="sunrise"] .vault-quick-prompts button:hover {
  background: rgba(232,160,32,0.15);
  border-color: rgba(232,160,32,0.4);
  color: #191970;
}
[data-theme="sunrise"] .crystal-panel.is-expanded-from-vault {
  box-shadow: 0 0 0 2px #E8A020, 0 20px 60px rgba(232,160,32,0.25);
}

/* ── Folder Tree (fullscreen sidebar) ───────────────────── */
.vault-tree-item {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 8px;
  border-radius: 6px;
  font-size: 12px;
  color: var(--text-secondary, #8888a0);
  cursor: pointer;
}
.vault-tree-item:hover {
  background: rgba(255,255,255,0.06);
  color: var(--text-primary, #e0e0e8);
}
.vault-tree-item.active {
  background: rgba(255,255,255,0.1);
  color: #fff;
}
.vault-tree-item__indent {
  width: 12px;
  flex-shrink: 0;
}

/* ── Create Vault Modal ─────────────────────────────────── */
.vault-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
}
.vault-modal {
  background: var(--panel-bg);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 16px;
  padding: 24px;
  width: 380px;
  max-width: 90vw;
}
.vault-modal__title {
  font-size: 16px;
  font-weight: 600;
  color: #fff;
  margin-bottom: 16px;
}
.vault-modal__field {
  margin-bottom: 12px;
}
.vault-modal__label {
  font-size: 11px;
  color: #8888a0;
  margin-bottom: 4px;
  display: block;
}
.vault-modal__input {
  width: 100%;
  padding: 8px 10px;
  background: var(--input-bg);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  color: #e0e0e8;
  font-size: 13px;
  outline: none;
  box-sizing: border-box;
}
.vault-modal__input:focus {
  border-color: #00d4ff;
}
.vault-modal__colors {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.vault-modal__color-swatch {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform 0.15s;
}
.vault-modal__color-swatch:hover {
  transform: scale(1.15);
}
.vault-modal__color-swatch.selected {
  border-color: #fff;
  box-shadow: 0 0 8px rgba(255,255,255,0.3);
}
.vault-modal__icons {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.vault-modal__icon-btn {
  width: 32px;
  height: 32px;
  border-radius: 6px;
  border: 1px solid rgba(255,255,255,0.1);
  background: none;
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.vault-modal__icon-btn:hover {
  background: rgba(255,255,255,0.08);
}
.vault-modal__icon-btn.selected {
  border-color: #00d4ff;
  background: rgba(0,212,255,0.1);
}
.vault-modal__actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 16px;
}
.vault-modal__btn {
  padding: 8px 16px;
  border-radius: 8px;
  border: none;
  font-size: 13px;
  cursor: pointer;
}
.vault-modal__btn--cancel {
  background: rgba(255,255,255,0.06);
  color: #ccc;
}
.vault-modal__btn--create {
  background: #00d4ff;
  color: #000;
  font-weight: 600;
}
.vault-modal__btn--create:hover {
  background: #00bfe0;
}

/* ── Vault Color Themes ─────────────────────────────────── */
.vault-cube--cosmic  { border-color: #00d4ff; background: rgba(0,212,255,0.08);  box-shadow: 0 4px 20px rgba(0,0,0,0.3), 0 0 15px rgba(0,212,255,0.2); }
.vault-cube--emerald { border-color: #00ff88; background: rgba(0,255,136,0.08);  box-shadow: 0 4px 20px rgba(0,0,0,0.3), 0 0 15px rgba(0,255,136,0.2); }
.vault-cube--gold    { border-color: #ffd700; background: rgba(255,215,0,0.08);  box-shadow: 0 4px 20px rgba(0,0,0,0.3), 0 0 15px rgba(255,215,0,0.2); }
.vault-cube--crimson { border-color: #ff4444; background: rgba(255,68,68,0.08);  box-shadow: 0 4px 20px rgba(0,0,0,0.3), 0 0 15px rgba(255,68,68,0.2); }
.vault-cube--violet  { border-color: #cc44ff; background: rgba(204,68,255,0.08); box-shadow: 0 4px 20px rgba(0,0,0,0.3), 0 0 15px rgba(204,68,255,0.2); }
.vault-cube--slate   { border-color: #607d8b; background: rgba(96,125,139,0.08); box-shadow: 0 4px 20px rgba(0,0,0,0.3), 0 0 15px rgba(96,125,139,0.2); }

/* ── Light-mode overrides ───────────────────────────────── */
[data-theme="sunrise"] .vault-grid-section {
  border-top-color: rgba(232,160,32,0.2);
}
[data-theme="sunrise"] .vault-cube__name {
  color: #191970;
}
[data-theme="sunrise"] .vault-cube__count {
  background: rgba(232,160,32,0.15);
  color: #191970;
}
[data-theme="sunrise"] .vault-cube__storage-bar {
  background: rgba(232,160,32,0.12);
}
[data-theme="sunrise"] .vault-expanded {
  background: #F5F0E8;
  backdrop-filter: blur(20px);
  box-shadow: 0 20px 60px rgba(232,160,32,0.2);
}
[data-theme="sunrise"] .vault-expanded__name {
  color: #191970;
}
[data-theme="sunrise"] .vault-expanded__btn {
  background: rgba(232,160,32,0.1);
  color: #191970;
}
[data-theme="sunrise"] .vault-item-card {
  border-color: rgba(232,160,32,0.25);
  background: rgba(232,160,32,0.05);
}
[data-theme="sunrise"] .vault-item-card:hover {
  background: rgba(232,160,32,0.12);
}
[data-theme="sunrise"] .vault-item-card__name {
  color: #191970;
}
[data-theme="sunrise"] .vault-modal {
  background: #F5F0E8;
  border-color: rgba(232,160,32,0.4);
}
[data-theme="sunrise"] .vault-modal__title {
  color: #191970;
}
[data-theme="sunrise"] .vault-modal__input {
  background: #EDE8DC;
  border-color: rgba(232,160,32,0.35);
  color: #191970;
}
[data-theme="sunrise"] .vault-fullscreen {
  background: #F5F0E8;
}
[data-theme="sunrise"] .vault-fullscreen__topbar {
  border-bottom-color: rgba(232,160,32,0.25);
}
[data-theme="sunrise"] .vault-fullscreen__breadcrumb {
  color: rgba(25,25,112,0.7);
}
[data-theme="sunrise"] .vault-canvas {
  background-image:
    linear-gradient(rgba(232,160,32,0.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(232,160,32,0.12) 1px, transparent 1px);
}
[data-theme="sunrise"] .vault-cube {
  border-color: #E8A020;
  background: #F5F0E8;
  box-shadow: 0 4px 20px rgba(232,160,32,0.15), 0 0 10px rgba(232,160,32,0.1);
}
[data-theme="sunrise"] .vault-cube--cosmic  { border-color: #E8A020; background: rgba(232,160,32,0.06); box-shadow: 0 4px 20px rgba(232,160,32,0.15), 0 0 15px rgba(232,160,32,0.1); }
[data-theme="sunrise"] .vault-cube--emerald { border-color: #E8A020; background: rgba(232,160,32,0.06); box-shadow: 0 4px 20px rgba(232,160,32,0.15), 0 0 15px rgba(232,160,32,0.1); }
[data-theme="sunrise"] .vault-cube--gold    { border-color: #E8A020; background: rgba(232,160,32,0.06); box-shadow: 0 4px 20px rgba(232,160,32,0.15), 0 0 15px rgba(232,160,32,0.1); }
[data-theme="sunrise"] .vault-cube--crimson { border-color: #E8A020; background: rgba(232,160,32,0.06); box-shadow: 0 4px 20px rgba(232,160,32,0.15), 0 0 15px rgba(232,160,32,0.1); }
[data-theme="sunrise"] .vault-cube--violet  { border-color: #E8A020; background: rgba(232,160,32,0.06); box-shadow: 0 4px 20px rgba(232,160,32,0.15), 0 0 15px rgba(232,160,32,0.1); }
[data-theme="sunrise"] .vault-cube--slate   { border-color: #E8A020; background: rgba(232,160,32,0.06); box-shadow: 0 4px 20px rgba(232,160,32,0.15), 0 0 15px rgba(232,160,32,0.1); }
[data-theme="sunrise"] .vault-cube.is-selected {
  box-shadow: 0 0 20px rgba(232,160,32,0.4) !important;
}

/* ═══════════════════════════════════════════════════════════
   PHASE 79: Layout Builder — Custom Workspace
   ═══════════════════════════════════════════════════════════ */

/* ── Nav Item Accent ───────────────────────────────────── */
.mig-nav-item--builder {
  color: var(--accent-gold) !important;
  font-weight: 600;
  border-left: 2px solid var(--accent-gold);
  margin: 4px var(--space-sm);
  padding-left: calc(var(--space-sm) - 2px);
}
.mig-nav-item--builder:hover {
  background: rgba(212,168,67,0.08);
  color: var(--accent-gold) !important;
}

/* ── Layout Builder Toolbar ────────────────────────────── */
.layout-builder__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--border-subtle);
}
.layout-builder__title {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
}

/* ── Layout Builder Canvas ─────────────────────────────── */
.layout-builder__canvas {
  position: relative;
  min-height: calc(100vh - 140px);
  padding: var(--space-md);
  overflow: auto;
}

/* ── Light Mode ────────────────────────────────────────── */
[data-theme="sunrise"] .mig-nav-item--builder {
  color: #E8A020 !important;
  border-left-color: #E8A020;
}
[data-theme="sunrise"] .mig-nav-item--builder:hover {
  background: rgba(232,160,32,0.1);
}

/* ══════════════════════════════════════════════════════════
   Phase 85: Universal Resize System
   ══════════════════════════════════════════════════════════ */

/* ── Generic Resize Handles ──────────────────────────────── */
.resize-handle {
  position: absolute;
  z-index: 10;
  background: transparent;
  transition: background 0.2s;
}
.resize-handle--e {
  top: 0; right: -4px; width: 8px; height: 100%;
  cursor: ew-resize;
}
.resize-handle--w {
  top: 0; left: -4px; width: 8px; height: 100%;
  cursor: ew-resize;
}
.resize-handle--s {
  bottom: -4px; left: 0; width: 100%; height: 8px;
  cursor: ns-resize;
}
.resize-handle--n {
  top: -4px; left: 0; width: 100%; height: 8px;
  cursor: ns-resize;
}
.resize-handle--se {
  bottom: -4px; right: -4px; width: 16px; height: 16px;
  cursor: nwse-resize;
  border-radius: 0 0 4px 0;
}
.resize-handle--sw {
  bottom: -4px; left: -4px; width: 16px; height: 16px;
  cursor: nesw-resize;
  border-radius: 0 0 0 4px;
}

/* Hover glow */
.resize-handle--e:hover,
.resize-handle--w:hover {
  background: linear-gradient(90deg, transparent, rgba(0,240,255,0.15), transparent);
}
.resize-handle--s:hover,
.resize-handle--n:hover {
  background: linear-gradient(180deg, transparent, rgba(0,240,255,0.15), transparent);
}
.resize-handle--se:hover,
.resize-handle--sw:hover {
  background: radial-gradient(circle at center, rgba(0,240,255,0.15), transparent);
}

/* Active resize state on body */
body.resizing {
  cursor: inherit;
  user-select: none;
  -webkit-user-select: none;
}
body.resizing * {
  cursor: inherit !important;
}

/* ── Sidebar Resize Handle ───────────────────────────────── */
.sidebar-resize-handle {
  position: absolute;
  top: 0;
  right: -4px;
  width: 8px;
  height: 100%;
  cursor: ew-resize;
  z-index: 101;
  background: transparent;
  transition: background 0.2s;
}
.sidebar-resize-handle:hover {
  background: linear-gradient(90deg, transparent, rgba(0,240,255,0.15), transparent);
}

/* ── Sidebar Preset Bar ──────────────────────────────────── */
.sidebar-preset-bar {
  display: flex;
  justify-content: center;
  gap: 6px;
  padding: 8px 12px;
  border-top: 1px solid var(--border-subtle, #1e1e2e);
}
.sidebar-preset-btn {
  background: rgba(0,240,255,0.06);
  border: 1px solid rgba(0,240,255,0.15);
  color: var(--text-secondary, #8888a0);
  border-radius: 6px;
  font-size: 11px;
  padding: 3px 12px;
  cursor: pointer;
  transition: all 0.2s;
}
.sidebar-preset-btn:hover {
  background: rgba(0,240,255,0.12);
  border-color: rgba(0,240,255,0.3);
  color: var(--text-primary, #e0e0e8);
}

/* ── Generic Resize Preset Bar ───────────────────────────── */
.resize-preset-bar {
  display: flex;
  gap: 4px;
  align-items: center;
}
.resize-preset-btn {
  background: rgba(0,240,255,0.06);
  border: 1px solid rgba(0,240,255,0.15);
  color: #8888a0;
  border-radius: 4px;
  font-size: 10px;
  padding: 2px 8px;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}
.resize-preset-btn:hover {
  background: rgba(0,240,255,0.12);
  border-color: rgba(0,240,255,0.3);
  color: #e0e0e8;
}

/* ── Vault Cube Size Variants ────────────────────────────── */
.vault-cube--sm {
  width: 80px !important;
  height: 80px !important;
}
.vault-cube--sm .vault-cube__icon { font-size: 20px; }
.vault-cube--sm .vault-cube__name { font-size: 9px; }
.vault-cube--sm .vault-cube__count { font-size: 8px; }
.vault-cube--sm .vault-cube__storage-bar { display: none; }

.vault-cube--md {
  width: 120px !important;
  height: 120px !important;
}
.vault-cube--md .vault-cube__icon { font-size: var(--icon-lg); }
.vault-cube--md .vault-cube__name { font-size: 11px; }

.vault-cube--lg {
  width: 160px !important;
  height: 160px !important;
}
.vault-cube--lg .vault-cube__icon { font-size: 36px; }
.vault-cube--lg .vault-cube__name { font-size: 13px; }

.vault-cube--xl {
  width: 200px !important;
  height: 200px !important;
}
.vault-cube--xl .vault-cube__icon { font-size: 44px; }
.vault-cube--xl .vault-cube__name { font-size: 14px; }
.vault-cube--xl .vault-cube__count { font-size: 12px; }

/* ── Vault Context Menu ──────────────────────────────────── */
.vault-context-menu {
  position: fixed;
  z-index: 10000;
  background: var(--dropdown-bg);
  border: 1px solid #2a2a3a;
  border-radius: 8px;
  padding: 4px 0;
  min-width: 160px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}
.vault-context-menu__item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  cursor: pointer;
  font-size: 12px;
  color: #e0e0e8;
  transition: background 0.15s;
}
.vault-context-menu__item:hover {
  background: rgba(0,240,255,0.08);
}
.vault-context-menu__item.active {
  color: #00f0ff;
  font-weight: 600;
}
.vault-context-menu__title {
  padding: 6px 14px;
  font-size: 10px;
  color: #8888a0;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 600;
}

/* ── Responsive: Hide sidebar resize at small widths ─────── */
@media (max-width: 1200px) {
  .sidebar-resize-handle,
  .sidebar-preset-bar {
    display: none !important;
  }
}
@media (max-width: 768px) {
  .sidebar-resize-handle,
  .sidebar-preset-bar {
    display: none !important;
  }
}

/* ── Light Mode Overrides ────────────────────────────────── */
[data-theme="sunrise"] .resize-handle--e:hover,
[data-theme="sunrise"] .resize-handle--w:hover {
  background: linear-gradient(90deg, transparent, rgba(232,160,32,0.15), transparent);
}
[data-theme="sunrise"] .resize-handle--s:hover,
[data-theme="sunrise"] .resize-handle--n:hover {
  background: linear-gradient(180deg, transparent, rgba(232,160,32,0.15), transparent);
}
[data-theme="sunrise"] .resize-handle--se:hover,
[data-theme="sunrise"] .resize-handle--sw:hover {
  background: radial-gradient(circle at center, rgba(232,160,32,0.15), transparent);
}
[data-theme="sunrise"] .sidebar-resize-handle:hover {
  background: linear-gradient(90deg, transparent, rgba(232,160,32,0.15), transparent);
}
[data-theme="sunrise"] .sidebar-preset-btn {
  background: rgba(232,160,32,0.06);
  border-color: rgba(232,160,32,0.15);
}
[data-theme="sunrise"] .sidebar-preset-btn:hover {
  background: rgba(232,160,32,0.12);
  border-color: rgba(232,160,32,0.3);
}
[data-theme="sunrise"] .resize-preset-btn {
  background: rgba(232,160,32,0.06);
  border-color: rgba(232,160,32,0.15);
}
[data-theme="sunrise"] .resize-preset-btn:hover {
  background: rgba(232,160,32,0.12);
  border-color: rgba(232,160,32,0.3);
}
[data-theme="sunrise"] .vault-context-menu {
  background: #F5F0E8;
  border-color: rgba(232,160,32,0.3);
}
[data-theme="sunrise"] .vault-context-menu__item {
  color: #2a2a2e;
}
[data-theme="sunrise"] .vault-context-menu__item:hover {
  background: rgba(232,160,32,0.08);
}
[data-theme="sunrise"] .vault-context-menu__item.active {
  color: #E8A020;
}

/* ═══════════════════════════════════════════════════════════════
   Phase 88: Notification Panel
   ═══════════════════════════════════════════════════════════════ */

.mig-notif-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  min-width: 18px;
  height: 18px;
  border-radius: 999px;
  background: var(--accent-red, #ef4444);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  line-height: 1;
  z-index: 2;
}

.mig-notif-panel {
  position: fixed;
  top: 60px;
  right: 24px;
  width: 360px;
  max-height: 480px;
  background: var(--bg-card, rgba(10,18,35,0.95));
  border: 1px solid var(--border-card, rgba(0,180,216,0.18));
  border-radius: var(--radius-card, 16px);
  box-shadow: 0 12px 48px rgba(0,0,0,0.55), 0 0 30px rgba(0,180,216,0.08);
  z-index: 9990;
  display: none;
  flex-direction: column;
  backdrop-filter: var(--glass-blur, blur(18px));
  animation: mig-slide-up 0.2s ease;
  overflow: hidden;
}

.mig-notif-panel--open {
  display: flex;
}

.mig-notif-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border-default, rgba(255,255,255,0.08));
  color: var(--text-primary, #fff);
}

.mig-notif-panel__list {
  flex: 1;
  overflow-y: auto;
  max-height: 400px;
}

.mig-notif-item {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-default, rgba(255,255,255,0.05));
  cursor: pointer;
  transition: background 0.15s ease;
}

.mig-notif-item:hover {
  background: rgba(0,180,216,0.06);
}

.mig-notif-item--unread {
  border-left: 3px solid var(--accent-cyan, #00b4d8);
  background: rgba(0,180,216,0.04);
}

.mig-notif-item__title {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-primary, #fff);
  margin-bottom: 2px;
}

.mig-notif-item__body {
  font-size: 0.8rem;
  color: var(--text-secondary, rgba(255,255,255,0.65));
  line-height: 1.4;
  margin-bottom: 4px;
}

.mig-notif-item__time {
  font-size: 0.7rem;
  color: var(--text-muted, rgba(255,255,255,0.35));
}

/* Light mode overrides */
[data-theme="sunrise"] .mig-notif-panel {
  background: #FEFCF7;
  border-color: rgba(232,160,32,0.25);
  box-shadow: 0 8px 32px rgba(0,0,0,0.12);
}
[data-theme="sunrise"] .mig-notif-panel__header {
  border-bottom-color: rgba(0,0,0,0.08);
  color: #2a2a2e;
}
[data-theme="sunrise"] .mig-notif-item {
  border-bottom-color: rgba(0,0,0,0.06);
}
[data-theme="sunrise"] .mig-notif-item:hover {
  background: rgba(232,160,32,0.06);
}
[data-theme="sunrise"] .mig-notif-item--unread {
  border-left-color: #E8A020;
  background: rgba(232,160,32,0.04);
}
[data-theme="sunrise"] .mig-notif-item__title {
  color: #2a2a2e;
}
[data-theme="sunrise"] .mig-notif-item__body {
  color: #555;
}
[data-theme="sunrise"] .mig-notif-item__time {
  color: #999;
}

/* ══════════════════════════════════════════════════════════════════════
   Phase 90: Dashboard Context Switcher
   ══════════════════════════════════════════════════════════════════════ */

.mig-ctx-switch {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: var(--bg-frosted);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-pill);
  color: var(--text-primary);
  font-size: var(--font-size-sm);
  font-family: inherit;
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
}
.mig-ctx-switch:hover {
  border-color: var(--accent-blue);
  background: rgba(0, 180, 216, 0.06);
}
.mig-ctx-switch__icon { font-size: 14px; }
.mig-ctx-switch__label { font-weight: var(--font-weight-semibold); }
.mig-ctx-switch__arrow { font-size: 8px; opacity: 0.5; }

.mig-ctx-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  min-width: 260px;
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  z-index: 9980;
  padding: 6px 0;
  overflow: hidden;
}
.mig-ctx-dropdown__item {
  padding: 10px 16px;
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  cursor: pointer;
  transition: background 0.12s;
}
.mig-ctx-dropdown__item:hover {
  background: rgba(0, 180, 216, 0.06);
  color: var(--text-primary);
}
.mig-ctx-dropdown__item--active {
  color: var(--accent-blue);
  font-weight: var(--font-weight-semibold);
  background: rgba(0, 180, 216, 0.04);
}
.mig-ctx-dropdown__divider {
  height: 1px;
  background: var(--border-subtle);
  margin: 4px 0;
}

/* ── Company Admin Panel Styles ── */

.mig-admin-section {
  margin-bottom: var(--space-xl);
}
.mig-admin-section__title {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-xs);
  border-bottom: 1px solid var(--border-subtle);
}
.mig-admin-stats {
  display: flex;
  gap: var(--space-lg);
  flex-wrap: wrap;
}
.mig-admin-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 80px;
}
.mig-admin-stat__val {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--accent-blue);
}
.mig-admin-stat__label {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  margin-top: 2px;
}
.mig-admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
}
.mig-admin-table thead th {
  text-align: left;
  font-weight: var(--font-weight-semibold);
  color: var(--text-muted);
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border-subtle);
}
.mig-admin-table tbody td {
  padding: 8px 12px;
  color: var(--text-secondary);
  border-bottom: 1px solid rgba(255,255,255,0.03);
}
.mig-admin-table tbody tr:hover td {
  background: rgba(0, 180, 216, 0.03);
}

/* ── Light Mode Overrides ── */
[data-theme="sunrise"] .mig-ctx-switch {
  background: #F5F0E8;
  border-color: rgba(232,160,32,0.2);
  color: #1a1a2e;
}
[data-theme="sunrise"] .mig-ctx-switch:hover {
  border-color: #E8A020;
  background: rgba(232,160,32,0.08);
}
[data-theme="sunrise"] .mig-ctx-dropdown {
  background: #F5F0E8;
  border-color: rgba(232,160,32,0.2);
}
[data-theme="sunrise"] .mig-ctx-dropdown__item:hover {
  background: rgba(232,160,32,0.06);
  color: #1a1a2e;
}
[data-theme="sunrise"] .mig-ctx-dropdown__item--active {
  color: #E8A020;
  background: rgba(232,160,32,0.04);
}
[data-theme="sunrise"] .mig-admin-stat__val {
  color: #E8A020;
}
[data-theme="sunrise"] .mig-admin-table tbody td {
  color: #333;
  border-bottom-color: rgba(0,0,0,0.05);
}
[data-theme="sunrise"] .mig-admin-table tbody tr:hover td {
  background: rgba(232,160,32,0.03);
}

/* ═══════════════════════════════════════════════════════════
   MIG Glow System — Phase 93.5
   ═══════════════════════════════════════════════════════════ */

/* Base transition for all glow elements */
[class*="mig-glow"] {
  transition: box-shadow var(--mig-glow-duration, 0.3s) var(--mig-glow-ease, cubic-bezier(0.4,0,0.2,1)),
              transform var(--mig-glow-duration, 0.3s) var(--mig-glow-ease, cubic-bezier(0.4,0,0.2,1)),
              border-color var(--mig-glow-duration, 0.3s) var(--mig-glow-ease, cubic-bezier(0.4,0,0.2,1));
  will-change: box-shadow, transform;
}

/* Gold glow on hover — standard */
.mig-glow-gold:hover {
  box-shadow: var(--mig-gold-glow-md);
  border-color: var(--mig-gold-border-hover);
}

/* Strong gold glow on hover */
.mig-glow-gold-strong:hover {
  box-shadow: var(--mig-gold-glow-lg);
  border-color: var(--mig-gold-border-hover);
}

/* Subtle gold glow on hover */
.mig-glow-gold-subtle:hover {
  box-shadow: var(--mig-gold-glow-sm);
  border-color: var(--mig-gold-border-hover);
}

/* Active/persistent glow (not hover-dependent) */
.mig-glow-gold-active {
  box-shadow: var(--mig-gold-glow-md);
  border-color: var(--mig-gold-border-hover);
}

/* Pulsing gold glow */
@keyframes mig-gold-pulse {
  0%, 100% { box-shadow: var(--mig-gold-glow-sm); }
  50%      { box-shadow: var(--mig-gold-glow-md); }
}
.mig-glow-gold-pulse {
  animation: mig-gold-pulse 3s ease-in-out infinite;
}

/* Lift on hover with glow */
.mig-glow-lift:hover {
  transform: translateY(-4px);
  box-shadow: var(--mig-gold-glow-md);
}

/* Star canvas — fullscreen background layer, night theme only */
.mig-star-canvas,
#mig-galaxy-canvas {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
}
/* Hide space canvas in all non-night themes via CSS (JS also hides it) */
[data-theme="sunrise"] .mig-star-canvas,
[data-theme="sunrise"] #mig-galaxy-canvas,
[data-theme="day"] .mig-star-canvas,
[data-theme="day"] #mig-galaxy-canvas,
[data-theme="sunset"] .mig-star-canvas,
[data-theme="sunset"] #mig-galaxy-canvas {
  display: none !important;
}

/* Gold glass card variant */
.mig-card--gold-glass {
  background: var(--mig-glass-gold);
  border: 1px solid var(--mig-glass-border);
  backdrop-filter: var(--mig-glass-blur);
  -webkit-backdrop-filter: var(--mig-glass-blur);
}

/* Gold theme toggle override */
.theme-btn--gold.active {
  background: var(--mig-toggle-gold-bg);
  border-color: var(--mig-toggle-gold-border);
  color: var(--mig-gold);
}

/* Reduced motion — disable all glow animations */
@media (prefers-reduced-motion: reduce) {
  [class*="mig-glow"] {
    transition: none !important;
    animation: none !important;
  }
  .mig-glow-gold-pulse {
    animation: none !important;
  }
  .mig-star-canvas {
    display: none !important;
  }
  #mig-galaxy-canvas {
    display: none !important;
  }
}

/* ══════════════════════════════════════════════════════════════
   Phase 96 — Universal panel glassmorphism + gold hover glow
   ══════════════════════════════════════════════════════════════ */

/* Universal panel style — applies to ALL panels platform-wide */
.crystal-panel, .mig-panel, .mig-card,
.dashboard-panel, .news-panel, .web-viewer-panel,
.eomi-panel, .vault-panel, .deep-dive-panel {
  background: var(--mig-panel-bg);
  border: var(--mig-panel-border);
  backdrop-filter: var(--mig-panel-blur);
  -webkit-backdrop-filter: var(--mig-panel-blur);
  box-shadow: var(--mig-panel-shadow);
  transition: border 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
  position: relative;
  z-index: 10;
}

/* Gold hover glow on panels */
.crystal-panel:hover, .mig-panel:hover, .mig-card:hover,
.dashboard-panel:hover, .news-panel:hover, .web-viewer-panel:hover,
.eomi-panel:hover, .vault-panel:hover, .deep-dive-panel:hover {
  border: var(--mig-panel-hover-border);
  box-shadow: var(--mig-panel-hover-shadow);
  transform: var(--mig-panel-hover-transform);
}

/* Sidebar — glass with gold tint */
.mig-sidebar {
  background: var(--mig-bg-sidebar);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

/* Body background — sky gradient from design_tokens.css takes priority */

/* Text tokens — applied via inheritance */
body, p, span, div, td, th, label {
  color: var(--mig-text-primary, #eeeef5);
}

h1, h2, h3, h4, h5, h6 {
  color: var(--mig-text-primary, #eeeef5);
}

/* Mig icon element sizing */
.mig-icon-el {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}
.mig-icon-el svg {
  width: 100%;
  height: 100%;
}

/* ══════════════════════════════════════════════════════════════
   Phase 98 — Universal Visibility: no invisible panels or text
   ══════════════════════════════════════════════════════════════ */

/* ── FIX 1: All panels always visible ──────────────────────── */
.crystal-panel, .mig-panel, .mig-card,
.dashboard-panel, .news-panel, .web-viewer-panel,
.eomi-panel, .vault-panel, .deep-dive-panel,
[class*="-panel"]:not([class*="__"]):not([class*="overlay"]),
[class*="-card"]:not([class*="__"]),
[class*="-widget"]:not([class*="__"]),
.workspace-card, .stat-card, .quick-action,
.sidebar-section, .nav-section {
  opacity: 1 !important;
  visibility: visible !important;
}

/* ── FIX 2: All text always visible, contrast-safe ─────────── */

/* Dark mode text base */
body, html {
  color: var(--mig-text-primary) !important;
}

/* Force all text elements to inherit correctly */
p, span, div, td, th, label, li,
h1, h2, h3, h4, h5, h6,
.panel-title, .card-title, .stat-label,
.stat-value, .nav-label, .menu-item,
.widget-title, .section-title,
[class*="-title"], [class*="-label"],
[class*="-value"], [class*="-text"] {
  color: inherit;
}

/* Panel children — always readable on panel background */
.crystal-panel *, .mig-panel *,
.dashboard-panel *, .news-panel *,
.web-viewer-panel *, .eomi-panel *,
.vault-panel *, .deep-dive-panel * {
  color: var(--mig-text-on-panel);
}

/* Gold accent text */
.gold-text, .accent-text, [class*="-gold"] {
  color: var(--mig-gold) !important;
}

/* Links always visible */
a:not(.mig-nav-item):not(.mig-btn):not([class*="__"]) {
  color: var(--mig-gold) !important;
}
a:not(.mig-nav-item):not(.mig-btn):not([class*="__"]):hover {
  color: var(--mig-gold-bright) !important;
  text-decoration: underline;
}

/* Input placeholders visible */
input::placeholder, textarea::placeholder {
  color: var(--mig-text-muted) !important;
  opacity: 1 !important;
}

/* Table text */
table, tr, td, th {
  color: var(--mig-text-primary) !important;
}

/* Light modes: catch white text that disappears */
[data-theme="sunrise"] .white-text,
[data-theme="sunrise"] [style*="color: white"],
[data-theme="sunrise"] [style*="color:#fff"],
[data-theme="sunrise"] [style*="color: #fff"],
[data-theme="sunrise"] [style*="color:#E8E4FF"],
[data-theme="sunrise"] [style*="color: #E8E4FF"],
[data-theme="day"] .white-text,
[data-theme="day"] [style*="color: white"],
[data-theme="day"] [style*="color:#fff"],
[data-theme="day"] [style*="color: #fff"],
[data-theme="day"] [style*="color:#E8E4FF"],
[data-theme="day"] [style*="color: #E8E4FF"] {
  color: var(--mig-text-primary) !important;
}

/* Dark mode: catch dark text that disappears */
:root .dark-text,
:root [style*="color: black"],
:root [style*="color:#000"],
:root [style*="color: #000"] {
  color: var(--mig-text-primary) !important;
}

/* ── FIX 3: Panel backgrounds — THEME-AWARE (no hardcoded colors) ── */

/* ALL panels — solid theme background, ALL themes */
:root .crystal-panel,
:root .mig-panel,
:root .mig-card,
:root .dashboard-panel,
:root .news-panel,
:root .web-viewer-panel,
:root .eomi-panel,
:root .vault-panel,
:root .deep-dive-panel,
:root [class*="-panel"]:not([class*="__"]):not([class*="overlay"]):not([class*="modal"]) {
  background: var(--panel-bg) !important;
  border: 1px solid var(--border-card) !important;
}

/* ═══════════════════════════════════════════════
   MIGESTI UNIVERSAL VISIBILITY GUARANTEE
   Theme-aware — uses CSS variables, not hardcoded colors
   ═══════════════════════════════════════════════ */

:root body * {
  -webkit-font-smoothing: antialiased;
}

/* Every element always visible (opacity/visibility only) */
:root p, :root span, :root div, :root h1, :root h2,
:root h3, :root h4, :root h5, :root h6, :root label,
:root td, :root th, :root li, :root a, :root button,
:root input, :root textarea, :root select {
  opacity: 1 !important;
  visibility: visible !important;
}

/* Text color — theme-aware for ALL themes */
:root p, :root span, :root div,
:root h1, :root h2, :root h3, :root h4, :root h5, :root h6,
:root label, :root td, :root th, :root li {
  color: var(--text-primary) !important;
}

/* ALL panels/cards always visible (opacity/visibility only) */
:root [class*="panel"], :root [class*="card"],
:root [class*="widget"], :root [class*="section"],
:root [class*="container"], :root [class*="box"] {
  opacity: 1 !important;
  visibility: visible !important;
}

/* Gold hover glow on interactive elements */
:root button:not([disabled]):hover,
:root [class*="btn"]:hover,
:root [class*="card"]:hover,
:root [class*="panel"]:hover {
  border-color: var(--border-card-hover, rgba(212, 168, 67, 0.7)) !important;
  box-shadow: var(--glow-gold, 0 0 20px rgba(212,168,67,0.35)) !important;
  transition: all 0.25s ease !important;
}

/* All cards/panels/tiles — solid theme background */
:root [class*="card"],
:root [class*="panel"],
:root [class*="tile"] {
  border: 1px solid var(--border-card) !important;
  background: var(--panel-bg) !important;
}

/* Inputs — theme-aware */
:root input, :root textarea, :root select {
  color: var(--text-primary) !important;
  background: var(--input-bg) !important;
  border: 1px solid var(--border-input) !important;
}

:root input::placeholder, :root textarea::placeholder {
  color: var(--text-muted) !important;
  opacity: 1 !important;
}

/* Tables — theme-aware */
:root table, :root tr, :root td, :root th {
  color: var(--text-primary) !important;
  border-color: var(--border-card) !important;
}

/* Links — theme-aware */
:root a:not([class*="btn"]) {
  color: var(--accent-color, var(--accent-gold)) !important;
}

/* Buttons always visible */
:root button {
  opacity: 1 !important;
  visibility: visible !important;
}

/* Remove any hover-only visibility */
:root [class*="hover-show"],
:root [class*="show-on-hover"] {
  opacity: 1 !important;
  visibility: visible !important;
}

/* ═══════════════════════════════════════════════
   MIGESTI GLOBAL TYPOGRAPHY
   ═══════════════════════════════════════════════ */

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

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: var(--mig-font) !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-normal) !important;
  line-height: var(--leading-normal) !important;
  letter-spacing: var(--tracking-normal) !important;
  color: var(--mig-text-primary) !important;
  text-rendering: optimizeLegibility !important;
  transition: color var(--transition-base) !important;
}

/* Headings */
h1 { font-size: var(--text-3xl) !important; font-weight: var(--font-bold) !important; line-height: var(--leading-tight) !important; letter-spacing: var(--tracking-tight) !important; }
h2 { font-size: var(--text-2xl) !important; font-weight: var(--font-semibold) !important; line-height: var(--leading-tight) !important; letter-spacing: var(--tracking-tight) !important; }
h3 { font-size: var(--text-xl) !important;  font-weight: var(--font-semibold) !important; line-height: var(--leading-tight) !important; }
h4 { font-size: var(--text-lg) !important;  font-weight: var(--font-semibold) !important; }
h5 { font-size: var(--text-base) !important;font-weight: var(--font-semibold) !important; }
h6 { font-size: var(--text-sm) !important;  font-weight: var(--font-semibold) !important; letter-spacing: var(--tracking-wide) !important; text-transform: uppercase !important; }

/* Body text */
p { font-size: var(--text-base) !important; line-height: var(--leading-relaxed) !important; }
small, .text-sm { font-size: var(--text-sm) !important; }
.text-xs { font-size: var(--text-xs) !important; }
.caption { font-size: var(--text-xs) !important; color: var(--mig-text-muted) !important; letter-spacing: var(--tracking-wide) !important; }
.overline { font-size: var(--text-xs) !important; font-weight: var(--font-semibold) !important; letter-spacing: var(--tracking-widest) !important; text-transform: uppercase !important; }

/* Navigation */
.nav-label, [class*="nav-"] > span,
.sidebar-label, [class*="sidebar"] a span {
  font-size: var(--text-sm) !important;
  font-weight: var(--font-medium) !important;
  letter-spacing: var(--tracking-wide) !important;
}

/* Section headers */
.section-title, [class*="section-title"],
.panel-title, [class*="panel-title"],
.card-title, [class*="card-title"] {
  font-size: var(--text-sm) !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: var(--tracking-wider) !important;
  text-transform: uppercase !important;
  color: var(--mig-gold) !important;
}

/* Labels */
label, .label, [class*="-label"] {
  font-size: var(--text-sm) !important;
  font-weight: var(--font-medium) !important;
  color: var(--mig-text-secondary) !important;
}

/* Values/stats */
.stat-value, [class*="stat-value"],
.value, [class*="-value"] {
  font-size: var(--text-md) !important;
  font-weight: var(--font-bold) !important;
  color: var(--mig-text-primary) !important;
}

/* Badges */
.badge, [class*="-badge"],
.tag, [class*="-tag"] {
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: var(--tracking-wide) !important;
  text-transform: uppercase !important;
}

/* Buttons */
button, .btn, [class*="-btn"] {
  font-family: var(--mig-font) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: var(--tracking-wide) !important;
}

/* Inputs */
input, textarea, select {
  font-family: var(--mig-font) !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-normal) !important;
  line-height: var(--leading-normal) !important;
}

/* Table */
th {
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: var(--tracking-widest) !important;
  text-transform: uppercase !important;
  color: var(--mig-text-secondary) !important;
}
td {
  font-size: var(--text-sm) !important;
  font-weight: var(--font-normal) !important;
}

/* Monospace — code, keys, IDs */
code, pre, .mono, [class*="-key"],
[class*="-code"], [class*="-id"] {
  font-family: var(--mig-font-mono) !important;
  font-size: var(--text-sm) !important;
}

/* ═══════════════════════════════════════════════
   MIGESTI ICON SYSTEM — Consistent Sizing
   ═══════════════════════════════════════════════ */

/* All mig-icon elements */
.mig-icon-el {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}

/* Nav icons — exactly 20px */
.sidebar .mig-icon-el,
.nav-item .mig-icon-el,
[class*="nav-"] .mig-icon-el {
  width: var(--icon-base) !important;
  height: var(--icon-base) !important;
}

.sidebar .mig-icon-el svg,
.nav-item .mig-icon-el svg,
[class*="nav-"] .mig-icon-el svg {
  width: var(--icon-base) !important;
  height: var(--icon-base) !important;
}

/* Button icons — 16px */
button .mig-icon-el,
.btn .mig-icon-el,
[class*="-btn"] .mig-icon-el {
  width: var(--icon-sm) !important;
  height: var(--icon-sm) !important;
}

button .mig-icon-el svg,
.btn .mig-icon-el svg {
  width: var(--icon-sm) !important;
  height: var(--icon-sm) !important;
}

/* Panel/section icons — 24px */
.panel-icon, .section-icon,
[class*="panel"] > .mig-icon-el:first-child,
[class*="card"] > .mig-icon-el:first-child {
  width: var(--icon-md) !important;
  height: var(--icon-md) !important;
}

/* Feature/workspace icons — 32px */
.workspace-card .mig-icon-el,
[class*="workspace"] .mig-icon-el,
[class*="feature"] .mig-icon-el {
  width: var(--icon-lg) !important;
  height: var(--icon-lg) !important;
}

[class*="workspace"] .mig-icon-el svg,
[class*="feature"] .mig-icon-el svg {
  width: var(--icon-lg) !important;
  height: var(--icon-lg) !important;
}

/* Industry/onboarding icons — 48px */
.industry-card .mig-icon-el,
.onboarding-card .mig-icon-el,
[class*="industry"] .mig-icon-el {
  width: var(--icon-xl) !important;
  height: var(--icon-xl) !important;
}

[class*="industry"] .mig-icon-el svg {
  width: var(--icon-xl) !important;
  height: var(--icon-xl) !important;
}

/* Remove any inline width/height overrides that cause inconsistency */
.mig-icon-el svg {
  max-width: 100% !important;
  max-height: 100% !important;
  display: block !important;
}

/* ═══════════════════════════════════════════════
   DASHBOARD SPECIFIC FIXES
   ═══════════════════════════════════════════════ */

/* Dashboard panel titles */
.dashboard-panel h3,
.crystal-panel h3,
[class*="-panel"] h3 {
  font-size: var(--text-sm) !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: var(--tracking-wider) !important;
  text-transform: uppercase !important;
  color: var(--mig-gold) !important;
  margin: 0 0 12px 0 !important;
}

/* Stat numbers on dashboard */
.stat-number, .big-number,
[class*="stat-num"], [class*="big-num"] {
  font-size: var(--text-xl) !important;
  font-weight: var(--font-bold) !important;
  line-height: 1 !important;
}

/* Sidebar nav item layout */
.nav-item, [class*="nav-item"],
.sidebar-item, [class*="sidebar-item"] {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 6px 12px !important;
  font-size: var(--text-sm) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
}
.nav-item span, [class*="nav-item"] span,
.sidebar-item span, [class*="sidebar-item"] span {
  display: inline-block !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

/* Topbar */
.topbar, [class*="topbar"],
.navbar, [class*="navbar"] {
  font-size: var(--text-sm) !important;
}

/* EOMI chat text */
.eomi-message, [class*="eomi-msg"],
.chat-message, [class*="chat-msg"] {
  font-size: var(--text-base) !important;
  line-height: var(--leading-relaxed) !important;
  border-radius: var(--radius-lg) !important;
  max-width: 82% !important;
}

/* Crystal panel content */
.crystal-content, [class*="crystal-content"] {
  font-size: var(--text-sm) !important;
  line-height: var(--leading-normal) !important;
}

/* ═══════════════════════════════════════════════════════════════════
   MSPG PHASE 1 — COMPLETE UI SYSTEM OVERHAUL
   Smart. Sharp. Sovereign. Every pixel intentional.
   ═══════════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════
   MIGESTI SIDEBAR — Collapsible Sovereign Nav
   ═══════════════════════════════════════════════ */

.sidebar, #sidebar, .mig-sidebar {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  height: 100vh !important;
  width: var(--sidebar-width-full) !important;
  background: var(--sidebar-bg) !important;
  border-right: var(--sidebar-border) !important;
  backdrop-filter: blur(24px) !important;
  -webkit-backdrop-filter: blur(24px) !important;
  z-index: 500 !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  transition: width var(--transition-base) !important;
  box-shadow: none !important;
  transform: none !important;
}

.sidebar.collapsed, #sidebar.collapsed, .mig-sidebar.collapsed {
  width: var(--sidebar-width-collapsed) !important;
}

/* Sidebar header */
.mig-sidebar__logo {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: var(--space-4) var(--space-4) !important;
  border-bottom: 1px solid rgba(212,168,67,0.1) !important;
  min-height: 52px !important;
  flex-shrink: 0 !important;
  box-shadow: none !important;
}

.mig-sidebar__logo-link {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-2) !important;
  text-decoration: none !important;
  text-shadow: none !important;
  flex: 1 !important;
  overflow: hidden !important;
}

.mig-sidebar__logo-icon {
  width: 28px !important;
  height: 28px !important;
  border-radius: var(--radius-full) !important;
  background: linear-gradient(135deg, var(--mig-gold), #B8922E) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: var(--font-bold) !important;
  font-size: 11px !important;
  color: #000010 !important;
  flex-shrink: 0 !important;
  box-shadow: 0 0 10px rgba(212,168,67,0.3) !important;
  transform: none !important;
}

.mig-sidebar__logo-text {
  font-size: var(--text-sm) !important;
  font-weight: var(--font-bold) !important;
  color: var(--mig-gold) !important;
  letter-spacing: var(--tracking-wider) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  transition: opacity var(--transition-base) !important;
}

.mig-sidebar.collapsed .mig-sidebar__logo-text {
  opacity: 0 !important;
  width: 0 !important;
}

/* Collapse toggle button */
.sidebar-toggle {
  width: 24px !important;
  height: 24px !important;
  background: none !important;
  border: 1px solid rgba(212,168,67,0.2) !important;
  border-radius: var(--radius-sm) !important;
  color: var(--mig-gold) !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 10px !important;
  flex-shrink: 0 !important;
  transition: all var(--transition-fast) !important;
  padding: 0 !important;
  min-height: auto !important;
}

.sidebar-toggle:hover {
  background: rgba(212,168,67,0.12) !important;
  box-shadow: var(--glow-gold) !important;
}

/* Scrollable nav area */
.mig-sidebar__nav {
  flex: 1 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: 8px 0 !important;
  scrollbar-width: thin !important;
  scrollbar-color: rgba(212,168,67,0.2) transparent !important;
}

/* Section labels */
.mig-sidebar__section-title {
  display: block !important;
  padding: var(--space-3) var(--space-4) var(--space-1) !important;
  font-size: 9px !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: var(--tracking-widest) !important;
  text-transform: uppercase !important;
  color: var(--mig-text-muted) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  transition: opacity var(--transition-base) !important;
}

.mig-sidebar.collapsed .mig-sidebar__section-title {
  opacity: 0 !important;
}

/* NAV ITEMS */
.mig-nav-item {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-3) !important;
  padding: var(--space-2) var(--space-3) !important;
  margin: 1px 6px !important;
  border-radius: var(--radius-md) !important;
  text-decoration: none !important;
  color: var(--mig-text-secondary) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-medium) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  cursor: pointer !important;
  transition: all var(--transition-fast) !important;
  border: 1px solid transparent !important;
  border-left: none !important;
  position: relative !important;
  transform: none !important;
  box-shadow: none !important;
}

.mig-nav-item:hover {
  color: var(--mig-text-primary) !important;
  background: rgba(212,168,67,0.08) !important;
  border-color: rgba(212,168,67,0.2) !important;
  box-shadow: 0 0 12px rgba(212,168,67,0.1) !important;
  transform: none !important;
  text-shadow: none !important;
}

.mig-nav-item--active {
  color: var(--mig-gold) !important;
  background: rgba(212,168,67,0.12) !important;
  border-color: rgba(212,168,67,0.3) !important;
  box-shadow: 0 0 16px rgba(212,168,67,0.15) !important;
  border-left: none !important;
  transform: none !important;
}

.mig-nav-item--active::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important;
  top: 20% !important;
  height: 60% !important;
  width: 2px !important;
  background: var(--mig-gold) !important;
  border-radius: 0 2px 2px 0 !important;
  box-shadow: 0 0 8px rgba(212,168,67,0.4) !important;
}

/* Nav icon */
.mig-nav-item .mig-icon-el,
.mig-nav-item__icon {
  width: var(--icon-base) !important;
  height: var(--icon-base) !important;
  flex-shrink: 0 !important;
}

/* Collapsed sidebar nav items */
.mig-sidebar.collapsed .mig-nav-item {
  justify-content: center !important;
  padding: 7px !important;
}

.mig-sidebar.collapsed .mig-nav-item > span:last-child,
.mig-sidebar.collapsed .mig-sidebar__link {
  opacity: 0 !important;
  width: 0 !important;
  overflow: hidden !important;
}

/* Collapsed tooltip */
.mig-sidebar.collapsed .mig-nav-item:hover::after {
  content: attr(data-tooltip) !important;
  position: absolute !important;
  left: calc(var(--sidebar-width-collapsed) + 8px) !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  background: var(--panel-bg, #0D102D) !important;
  border: 1px solid var(--border-card, rgba(212,168,67,0.3)) !important;
  border-radius: var(--radius-sm) !important;
  padding: 4px 10px !important;
  font-size: var(--text-xs) !important;
  color: var(--mig-text-primary) !important;
  white-space: nowrap !important;
  pointer-events: none !important;
  z-index: 1000 !important;
  box-shadow: var(--glow-gold) !important;
}

/* WORKSPACE CARDS — compact */
.mig-workspace-cards {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 4px !important;
  padding: 4px 6px !important;
}

.mig-workspace-card {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 3px !important;
  padding: 6px 4px !important;
  border-radius: var(--radius-md) !important;
  background: var(--panel-bg) !important;
  border: 1px solid var(--border-card) !important;
  cursor: pointer !important;
  transition: all var(--transition-fast) !important;
  text-align: center !important;
  box-shadow: none !important;
  transform: none !important;
}

.mig-workspace-card:hover {
  background: var(--surface-hover, rgba(212,168,67,0.1)) !important;
  border-color: rgba(212,168,67,0.35) !important;
  box-shadow: 0 0 12px rgba(212,168,67,0.15) !important;
  transform: none !important;
}

.mig-workspace-card__icon {
  font-size: 16px !important;
}

.mig-workspace-card__label {
  font-size: 9px !important;
  font-weight: var(--font-semibold) !important;
  color: var(--mig-text-secondary) !important;
  letter-spacing: 0.05em !important;
}

.mig-sidebar.collapsed .mig-workspace-cards {
  display: none !important;
}

/* Sidebar footer */
.mig-sidebar__footer {
  border-top: 1px solid rgba(212,168,67,0.1) !important;
  padding: 10px !important;
  flex-shrink: 0 !important;
}

.mig-sidebar__user {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 6px !important;
  border-radius: var(--radius-md) !important;
}

.mig-sidebar__avatar {
  width: 28px !important;
  height: 28px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, var(--mig-gold), #B8922E) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-bold) !important;
  color: #000010 !important;
  flex-shrink: 0 !important;
  box-shadow: 0 0 10px rgba(212,168,67,0.3) !important;
}

.mig-sidebar__user-name {
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  color: var(--mig-text-primary) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.mig-sidebar__user-role {
  font-size: 9px !important;
  color: var(--mig-text-muted) !important;
}

.mig-sidebar.collapsed .mig-sidebar__user-name,
.mig-sidebar.collapsed .mig-sidebar__user-role,
.mig-sidebar.collapsed .mig-sidebar__user-info {
  display: none !important;
}

/* Industry switcher compact */
.mig-industry-switcher {
  padding: 6px 10px !important;
  border-bottom: 1px solid rgba(212,168,67,0.1) !important;
}

.mig-sidebar.collapsed .mig-industry-switcher {
  display: none !important;
}

/* Recent chats section */
.mig-sidebar.collapsed #chat-history-section {
  display: none !important;
}

.mig-sidebar.collapsed #nav-header-info,
.mig-sidebar.collapsed #nav-footer,
.mig-sidebar.collapsed #dynamic-nav {
  display: none !important;
}

/* ═══════════════════════════════════════════════
   MIGESTI TOPBAR — Sovereign Command Bar
   ═══════════════════════════════════════════════ */

.mig-topbar {
  height: var(--topbar-height) !important;
  background: var(--topbar-bg) !important;
  border-bottom: var(--topbar-border) !important;
  backdrop-filter: blur(24px) !important;
  -webkit-backdrop-filter: blur(24px) !important;
  z-index: 400 !important;
  display: flex !important;
  align-items: center !important;
  padding: 0 20px !important;
  gap: 12px !important;
  position: sticky !important;
  top: 0 !important;
  box-shadow: none !important;
  transform: none !important;
}

.mig-topbar__title { flex: 1 !important; }

.mig-topbar__title h1 {
  font-size: var(--text-md) !important;
  font-weight: var(--font-bold) !important;
  color: var(--mig-text-primary) !important;
  line-height: 1.2 !important;
  margin: 0 !important;
}

.mig-topbar__title p {
  font-size: var(--text-xs) !important;
  color: var(--mig-text-muted) !important;
  margin: 0 !important;
}

/* Search bar */
.mig-topbar__search input {
  height: 32px !important;
  width: 220px !important;
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(212,168,67,0.2) !important;
  border-radius: var(--radius-md) !important;
  padding: 0 12px 0 32px !important;
  color: var(--mig-text-primary) !important;
  font-size: var(--text-sm) !important;
  transition: all var(--transition-fast) !important;
  box-shadow: none !important;
}

.mig-topbar__search input:focus {
  width: 280px !important;
  border-color: var(--mig-gold) !important;
  box-shadow: 0 0 12px rgba(212,168,67,0.2) !important;
  outline: none !important;
}

/* Topbar buttons */
.mig-topbar__vault-actions .mig-btn--primary,
.mig-topbar__vault-actions .mig-btn {
  height: 32px !important;
  padding: 0 14px !important;
  border-radius: var(--radius-md) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  background: linear-gradient(135deg, var(--mig-gold), #B8922E) !important;
  color: #000010 !important;
  border: none !important;
  box-shadow: 0 2px 10px rgba(212,168,67,0.3) !important;
  min-height: auto !important;
}

.mig-topbar__vault-actions .mig-btn:hover {
  box-shadow: 0 0 20px rgba(212,168,67,0.5) !important;
  transform: translateY(-1px) !important;
}

/* Notification bell */
.mig-topbar__icon-btn {
  width: 32px !important;
  height: 32px !important;
  border-radius: var(--radius-md) !important;
  background: rgba(255,255,255,0.05) !important;
  border: 1px solid rgba(212,168,67,0.15) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  transition: all var(--transition-fast) !important;
  color: var(--mig-text-secondary) !important;
  font-size: var(--text-base) !important;
  position: relative !important;
}

.mig-topbar__icon-btn:hover {
  border-color: rgba(212,168,67,0.4) !important;
  box-shadow: var(--glow-gold) !important;
  color: var(--mig-gold) !important;
}

.mig-topbar__avatar {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, var(--mig-gold), #B8922E) !important;
  font-size: 10px !important;
}

/* ═══════════════════════════════════════════════
   MIGESTI PANELS — Semi-transparent Sovereign
   ═══════════════════════════════════════════════ */

.mig-main {
  flex: 1 !important;
  margin-left: var(--sidebar-width-full) !important;
  transition: margin-left var(--transition-base) !important;
}

.mig-sidebar.collapsed ~ .mig-main {
  margin-left: var(--sidebar-width-collapsed) !important;
}

/* ALL cards/panels */
.mig-card {
  background: var(--panel-bg) !important;
  border: var(--panel-border) !important;
  border-radius: var(--panel-radius) !important;
  backdrop-filter: var(--panel-blur) !important;
  -webkit-backdrop-filter: var(--panel-blur) !important;
  box-shadow: var(--panel-shadow) !important;
  padding: var(--panel-padding) !important;
  transition: border var(--transition-fast),
              box-shadow var(--transition-fast),
              transform var(--transition-fast) !important;
  position: relative !important;
  overflow: hidden !important;
  transform: none !important;
}

/* Gold top accent line on panels */
.mig-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 10% !important;
  width: 80% !important;
  height: 1px !important;
  background: linear-gradient(90deg,
    transparent, rgba(212,168,67,0.4), transparent) !important;
}

/* Panel hover */
.mig-card:hover {
  border: var(--panel-hover-border) !important;
  box-shadow: var(--panel-hover-shadow) !important;
  transform: var(--panel-hover-transform) !important;
}

/* Panel header */
.mig-card__header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin-bottom: var(--space-3) !important;
  padding-bottom: var(--space-3) !important;
  border-bottom: 1px solid rgba(212,168,67,0.1) !important;
}

.mig-card__title {
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: var(--tracking-wider) !important;
  text-transform: uppercase !important;
  color: var(--mig-gold) !important;
  margin: 0 !important;
}

/* STAT/METRIC CARDS */
.mig-metric-card {
  padding: var(--space-4) var(--space-4) !important;
  background: var(--panel-bg) !important;
  border: var(--panel-border) !important;
  border-radius: var(--panel-radius) !important;
  backdrop-filter: var(--panel-blur) !important;
  border-left: 3px solid var(--mig-gold) !important;
}

.mig-metric-card__label {
  font-size: var(--text-xs) !important;
  color: var(--mig-text-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: var(--tracking-wider) !important;
  margin-bottom: var(--space-2) !important;
}

.mig-metric-card__value {
  font-size: var(--text-xl) !important;
  font-weight: var(--font-bold) !important;
  color: var(--mig-text-primary) !important;
  line-height: 1 !important;
}

/* ═══════════════════════════════════════════════
   BUTTONS — Sovereign Action System (MSPG)
   ═══════════════════════════════════════════════ */

.mig-btn {
  font-family: var(--font-primary) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: var(--tracking-wide) !important;
  border-radius: var(--radius-md) !important;
  cursor: pointer !important;
  transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-2) !important;
  padding: var(--space-2) var(--space-4) !important;
  border: 1px solid transparent !important;
  white-space: nowrap !important;
  min-height: auto !important;
}

.mig-btn--primary {
  background: linear-gradient(135deg, var(--mig-gold), #B8922E) !important;
  color: #000010 !important;
  border: none !important;
  box-shadow: 0 2px 12px rgba(212,168,67,0.3) !important;
}

.mig-btn--primary:hover {
  box-shadow: 0 0 24px rgba(212,168,67,0.5) !important;
  transform: translateY(-1px) scale(1.01) !important;
  color: #000010 !important;
}

.mig-btn--gold {
  background: linear-gradient(135deg, var(--mig-gold), #B8922E) !important;
  color: #000010 !important;
}

.mig-btn--gold:hover {
  box-shadow: 0 0 24px rgba(212,168,67,0.5) !important;
  color: #000010 !important;
}

.mig-btn--ghost {
  background: transparent !important;
  color: var(--mig-text-secondary) !important;
  border: 1px solid rgba(212,168,67,0.2) !important;
}

.mig-btn--ghost:hover {
  background: rgba(212,168,67,0.08) !important;
  color: var(--mig-gold) !important;
  border-color: rgba(212,168,67,0.4) !important;
}

/* Click micro-animation */
.mig-btn:active {
  transform: scale(0.97) !important;
}

/* ═══════════════════════════════════════════════
   SCROLLBARS — Sovereign Style (MSPG)
   ═══════════════════════════════════════════════ */

::-webkit-scrollbar {
  width: 4px !important;
  height: 4px !important;
}

::-webkit-scrollbar-track {
  background: transparent !important;
}

::-webkit-scrollbar-thumb {
  background: rgba(212,168,67,0.25) !important;
  border-radius: var(--radius-full) !important;
}

::-webkit-scrollbar-thumb:hover {
  background: rgba(212,168,67,0.5) !important;
}

/* ═══════════════════════════════════════════════
   LOADING SHIMMER (MSPG)
   ═══════════════════════════════════════════════ */

@keyframes mig-shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}

.loading-shimmer, [class*="shimmer"],
.skeleton, [class*="skeleton"] {
  background: linear-gradient(90deg,
    rgba(212,168,67,0.05) 25%,
    rgba(212,168,67,0.12) 50%,
    rgba(212,168,67,0.05) 75%) !important;
  background-size: 200% auto !important;
  animation: mig-shimmer 1.5s linear infinite !important;
  border-radius: var(--radius-sm) !important;
}

/* ═══════════════════════════════════════════════
   PAGE TRANSITIONS (MSPG)
   ═══════════════════════════════════════════════ */

@keyframes mig-page-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.mig-content {
  background: var(--panel-bg) !important;
  animation: mig-page-in 0.3s cubic-bezier(0.4, 0, 0.2, 1) forwards !important;
}

/* ═══════════════════════════════════════════════
   BADGES (MSPG)
   ═══════════════════════════════════════════════ */

.mig-badge {
  display: inline-flex !important;
  align-items: center !important;
  padding: 2px 8px !important;
  border-radius: var(--radius-full) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: var(--tracking-wide) !important;
}

.mig-badge--gold {
  background: rgba(212,168,67,0.15) !important;
  color: var(--mig-gold) !important;
  border: 1px solid rgba(212,168,67,0.3) !important;
}

.mig-badge--green {
  background: rgba(0,232,122,0.12) !important;
  color: var(--mig-success) !important;
  border: 1px solid rgba(0,232,122,0.25) !important;
}

.mig-badge--blue {
  background: rgba(0,212,255,0.12) !important;
  color: var(--mig-cyan) !important;
  border: 1px solid rgba(0,212,255,0.25) !important;
}

/* ═══════════════════════════════════════════════
   FOCUS RING — Universal Accessibility (MSPG)
   ═══════════════════════════════════════════════ */

*:focus-visible {
  outline: 2px solid var(--mig-gold) !important;
  outline-offset: 2px !important;
}

/* ═══════════════════════════════════════════════
   SELECTION (MSPG)
   ═══════════════════════════════════════════════ */

::selection {
  background: rgba(212,168,67,0.25) !important;
  color: inherit !important;
}

/* ═══════════════════════════════════════════════
   DIVIDERS (MSPG)
   ═══════════════════════════════════════════════ */

hr, .divider, [class*="divider"] {
  border: none !important;
  border-top: 1px solid rgba(212,168,67,0.12) !important;
  margin: var(--space-4) 0 !important;
}

/* ═══════════════════════════════════════════════
   RESPONSIVE — Mobile Sovereign (MSPG)
   ═══════════════════════════════════════════════ */

@media (max-width: 768px) {
  .mig-sidebar {
    width: var(--sidebar-width-collapsed) !important;
  }

  .mig-sidebar .mig-sidebar__logo-text,
  .mig-sidebar .mig-sidebar__section-title,
  .mig-sidebar .mig-workspace-cards,
  .mig-sidebar #chat-history-section,
  .mig-sidebar .mig-sidebar__user-info {
    display: none !important;
  }

  .mig-main {
    margin-left: var(--sidebar-width-collapsed) !important;
  }

  .mig-topbar {
    padding: 0 12px !important;
  }

  .mig-topbar__search {
    width: 160px !important;
  }
}

@media (max-width: 480px) {
  .mig-content {
    padding: 12px !important;
  }

  .mig-topbar__search {
    display: none !important;
  }
}
