/* ==========================================================================
   TIASTICA — Cockpit Shell CSS
   Estilos del overlay, HUD, panels y stepper compartidos por todos los módulos.
   Los módulos sólo aportan sus propios *-module.css para diferencias de color
   y simuladores propios.
   ========================================================================== */

/* ==========================================================================
   MOUNT POINT — único div en index.html
   ========================================================================== */
#cockpit-mount {
  position: fixed;
  inset: 0;
  z-index: 10002;
  display: none;
  flex-direction: column;
  padding: 1.25rem 1.5rem;
  background: var(--color-bg);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  opacity: 0;
  transform: scale(1.02);
  transition: opacity 0.5s cubic-bezier(0.22, 1, 0.36, 1), transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
#cockpit-mount::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  transition: opacity 0.8s ease;
}
#cockpit-mount.is-active::before { opacity: 1; }
#cockpit-mount.cockpit-mount--geo::before  { background: radial-gradient(ellipse at 30% 20%, var(--geo-glow-faint) 0%, transparent 60%); }
#cockpit-mount.cockpit-mount--erp::before  { background: radial-gradient(ellipse at 30% 20%, var(--erp-glow-faint) 0%, transparent 60%); }
#cockpit-mount.cockpit-mount--um::before   { background: radial-gradient(ellipse at 30% 20%, var(--um-glow-faint) 0%, transparent 60%); }
#cockpit-mount.cockpit-mount--ia::before   { background: radial-gradient(ellipse at 30% 20%, var(--ia-glow-faint) 0%, transparent 60%); }
#cockpit-mount.cockpit-mount--ben::before  { background: radial-gradient(ellipse at 30% 20%, var(--ben-glow-faint) 0%, transparent 60%); }
#cockpit-mount.cockpit-mount--portal::before { background: radial-gradient(ellipse at 30% 20%, var(--portal-glow-faint) 0%, transparent 60%); }

#cockpit-mount[hidden] {
  display: none !important;
}

#cockpit-mount.is-active {
  opacity: 1;
  transform: scale(1);
}

/* Starfield canvas (inyectado por cockpit-shell.js) */
#cockpit-starfield {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  opacity: 0.8;
}
:root[data-theme="light"] #cockpit-starfield {
  opacity: 0.15;
}

/* ==========================================================================
   HUD — barra superior
   ========================================================================== */
.cockpit-hud {
  position: relative;
  z-index: 5;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem 1.25rem;
  background: var(--color-bg-glass);
  border: 1px solid var(--color-border);
  border-radius: 14px;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  margin-bottom: 1.25rem;
  box-shadow: 0 4px 30px var(--shadow-color);
  flex-shrink: 0;
  transition: border-color 0.6s ease, box-shadow 0.6s ease;
}
#cockpit-mount.cockpit-mount--geo .cockpit-hud    { border-color: rgba(var(--geo-rgb),0.12); box-shadow: 0 4px 30px var(--shadow-color), inset 0 0 30px rgba(var(--geo-rgb),0.02); }
#cockpit-mount.cockpit-mount--erp .cockpit-hud    { border-color: rgba(var(--erp-rgb),0.12); box-shadow: 0 4px 30px var(--shadow-color), inset 0 0 30px rgba(var(--erp-rgb),0.02); }
#cockpit-mount.cockpit-mount--um .cockpit-hud     { border-color: rgba(var(--um-rgb),0.12); box-shadow: 0 4px 30px var(--shadow-color), inset 0 0 30px rgba(var(--um-rgb),0.02); }
#cockpit-mount.cockpit-mount--ia .cockpit-hud     { border-color: rgba(var(--ia-rgb),0.12); box-shadow: 0 4px 30px var(--shadow-color), inset 0 0 30px rgba(var(--ia-rgb),0.02); }
#cockpit-mount.cockpit-mount--ben .cockpit-hud    { border-color: rgba(var(--ben-rgb),0.12); box-shadow: 0 4px 30px var(--shadow-color), inset 0 0 30px rgba(var(--ben-rgb),0.02); }
#cockpit-mount.cockpit-mount--portal .cockpit-hud { border-color: rgba(var(--portal-rgb),0.12); box-shadow: 0 4px 30px var(--shadow-color), inset 0 0 30px rgba(var(--portal-rgb),0.02); }

.cockpit-hud__left {
  display: flex;
  align-items: center;
  gap: 12px;
}

