/* ============================================================
   MasOrange SDWAN Multivendor Portal — Design System
   Identity: +O (MasOrange) — Investigated from masorange.es
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ── CSS Custom Properties ─────────────────────────────────── */
:root {
  /* MasOrange Brand */
  --mo-orange: #FF7900;
  --mo-orange-hover: #E66D00;
  --mo-orange-light: rgba(255, 121, 0, 0.12);
  --mo-black: #000000;
  --mo-navy: #0D1117;
  --mo-navy-light: #161B22;
  --mo-navy-lighter: #1C2333;
  --mo-white: #FFFFFF;
  --mo-gray-50: #F8F9FA;
  --mo-gray-100: #F2F2F2;
  --mo-gray-200: #E5E7EB;
  --mo-gray-300: #D1D5DB;
  --mo-gray-400: #9CA3AF;
  --mo-gray-500: #6B7280;
  --mo-gray-600: #4B5563;
  --mo-gray-700: #374151;
  --mo-border: #2D2D2D;
  --mo-border-light: #3A3F4B;

  /* Status */
  --status-ok: #22C55E;
  --status-ok-bg: rgba(34, 197, 94, 0.12);
  --status-warning: #F59E0B;
  --status-warning-bg: rgba(245, 158, 11, 0.12);
  --status-critical: #EF4444;
  --status-critical-bg: rgba(239, 68, 68, 0.12);
  --status-info: #3B82F6;
  --status-info-bg: rgba(59, 130, 246, 0.12);

  /* Vendor Colors */
  --vendor-fortinet: #EE3124;
  --vendor-meraki: #78BE20;
  --vendor-aruba: #FF8300;
  --vendor-teldat: #0072CE;
  --vendor-mist: #00A86B;
  --vendor-huawei: #CF0A2C;

  /* Layout */
  --sidebar-width: 260px;
  --sidebar-collapsed: 68px;
  --header-height: 60px;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-xl: 20px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.4);
  --shadow-lg: 0 8px 24px rgba(0,0,0,0.5);

  /* Transitions */
  --transition-fast: 150ms ease;
  --transition-base: 250ms ease;
  --transition-slow: 400ms ease;
}

/* ── Reset & Base ──────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 14px; scroll-behavior: smooth; }
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  background: var(--mo-navy);
  color: var(--mo-gray-200);
  line-height: 1.5;
  overflow: hidden;
  height: 100vh;
}
a { color: var(--mo-orange); text-decoration: none; transition: color var(--transition-fast); }
a:hover { color: var(--mo-orange-hover); }
button { font-family: inherit; cursor: pointer; border: none; outline: none; }
input, select { font-family: inherit; outline: none; }
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--mo-gray-600); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--mo-gray-500); }

/* ── App Layout ────────────────────────────────────────────── */
.app-container {
  display: flex;
  height: 100vh;
  overflow: hidden;
}

/* ── Sidebar ───────────────────────────────────────────────── */
.sidebar {
  width: var(--sidebar-width);
  min-width: var(--sidebar-width);
  height: 100vh;
  background: var(--mo-black);
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--mo-border);
  transition: width var(--transition-base), min-width var(--transition-base);
  z-index: 100;
}
.sidebar-logo {
  height: var(--header-height);
  display: flex;
  align-items: center;
  padding: 0 20px;
  gap: 12px;
  border-bottom: 1px solid var(--mo-border);
}
.sidebar-logo .logo-symbol {
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -1px;
  display: flex;
  align-items: center;
  gap: 2px;
}
.sidebar-logo .logo-plus { color: var(--mo-orange); }
.sidebar-logo .logo-o { color: var(--mo-white); }
.sidebar-logo .logo-text {
  font-size: 11px;
  font-weight: 500;
  color: var(--mo-gray-400);
  letter-spacing: 1.5px;
  text-transform: uppercase;
}
.sidebar-nav {
  flex: 1;
  padding: 16px 0;
  overflow-y: auto;
}
.nav-section-title {
  padding: 8px 24px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--mo-gray-500);
  margin-top: 12px;
}
.nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 24px;
  color: var(--mo-gray-400);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
  position: relative;
  border: none;
  background: none;
  width: 100%;
  text-align: left;
}
.nav-item:hover {
  color: var(--mo-white);
  background: var(--mo-navy-light);
}
.nav-item.active {
  color: var(--mo-orange);
  background: var(--mo-orange-light);
}
.nav-item.active::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--mo-orange);
  border-radius: 0 3px 3px 0;
}
.nav-item i {
  width: 20px;
  text-align: center;
  font-size: 15px;
}
.nav-badge {
  margin-left: auto;
  background: var(--status-critical);
  color: var(--mo-white);
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 10px;
  min-width: 18px;
  text-align: center;
}
.sidebar-footer {
  padding: 16px 20px;
  border-top: 1px solid var(--mo-border);
}
.sidebar-footer .powered-by {
  font-size: 10px;
  color: var(--mo-gray-500);
  text-align: center;
}
.sidebar-footer .kiw-logo {
  font-size: 11px;
  color: var(--mo-gray-400);
  font-weight: 700;
  letter-spacing: 2px;
}

