/* ════════════════════════════════════════════════════════
   LDCONTAB — Sistema ERP Fiscal / Contable Mexico
   Inspirado en CONTPAQi · NomiPaq · SAP · Odoo Enterprise
   ════════════════════════════════════════════════════════ */
:root{
  --cmd-primary:#1d4ed8;
  --cmd-primary-600:#1e40af;
  --cmd-primary-50:#eff6ff;
  --cmd-bg:#f0f4f8;
  --cmd-surface:#ffffff;
  --cmd-border:#e2e8f0;
  --cmd-border-strong:#cbd5e1;
  --cmd-text:#0f172a;
  --cmd-text-muted:#64748b;
  --cmd-text-subtle:#94a3b8;
  --cmd-success:#059669;
  --cmd-success-bg:#d1fae5;
  --cmd-warning:#d97706;
  --cmd-warning-bg:#fef3c7;
  --cmd-danger:#dc2626;
  --cmd-danger-bg:#fee2e2;
  --cmd-info:#0284c7;
  --cmd-info-bg:#e0f2fe;
  --cmd-nav-bg:#0f172a;
  --cmd-nav-text:#94a3b8;
  --cmd-nav-active:#3b82f6;
  --cmd-nav-hover:#1e293b;
  --cmd-nav-border:#1e293b;
  --cmd-sub-bg:#ffffff;
  --cmd-radius:8px;
  --cmd-radius-sm:5px;
  --cmd-shadow:0 1px 3px rgba(15,23,42,.08);
  --cmd-shadow-md:0 4px 12px rgba(15,23,42,.10);
  --cmd-shadow-lg:0 12px 32px rgba(15,23,42,.14);
  --cmd-font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--cmd-font);font-size:13px;background:var(--cmd-bg);
  color:var(--cmd-text);-webkit-font-smoothing:antialiased;line-height:1.5;}
a{color:var(--cmd-primary);text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:inherit}

/* ── LAYOUT ── */
.cmd-app{display:flex;flex-direction:column;min-height:100vh}
.cmd-main{flex:1;display:flex;flex-direction:column;min-width:0;margin-top:0}
.cmd-content{padding:20px 24px;flex:1;max-width:1440px;width:100%;margin:0 auto}

/* ════════════════════════════════════════════════════════
   TOP NAVIGATION — CONTPAQi Style
   ════════════════════════════════════════════════════════ */