.hud-label {
  font-family: var(--font-heading);
  font-size: 0.72rem;
  font-weight: var(--fw-bold);
  color: var(--color-text-muted);
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.hud-divider {
  width: 1px;
  height: 14px;
  background: var(--color-border);
}

.hud-breadcrumb {
  font-size: 0.75rem;
  font-weight: var(--fw-medium);
  transition: color 0.5s ease;
}
#cockpit-mount.cockpit-mount--geo .hud-breadcrumb    { color: #7DD3FC; }
#cockpit-mount.cockpit-mount--erp .hud-breadcrumb    { color: #53BAE3; }
#cockpit-mount.cockpit-mount--um .hud-breadcrumb     { color: #6EE7B7; }
#cockpit-mount.cockpit-mount--ia .hud-breadcrumb     { color: #C4B5FD; }
#cockpit-mount.cockpit-mount--ben .hud-breadcrumb    { color: #F9A8D4; }
#cockpit-mount.cockpit-mount--portal .hud-breadcrumb { color: #67E8F9; }

.cockpit-hud__center {
  font-family: var(--font-heading);
  font-size: 0.75rem;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.05em;
}

.hud-coords {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--color-bg-glass);
  padding: 4px 10px;
  border-radius: 8px;
  border: 0.5px solid var(--color-border);
}

.glow-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #10B981;
  box-shadow: 0 0 8px #10B981;
  animation: hudPulse 2s infinite;
  flex-shrink: 0;
}

@keyframes hudPulse {
  0%, 100% { opacity: 0.6; }
  50%       { opacity: 1; transform: scale(1.15); }
}

#cockpit-mount .hud-exit {
  border-radius: 8px;
  border-color: rgba(239, 68, 68, 0.3);
  color: #F87171;
  background: rgba(239, 68, 68, 0.04);
  display: flex;
  align-items: center;
  gap: 4px;
}

#cockpit-mount .hud-exit:hover {
  background: rgba(239, 68, 68, 0.12);
  border-color: #EF4444;
  color: white;
}

#cockpit-mount .hud-nav-btn {
  padding: 0.45rem 0.9rem;
  font-size: 0.72rem;
  border-radius: 8px;
  transition: all 0.3s cubic-bezier(0.22,1,0.36,1);
}
#cockpit-mount .hud-nav-btn:hover {
  transform: translateY(-1px);
}
#cockpit-mount.cockpit-mount--geo .hud-nav-btn:hover    { border-color: var(--geo-glow-intense); color: #7DD3FC; }
#cockpit-mount.cockpit-mount--erp .hud-nav-btn:hover    { border-color: var(--erp-glow-intense); color: #53BAE3; }
#cockpit-mount.cockpit-mount--um .hud-nav-btn:hover     { border-color: var(--um-glow-intense); color: #6EE7B7; }
#cockpit-mount.cockpit-mount--ia .hud-nav-btn:hover     { border-color: var(--ia-glow-intense); color: #C4B5FD; }
#cockpit-mount.cockpit-mount--ben .hud-nav-btn:hover    { border-color: var(--ben-glow-intense); color: #F9A8D4; }
#cockpit-mount.cockpit-mount--portal .hud-nav-btn:hover { border-color: var(--portal-glow-intense); color: #67E8F9; }

.hud-deck-indicator {
  font-size: 0.7rem;
  font-weight: var(--fw-semibold);
  color: var(--color-text-muted);
  letter-spacing: 0.02em;
  padding: 4px 10px;
  background: var(--color-bg-glass);
  border: 1px solid var(--color-border);
  border-radius: 6px;
}

/* ==========================================================================
   INTERFACE LAYOUT — grilla de 3 columnas
   ========================================================================== */
.cockpit-interface {
  position: relative;
  z-index: 5;
  flex: 1;
  display: grid;
  grid-template-columns: 300px 1fr 320px;
  gap: 1.25rem;
  margin-bottom: 1.25rem;
  min-height: 0;
  overflow: hidden;
  transition: grid-template-columns 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

/* ==========================================================================
   PANEL IZQUIERDO
   ========================================================================== */
.cockpit-panel-left {
  background: var(--color-bg-glass);
  border: 1px solid var(--color-border);
  border-radius: 14px;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  box-shadow: 0 8px 32px var(--shadow-color);
  overflow-y: auto;
}
#cockpit-mount.cockpit-mount--geo .cockpit-panel-left    { border-color: rgba(var(--geo-rgb),0.08); }
#cockpit-mount.cockpit-mount--erp .cockpit-panel-left    { border-color: rgba(var(--erp-rgb),0.08); }
#cockpit-mount.cockpit-mount--um .cockpit-panel-left     { border-color: rgba(var(--um-rgb),0.08); }
#cockpit-mount.cockpit-mount--ia .cockpit-panel-left     { border-color: rgba(var(--ia-rgb),0.08); }
#cockpit-mount.cockpit-mount--ben .cockpit-panel-left    { border-color: rgba(var(--ben-rgb),0.08); }
#cockpit-mount.cockpit-mount--portal .cockpit-panel-left { border-color: rgba(var(--portal-rgb),0.08); }

.cockpit-platform-title {
  font-family: var(--font-heading);
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  line-height: 1.2;
  margin-top: 1rem;
  margin-bottom: 1rem;
  letter-spacing: -0.01em;
}

.cockpit-platform-desc {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  line-height: var(--lh-normal);
}

.cockpit-nav-deck {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--color-bg-glass);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 6px 10px;
  margin-top: 1.5rem;
  flex-shrink: 0;
}