/* ── Main Content ──────────────────────────────────────────── */
.main-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* ── Header ────────────────────────────────────────────────── */
.header {
  height: var(--header-height);
  background: var(--mo-navy-light);
  border-bottom: 1px solid var(--mo-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 24px;
  gap: 16px;
}
.header-left {
  display: flex;
  align-items: center;
  gap: 16px;
}
.header-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--mo-white);
}
.header-breadcrumb {
  font-size: 12px;
  color: var(--mo-gray-500);
}
.header-right {
  display: flex;
  align-items: center;
  gap: 12px;
}
.header-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 500;
  color: var(--mo-gray-300);
  background: var(--mo-navy);
  border: 1px solid var(--mo-border);
  transition: all var(--transition-fast);
}
.header-btn:hover {
  border-color: var(--mo-orange);
  color: var(--mo-orange);
}
.header-btn.active {
  border-color: var(--mo-orange);
  color: var(--mo-orange);
  background: var(--mo-orange-light);
}
.header-tenant-select {
  background: var(--mo-navy);
  border: 1px solid var(--mo-border);
  color: var(--mo-gray-200);
  padding: 7px 12px;
  border-radius: var(--radius-sm);
  font-size: 12px;
}
.lang-select {
  background: var(--mo-navy);
  border: 1px solid var(--mo-border);
  color: var(--mo-gray-300);
  padding: 6px 8px;
  border-radius: var(--radius-sm);
  font-size: 12px;
}
.user-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--mo-orange);
  color: var(--mo-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  transition: box-shadow var(--transition-fast);
}
.user-avatar:hover {
  box-shadow: 0 0 0 2px var(--mo-orange);
}

/* ── Page Content ──────────────────────────────────────────── */
.page-content {
  flex: 1;
  overflow-y: auto;
  padding: 24px;
}
.page-section {
  display: none;
  animation: fadeIn 0.3s ease;
}
.page-section.active { display: block; }
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Cards ─────────────────────────────────────────────────── */
.card {
  background: var(--mo-navy-light);
  border: 1px solid var(--mo-border);
  border-radius: var(--radius-md);
  padding: 20px;
  transition: border-color var(--transition-fast);
}
.card:hover {
  border-color: var(--mo-border-light);
}
.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.card-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--mo-gray-300);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.card-action {
  font-size: 12px;
  color: var(--mo-orange);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 4px;
  background: none;
  border: none;
}
.card-action:hover { color: var(--mo-orange-hover); }

/* ── KPI Cards ─────────────────────────────────────────────── */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}
.kpi-card {
  background: var(--mo-navy-light);
  border: 1px solid var(--mo-border);
  border-radius: var(--radius-md);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: all var(--transition-fast);
  position: relative;
  overflow: hidden;
}
.kpi-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
}
.kpi-card.orange::before { background: var(--mo-orange); }
.kpi-card.green::before { background: var(--status-ok); }
.kpi-card.red::before { background: var(--status-critical); }
.kpi-card.blue::before { background: var(--status-info); }
.kpi-card:hover { border-color: var(--mo-border-light); transform: translateY(-2px); }
.kpi-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--mo-gray-400);
}
.kpi-value {
  font-size: 32px;
  font-weight: 800;
  color: var(--mo-white);
  line-height: 1;
}
.kpi-sub {
  font-size: 12px;
  color: var(--mo-gray-500);
  display: flex;
  align-items: center;
  gap: 4px;
}
.kpi-sub .up { color: var(--status-ok); }
.kpi-sub .down { color: var(--status-critical); }