.cmd-topnav{
  background:var(--cmd-nav-bg);
  height:48px;
  display:flex;
  align-items:center;
  position:sticky;top:0;z-index:1000;
  box-shadow:0 2px 8px rgba(0,0,0,.3);
  user-select:none;
}
.cmd-topnav-brand{
  display:flex;align-items:center;gap:8px;
  padding:0 20px;
  border-right:1px solid var(--cmd-nav-border);
  height:100%;min-width:160px;
  text-decoration:none;
}
.cmd-topnav-logo{
  width:30px;height:30px;border-radius:6px;
  background:linear-gradient(135deg,#3b82f6,#6366f1);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:13px;color:#fff;letter-spacing:-.5px;
  flex-shrink:0;
}
.cmd-topnav-name{font-weight:700;font-size:15px;color:#fff;letter-spacing:-.2px}
.cmd-topnav-tag{font-size:9px;color:#64748b;font-weight:500}

.cmd-topnav-menu{display:flex;align-items:center;height:100%;flex:1}

/* Empresa + sucursal selectors */
.cmd-topnav-ctx{
  display:flex;align-items:center;gap:0;
  border-right:1px solid var(--cmd-nav-border);
  height:100%;
}
.cmd-ctx-btn{
  display:flex;align-items:center;gap:6px;padding:0 14px;height:100%;
  color:#94a3b8;font-size:12px;font-weight:500;cursor:pointer;
  border:none;background:none;font-family:inherit;
  transition:background .15s,color .15s;
  border-right:1px solid var(--cmd-nav-border);
}
.cmd-ctx-btn:hover{background:var(--cmd-nav-hover);color:#fff}
.cmd-ctx-btn .ctx-label{font-size:9px;color:#64748b;display:block;line-height:1}
.cmd-ctx-btn .ctx-val{color:#e2e8f0;font-size:12px;display:block;line-height:1.3}
.cmd-ctx-btn svg{width:10px;height:10px;fill:#64748b;flex-shrink:0}

/* Menú principal */
.cmd-nav-items{display:flex;align-items:center;height:100%;flex:1}
.cmd-nav-item{
  position:relative;height:100%;display:flex;align-items:center;
}
.cmd-nav-link{
  display:flex;align-items:center;gap:5px;padding:0 14px;height:100%;
  color:var(--cmd-nav-text);font-size:12px;font-weight:500;
  cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;
  border:none;background:none;font-family:inherit;
}
.cmd-nav-link:hover,.cmd-nav-link.active{
  background:var(--cmd-nav-hover);color:#fff;
}
.cmd-nav-link.active{border-bottom:2px solid var(--cmd-nav-active);}
.cmd-nav-link svg{width:12px;height:12px;fill:currentColor;opacity:.6;flex-shrink:0}

/* Dropdown */
.cmd-nav-dropdown{
  position:absolute;top:100%;left:0;min-width:220px;
  background:var(--cmd-sub-bg);
  border:1px solid var(--cmd-border);
  border-radius:0 0 8px 8px;
  box-shadow:var(--cmd-shadow-lg);
  display:none;z-index:2000;
}
.cmd-nav-item:hover .cmd-nav-dropdown{display:block}
.cmd-nav-dropdown-section{
  padding:6px 0 4px;
  border-bottom:1px solid var(--cmd-border);
}
.cmd-nav-dropdown-section:last-child{border-bottom:none}
.cmd-nav-dropdown-title{
  font-size:10px;font-weight:700;color:var(--cmd-text-subtle);
  text-transform:uppercase;letter-spacing:.06em;padding:4px 14px 2px;
}
.cmd-nav-dropdown-item{
  display:flex;align-items:center;gap:10px;padding:7px 14px;
  color:var(--cmd-text);font-size:12px;font-weight:400;
  cursor:pointer;transition:background .12s;text-decoration:none;
}
.cmd-nav-dropdown-item:hover{background:#f1f5f9;color:var(--cmd-primary)}
.cmd-nav-dropdown-item .ddi-icon{
  width:22px;height:22px;border-radius:5px;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;flex-shrink:0;
  background:#f1f5f9;
}
.cmd-nav-dropdown-item:hover .ddi-icon{background:var(--cmd-primary-50)}
.cmd-nav-dropdown-item .ddi-text{}
.cmd-nav-dropdown-item .ddi-badge{
  margin-left:auto;font-size:10px;font-weight:700;
  padding:1px 6px;border-radius:10px;
  background:var(--cmd-danger-bg);color:var(--cmd-danger);
}

/* Right side */
.cmd-topnav-right{
  display:flex;align-items:center;gap:0;
  height:100%;margin-left:auto;
  border-left:1px solid var(--cmd-nav-border);
}
.cmd-topnav-icon-btn{
  width:44px;height:100%;display:flex;align-items:center;justify-content:center;
  color:#94a3b8;cursor:pointer;position:relative;
  border:none;background:none;font-family:inherit;
  border-left:1px solid var(--cmd-nav-border);
  transition:background .15s;
}
.cmd-topnav-icon-btn:hover{background:var(--cmd-nav-hover);color:#fff}
.cmd-topnav-icon-btn svg{width:16px;height:16px;fill:currentColor}
.cmd-topnav-badge{
  position:absolute;top:6px;right:6px;
  min-width:16px;height:16px;border-radius:8px;
  background:var(--cmd-danger);color:#fff;
  font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;
  padding:0 3px;
}
.cmd-topnav-user{
  display:flex;align-items:center;gap:8px;padding:0 14px;height:100%;
  cursor:pointer;transition:background .15s;
  border-left:1px solid var(--cmd-nav-border);
}
.cmd-topnav-user:hover{background:var(--cmd-nav-hover)}
.cmd-topnav-avatar{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,#6366f1,#8b5cf6);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:11px;color:#fff;
}
.cmd-topnav-user-info{line-height:1.2}
.cmd-topnav-user-name{font-size:12px;color:#e2e8f0;font-weight:600}
.cmd-topnav-user-role{font-size:10px;color:#64748b}

/* AI Button */
.cmd-ai-btn{
  display:flex;align-items:center;gap:6px;padding:0 14px;height:100%;
  background:linear-gradient(135deg,#1d4ed8,#6366f1);
  color:#fff;font-size:12px;font-weight:600;cursor:pointer;
  border:none;font-family:inherit;border-left:1px solid var(--cmd-nav-border);
  transition:opacity .15s;letter-spacing:.02em;
}
.cmd-ai-btn:hover{opacity:.9}
.cmd-ai-btn-dot{
  width:6px;height:6px;border-radius:50%;background:#34d399;
  animation:pulse-ai 2s infinite;
}
@keyframes pulse-ai{0%,100%{opacity:1}50%{opacity:.4}}

/* ── BREADCRUMB ── */
.cmd-breadcrumb{
  display:flex;align-items:center;gap:6px;
  background:#fff;border-bottom:1px solid var(--cmd-border);
  padding:0 24px;height:38px;font-size:12px;color:var(--cmd-text-muted);
}
.cmd-breadcrumb-item{color:var(--cmd-text-muted)}
.cmd-breadcrumb-item.active{color:var(--cmd-text);font-weight:600}
.cmd-breadcrumb-sep{color:var(--cmd-border-strong)}

/* ── ALERT BAR ── */
.cmd-alertbar{
  display:flex;align-items:center;gap:12px;
  padding:0 24px;height:34px;
  font-size:11px;overflow:hidden;
  transition:height .3s;
}
.cmd-alertbar.danger{background:#fee2e2;color:#991b1b;border-bottom:1px solid #fecaca}
.cmd-alertbar.warning{background:#fef3c7;color:#92400e;border-bottom:1px solid #fde68a}
.cmd-alertbar.info{background:#dbeafe;color:#1e40af;border-bottom:1px solid #bfdbfe}
.cmd-alertbar-items{display:flex;gap:16px;flex:1;overflow:hidden}
.cmd-alertbar-item{display:flex;align-items:center;gap:6px;white-space:nowrap;cursor:pointer}
.cmd-alertbar-item:hover{text-decoration:underline}
.cmd-alertbar-close{margin-left:auto;cursor:pointer;opacity:.6}

/* ════════════════════════════════════════════════════════
   PAGE HEADER
   ════════════════════════════════════════════════════════ */
.cmd-page-head{
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:16px;margin-bottom:20px;padding-bottom:16px;
  border-bottom:1px solid var(--cmd-border);
}
.cmd-page-title{font-size:20px;font-weight:700;color:var(--cmd-text);letter-spacing:-.3px}
.cmd-page-sub{font-size:12px;color:var(--cmd-text-muted);margin-top:3px}
.cmd-page-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* ════════════════════════════════════════════════════════
   CARDS / KPI
   ════════════════════════════════════════════════════════ */
.cmd-card{
  background:var(--cmd-surface);border:1px solid var(--cmd-border);
  border-radius:var(--cmd-radius);padding:16px;
  box-shadow:var(--cmd-shadow);
}
.cmd-kpi-label{font-size:11px;font-weight:600;color:var(--cmd-text-muted);
  text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.cmd-kpi-value{font-size:24px;font-weight:700;color:var(--cmd-text);letter-spacing:-.5px;line-height:1}
.cmd-kpi-delta{font-size:11px;font-weight:600;margin-top:6px;display:flex;align-items:center;gap:4px}
.cmd-kpi-delta.up{color:var(--cmd-success)}
.cmd-kpi-delta.down{color:var(--cmd-danger)}
.cmd-kpi-delta .vs{font-weight:400;color:var(--cmd-text-muted)}
.cmd-kpi-trend{height:3px;border-radius:2px;margin-top:8px;background:var(--cmd-border)}
.cmd-kpi-trend-fill{height:100%;border-radius:2px;transition:width .4s}

/* ════════════════════════════════════════════════════════
   SECCIÓN / TABLA
   ════════════════════════════════════════════════════════ */
.cmd-section{
  background:var(--cmd-surface);border:1px solid var(--cmd-border);
  border-radius:var(--cmd-radius);box-shadow:var(--cmd-shadow);
  overflow:hidden;margin-bottom:16px;
}
.cmd-section-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;border-bottom:1px solid var(--cmd-border);
  background:#fcfcfd;
}
.cmd-section-title{font-size:13px;font-weight:600;color:var(--cmd-text)}
.cmd-section-body{padding:16px}
.cmd-mt-16{margin-top:16px}

.cmd-table{width:100%;border-collapse:collapse;font-size:12px}
.cmd-table th{
  background:#f8fafc;border-bottom:2px solid var(--cmd-border);
  padding:8px 12px;text-align:left;font-size:11px;font-weight:700;
  color:var(--cmd-text-muted);text-transform:uppercase;letter-spacing:.04em;
  white-space:nowrap;cursor:pointer;
}
.cmd-table th:hover{background:#f1f5f9;color:var(--cmd-text)}
.cmd-table td{
  padding:9px 12px;border-bottom:1px solid var(--cmd-border);
  vertical-align:middle;
}
.cmd-table tbody tr:hover{background:#f8fafc}
.cmd-table tbody tr:last-child td{border-bottom:none}
.cmd-table .num{text-align:right;font-variant-numeric:tabular-nums;font-weight:500}
.cmd-table a.cmd-link{font-weight:600;color:var(--cmd-primary)}
.cmd-table a.cmd-link:hover{text-decoration:underline}

/* Tabs */
.cmd-tabs{display:flex;border-bottom:2px solid var(--cmd-border);padding:0 16px;background:#fcfcfd}
.cmd-tab{
  padding:10px 16px;font-size:12px;font-weight:600;color:var(--cmd-text-muted);
  cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;
  transition:color .15s,border-color .15s;white-space:nowrap;
}
.cmd-tab.active,.cmd-tab:hover{color:var(--cmd-primary)}
.cmd-tab.active{border-bottom-color:var(--cmd-primary)}

/* ════════════════════════════════════════════════════════
   FORMULARIOS
   ════════════════════════════════════════════════════════ */
.cmd-field{margin-bottom:14px}
.cmd-label{display:block;font-size:11px;font-weight:600;color:var(--cmd-text-muted);
  text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px}
.cmd-input{
  width:100%;padding:7px 10px;border:1.5px solid var(--cmd-border);
  border-radius:var(--cmd-radius-sm);font-size:13px;color:var(--cmd-text);
  background:var(--cmd-surface);transition:border-color .15s,box-shadow .15s;
  outline:none;
}
.cmd-input:focus{border-color:var(--cmd-primary);box-shadow:0 0 0 3px rgba(29,78,216,.12)}
.cmd-input::placeholder{color:var(--cmd-text-subtle)}
.cmd-input[readonly]{background:#f8fafc;color:var(--cmd-text-muted)}
.cmd-select-input{
  width:100%;padding:7px 10px;border:1.5px solid var(--cmd-border);
  border-radius:var(--cmd-radius-sm);font-size:13px;color:var(--cmd-text);
  background:var(--cmd-surface);outline:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;padding-right:30px;
  cursor:pointer;
}
.cmd-select-input:focus{border-color:var(--cmd-primary);box-shadow:0 0 0 3px rgba(29,78,216,.12);outline:none}

/* ════════════════════════════════════════════════════════
   BOTONES
   ════════════════════════════════════════════════════════ */
.cmd-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:7px 14px;border-radius:var(--cmd-radius-sm);font-size:12px;font-weight:600;
  transition:all .15s;cursor:pointer;white-space:nowrap;border:1.5px solid transparent;
  font-family:inherit;
}
.cmd-btn-primary{background:var(--cmd-primary);color:#fff;border-color:var(--cmd-primary)}
.cmd-btn-primary:hover{background:var(--cmd-primary-600);border-color:var(--cmd-primary-600)}
.cmd-btn-secondary{background:#fff;color:var(--cmd-text);border-color:var(--cmd-border)}
.cmd-btn-secondary:hover{background:#f8fafc;border-color:var(--cmd-border-strong)}
.cmd-btn-success{background:var(--cmd-success);color:#fff;border-color:var(--cmd-success)}
.cmd-btn-success:hover{filter:brightness(.9)}
.cmd-btn-danger{background:var(--cmd-danger);color:#fff;border-color:var(--cmd-danger)}
.cmd-btn-danger:hover{filter:brightness(.9)}
.cmd-btn-warning{background:var(--cmd-warning);color:#fff;border-color:var(--cmd-warning)}
.cmd-btn-ghost{background:transparent;color:var(--cmd-text-muted);border-color:transparent}
.cmd-btn-ghost:hover{background:#f1f5f9;color:var(--cmd-text)}
.cmd-btn-sm{padding:4px 10px;font-size:11px}
.cmd-btn-lg{padding:10px 20px;font-size:14px}
.cmd-btn:disabled{opacity:.4;cursor:not-allowed}
.cmd-btn-ai{
  background:linear-gradient(135deg,#1d4ed8,#6366f1);
  color:#fff;border:none;
}
.cmd-btn-ai:hover{filter:brightness(1.1)}

/* ════════════════════════════════════════════════════════
   PILLS / BADGES
   ════════════════════════════════════════════════════════ */
.cmd-pill{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;
  white-space:nowrap;
}
.cmd-pill.success{background:var(--cmd-success-bg);color:var(--cmd-success)}
.cmd-pill.danger{background:var(--cmd-danger-bg);color:var(--cmd-danger)}
.cmd-pill.warning{background:var(--cmd-warning-bg);color:var(--cmd-warning)}
.cmd-pill.info{background:var(--cmd-info-bg);color:var(--cmd-info)}
.cmd-pill.neutral{background:#f1f5f9;color:var(--cmd-text-muted)}
.cmd-pill.primary{background:var(--cmd-primary-50);color:var(--cmd-primary)}
.cmd-pill::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor}

/* ════════════════════════════════════════════════════════
   MODAL
   ════════════════════════════════════════════════════════ */
.cmd-modal-backdrop{
  position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(3px);
  z-index:9000;display:flex;align-items:center;justify-content:center;padding:24px;
  opacity:0;transition:opacity .2s;
}
.cmd-modal-backdrop.show{opacity:1}
.cmd-modal{
  background:#fff;border-radius:12px;box-shadow:var(--cmd-shadow-lg);
  width:100%;max-height:calc(100vh - 48px);display:flex;flex-direction:column;
  transform:scale(.96) translateY(8px);transition:transform .2s;
}
.cmd-modal-backdrop.show .cmd-modal{transform:scale(1) translateY(0)}
.cmd-modal-sm{max-width:440px}
.cmd-modal-md{max-width:640px}
.cmd-modal-lg{max-width:900px}
.cmd-modal-xl{max-width:1100px}
.cmd-modal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--cmd-border);flex-shrink:0;
}
.cmd-modal-title{font-size:15px;font-weight:700;color:var(--cmd-text)}
.cmd-modal-close{
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  border-radius:6px;cursor:pointer;color:var(--cmd-text-muted);font-size:16px;
  transition:background .15s;
}
.cmd-modal-close:hover{background:#f1f5f9;color:var(--cmd-text)}
.cmd-modal-body{padding:20px;overflow-y:auto;flex:1}
.cmd-modal-footer{
  padding:14px 20px;border-top:1px solid var(--cmd-border);
  display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-shrink:0;
  background:#fcfcfd;border-radius:0 0 12px 12px;
}

/* ════════════════════════════════════════════════════════
   TOAST
   ════════════════════════════════════════════════════════ */
.cmd-toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.cmd-toast{
  display:flex;align-items:center;gap:10px;padding:12px 16px;
  border-radius:8px;box-shadow:var(--cmd-shadow-lg);min-width:260px;max-width:420px;
  animation:toastIn .25s cubic-bezier(.34,1.56,.64,1);
  font-size:12px;font-weight:500;
}
.cmd-toast.success{background:#fff;border-left:4px solid var(--cmd-success)}
.cmd-toast.danger{background:#fff;border-left:4px solid var(--cmd-danger)}
.cmd-toast.warning{background:#fff;border-left:4px solid var(--cmd-warning)}
.cmd-toast.info{background:#fff;border-left:4px solid var(--cmd-info)}
.cmd-toast-icon{font-size:16px;flex-shrink:0}
.cmd-toast-msg{flex:1;color:var(--cmd-text)}
.cmd-toast-close{cursor:pointer;color:var(--cmd-text-muted);font-size:14px;flex-shrink:0}
@keyframes toastIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}

/* ════════════════════════════════════════════════════════
   GRID / HELPERS
   ════════════════════════════════════════════════════════ */
.cmd-grid{display:grid;gap:16px}
.cmd-grid-2{grid-template-columns:repeat(2,1fr)}
.cmd-grid-3{grid-template-columns:repeat(3,1fr)}
.cmd-grid-4{grid-template-columns:repeat(4,1fr)}
.cmd-grid-5{grid-template-columns:repeat(5,1fr)}
.cmd-grid-6{grid-template-columns:repeat(6,1fr)}
@media(max-width:900px){.cmd-grid-4{grid-template-columns:repeat(2,1fr)}.cmd-grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cmd-grid-2,.cmd-grid-3,.cmd-grid-4{grid-template-columns:1fr}}
.cmd-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cmd-muted{color:var(--cmd-text-muted)}
.cmd-strong{font-weight:600}
.cmd-help{font-size:12px;color:var(--cmd-text-muted);line-height:1.5}
.cmd-mb-12{margin-bottom:12px}
.cmd-link{color:var(--cmd-primary);cursor:pointer;font-weight:600}
.cmd-link:hover{text-decoration:underline}
.cmd-section-title{font-size:11px;font-weight:700;color:var(--cmd-text-muted);
  text-transform:uppercase;letter-spacing:.05em;margin:14px 0 6px}

/* Status indicator */
.cmd-status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.cmd-status-dot.green{background:var(--cmd-success)}
.cmd-status-dot.yellow{background:var(--cmd-warning)}
.cmd-status-dot.red{background:var(--cmd-danger)}
.cmd-status-dot.gray{background:var(--cmd-text-muted)}

/* Progress bar */
.cmd-progress{height:6px;background:var(--cmd-border);border-radius:3px;overflow:hidden}
.cmd-progress-fill{height:100%;border-radius:3px;transition:width .4s}
.cmd-progress-fill.blue{background:var(--cmd-primary)}
.cmd-progress-fill.green{background:var(--cmd-success)}
.cmd-progress-fill.red{background:var(--cmd-danger)}

/* AI Chat Panel */
.cmd-ai-panel{
  position:fixed;right:0;top:48px;bottom:0;width:380px;
  background:#fff;border-left:1px solid var(--cmd-border);
  box-shadow:var(--cmd-shadow-lg);z-index:500;
  display:flex;flex-direction:column;transform:translateX(100%);
  transition:transform .25s cubic-bezier(.4,0,.2,1);
}
.cmd-ai-panel.open{transform:translateX(0)}
.cmd-ai-panel-head{
  padding:14px 16px;border-bottom:1px solid var(--cmd-border);
  background:linear-gradient(135deg,#1d4ed8,#6366f1);color:#fff;
  display:flex;align-items:center;justify-content:space-between;
}
.cmd-ai-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.cmd-ai-msg{max-width:85%;padding:10px 12px;border-radius:12px;font-size:12px;line-height:1.5}
.cmd-ai-msg.user{background:var(--cmd-primary-50);color:var(--cmd-primary);margin-left:auto;border-bottom-right-radius:4px}
.cmd-ai-msg.ai{background:#f8fafc;color:var(--cmd-text);margin-right:auto;border-bottom-left-radius:4px}
.cmd-ai-msg.ai.typing{opacity:.6}
.cmd-ai-input-area{padding:12px;border-top:1px solid var(--cmd-border);display:flex;gap:8px}
.cmd-ai-input{flex:1;border:1.5px solid var(--cmd-border);border-radius:8px;padding:8px 12px;
  font-size:12px;resize:none;outline:none;font-family:inherit}
.cmd-ai-input:focus{border-color:var(--cmd-primary)}
.cmd-ai-send{width:34px;height:34px;border-radius:8px;background:var(--cmd-primary);
  color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;flex-shrink:0}

/* Quick actions bar */
.cmd-quick-actions{
  display:flex;gap:6px;padding:10px 24px;
  background:var(--cmd-surface);border-bottom:1px solid var(--cmd-border);
  overflow-x:auto;
}
.cmd-quick-actions::-webkit-scrollbar{height:0}
.cmd-quick-action{
  display:flex;align-items:center;gap:6px;padding:5px 12px;
  border-radius:20px;font-size:11px;font-weight:600;
  cursor:pointer;white-space:nowrap;transition:all .15s;
  border:1.5px solid var(--cmd-border);color:var(--cmd-text);background:#fff;
  font-family:inherit;
}
.cmd-quick-action:hover{border-color:var(--cmd-primary);color:var(--cmd-primary);background:var(--cmd-primary-50)}

/* Partidas table */
.cmd-partidas-tbl td{padding:6px 8px}
.cmd-partidas-tbl input{padding:5px 8px}

/* Chart placeholder */
.cmd-chart-area{background:#f8fafc;border-radius:8px;height:180px;
  display:flex;align-items:center;justify-content:center;color:var(--cmd-text-muted);font-size:12px}

/* Misc */
@keyframes cmdFadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.cmd-fade-in{animation:cmdFadeIn .3s ease}
@keyframes spin{to{transform:rotate(360deg)}}
.cmd-spinner{width:18px;height:18px;border:2px solid var(--cmd-border);
  border-top-color:var(--cmd-primary);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}
.cmd-empty{text-align:center;padding:40px;color:var(--cmd-text-muted);font-size:13px}
.cmd-empty-icon{font-size:32px;margin-bottom:8px}

/* ════════════════════════════════════════════════════════
   MODALES — Estilos enterprise profesionales
   ════════════════════════════════════════════════════════ */

/* Header del modal */
.cmd-modal-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--cmd-border);flex-shrink:0;
  background:linear-gradient(135deg,#0f172a,#1e293b);
}
.cmd-modal-title{
  font-size:14px;font-weight:700;color:#fff;letter-spacing:-.1px;
}
.cmd-icon-btn.cmd-modal-x{
  width:28px;height:28px;border-radius:6px;
  background:rgba(255,255,255,.1);border:none;color:#fff;font-size:18px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .15s;line-height:1;
}
.cmd-icon-btn.cmd-modal-x:hover{background:rgba(255,255,255,.2)}

/* Footer del modal */
.cmd-modal-foot,.cmd-modal-footer{
  padding:14px 20px;border-top:1px solid var(--cmd-border);
  display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-shrink:0;
  background:#f8fafc;border-radius:0 0 12px 12px;
}

/* Body del modal */
.cmd-modal-body{padding:20px;overflow-y:auto;flex:1}

/* Secciones dentro del modal */
.cmd-modal-body .cmd-section-title{
  font-size:11px;font-weight:700;color:var(--cmd-text-muted);
  text-transform:uppercase;letter-spacing:.06em;
  margin:16px 0 10px;padding-bottom:6px;
  border-bottom:1px solid var(--cmd-border);
}
.cmd-modal-body .cmd-section-title:first-child{margin-top:0}

/* Backdrop más sofisticado */
.cmd-modal-backdrop{
  position:fixed;inset:0;
  background:rgba(15,23,42,.6);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  z-index:9000;display:flex;align-items:center;
  justify-content:center;padding:24px;
  opacity:0;transition:opacity .2s;
}
.cmd-modal-backdrop.show{opacity:1}

/* Modal con sombra más dramática */
.cmd-modal{
  background:#fff;border-radius:12px;
  box-shadow:0 25px 60px rgba(0,0,0,.25),0 0 0 1px rgba(255,255,255,.1);
  width:100%;max-height:calc(100vh - 48px);
  display:flex;flex-direction:column;
  transform:scale(.96) translateY(12px);
  transition:transform .2s cubic-bezier(.34,1.56,.64,1);
  overflow:hidden;
}
.cmd-modal-backdrop.show .cmd-modal{transform:scale(1) translateY(0)}

/* Tamaños */
.cmd-modal-sm{max-width:400px}
.cmd-modal-md{max-width:600px}
.cmd-modal-lg{max-width:860px}
.cmd-modal-xl{max-width:1100px}

/* ════════════════════════════════════════════════════════
   MODAL DE ACCIONES — Row Actions
   ════════════════════════════════════════════════════════ */
.cmd-row-act-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 16px;cursor:pointer;
  transition:background .12s;
}
.cmd-row-act-item:hover{background:#f1f5f9}

/* ════════════════════════════════════════════════════════
   FORMULARIOS dentro de modales — Mejoras
   ════════════════════════════════════════════════════════ */
.cmd-modal-body .cmd-field{margin-bottom:14px}
.cmd-modal-body .cmd-label{
  display:block;font-size:11px;font-weight:700;
  color:var(--cmd-text-muted);text-transform:uppercase;
  letter-spacing:.05em;margin-bottom:5px;
}
.cmd-modal-body .cmd-input:focus{
  border-color:var(--cmd-primary);
  box-shadow:0 0 0 3px rgba(29,78,216,.1);
}

/* Badge en header del modal de acciones */
.cmd-action-header{
  padding:16px 20px 14px;
  background:linear-gradient(135deg,#0f172a,#1e293b);
  border-bottom:1px solid rgba(255,255,255,.1);
}
.cmd-action-module{
  font-size:10px;font-weight:700;color:rgba(255,255,255,.4);
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;
}
.cmd-action-id{font-size:15px;font-weight:700;color:#fff}
.cmd-action-sub{font-size:11px;color:rgba(255,255,255,.5);margin-top:2px}

/* ════════════════════════════════════════════════════════
   CONFIRM DIALOG — Estilo destructivo / informativo
   ════════════════════════════════════════════════════════ */
.cmd-confirm-icon{
  width:48px;height:48px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;margin:0 auto 12px;
}
.cmd-confirm-icon.danger{background:#fee2e2}
.cmd-confirm-icon.warning{background:#fef3c7}
.cmd-confirm-icon.info{background:#dbeafe}

/* ════════════════════════════════════════════════════════
   TOASTS — Más profesionales
   ════════════════════════════════════════════════════════ */
.cmd-toast{
  display:flex;align-items:center;gap:10px;padding:12px 16px;
  border-radius:10px;box-shadow:0 8px 24px rgba(15,23,42,.15);
  min-width:280px;max-width:420px;pointer-events:all;
  font-size:12px;font-weight:500;background:#fff;
  border:1px solid var(--cmd-border);
  animation:toastIn .25s cubic-bezier(.34,1.56,.64,1);
}
.cmd-toast.success{border-left:3px solid var(--cmd-success)}
.cmd-toast.danger{border-left:3px solid var(--cmd-danger)}
.cmd-toast.warning{border-left:3px solid var(--cmd-warning)}
.cmd-toast.info{border-left:3px solid var(--cmd-info)}
.cmd-toast-ico{
  width:24px;height:24px;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;flex-shrink:0;
}
.cmd-toast.success .cmd-toast-ico{background:var(--cmd-success-bg);color:var(--cmd-success)}
.cmd-toast.danger  .cmd-toast-ico{background:var(--cmd-danger-bg);color:var(--cmd-danger)}
.cmd-toast.warning .cmd-toast-ico{background:var(--cmd-warning-bg);color:var(--cmd-warning)}
.cmd-toast.info    .cmd-toast-ico{background:var(--cmd-info-bg);color:var(--cmd-info)}
.cmd-toast-x{cursor:pointer;color:var(--cmd-text-muted);margin-left:auto;flex-shrink:0;font-size:16px;border:none;background:none}
@keyframes toastIn{from{opacity:0;transform:translateX(20px) scale(.95)}to{opacity:1;transform:none}}

/* ════════════════════════════════════════════════════════
   TABLA — Mejoras enterprise
   ════════════════════════════════════════════════════════ */
.cmd-table th{position:sticky;top:0;z-index:1}
.cmd-table tbody tr:last-child td{border-bottom:none}
.cmd-table tfoot td{
  background:#f8fafc;font-weight:700;
  border-top:2px solid var(--cmd-border);
}

/* ════════════════════════════════════════════════════════
   QUICK ACTIONS — Barra de acciones rápidas
   ════════════════════════════════════════════════════════ */
.cmd-quick-actions{scrollbar-width:none}
.cmd-quick-action svg{width:13px;height:13px;flex-shrink:0}