.deck-indicator {
  font-size: 0.7rem;
  font-weight: var(--fw-semibold);
  color: var(--color-text-muted);
  letter-spacing: 0.02em;
}

.btn-nav-deck {
  padding: 6px 12px !important;
  font-size: 0.72rem !important;
  border-radius: 8px !important;
}

/* ==========================================================================
   PANEL CENTRAL — pantalla del simulador
   ========================================================================== */
.cockpit-panel-center {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.cockpit-screen {
  position: relative;
  flex: 1;
  background: #020408;
  border: 1px solid var(--color-border);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: inset 0 0 40px rgba(0, 0, 0, 0.95);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  min-height: 0;
}

.screen-glow-border {
  position: absolute;
  inset: 0;
  border: 1.5px solid transparent;
  pointer-events: none;
  z-index: 3;
  border-radius: 14px;
  transition: border-color 0.6s, box-shadow 0.6s;
}

/* Color del borde por plataforma activa */
#cockpit-mount.cockpit-mount--geo .screen-glow-border  { border-color: var(--geo-glow-bright); box-shadow: inset 0 0 25px var(--geo-glow-faint); }
#cockpit-mount.cockpit-mount--erp .screen-glow-border  { border-color: var(--erp-glow-bright); box-shadow: inset 0 0 25px var(--erp-glow-faint); }
#cockpit-mount.cockpit-mount--um  .screen-glow-border  { border-color: var(--um-glow-bright); box-shadow: inset 0 0 25px var(--um-glow-faint); }
#cockpit-mount.cockpit-mount--ia  .screen-glow-border  { border-color: var(--ia-glow-bright); box-shadow: inset 0 0 25px var(--ia-glow-faint); }
#cockpit-mount.cockpit-mount--ben .screen-glow-border  { border-color: var(--ben-glow-bright); box-shadow: inset 0 0 25px var(--ben-glow-faint); }
#cockpit-mount.cockpit-mount--portal .screen-glow-border { border-color: var(--portal-glow-bright); box-shadow: inset 0 0 25px var(--portal-glow-faint); }

/* Sim container base */
.cockpit-sim-container {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}

.sim-tag {
  position: absolute;
  top: 12px;
  left: 16px;
  font-family: var(--font-heading);
  font-size: 0.58rem;
  color: var(--color-text-muted);
  letter-spacing: 0.12em;
  background: var(--color-bg-glass-strong);
  padding: 4px 8px;
  border-radius: 4px;
  border: 1px solid var(--color-border);
  backdrop-filter: blur(4px);
  z-index: 10;
  text-transform: uppercase;
}

/* ==========================================================================
   PANEL DERECHO — NAVEGADOR interactivo
   ========================================================================== */
.cockpit-panel-right {
  background: var(--color-bg-glass);
  border: 1px solid var(--color-border);
  border-radius: 14px;
  padding: 1.25rem 1.25rem 1rem;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  box-shadow: 0 8px 32px var(--shadow-color);
  overflow: hidden;
}
#cockpit-mount.cockpit-mount--geo .cockpit-panel-right    { border-color: rgba(var(--geo-rgb),0.10); }
#cockpit-mount.cockpit-mount--erp .cockpit-panel-right    { border-color: rgba(var(--erp-rgb),0.10); }
#cockpit-mount.cockpit-mount--um .cockpit-panel-right     { border-color: rgba(var(--um-rgb),0.10); }
#cockpit-mount.cockpit-mount--ia .cockpit-panel-right     { border-color: rgba(var(--ia-rgb),0.10); }
#cockpit-mount.cockpit-mount--ben .cockpit-panel-right    { border-color: rgba(var(--ben-rgb),0.10); }
#cockpit-mount.cockpit-mount--portal .cockpit-panel-right { border-color: rgba(var(--portal-rgb),0.10); }

/* --- Navigador drill-down prompt (estado reposo) --- */
.drilldown-prompt {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 0.5rem 0;
}

.drilldown-prompt svg {
  color: var(--color-primary-light);
  filter: drop-shadow(0 0 10px var(--geo-glow-bright));
  animation: promptPulse 2s ease-in-out infinite;
}

@keyframes promptPulse {
  0%,100% { opacity: 0.65; transform: scale(1); }
  50%      { opacity: 1;    transform: scale(1.06); }
}

.drilldown-prompt h3 {
  font-family: var(--font-heading);
  font-size: 0.85rem;
  font-weight: var(--fw-semibold);
  color: var(--color-text-heading);
}

.drilldown-prompt p {
  font-size: 0.65rem;
  color: var(--color-text-muted);
  line-height: var(--lh-normal);
}

/* --- Stepper (navegador activo) --- */
.cockpit-stepper {
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: space-between;
}

.stepper-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 0.65rem;
  margin-bottom: 0.75rem;
  gap: 0.5rem;
}