/* ── Charts Grid ───────────────────────────────────────────── */
.charts-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 16px;
  margin-bottom: 24px;
}
.chart-container {
  position: relative;
  height: 280px;
}

/* ── Tables ────────────────────────────────────────────────── */
.table-container {
  overflow-x: auto;
}
table {
  width: 100%;
  border-collapse: collapse;
}
table th {
  text-align: left;
  padding: 12px 16px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--mo-gray-400);
  border-bottom: 1px solid var(--mo-border);
  background: var(--mo-navy);
  position: sticky;
  top: 0;
}
table td {
  padding: 12px 16px;
  font-size: 13px;
  border-bottom: 1px solid var(--mo-border);
  vertical-align: middle;
}
table tr:hover td {
  background: var(--mo-navy-lighter);
}

/* ── Badges ────────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
}
.badge-online, .badge-up, .badge-active { background: var(--status-ok-bg); color: var(--status-ok); }
.badge-warning, .badge-degraded { background: var(--status-warning-bg); color: var(--status-warning); }
.badge-critical, .badge-down, .badge-offline { background: var(--status-critical-bg); color: var(--status-critical); }
.badge-info { background: var(--status-info-bg); color: var(--status-info); }
.badge-vendor {
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  color: var(--mo-white);
}

/* ── Vendor Tabs ───────────────────────────────────────────── */
.vendor-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.vendor-tab {
  padding: 8px 16px;
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 600;
  background: var(--mo-navy);
  border: 1px solid var(--mo-border);
  color: var(--mo-gray-400);
  cursor: pointer;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  gap: 6px;
}
.vendor-tab:hover {
  border-color: var(--mo-gray-500);
  color: var(--mo-gray-200);
}
.vendor-tab.active {
  border-color: var(--mo-orange);
  color: var(--mo-orange);
  background: var(--mo-orange-light);
}
.vendor-tab .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}

/* ── Section Headers ───────────────────────────────────────── */
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}
.section-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--mo-white);
  position: relative;
  padding-bottom: 8px;
}
.section-title::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 40px;
  height: 3px;
  background: var(--mo-orange);
  border-radius: 2px;
}

/* ── Alarm Items ───────────────────────────────────────────── */
.alarm-list { display: flex; flex-direction: column; gap: 8px; }
.alarm-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  background: var(--mo-navy);
  border: 1px solid var(--mo-border);
  border-radius: var(--radius-sm);
  transition: border-color var(--transition-fast);
  cursor: pointer;
}
.alarm-item:hover { border-color: var(--mo-border-light); }
.alarm-item.critical { border-left: 3px solid var(--status-critical); }
.alarm-item.high { border-left: 3px solid var(--mo-orange); }
.alarm-item.medium { border-left: 3px solid var(--status-warning); }
.alarm-item.low { border-left: 3px solid var(--status-info); }
.alarm-item.info { border-left: 3px solid var(--mo-gray-500); }
.alarm-severity-icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 14px;
}
.alarm-severity-icon.critical { background: var(--status-critical-bg); color: var(--status-critical); }
.alarm-severity-icon.high { background: var(--mo-orange-light); color: var(--mo-orange); }
.alarm-severity-icon.medium { background: var(--status-warning-bg); color: var(--status-warning); }
.alarm-severity-icon.low { background: var(--status-info-bg); color: var(--status-info); }
.alarm-severity-icon.info { background: rgba(107,114,128,0.15); color: var(--mo-gray-400); }
.alarm-body { flex: 1; min-width: 0; }
.alarm-title { font-size: 13px; font-weight: 600; color: var(--mo-gray-200); margin-bottom: 4px; }
.alarm-meta { font-size: 11px; color: var(--mo-gray-500); display: flex; gap: 12px; flex-wrap: wrap; }

