/* ════════════════════════════════════════════════════════════════
   MIMBRAL 360 — SHELL COMÚN
   Tokens, header, sidebar colapsable a íconos, y primitivos UI.
   Importar en TODAS las pantallas para garantizar consistencia.
   ════════════════════════════════════════════════════════════════ */

:root{
  /* Colores marca */
  --mb-navy:#14365e; --mb-navy-dk:#0f2845; --mb-navy-lt:#e8eef5;
  --mb-red:#dc1c2e;  --mb-red-dk:#a8121f; --mb-red-lt:#fdecee;
  /* Superficie */
  --bg:#f7f8fa; --surface:#fff; --surface-alt:#f3f5f8;
  --text:#1a2433; --text-soft:#4a5566; --muted:#6f7a89;
  --border:#dde2ea; --border-soft:#e8ecf2;
  /* Estado */
  --ok-bg:#e7f6ec; --ok-fg:#0f7a3b; --ok-border:#a8dcb8;
  --warn-bg:#fff5e1; --warn-fg:#9a5a00; --warn-border:#f5d496;
  --err-bg:#fdecee;  --err-fg:#a8121f;  --err-border:#f4b3bb;
  --info-bg:#e7f0fb; --info-fg:#1c4e8f; --info-border:#b3cee9;
  /* Geometría */
  --r:6px; --r-lg:9px; --r-xl:13px;
  --shadow-sm:0 1px 2px rgba(20,54,94,.06);
  --shadow:0 2px 8px rgba(20,54,94,.08);
  --shadow-lg:0 8px 24px rgba(20,54,94,.13);
  --hdr-h:54px; --cintillo-h:3px;
  --sidebar-w:64px; --sidebar-w-open:230px;
  --font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;
  --mono:"SF Mono","Roboto Mono","JetBrains Mono",ui-monospace,monospace;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font);font-size:13.5px;color:var(--text);
  background:var(--bg);-webkit-font-smoothing:antialiased;letter-spacing:-.003em;
  display:flex;flex-direction:column;min-height:100vh
}
code,pre{font-family:var(--mono)}
button{font-family:inherit}
a{color:inherit}

/* ── Tipografía global forzada (sobreescribe legacy) ─ */
html, body, input, button, select, textarea {
  font-family: var(--font) !important;
}

/* ── Componentes UI compartidos ───────────────────── */
.mb-card{
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:18px 20px;
  box-shadow:var(--shadow-sm); margin-bottom:14px;
}
.mb-card-title{
  font-size:11px; font-weight:700; text-transform:uppercase;
  letter-spacing:.06em; color:var(--muted); margin-bottom:14px;
  display:flex; align-items:center; gap:8px;
}
.mb-section-title{
  font-size:18px; font-weight:600; letter-spacing:-.015em;
  color:var(--text); margin-bottom:4px;
}
.mb-section-sub{
  font-size:13px; color:var(--muted); margin-bottom:18px;
}