.stepper-feature-area {
  flex: 1;
  min-width: 0;
}

.stepper-breadcrumb {
  display: block;
  font-family: var(--font-heading);
  font-size: 0.52rem;
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 2px;
}
#cockpit-mount.cockpit-mount--geo    .stepper-breadcrumb { color: #0EA5E9; }
#cockpit-mount.cockpit-mount--erp    .stepper-breadcrumb { color: #1C8FD6; }
#cockpit-mount.cockpit-mount--um     .stepper-breadcrumb { color: #10B981; }
#cockpit-mount.cockpit-mount--ia     .stepper-breadcrumb { color: #8B5CF6; }
#cockpit-mount.cockpit-mount--ben    .stepper-breadcrumb { color: #EC4899; }
#cockpit-mount.cockpit-mount--portal .stepper-breadcrumb { color: #06B6D4; }

.stepper-feature-name {
  font-family: var(--font-heading);
  font-size: 0.7rem;
  font-weight: var(--fw-semibold);
  color: var(--color-text-heading);
  line-height: 1.2;
}

#cockpit-mount .btn-stepper-exit {
  padding: 4px 8px;
  font-size: 0.6rem;
  border-radius: 6px;
  border-color: var(--color-border);
  color: var(--color-text-muted);
  flex-shrink: 0;
}

#cockpit-mount .btn-stepper-exit:hover {
  border-color: var(--color-border-hover);
  color: var(--color-text-heading);
}

.stepper-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
  min-height: 0;
  overflow-y: auto;
}

.stepper-step-label {
  font-family: var(--font-heading);
  font-size: 0.55rem;
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  opacity: 0.5;
}
#cockpit-mount.cockpit-mount--geo    .stepper-step-label { color: #0EA5E9; }
#cockpit-mount.cockpit-mount--erp    .stepper-step-label { color: #1C8FD6; }
#cockpit-mount.cockpit-mount--um     .stepper-step-label { color: #10B981; }
#cockpit-mount.cockpit-mount--ia     .stepper-step-label { color: #8B5CF6; }
#cockpit-mount.cockpit-mount--ben    .stepper-step-label { color: #EC4899; }
#cockpit-mount.cockpit-mount--portal .stepper-step-label { color: #06B6D4; }

.stepper-title {
  font-family: var(--font-heading);
  font-size: 0.85rem;
  font-weight: var(--fw-bold);
  color: var(--color-text-heading);
  line-height: 1.3;
}

.stepper-desc {
  font-size: 0.62rem;
  color: var(--color-text-muted);
  line-height: var(--lh-normal);
}

.stepper-dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin: 0.9rem 0 0.75rem;
}

.stepper-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-border);
  transition: all 0.3s ease;
  cursor: pointer;
}
.stepper-dot:hover { background: var(--color-text-muted); }
.stepper-dot--active {
  transform: scale(1.25);
}
#cockpit-mount.cockpit-mount--geo    .stepper-dot--active { background: #0EA5E9; box-shadow: 0 0 8px #0EA5E9; }
#cockpit-mount.cockpit-mount--erp    .stepper-dot--active { background: #1C8FD6; box-shadow: 0 0 8px #1C8FD6; }
#cockpit-mount.cockpit-mount--um     .stepper-dot--active { background: #10B981; box-shadow: 0 0 8px #10B981; }
#cockpit-mount.cockpit-mount--ia     .stepper-dot--active { background: #8B5CF6; box-shadow: 0 0 8px #8B5CF6; }
#cockpit-mount.cockpit-mount--ben    .stepper-dot--active { background: #EC4899; box-shadow: 0 0 8px #EC4899; }
#cockpit-mount.cockpit-mount--portal .stepper-dot--active { background: #06B6D4; box-shadow: 0 0 8px #06B6D4; }