/* ── Workflow Cards ────────────────────────────────────────── */
.workflow-list { display: flex; flex-direction: column; gap: 10px; }
.workflow-item {
  padding: 16px;
  background: var(--mo-navy);
  border: 1px solid var(--mo-border);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  gap: 16px;
  transition: border-color var(--transition-fast);
}
.workflow-item:hover { border-color: var(--mo-border-light); }
.workflow-status-icon {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 15px;
}
.workflow-status-icon.pending { background: var(--status-warning-bg); color: var(--status-warning); }
.workflow-status-icon.approved { background: var(--status-ok-bg); color: var(--status-ok); }
.workflow-status-icon.executed { background: var(--status-info-bg); color: var(--status-info); }
.workflow-status-icon.rejected { background: var(--status-critical-bg); color: var(--status-critical); }
.workflow-body { flex: 1; }
.workflow-title { font-size: 14px; font-weight: 600; color: var(--mo-gray-200); margin-bottom: 4px; }
.workflow-meta { font-size: 11px; color: var(--mo-gray-500); display: flex; gap: 12px; flex-wrap: wrap; }
.workflow-type-badge {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 4px;
  letter-spacing: 0.5px;
}
.workflow-type-badge.basic { background: var(--status-info-bg); color: var(--status-info); }
.workflow-type-badge.advanced { background: var(--mo-orange-light); color: var(--mo-orange); }

/* ── API Panel ─────────────────────────────────────────────── */
.api-panel {
  background: var(--mo-navy);
  border: 1px solid var(--mo-border);
  border-radius: var(--radius-md);
  padding: 20px;
  margin-top: 20px;
}
.api-tabs {
  display: flex;
  gap: 6px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.api-tab {
  padding: 6px 14px;
  border-radius: var(--radius-sm);
  font-size: 11px;
  font-weight: 600;
  background: transparent;
  border: 1px solid var(--mo-border);
  color: var(--mo-gray-500);
  cursor: pointer;
  transition: all var(--transition-fast);
}
.api-tab.active, .api-tab:hover {
  border-color: var(--mo-orange);
  color: var(--mo-orange);
  background: var(--mo-orange-light);
}
.api-code {
  background: var(--mo-black);
  border-radius: var(--radius-sm);
  padding: 16px;
  font-family: 'JetBrains Mono', 'Fira Code', monospace;
  font-size: 12px;
  line-height: 1.6;
  color: var(--mo-gray-300);
  overflow-x: auto;
  white-space: pre;
  border: 1px solid var(--mo-border);
}
.api-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.api-label .abstract { color: var(--mo-orange); }
.api-label .vendor { color: var(--status-ok); }
.api-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
  color: var(--mo-orange);
  font-size: 20px;
}