/* Botones */
.mb-btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:7px; padding:8px 16px; border-radius:var(--r);
  font-size:13px; font-weight:600; cursor:pointer; border:1px solid transparent;
  transition:background .12s, color .12s, border-color .12s, box-shadow .12s;
  font-family:var(--font); line-height:1.2;
}
.mb-btn-primary{ background:var(--mb-red); color:#fff; border-color:var(--mb-red); }
.mb-btn-primary:hover{ background:var(--mb-red-dk); border-color:var(--mb-red-dk); }
.mb-btn-secondary{ background:#fff; color:var(--mb-navy); border-color:var(--border); }
.mb-btn-secondary:hover{ background:var(--surface-alt); border-color:var(--mb-navy); }
.mb-btn-ghost{ background:transparent; color:var(--text-soft); }
.mb-btn-ghost:hover{ background:var(--surface-alt); color:var(--mb-navy); }
.mb-btn-sm{ padding:5px 11px; font-size:12px; }
.mb-btn:disabled{ opacity:.5; cursor:not-allowed; }

/* Inputs */
.mb-input, .mb-select, .mb-textarea{
  width:100%; padding:8px 11px; border:1px solid var(--border);
  border-radius:var(--r); font-size:13px; font-family:var(--font);
  background:#fff; color:var(--text); outline:none;
  transition:border-color .12s, box-shadow .12s;
}
.mb-input:focus, .mb-select:focus, .mb-textarea:focus{
  border-color:var(--mb-navy); box-shadow:0 0 0 3px rgba(20,54,94,.1);
}

/* Badges */
.mb-badge{
  display:inline-flex; align-items:center; gap:4px; padding:2px 9px;
  border-radius:99px; font-size:11px; font-weight:600;
  background:var(--surface-alt); color:var(--text-soft);
  border:1px solid var(--border);
}
.mb-badge-ok{ background:var(--ok-bg); color:var(--ok-fg); border-color:var(--ok-border); }
.mb-badge-warn{ background:var(--warn-bg); color:var(--warn-fg); border-color:var(--warn-border); }
.mb-badge-err{ background:var(--err-bg); color:var(--err-fg); border-color:var(--err-border); }
.mb-badge-info{ background:var(--info-bg); color:var(--info-fg); border-color:var(--info-border); }
.mb-badge-navy{ background:var(--mb-navy-lt); color:var(--mb-navy); border-color:#cdd9e8; }

/* ── Header ───────────────────────────────────────── */
.mb-top{
  position:sticky;top:0;z-index:100;
  background:var(--mb-navy);color:#fff;
  height:var(--hdr-h);display:flex;align-items:center;
  padding:0 22px;box-shadow:0 2px 8px rgba(15,40,69,.18)
}
.mb-logo{
  display:flex;align-items:center;gap:11px;font-weight:600;font-size:14.5px;
  letter-spacing:-.015em;color:#fff;text-decoration:none
}
.mb-logo img{height:22px;display:block}
.mb-logo-img{height:32px !important;display:block;margin:-2px 0}
.mb-logo .div{width:1px;height:18px;background:rgba(255,255,255,.22);margin:0 4px}
.mb-logo .crumb{font-weight:500;color:rgba(255,255,255,.78);font-size:13px}
.mb-spacer{flex:1}
.mb-search{
  display:flex;align-items:center;gap:8px;padding:5px 11px;
  background:rgba(255,255,255,.08);border-radius:var(--r);
  font-size:12.5px;color:rgba(255,255,255,.7);cursor:pointer;
  transition:background .12s;border:1px solid rgba(255,255,255,.08)
}
.mb-search:hover{background:rgba(255,255,255,.13)}
.mb-search svg{width:13px;height:13px}
.mb-search kbd{
  font-family:var(--mono);font-size:10.5px;
  background:rgba(255,255,255,.12);padding:1px 5px;border-radius:3px;
  border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.85)
}
.mb-user{
  display:flex;align-items:center;gap:9px;font-size:12.5px;
  color:rgba(255,255,255,.85);padding:6px 11px;border-radius:var(--r);
  margin-left:10px;transition:background .12s;cursor:pointer
}
.mb-user:hover{background:rgba(255,255,255,.08)}
.mb-avatar{
  width:26px;height:26px;border-radius:50%;background:var(--mb-red);
  display:grid;place-items:center;font-size:11px;font-weight:700;color:#fff
}

.mb-cintillo{height:var(--cintillo-h);background:var(--mb-red);flex-shrink:0}

/* ── Shell layout ─────────────────────────────────── */
.mb-shell{flex:1;display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:0;transition:grid-template-columns .2s ease}
.mb-shell.open{grid-template-columns:var(--sidebar-w-open) 1fr}

/* ── Sidebar (colapsado a íconos por defecto) ──── */
.mb-side{
  background:var(--surface);border-right:1px solid var(--border);
  padding:10px 0 24px;overflow:hidden;
  position:sticky;top:calc(var(--hdr-h) + var(--cintillo-h));
  height:calc(100vh - var(--hdr-h) - var(--cintillo-h));
  display:flex;flex-direction:column
}
.mb-side-toggle{
  display:flex;align-items:center;justify-content:center;
  width:40px;height:34px;margin:4px auto 8px;border-radius:var(--r);
  background:transparent;border:none;cursor:pointer;color:var(--muted);
  transition:background .12s,color .12s
}
.mb-side-toggle:hover{background:var(--surface-alt);color:var(--mb-navy)}
.mb-side-toggle svg{width:16px;height:16px}
.mb-shell.open .mb-side-toggle svg{transform:rotate(180deg)}

.mb-side-grp{padding:0 10px;margin-bottom:14px}
.mb-side-lbl{
  font-size:10px;font-weight:700;color:var(--muted);
  letter-spacing:.08em;text-transform:uppercase;
  padding:0 9px;margin-bottom:5px;height:14px;
  opacity:0;transition:opacity .15s;white-space:nowrap;overflow:hidden
}
.mb-shell.open .mb-side-lbl{opacity:1}

.mb-side-item{
  display:flex;align-items:center;gap:11px;
  padding:8px 10px;border-radius:var(--r);
  font-size:13px;color:var(--text-soft);font-weight:500;
  cursor:pointer;text-decoration:none;
  transition:background .12s,color .12s;
  position:relative;white-space:nowrap;overflow:hidden;margin-bottom:1px
}
.mb-side-item:hover{background:var(--surface-alt);color:var(--text)}
.mb-side-item.active{background:var(--mb-navy-lt);color:var(--mb-navy);font-weight:600}
.mb-side-item.active::before{
  content:"";position:absolute;left:-10px;top:6px;bottom:6px;width:3px;
  background:var(--mb-red);border-radius:0 2px 2px 0
}
.mb-side-icn{
  width:22px;height:22px;display:grid;place-items:center;flex-shrink:0;color:inherit
}
.mb-side-icn svg{width:17px;height:17px}
.mb-side-txt{
  opacity:0;transition:opacity .15s;font-size:13px
}
.mb-shell.open .mb-side-txt{opacity:1}
.mb-side-item .mb-count{
  margin-left:auto;font-size:11px;color:var(--muted);
  background:var(--surface-alt);padding:1px 7px;border-radius:9px;
  font-variant-numeric:tabular-nums;font-weight:600;
  opacity:0;transition:opacity .15s
}
.mb-shell.open .mb-side-item .mb-count{opacity:1}
.mb-side-item.active .mb-count{background:#fff;color:var(--mb-navy)}

/* tooltip cuando colapsado */
.mb-side-item:not(.mb-shell.open *):hover::after{}

/* ── Tooltips para sidebar colapsado ── */
.mb-shell:not(.open) .mb-side-item{position:relative}
.mb-shell:not(.open) .mb-side-item:hover .mb-tip{opacity:1;transform:translateX(0)}
.mb-tip{
  position:absolute;left:calc(100% + 8px);top:50%;transform:translate(-4px,-50%);
  background:var(--mb-navy-dk);color:#fff;font-size:11.5px;font-weight:500;
  padding:5px 9px;border-radius:5px;white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .15s,transform .15s;
  z-index:50;box-shadow:var(--shadow)
}
.mb-shell.open .mb-tip{display:none}

.mb-side-spacer{flex:1}

/* ── Wizard sidebar (siempre expandida, contenido custom) ── */
.mb-shell-wizard{grid-template-columns:280px 1fr !important}
.mb-side-wizard{
  width:280px;padding:0;overflow-y:auto;
  display:flex;flex-direction:column
}
.mb-wizard-back{
  display:flex;align-items:center;gap:8px;
  padding:14px 18px;border-bottom:1px solid var(--border-soft);
  font-size:12.5px;font-weight:600;color:var(--muted);
  text-decoration:none;transition:background .12s,color .12s
}
.mb-wizard-back:hover{background:var(--surface-alt);color:var(--mb-navy)}
.mb-wizard-back svg{width:14px;height:14px}
.mb-wizard-hd{padding:16px 18px 12px}
.mb-wizard-ttl{font-size:11px;font-weight:700;color:var(--muted);
  text-transform:uppercase;letter-spacing:.1em}
.mb-wizard-sub{font-size:16px;font-weight:600;color:var(--text);
  letter-spacing:-.018em;margin-top:3px}
.mb-wizard-slot{flex:1;display:flex;flex-direction:column;padding:0 14px 18px}
@media (max-width:900px){
  .mb-shell-wizard{grid-template-columns:0 1fr !important}
  .mb-shell-wizard.open{grid-template-columns:280px 1fr !important}
}

/* ── Main ────────────────────────────────────────── */
.mb-main{padding:24px 28px 60px;min-width:0;overflow-x:hidden}
.mb-page-hdr{margin-bottom:18px;display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap}
.mb-page-ttl{font-size:21px;font-weight:700;letter-spacing:-.018em;color:var(--text)}
.mb-page-sub{font-size:13px;color:var(--muted);margin-top:3px}

/* ── Card ────────────────────────────────────────── */
.mb-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-xl);box-shadow:var(--shadow-sm);
  margin-bottom:14px
}
.mb-card-hdr{
  padding:14px 20px;border-bottom:1px solid var(--border-soft);
  display:flex;align-items:center;gap:12px
}
.mb-card-hdr h2{font-size:14px;font-weight:600;letter-spacing:-.005em}
.mb-card-hdr .mb-sub{font-size:12px;color:var(--muted);font-weight:400;margin-left:auto}
.mb-card-bd{padding:18px 20px}

/* ── Botones ─────────────────────────────────────── */
.mb-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:8px 14px;border-radius:var(--r);font-size:13px;font-weight:600;
  border:1px solid transparent;cursor:pointer;font-family:inherit;
  transition:background .12s,border-color .12s,box-shadow .12s,opacity .12s;
  white-space:nowrap;letter-spacing:-.005em;line-height:1.2;text-decoration:none
}
.mb-btn:disabled{opacity:.45;cursor:not-allowed}
.mb-btn-primary{background:var(--mb-navy);color:#fff}
.mb-btn-primary:hover:not(:disabled){background:var(--mb-navy-dk)}
.mb-btn-success{background:#0f7a3b;color:#fff}
.mb-btn-success:hover:not(:disabled){background:#0c6431}
.mb-btn-warn{background:#c97400;color:#fff}
.mb-btn-warn:hover:not(:disabled){background:#a96100}
.mb-btn-danger{background:var(--mb-red);color:#fff}
.mb-btn-danger:hover:not(:disabled){background:var(--mb-red-dk)}
.mb-btn-ghost{background:transparent;color:var(--text-soft);border-color:var(--border)}
.mb-btn-ghost:hover:not(:disabled){background:var(--surface-alt);color:var(--text)}
.mb-btn-sm{padding:5px 10px;font-size:12px;border-radius:5px}
.mb-btn svg{width:14px;height:14px;flex-shrink:0}

/* ── Pills / chips ───────────────────────────────── */
.mb-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:2px 8px;border-radius:9px;font-size:11px;font-weight:600;
  background:var(--surface-alt);color:var(--text-soft);
  border:1px solid var(--border-soft);font-variant-numeric:tabular-nums
}
.mb-pill.ok{background:var(--ok-bg);color:var(--ok-fg);border-color:var(--ok-border)}
.mb-pill.warn{background:var(--warn-bg);color:var(--warn-fg);border-color:var(--warn-border)}
.mb-pill.err{background:var(--err-bg);color:var(--err-fg);border-color:var(--err-border)}
.mb-pill.info{background:var(--info-bg);color:var(--info-fg);border-color:var(--info-border)}

/* ── Form controls ────────────────────────────────── */
.mb-input{
  padding:8px 11px;border:1px solid var(--border);border-radius:var(--r);
  font-size:13px;font-family:inherit;background:#fff;
  color:var(--text);outline:none;transition:border-color .12s,box-shadow .12s;width:100%
}
.mb-input:focus{
  border-color:var(--mb-navy);box-shadow:0 0 0 3px rgba(20,54,94,.1)
}

/* ── Toasts ──────────────────────────────────────── */
.mb-toasts{
  position:fixed;bottom:20px;right:20px;z-index:500;
  display:flex;flex-direction:column;gap:8px;align-items:flex-end;pointer-events:none
}
.mb-toast{
  pointer-events:auto;background:#1a2433;color:#fff;
  padding:11px 14px;border-radius:var(--r-lg);
  font-size:13px;font-weight:500;letter-spacing:-.005em;
  box-shadow:var(--shadow-lg);max-width:380px;
  display:flex;align-items:flex-start;gap:9px;
  animation:mbSlideUp .25s ease-out
}
@keyframes mbSlideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.mb-toast.success{background:#0f7a3b}
.mb-toast.error{background:var(--mb-red-dk)}
.mb-toast .t-icn{flex-shrink:0;line-height:0;margin-top:1px}
.mb-toast .t-icn svg{width:14px;height:14px}
.mb-toast .t-body{flex:1;line-height:1.45;white-space:pre-wrap}

/* ── Spinner ────────────────────────────────────── */
.mb-spin{
  display:inline-block;width:14px;height:14px;
  border:2px solid var(--border);border-top-color:var(--mb-navy);
  border-radius:50%;animation:mbSpin .8s linear infinite;
  vertical-align:-3px;margin-right:7px
}
@keyframes mbSpin{to{transform:rotate(360deg)}}

/* ── Responsive ─────────────────────────────────── */
@media (max-width:900px){
  .mb-shell{grid-template-columns:0 1fr}
  .mb-shell.open{grid-template-columns:var(--sidebar-w-open) 1fr;position:relative}
  .mb-side{position:fixed;left:0;top:calc(var(--hdr-h) + var(--cintillo-h));z-index:90;width:var(--sidebar-w-open)}
  .mb-shell:not(.open) .mb-side{transform:translateX(-100%);transition:transform .2s}
  .mb-main{padding:18px 16px 60px}
}