.stepper-controls {
  display: flex;
  gap: 8px;
}
.stepper-controls .btn {
  flex: 1;
  font-size: 0.68rem !important;
  padding: 0.5rem 0.6rem !important;
  border-radius: 8px !important;
}
#cockpit-mount #stepperPrevBtn {
  border-color: var(--color-border);
  color: var(--color-text-muted);
}
#cockpit-mount #stepperPrevBtn:hover {
  border-color: var(--color-border-hover);
  color: var(--color-text-heading);
}

/* Portal pulse animation for stepper step 2 */
.pulse-active {
  animation: portalPulse 1.2s ease-in-out infinite;
}

@keyframes portalPulse {
  0%, 100% { transform: translateY(0); opacity: 1; }
  50%      { transform: translateY(-2px); opacity: 0.85; }
}

/* Portal simulator styles */
.portal-nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 6px 4px;
  font-size: 0.5rem;
  color: var(--color-text-muted);
  cursor: default;
  transition: all 0.2s;
}
.portal-nav-item i { font-size: 1rem; }
.portal-nav-item--active {
  color: #67E8F9;
  background: var(--portal-glow-soft);
  border-right: 2px solid #06B6D4;
}
.portal-widget {
  flex: 1;
  background: var(--color-bg-glass);
  border: 1px solid var(--color-border);
  border-radius: 6px;
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  transition: all 0.4s ease;
}

/* ==========================================================================
   BOTTOM CONSOLE — cards de features
   ========================================================================== */
.cockpit-console {
  position: relative;
  z-index: 5;
  background: var(--color-bg-glass);
  border: 1px solid var(--color-border);
  border-radius: 14px;
  padding: 0.75rem;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 -4px 30px var(--shadow-color);
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  flex-shrink: 0;
}
#cockpit-mount.cockpit-mount--geo .cockpit-console    { border-color: rgba(var(--geo-rgb),0.08); }
#cockpit-mount.cockpit-mount--erp .cockpit-console    { border-color: rgba(var(--erp-rgb),0.08); }
#cockpit-mount.cockpit-mount--um .cockpit-console     { border-color: rgba(var(--um-rgb),0.08); }
#cockpit-mount.cockpit-mount--ia .cockpit-console     { border-color: rgba(var(--ia-rgb),0.08); }
#cockpit-mount.cockpit-mount--ben .cockpit-console    { border-color: rgba(var(--ben-rgb),0.08); }
#cockpit-mount.cockpit-mount--portal .cockpit-console { border-color: rgba(var(--portal-rgb),0.08); }

.console-deck {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}

/* Console Cards */
.btn-console-card {
  background: var(--color-bg-glass);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 12px;
  text-align: left;
  cursor: pointer;
  outline: none;
  transition: transform 0.28s ease, border-color 0.28s ease, box-shadow 0.28s ease;
}

.btn-console-card:hover        { background: var(--color-bg-elevated); transform: translateY(-4px); }
.btn-console-card:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 2px; }

.btn-console-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all 0.3s;
}

.btn-console-icon svg { width: 16px; height: 16px; opacity: 0.7; }

.btn-console-txt h4 {
  font-family: var(--font-heading);
  font-size: 0.72rem;
  font-weight: var(--fw-semibold);
  color: var(--color-text-heading);
  margin-bottom: 2px;
}

.btn-console-txt span {
  font-size: 0.58rem;
  color: var(--color-text-muted);
}

/* Color-coded cards */
.btn-console-card--geo    .btn-console-icon { background: var(--geo-glow-soft);  color: var(--color-geo);    border: 0.5px solid var(--geo-glow); }
.btn-console-card--geo:hover                { border-color: var(--geo-glow-intense); box-shadow: 0 0 15px var(--geo-glow-soft); }
.btn-console-card--geo:hover .btn-console-icon { background: var(--geo-glow); }

.btn-console-card--erp    .btn-console-icon { background: var(--erp-glow-soft);  color: var(--color-erp);    border: 0.5px solid var(--erp-glow); }
.btn-console-card--erp:hover                { border-color: var(--erp-glow-intense); box-shadow: 0 0 15px var(--erp-glow-soft); }
.btn-console-card--erp:hover .btn-console-icon { background: var(--erp-glow); }