/* ── IA Assistant Panel ────────────────────────────────────── */
.ai-panel {
  position: fixed;
  right: -420px;
  top: 0;
  bottom: 0;
  width: 420px;
  background: var(--mo-navy-light);
  border-left: 1px solid var(--mo-border);
  z-index: 200;
  display: flex;
  flex-direction: column;
  transition: right var(--transition-slow);
  box-shadow: -8px 0 30px rgba(0,0,0,0.5);
}
.ai-panel.open { right: 0; }
.ai-header {
  height: var(--header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  border-bottom: 1px solid var(--mo-border);
}
.ai-header-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 600;
  color: var(--mo-white);
}
.ai-header-title i { color: var(--mo-orange); }
.ai-close {
  background: none;
  border: none;
  color: var(--mo-gray-400);
  font-size: 18px;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: var(--radius-sm);
}
.ai-close:hover { color: var(--mo-white); background: var(--mo-navy); }
.ai-messages {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.ai-message {
  max-width: 90%;
  padding: 12px 16px;
  border-radius: var(--radius-md);
  font-size: 13px;
  line-height: 1.6;
  animation: slideUp 0.3s ease;
}
@keyframes slideUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.ai-message.assistant {
  background: var(--mo-navy);
  border: 1px solid var(--mo-border);
  color: var(--mo-gray-200);
  align-self: flex-start;
}
.ai-message.user {
  background: var(--mo-orange);
  color: var(--mo-white);
  align-self: flex-end;
  border-radius: var(--radius-md) var(--radius-md) 4px var(--radius-md);
}
.ai-input-area {
  padding: 16px 20px;
  border-top: 1px solid var(--mo-border);
  display: flex;
  gap: 8px;
}
.ai-input {
  flex: 1;
  background: var(--mo-navy);
  border: 1px solid var(--mo-border);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  color: var(--mo-gray-200);
  font-size: 13px;
}
.ai-input:focus { border-color: var(--mo-orange); }
.ai-send {
  background: var(--mo-orange);
  color: var(--mo-white);
  border-radius: var(--radius-sm);
  padding: 10px 16px;
  font-weight: 600;
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: background var(--transition-fast);
}
.ai-send:hover { background: var(--mo-orange-hover); }

/* ── Policy Cards ──────────────────────────────────────────── */
.policy-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 16px;
}
.policy-card {
  background: var(--mo-navy);
  border: 1px solid var(--mo-border);
  border-radius: var(--radius-sm);
  padding: 16px;
  transition: border-color var(--transition-fast);
}
.policy-card:hover { border-color: var(--mo-border-light); }
.policy-name { font-size: 14px; font-weight: 600; color: var(--mo-white); margin-bottom: 6px; }
.policy-desc { font-size: 12px; color: var(--mo-gray-500); margin-bottom: 10px; }
.policy-meta { display: flex; gap: 8px; flex-wrap: wrap; }
.policy-tag {
  font-size: 10px;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 4px;
  background: var(--mo-navy-lighter);
  color: var(--mo-gray-300);
  border: 1px solid var(--mo-border);
}

/* ── Topology ──────────────────────────────────────────────── */
.topology-container {
  background: var(--mo-navy);
  border: 1px solid var(--mo-border);
  border-radius: var(--radius-md);
  padding: 20px;
  min-height: 500px;
  position: relative;
}
.map-placeholder {
  width: 100%;
  height: 480px;
  position: relative;
  background: var(--mo-navy-light);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.map-spain-svg { width: 100%; height: 100%; }
.site-pin {
  position: absolute;
  transform: translate(-50%, -50%);
  cursor: pointer;
  z-index: 10;
  transition: transform var(--transition-fast);
}
.site-pin:hover { transform: translate(-50%, -50%) scale(1.3); }
.site-pin .pin-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid var(--mo-white);
  box-shadow: 0 0 8px rgba(0,0,0,0.4);
}
.site-pin .pin-dot.online { background: var(--status-ok); }
.site-pin .pin-dot.warning { background: var(--status-warning); }
.site-pin .pin-dot.critical { background: var(--status-critical); }
.site-pin .pin-dot.hub { width: 18px; height: 18px; box-shadow: 0 0 12px rgba(255,121,0,0.5); border-color: var(--mo-orange); }
.site-pin .pin-label {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  margin-top: 4px;
  font-size: 10px;
  font-weight: 600;
  color: var(--mo-gray-300);
  white-space: nowrap;
  text-shadow: 0 1px 3px rgba(0,0,0,0.8);
}
.site-popup {
  position: absolute;
  background: var(--mo-navy-light);
  border: 1px solid var(--mo-border);
  border-radius: var(--radius-md);
  padding: 16px;
  width: 260px;
  z-index: 20;
  box-shadow: var(--shadow-lg);
  display: none;
}
.site-popup.show { display: block; }

/* ── Autogestión ───────────────────────────────────────────── */
.self-service-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}
.self-service-card {
  background: var(--mo-navy);
  border: 1px solid var(--mo-border);
  border-radius: var(--radius-md);
  padding: 20px;
  cursor: pointer;
  transition: all var(--transition-fast);
}
.self-service-card:hover {
  border-color: var(--mo-orange);
  transform: translateY(-2px);
}
.self-service-card .ss-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm);
  background: var(--mo-orange-light);
  color: var(--mo-orange);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  margin-bottom: 12px;
}
.self-service-card .ss-title { font-size: 14px; font-weight: 600; color: var(--mo-white); margin-bottom: 4px; }
.self-service-card .ss-desc { font-size: 12px; color: var(--mo-gray-500); }

/* ── Buttons ───────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 600;
  transition: all var(--transition-fast);
  border: none;
}
.btn-primary { background: var(--mo-orange); color: var(--mo-white); }
.btn-primary:hover { background: var(--mo-orange-hover); }
.btn-secondary { background: var(--mo-navy); color: var(--mo-gray-300); border: 1px solid var(--mo-border); }
.btn-secondary:hover { border-color: var(--mo-orange); color: var(--mo-orange); }

/* ── Filters Bar ───────────────────────────────────────────── */
.filters-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.filter-chip {
  padding: 6px 14px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  background: var(--mo-navy);
  border: 1px solid var(--mo-border);
  color: var(--mo-gray-400);
  cursor: pointer;
  transition: all var(--transition-fast);
}
.filter-chip:hover, .filter-chip.active {
  border-color: var(--mo-orange);
  color: var(--mo-orange);
  background: var(--mo-orange-light);
}

/* ── Multi-column layouts ──────────────────────────────────── */
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.three-col { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }

/* ── Login Page ────────────────────────────────────────────── */
.login-page {
  display: none;
  height: 100vh;
  background: var(--mo-navy);
  align-items: center;
  justify-content: center;
  position: fixed;
  inset: 0;
  z-index: 500;
}
.login-page.active { display: flex; }
.login-card {
  background: var(--mo-navy-light);
  border: 1px solid var(--mo-border);
  border-radius: var(--radius-lg);
  padding: 48px 40px;
  width: 420px;
  max-width: 90vw;
  text-align: center;
}
.login-logo {
  font-size: 48px;
  font-weight: 800;
  margin-bottom: 8px;
}
.login-subtitle {
  font-size: 12px;
  color: var(--mo-gray-500);
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: 36px;
}
.login-field {
  width: 100%;
  margin-bottom: 14px;
}
.login-field input, .login-field select {
  width: 100%;
  padding: 12px 16px;
  background: var(--mo-navy);
  border: 1px solid var(--mo-border);
  border-radius: var(--radius-sm);
  color: var(--mo-gray-200);
  font-size: 14px;
  transition: border-color var(--transition-fast);
}
.login-field input:focus, .login-field select:focus {
  border-color: var(--mo-orange);
}
.login-field input::placeholder { color: var(--mo-gray-600); }
.login-btn {
  width: 100%;
  padding: 14px;
  margin-top: 8px;
  background: var(--mo-orange);
  color: var(--mo-white);
  border: none;
  border-radius: var(--radius-sm);
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: background var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.login-btn:hover { background: var(--mo-orange-hover); }
.login-sso {
  margin-top: 20px;
  font-size: 12px;
  color: var(--mo-gray-500);
}
.login-sso a { font-weight: 600; }
.login-mfa {
  margin-top: 12px;
  font-size: 11px;
  color: var(--mo-gray-600);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

/* ── Pulse animation ───────────────────────────────────────── */
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(239,68,68,0.5); }
  70% { box-shadow: 0 0 0 8px rgba(239,68,68,0); }
  100% { box-shadow: 0 0 0 0 rgba(239,68,68,0); }
}
.pulse-red { animation: pulse 2s infinite; }

@keyframes pulseOrange {
  0% { box-shadow: 0 0 0 0 rgba(255,121,0,0.4); }
  70% { box-shadow: 0 0 0 10px rgba(255,121,0,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,121,0,0); }
}

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .charts-grid { grid-template-columns: 1fr; }
  .two-col, .three-col { grid-template-columns: 1fr; }
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .sidebar { position: fixed; left: -260px; z-index: 300; }
  .sidebar.open { left: 0; }
  .kpi-grid { grid-template-columns: 1fr; }
  .ai-panel { width: 100%; right: -100%; }
}