.btn-console-card--um     .btn-console-icon { background: var(--um-glow-soft);  color: var(--color-um);     border: 0.5px solid var(--um-glow); }
.btn-console-card--um:hover                 { border-color: var(--um-glow-intense); box-shadow: 0 0 15px var(--um-glow-soft); }
.btn-console-card--um:hover .btn-console-icon { background: var(--um-glow); }

.btn-console-card--ia     .btn-console-icon { background: var(--ia-glow-soft);  color: var(--color-ia);     border: 0.5px solid var(--ia-glow); }
.btn-console-card--ia:hover                 { border-color: var(--ia-glow-intense); box-shadow: 0 0 15px var(--ia-glow-soft); }
.btn-console-card--ia:hover .btn-console-icon { background: var(--ia-glow); }

.btn-console-card--ben    .btn-console-icon { background: var(--ben-glow-soft);  color: var(--color-ben);    border: 0.5px solid var(--ben-glow); }
.btn-console-card--ben:hover                { border-color: var(--ben-glow-intense); box-shadow: 0 0 15px var(--ben-glow-soft); }
.btn-console-card--ben:hover .btn-console-icon { background: var(--ben-glow); }

.btn-console-card--portal .btn-console-icon { background: var(--portal-glow-soft);  color: var(--color-portal);  border: 0.5px solid var(--portal-glow); }
.btn-console-card--portal:hover             { border-color: var(--portal-glow-intense); box-shadow: 0 0 15px var(--portal-glow-soft); }
.btn-console-card--portal:hover .btn-console-icon { background: var(--portal-glow); }

/* Active console card */
#cockpit-mount .btn-console-card--active {
  transform: translateY(-2px);
}
#cockpit-mount .btn-console-card--geo.btn-console-card--active    { border-color: #0EA5E9; box-shadow: 0 0 20px var(--geo-glow-bright), 0 4px 12px var(--geo-glow-soft); }
#cockpit-mount .btn-console-card--erp.btn-console-card--active    { border-color: #1C8FD6; box-shadow: 0 0 20px var(--erp-glow-bright), 0 4px 12px var(--erp-glow-soft); }
#cockpit-mount .btn-console-card--um.btn-console-card--active     { border-color: #10B981; box-shadow: 0 0 20px var(--um-glow-bright), 0 4px 12px var(--um-glow-soft); }
#cockpit-mount .btn-console-card--ia.btn-console-card--active     { border-color: #8B5CF6; box-shadow: 0 0 20px var(--ia-glow-bright), 0 4px 12px var(--ia-glow-soft); }
#cockpit-mount .btn-console-card--ben.btn-console-card--active    { border-color: #EC4899; box-shadow: 0 0 20px var(--ben-glow-bright), 0 4px 12px var(--ben-glow-soft); }
#cockpit-mount .btn-console-card--portal.btn-console-card--active { border-color: #06B6D4; box-shadow: 0 0 20px var(--portal-glow-bright), 0 4px 12px var(--portal-glow-soft); }

/* ==========================================================================
   DRILL-DOWN STATE
   ========================================================================== */
#cockpit-mount.state-drilled-down .cockpit-panel-left {
  overflow: hidden;
  min-width: 0;
  padding: 0;
  border: none;
  opacity: 0;
  pointer-events: none;
  transform: none;
  filter: none;
}

#cockpit-mount.state-drilled-down .cockpit-interface {
  grid-template-columns: 0 1fr 360px;
}

#cockpit-mount.state-drilled-down .cockpit-panel-right {
  justify-content: flex-start;
}

#cockpit-mount.state-drilled-down .cockpit-console {
  opacity: 1;
  filter: none;
  transform: none;
  pointer-events: auto;
}

/* ==========================================================================
   COCKPIT EFFECTS — Transiciones suaves, feedback táctil, ambiente activo
   ========================================================================== */

/* --- Button press tactile feedback --- */
#cockpit-mount .hud-nav-btn:active,
#cockpit-mount .hud-exit:active,
#cockpit-mount .btn-stepper-exit:active,
#cockpit-mount #stepperPrevBtn:active,
#cockpit-mount #stepperNextBtn:active {
  transform: scale(0.94) !important;
  transition-duration: 0.06s !important;
}
#cockpit-mount .btn-console-card:active {
  transform: scale(0.97) translateY(-1px) !important;
  transition-duration: 0.06s !important;
}

/* --- Console card active: bottom indicator bar + icon glow --- */
.btn-console-card { position: relative; }
.btn-console-card--active::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 24%;
  right: 24%;
  height: 2px;
  border-radius: 2px 2px 0 0;
  transition: all 0.3s ease;
}
#cockpit-mount.cockpit-mount--geo    .btn-console-card--active::after { background: #0EA5E9; box-shadow: 0 0 8px #0EA5E9; }
#cockpit-mount.cockpit-mount--erp    .btn-console-card--active::after { background: #1C8FD6; box-shadow: 0 0 8px #1C8FD6; }
#cockpit-mount.cockpit-mount--um     .btn-console-card--active::after { background: #10B981; box-shadow: 0 0 8px #10B981; }
#cockpit-mount.cockpit-mount--ia     .btn-console-card--active::after { background: #8B5CF6; box-shadow: 0 0 8px #8B5CF6; }
#cockpit-mount.cockpit-mount--ben    .btn-console-card--active::after { background: #EC4899; box-shadow: 0 0 8px #EC4899; }
#cockpit-mount.cockpit-mount--portal .btn-console-card--active::after { background: #06B6D4; box-shadow: 0 0 8px #06B6D4; }
.btn-console-card--active .btn-console-icon {
  transform: scale(1.08);
  box-shadow: 0 0 12px currentColor;
}

@keyframes simFadeIn {
  from { opacity: 0; transform: scale(0.97); }
  to   { opacity: 1; transform: scale(1); }
}

/* --- Deck navigation crossfade (module switching) --- */
#cockpit-mount.module-switching .cockpit-interface {
  transition: all 0.35s cubic-bezier(0.65, 0, 0.35, 1);
}
#cockpit-mount.module-switching .cockpit-panel-left,
#cockpit-mount.module-switching .cockpit-panel-center,
#cockpit-mount.module-switching .cockpit-panel-right {
  opacity: 0;
  filter: blur(3px);
  transform: scale(0.97);
}
/* --- Scan line CRT overlay on screen --- */
.cockpit-screen::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 4;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0, 0, 0, 0.18) 2px,
    rgba(0, 0, 0, 0.18) 4px
  );
  animation: scanlineMove 10s linear infinite;
}
@keyframes scanlineMove {
  0%   { background-position: 0 0; }
  100% { background-position: 0 4px; }
}

/* --- Panel border breathing (active system feel) --- */
#cockpit-mount.cockpit-mount--geo    .cockpit-panel-left,
#cockpit-mount.cockpit-mount--geo    .cockpit-panel-right { animation: panelGlowGeo 4s ease-in-out infinite; }
#cockpit-mount.cockpit-mount--erp    .cockpit-panel-left,
#cockpit-mount.cockpit-mount--erp    .cockpit-panel-right { animation: panelGlowErp 4s ease-in-out infinite; }
#cockpit-mount.cockpit-mount--um     .cockpit-panel-left,
#cockpit-mount.cockpit-mount--um     .cockpit-panel-right { animation: panelGlowUm  4s ease-in-out infinite; }
#cockpit-mount.cockpit-mount--ia     .cockpit-panel-left,
#cockpit-mount.cockpit-mount--ia     .cockpit-panel-right { animation: panelGlowIa  4s ease-in-out infinite; }
#cockpit-mount.cockpit-mount--ben    .cockpit-panel-left,
#cockpit-mount.cockpit-mount--ben    .cockpit-panel-right { animation: panelGlowBen 4s ease-in-out infinite; }
#cockpit-mount.cockpit-mount--portal .cockpit-panel-left,
#cockpit-mount.cockpit-mount--portal .cockpit-panel-right { animation: panelGlowPortal 4s ease-in-out infinite; }

@keyframes panelGlowGeo {
  0%,100% { border-color: var(--geo-glow-soft); box-shadow: 0 8px 32px var(--shadow-color); }
  50%     { border-color: var(--geo-glow-bright); box-shadow: 0 8px 32px var(--shadow-color), 0 0 30px var(--geo-glow-faint); }
}
@keyframes panelGlowErp {
  0%,100% { border-color: var(--erp-glow-soft); box-shadow: 0 8px 32px var(--shadow-color); }
  50%     { border-color: var(--erp-glow-bright); box-shadow: 0 8px 32px var(--shadow-color), 0 0 30px var(--erp-glow-faint); }
}
@keyframes panelGlowUm {
  0%,100% { border-color: var(--um-glow-soft); box-shadow: 0 8px 32px var(--shadow-color); }
  50%     { border-color: var(--um-glow-bright); box-shadow: 0 8px 32px var(--shadow-color), 0 0 30px var(--um-glow-faint); }
}
@keyframes panelGlowIa {
  0%,100% { border-color: var(--ia-glow-soft); box-shadow: 0 8px 32px var(--shadow-color); }
  50%     { border-color: var(--ia-glow-bright); box-shadow: 0 8px 32px var(--shadow-color), 0 0 30px var(--ia-glow-faint); }
}
@keyframes panelGlowBen {
  0%,100% { border-color: var(--ben-glow-soft); box-shadow: 0 8px 32px var(--shadow-color); }
  50%     { border-color: var(--ben-glow-bright); box-shadow: 0 8px 32px var(--shadow-color), 0 0 30px var(--ben-glow-faint); }
}
@keyframes panelGlowPortal {
  0%,100% { border-color: var(--portal-glow-soft); box-shadow: 0 8px 32px var(--shadow-color); }
  50%     { border-color: var(--portal-glow-bright); box-shadow: 0 8px 32px var(--shadow-color), 0 0 30px var(--portal-glow-faint); }
}

/* ==========================================================================
   COEXISTENCIA CON EL ORB
   ========================================================================== */
body.cockpit-active #orbNav {
  z-index: 10011;
}

body.cockpit-active #orbNav::after {
  content: 'Cerrar Panel';
  position: absolute;
  bottom: -22px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 9px;
  font-weight: 600;
  color: var(--color-accent);
  white-space: nowrap;
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
  text-shadow: 0 2px 4px var(--shadow-color);
  letter-spacing: 0.05em;
}

body.cockpit-active #orbNav:hover::after {
  opacity: 1;
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1024px) {
  .cockpit-interface {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr auto;
  }

  .cockpit-panel-left { padding: 1rem; }
  .cockpit-nav-deck   { margin-top: 1rem; }
  .cockpit-console    { overflow-x: auto; }

  .console-deck {
    grid-template-columns: repeat(4, 220px);
    width: max-content;
  }

  #cockpit-mount.state-drilled-down .cockpit-interface {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto 1fr auto;
  }
  #cockpit-mount.state-drilled-down .cockpit-panel-left { display: none; } /* instant at breakpoint */
}

@media (max-width: 768px) {
  #cockpit-mount       { padding: 0.75rem; overflow-y: auto; }
  .cockpit-hud         { padding: 0.5rem 0.75rem; margin-bottom: 0.75rem; flex-wrap: wrap; gap: 6px; }
  .hud-label, .hud-divider { display: none; }
  .cockpit-hud__right  { gap: 4px; }
  .hud-nav-btn         { padding: 0.35rem 0.6rem !important; font-size: 0.65rem !important; }
  .hud-deck-indicator  { padding: 2px 6px; font-size: 0.6rem; }
  .hud-exit            { padding: 0.35rem 0.6rem !important; font-size: 0.65rem !important; }
  .cockpit-interface   { gap: 0.75rem; margin-bottom: 0.75rem; grid-template-columns: 1fr !important; }
  .cockpit-screen      { height: 220px; }
  .cockpit-stepper     { gap: 10px; }
  .stepper-header      { padding-bottom: 0.5rem; margin-bottom: 0.5rem; }
  .stepper-dots        { margin: 0.75rem 0; }
  .cockpit-panel-left  { order: 2; padding: 0.75rem; }
  .cockpit-panel-right { order: 3; padding: 0.75rem; }
  .cockpit-panel-center { order: 1; min-height: 300px; }
}

@media (max-width: 480px) {
  #cockpit-mount       { padding: 0.5rem; }
  .cockpit-hud         { padding: 0.35rem 0.5rem; margin-bottom: 0.5rem; }
  .cockpit-hud__left   { gap: 4px; }
  .hud-breadcrumb      { font-size: 0.65rem; }
  .hud-coords          { font-size: 0.6rem; padding: 2px 6px; }
  .cockpit-screen      { height: 180px; }
  .cockpit-panel-center { min-height: 240px; }
  .cockpit-panel-left,
  .cockpit-panel-right  { padding: 0.5rem; }
  .console-deck {
    grid-template-columns: repeat(4, 180px);
    gap: 6px;
  }
  .btn-console-card    { padding: 6px 10px; gap: 8px; }
  .btn-console-txt h4  { font-size: 0.65rem; }
  .btn-console-txt span { font-size: 0.52rem; }
}

@media print {
  #cockpit-mount { display: none !important; }
}
