:root {
  --bg: #f6f7fb;
  --card: #ffffff;
  --text: #152235;
  --muted: #66768a;
  --border: #dce3ea;
  --primary: #1f6feb;
  --primary-dark: #175bc2;
  --danger: #b42318;
  --success: #067647;
  --shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  --radius: 18px;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
a { color: var(--primary); text-decoration: none; }
h1,h2,h3,p { margin-top: 0; }
small, .muted { color: var(--muted); }
.app-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 280px 1fr;
}
.sidebar {
  background: #0f1728;
  color: #fff;
  border-right: 1px solid rgba(255,255,255,.06);
  box-shadow: 18px 0 36px rgba(15, 23, 42, 0.10);
  padding: 24px 18px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 18px;
  position: sticky;
  top: 0;
  min-height: 100vh;
}
.brand { display:flex; gap:12px; align-items:center; margin-bottom: 18px; }
.brand small { display:block; color:#a4b1c2; }
.brand-mark {
  width: 44px; height: 44px; border-radius: 14px; display:grid; place-items:center;
  background: rgba(255,255,255,.1); font-size: 1.3rem;
}
.menu { display:grid; gap:10px; }
.menu a {
  color:#dbe5f0; padding: 12px 14px; border-radius: 12px; display:block;
}
.menu a.active, .menu a:hover { background: rgba(255,255,255,.08); color:#fff; }
.sidebar-footer { display:grid; gap:4px; padding-top:10px; border-top:1px solid rgba(255,255,255,.12); }
.link-danger { color: #ffb4a8; margin-top: 8px; }
.main-content { padding: 26px; }
.topbar, .card-actions {
  display:flex; justify-content:space-between; align-items:flex-start; gap:16px; flex-wrap:wrap;
}
.topbar { margin-bottom: 22px; }
.topbar-actions, .actions-inline, .actions-row, .inline-form { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.btn {
  background: var(--primary); color:#fff; border:none; border-radius: 12px; padding: 11px 16px;
  cursor:pointer; box-shadow: var(--shadow); font-weight: 600;
}
.btn:hover { background: var(--primary-dark); }
.btn.secondary { background:#fff; color:var(--text); border:1px solid var(--border); box-shadow:none; }
.btn.small { padding: 8px 12px; font-size: .9rem; }
.btn.full { width:100%; }
.card {
  background: var(--card); border:1px solid var(--border); border-radius: var(--radius); padding: 18px; box-shadow: var(--shadow);
}
.stats-grid {
  display:grid; grid-template-columns: repeat(4, 1fr); gap:16px; margin-bottom:18px;
}
.stat span { color: var(--muted); display:block; margin-bottom:6px; }
.stat strong { font-size: 1.8rem; }
.grid-2 { display:grid; grid-template-columns: 1.2fr 1fr; gap:16px; margin-bottom:18px; }
.table-wrap { overflow:auto; }
table { width:100%; border-collapse: collapse; }
th, td { padding: 12px 10px; border-bottom: 1px solid var(--border); text-align:left; vertical-align: top; }
th { color: var(--muted); font-size: .92rem; font-weight:700; }

/* ── Badges ────────────────────────────────────────────────── */
.badge {
  display:inline-flex; align-items:center; gap:6px; border-radius: 999px; padding: 5px 10px;
  background:#eff4ff; color:#244b99; font-size:.82rem; font-weight:700; text-transform: capitalize; white-space:nowrap;
}
.badge-success  { background:#ecfdf3; color:#067647; }
.badge-warning  { background:#fffaeb; color:#b54708; }
.badge-danger   { background:#fef3f2; color:#b42318; }
.badge-info     { background:#eff4ff; color:#244b99; }
.badge-muted    { background:#f2f4f7; color:#66768a; }

/* ── KPI grid ─────────────────────────────────────────────── */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
  margin-bottom: 20px;
}
.kpi-grid-4 { grid-template-columns: repeat(4, 1fr); }
.kpi-grid-3 { grid-template-columns: repeat(3, 1fr); }
.kpi-card { padding: 18px 20px; }
.kpi-label { font-size: .85rem; color: var(--muted); font-weight: 600; margin-bottom: 8px; text-transform: uppercase; letter-spacing: .03em; }
.kpi-value { font-size: 2.2rem; font-weight: 800; line-height: 1; margin-bottom: 6px; color: var(--text); }
.kpi-sub   { font-size: .8rem; color: var(--muted); }
.kpi-alert  { color: #b54708; }
.kpi-danger { color: var(--danger); }
.kpi-ok     { color: var(--success); }

/* ── Pending approval highlight ──────────────────────────── */
.pending-approval-section { border-left: 4px solid #f79009; }

/* ── Coverage badges ─────────────────────────────────────── */
.coverage-badge {
  display: inline-flex; align-items: center;
  border-radius: 999px; padding: 5px 12px;
  font-size: .84rem; font-weight: 700; white-space: nowrap;
}
.coverage-red    { background: #fef3f2; color: #b42318; }
.coverage-orange { background: #fffaeb; color: #b54708; }
.coverage-green  { background: #ecfdf3; color: #067647; }

/* ── Row states ──────────────────────────────────────────── */
.row-alert    { background: #fff7ed; }
.row-critical { background: #fef3f2; }

/* ── Forms ───────────────────────────────────────────────── */
.form-grid { display:grid; grid-template-columns: repeat(2, 1fr); gap:16px; }
.form-grid.compact { grid-template-columns: 1fr; }
.form-grid label { display:block; margin-bottom:6px; font-weight:600; }
.form-grid input, .form-grid select, .form-grid textarea {
  width:100%; border:1px solid var(--border); border-radius: 12px; padding: 12px 14px; background:#fff; font: inherit;
}
.form-grid textarea { resize: vertical; }
.full-width { grid-column: 1 / -1; }
.item-row {
  display:grid; grid-template-columns: 1.6fr 1.6fr .8fr .7fr 1fr auto; gap:12px; margin-bottom:12px; align-items:center;
}
.btn-remove { padding: 8px 10px; color: var(--danger); border-color: #fecdca; }
.btn-remove:hover { background: #fef3f2; }

/* ── Alerts ──────────────────────────────────────────────── */
.alert { padding: 12px 14px; border-radius: 12px; margin-bottom: 14px; }
.alert.success { background: #ecfdf3; color: var(--success); border:1px solid #abefc6; }
.alert.error   { background: #fef3f2; color: var(--danger);  border:1px solid #fecdca; }

/* ── Auth ────────────────────────────────────────────────── */
.auth-body { min-height:100vh; display:grid; place-items:center; padding:18px; }
.auth-card {
  width:min(100%, 460px); background:#fff; border:1px solid var(--border); border-radius: 24px; padding: 28px; box-shadow: var(--shadow);
}
.auth-logo { font-size: 2rem; margin-bottom: 10px; }

/* ── Summary grid (show page) ────────────────────────────── */
.summary-grid {
  display:grid; grid-template-columns: repeat(3, 1fr); gap:16px; margin-bottom:16px;
}
.summary-grid span  { color: var(--muted); display:block; font-size:.92rem; }
.summary-grid strong { display:block; margin-top:4px; }

/* ── Misc ────────────────────────────────────────────────── */
.card-header { display:flex; justify-content:space-between; align-items:center; gap:12px; margin-bottom: 12px; }
.compact-stats { margin-bottom: 16px; }
.is-tab-active { border-color: var(--primary); color: var(--primary); }
.hint-box {
  padding: 14px 16px; border-radius: 14px; background: #f8fbff; border: 1px solid #d7e8ff;
}
.ordered-list { margin: 0; padding-left: 20px; }
.ordered-list li { margin-bottom: 10px; }
code { background: #0f1728; color: #fff; padding: 2px 6px; border-radius: 8px; }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 1080px) {
  .stats-grid, .grid-2, .summary-grid, .kpi-grid-4, .kpi-grid-3 { grid-template-columns: 1fr 1fr; }
  .item-row { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 840px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar { position: static; min-height: auto; }
  .stats-grid, .grid-2, .summary-grid, .form-grid, .kpi-grid, .kpi-grid-4, .kpi-grid-3 { grid-template-columns: 1fr; }
  .main-content { padding: 18px; }
  .item-row { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .topbar-actions { display:grid; grid-template-columns:1fr; gap:8px; }
  .menu a, .btn { min-height:44px; display:inline-flex; align-items:center; justify-content:center; }
  .table-wrap { overflow:auto; }
}

/* ── Notif dot en menú ───────────────────────────────────── */
.menu-with-badge { display:flex; justify-content:space-between; align-items:center; }
.notif-dot {
  background: var(--danger); color: #fff;
  border-radius: 999px; padding: 2px 7px;
  font-size: .72rem; font-weight: 800; min-width: 20px; text-align:center;
}
.notif-btn { position:relative; gap:6px; }

/* ── Notif list page ─────────────────────────────────────── */
.notif-list { display:grid; gap:8px; }
.notif-item {
  display:grid; grid-template-columns: auto 1fr auto; grid-template-rows: auto auto;
  gap:2px 12px; align-items:start;
  padding:14px 16px; border-radius:14px; border:1px solid var(--border);
  background:var(--card); color:var(--text); text-decoration:none;
  transition: background .15s;
}
.notif-item:hover { background:#f4f7ff; }
.notif-item.is-unread { border-left:4px solid var(--primary); background:#f8fbff; }
.notif-item.is-read   { opacity:.7; }
.notif-type  { grid-column:1; grid-row:1; font-size:.8rem; color:var(--muted); }
.notif-title { grid-column:2; grid-row:1; font-weight:700; }
.notif-body  { grid-column:2; grid-row:2; font-size:.88rem; color:var(--muted); }
.notif-time  { grid-column:3; grid-row:1; font-size:.8rem; white-space:nowrap; }

/* ── Notif banner dashboard ──────────────────────────────── */
.notif-banner-list { display:grid; gap:4px; margin-top:8px; }
.notif-banner-item {
  display:flex; align-items:baseline; gap:10px;
  padding:8px 10px; border-radius:10px; color:var(--text); text-decoration:none;
}
.notif-banner-item:hover { background:var(--bg); }
.notif-icon         { font-size:1rem; flex-shrink:0; }
.notif-banner-title { font-weight:600; flex:1; }
.notif-banner-body  { font-size:.85rem; }
.notif-banner-time  { font-size:.8rem; white-space:nowrap; }

/* ── Consolidation banner ────────────────────────────────── */
.consolidation-banner { margin-bottom:18px; display:grid; gap:12px; }
.consolidation-banner-header {
  display:flex; align-items:center; gap:12px; flex-wrap:wrap;
  padding:14px 16px; border-radius:14px;
  background:#fffaeb; border:1px solid #fde68a; margin-bottom:4px;
}
.consolidation-group { padding:16px; }
.consolidation-form table { width:100%; margin-bottom:0; }

/* ── Comments ────────────────────────────────────────────── */
.comments-thread { display:grid; gap:10px; margin-bottom:16px; }
.comment-bubble {
  padding:12px 16px; border-radius:14px; max-width:85%;
}
.comment-mine   { background:#eff4ff; margin-left:auto; border-bottom-right-radius:4px; }
.comment-theirs { background:#f6f7fb; border:1px solid var(--border); border-bottom-left-radius:4px; }
.comment-meta   { display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin-bottom:6px; font-size:.85rem; }
.comment-body   { line-height:1.5; }

/* ── Status tabs ──────────────────────────────────────────── */
.status-tabs {
  display: flex; gap: 4px; margin-bottom: 16px;
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  padding-bottom: 2px;
}
.status-tab {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 16px; border-radius: 12px; white-space: nowrap;
  border: 1px solid var(--border); background: var(--card);
  color: var(--muted); font-weight: 600; font-size: .9rem; text-decoration: none;
  flex-shrink: 0;
}
.status-tab.is-active { background: var(--primary); color: #fff; border-color: var(--primary); }
.status-tab:hover:not(.is-active) { background: #f0f4ff; color: var(--text); }
.tab-count {
  background: rgba(0,0,0,.1); border-radius: 999px;
  padding: 1px 7px; font-size: .78rem; font-weight: 800;
}
.status-tab.is-active .tab-count { background: rgba(255,255,255,.25); }
.tab-count-alert { background: var(--danger) !important; color: #fff; }
.status-tab:not(.is-active) .tab-count-alert { background: var(--danger) !important; color: #fff; }

/* ── Desktop/mobile toggle ───────────────────────────────── */
.desktop-only { display: block; }
.mobile-only  { display: none;  }

/* ── Request cards (mobile) ──────────────────────────────── */
.request-cards { display: grid; gap: 12px; }
.request-card { padding: 16px; }
.request-card-top {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 8px; margin-bottom: 10px;
}
.request-card-code { font-weight: 700; font-size: 1rem; display: block; }
.request-card-date { font-size: .82rem; }
.request-card-badges { display: flex; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
.request-card-meta {
  display: flex; gap: 14px; font-size: .88rem;
  color: var(--muted); margin-bottom: 14px; flex-wrap: wrap;
}
.request-card-actions {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.request-card-actions .btn,
.request-card-actions .btn.secondary { flex: 1; min-width: 120px; text-align: center; justify-content: center; }

@media (max-width: 768px) {
  .desktop-only { display: none !important; }
  .mobile-only  { display: block !important; }
  .status-tabs  { gap: 6px; }
  .status-tab   { padding: 10px 14px; font-size: .88rem; }
}

/* ── AI Price Scanner ────────────────────────────────────── */
.ai-upload-area {
  border: 2px dashed var(--border); border-radius: 16px;
  padding: 32px 24px; text-align: center;
  background: #f8fbff; cursor: pointer;
  transition: border-color .2s;
}
.ai-upload-area:hover { border-color: var(--primary); }
.ai-upload-icon { font-size: 2.4rem; margin-bottom: 8px; }
.ai-preview-grid { }
@media (max-width: 640px) { .ai-preview-grid { grid-template-columns: 1fr !important; } }

.remito-info-banner {
  display: flex; gap: 12px; flex-wrap: wrap;
  background: #f8fbff; border: 1px solid #d7e8ff;
  border-radius: 12px; padding: 10px 14px;
  font-size: .88rem; margin-bottom: 12px;
}

.ai-match-list { display: grid; gap: 10px; }
.ai-match-item {
  border: 1px solid var(--border); border-radius: 14px; overflow: hidden;
  transition: opacity .2s;
}
.ai-match-header {
  display: flex; justify-content: space-between; align-items: center;
  gap: 10px; padding: 12px 14px; background: #f6f7fb; flex-wrap: wrap;
}
.ai-match-body { padding: 12px 14px; }
.ai-match-prices {
  display: flex; gap: 20px; flex-wrap: wrap; margin-bottom: 6px;
}
.ai-match-prices > div { display: flex; flex-direction: column; gap: 2px; }
.ai-match-prices span { font-size: .8rem; color: var(--muted); }
.ai-match-prices strong { font-size: 1.05rem; }

.confidence-badge {
  display: inline-flex; align-items: center;
  border-radius: 999px; padding: 4px 10px;
  font-size: .78rem; font-weight: 700; white-space: nowrap;
}
.conf-high { background: #ecfdf3; color: #067647; }
.conf-mid  { background: #fffaeb; color: #b54708; }
.conf-low  { background: #fef3f2; color: #b42318; }

/* ── v0.9: Ítems faltantes ──────────────────────────────── */
.missing-panel { overflow: hidden; }
.missing-request-block:last-child { border-bottom: none !important; }

/* Checkbox faltante en tabla receive */
.missing-toggle {
  display: inline-flex; align-items: center; gap: 6px;
  cursor: pointer; user-select: none;
  padding: 4px 8px; border-radius: 6px;
  border: 1px solid var(--border);
  font-size: .83rem; transition: background .15s, border-color .15s;
}
.missing-toggle:hover { background: rgba(239,68,68,.06); border-color: #ef4444; }
.missing-toggle.is-missing {
  background: rgba(239,68,68,.1);
  border-color: #ef4444;
  color: #b91c1c;
  font-weight: 600;
}
.missing-toggle input[type="checkbox"] { accent-color: #ef4444; width: 15px; height: 15px; }
.missing-chk-label { pointer-events: none; }
.missing-reason-input {
  border: 1px solid rgba(239,68,68,.4);
  border-radius: 6px; padding: 4px 8px;
  background: rgba(239,68,68,.04);
  font-size: .82rem; outline: none;
}
.missing-reason-input:focus { border-color: #ef4444; box-shadow: 0 0 0 2px rgba(239,68,68,.15); }

/* Leyenda faltantes en receive */
.missing-legend { border-radius: 8px; }

/* Badge urgente inline */
.badge-missing {
  background: #fef2f2; color: #991b1b;
  border: 1px solid #fca5a5;
  border-radius: 6px; padding: 2px 8px;
  font-size: .75rem; font-weight: 700;
}


/* ════════════════════════════════════════════════════════════
   Cuadra UI 1.0.x · refresh visual principal
   ════════════════════════════════════════════════════════════ */
:root {
  --bg: #f3f4f8;
  --card: #ffffff;
  --text: #162235;
  --muted: #607086;
  --border: #d7deea;
  --primary: #2f5cff;
  --primary-dark: #2348d5;
  --accent: #7c3aed;
  --danger: #c0392b;
  --warning: #c27a10;
  --success: #1f8f5f;
  --sidebar-bg: linear-gradient(180deg, #0e1628 0%, #121d34 52%, #0f1728 100%);
  --shadow-soft: 0 18px 40px rgba(15, 23, 42, 0.08);
  --shadow-card: 0 10px 26px rgba(15, 23, 42, 0.07);
  --radius: 22px;
}

html { scroll-behavior: smooth; }

body.cuadra-ui {
  background:
    radial-gradient(circle at top right, rgba(47, 92, 255, 0.11), transparent 20rem),
    radial-gradient(circle at bottom left, rgba(124, 58, 237, 0.10), transparent 22rem),
    var(--bg);
  color: var(--text);
}

body.cuadra-ui a { transition: color .16s ease, background .16s ease, border-color .16s ease, transform .16s ease; }
body.cuadra-ui h1, 
body.cuadra-ui h2, 
body.cuadra-ui h3 { letter-spacing: -.02em; }
body.cuadra-ui h1 { margin: 0; font-size: clamp(1.6rem, 2vw, 2.15rem); }
body.cuadra-ui h2 { margin-bottom: .35rem; }

body.cuadra-ui .app-shell {
  grid-template-columns: 292px minmax(0, 1fr);
  gap: 0;
}

body.cuadra-ui .sidebar {
  background: var(--sidebar-bg);
  padding: 22px 16px 18px;
  border-right: 1px solid rgba(255,255,255,.08);
  box-shadow: inset -1px 0 0 rgba(255,255,255,.04);
}

body.cuadra-ui .brand-shell {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding: 6px 4px 16px;
  margin-bottom: 12px;
}

body.cuadra-ui .brand-core { display:flex; gap:12px; align-items:center; min-width:0; }
body.cuadra-ui .brand-mark {
  width: 50px;
  height: 50px;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(255,255,255,.18), rgba(255,255,255,.06));
  border: 1px solid rgba(255,255,255,.09);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18);
  font-weight: 800;
}
body.cuadra-ui .brand-text strong { display:block; font-size:1rem; }
body.cuadra-ui .brand-text small { color:#93a7be; line-height:1.35; }

body.cuadra-ui .nav-section {
  color:#7f91aa;
  font-size:.76rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.14em;
  padding: 6px 10px 10px;
}

body.cuadra-ui .menu { gap: 8px; }
body.cuadra-ui .menu a {
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap: 12px;
  color:#dce7f5;
  border:1px solid transparent;
  border-radius: 15px;
  padding: 12px 13px;
  font-weight: 600;
}
body.cuadra-ui .menu a .menu-icon {
  width: 22px;
  display:inline-flex;
  justify-content:center;
  font-size: 1rem;
}
body.cuadra-ui .menu a:hover {
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.08);
  transform: translateX(1px);
}
body.cuadra-ui .menu a.active {
  color:#fff;
  background: linear-gradient(135deg, rgba(47, 92, 255, .26), rgba(124, 58, 237, .18));
  border-color: rgba(118, 147, 255, .24);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}
body.cuadra-ui .notif-dot {
  background: linear-gradient(135deg, #ff6a5f, #ff8861);
  min-width: 22px;
}

body.cuadra-ui .sidebar-footer {
  gap: 12px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.10);
}
body.cuadra-ui .sidebar-user-card {
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px;
  border-radius: 16px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.07);
}
body.cuadra-ui .sidebar-user-avatar {
  width: 38px;
  height: 38px;
  border-radius: 13px;
  display:grid;
  place-items:center;
  background: rgba(255,255,255,.13);
  color:#fff;
  font-weight:800;
}
body.cuadra-ui .sidebar-user-meta strong { display:block; color:#fff; font-size:.93rem; }
body.cuadra-ui .sidebar-user-meta small { display:block; color:#9eb0c6; line-height:1.35; }
body.cuadra-ui .sidebar-version {
  color:#8ea2ba;
  font-size:.76rem;
  padding: 0 2px;
}
body.cuadra-ui .sidebar-logout {
  display:inline-flex;
  align-items:center;
  gap: 8px;
  color:#ffb4a8;
  font-weight:700;
}

body.cuadra-ui .main-content {
  padding: 28px 28px 36px;
}

body.cuadra-ui .topbar-panel {
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.82);
  border-radius: 26px;
  box-shadow: var(--shadow-soft);
  padding: 20px 22px;
  margin-bottom: 20px;
  align-items: center;
}
body.cuadra-ui .topbar-main { flex: 1; min-width: 280px; }
body.cuadra-ui .page-context-row {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom: 8px;
}
body.cuadra-ui .page-context-badge,
body.cuadra-ui .page-context-muted {
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding: 5px 10px;
  border-radius: 999px;
  font-size:.76rem;
  font-weight:700;
}
body.cuadra-ui .page-context-badge {
  background: rgba(47,92,255,.10);
  color: var(--primary);
}
body.cuadra-ui .page-context-muted {
  background: #f3f6fb;
  color: var(--muted);
}
body.cuadra-ui .page-lead {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: .95rem;
}

body.cuadra-ui .topbar-actions { justify-content:flex-end; }
body.cuadra-ui .topbar-actions .btn { min-height: 44px; }

body.cuadra-ui .btn {
  border-radius: 14px;
  padding: 11px 16px;
  box-shadow: 0 10px 22px rgba(47, 92, 255, 0.16);
}
body.cuadra-ui .btn:hover { transform: translateY(-1px); }
body.cuadra-ui .btn.secondary {
  background: #fff;
  border: 1px solid var(--border);
  box-shadow: none;
}

body.cuadra-ui .card {
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(213, 222, 236, .9);
  border-radius: var(--radius);
  box-shadow: var(--shadow-card);
  padding: 20px;
}
body.cuadra-ui .card-actions {
  align-items: center;
  margin-bottom: 18px;
}
body.cuadra-ui .card-header {
  margin-bottom: 14px;
  align-items:center;
}

body.cuadra-ui .stats-grid,
body.cuadra-ui .kpi-grid,
body.cuadra-ui .summary-grid,
body.cuadra-ui .grid-2 {
  gap: 18px;
}

body.cuadra-ui .stat,
body.cuadra-ui .kpi-card {
  position: relative;
  overflow: hidden;
}
body.cuadra-ui .stat::after,
body.cuadra-ui .kpi-card::after {
  content: "";
  position: absolute;
  inset: auto -28px -28px auto;
  width: 96px;
  height: 96px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(47,92,255,.16), rgba(47,92,255,0));
}
body.cuadra-ui .stat span {
  color: var(--muted);
  font-size:.86rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight:700;
}
body.cuadra-ui .stat strong,
body.cuadra-ui .kpi-value {
  font-size: clamp(1.7rem, 2vw, 2.35rem);
  font-weight: 800;
}
body.cuadra-ui .kpi-label { font-size:.78rem; letter-spacing:.12em; }

body.cuadra-ui table { border-collapse: separate; border-spacing: 0; }
body.cuadra-ui th {
  color: #6d7d93;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .74rem;
  font-weight: 800;
  background: #fbfcff;
}
body.cuadra-ui td, 
body.cuadra-ui th { padding: 13px 12px; }
body.cuadra-ui td {
  border-bottom: 1px solid #edf1f7;
}
body.cuadra-ui tbody tr {
  transition: background .15s ease, transform .15s ease;
}
body.cuadra-ui tbody tr:hover {
  background: #fbfcff;
}
body.cuadra-ui tbody tr:last-child td { border-bottom: none; }

body.cuadra-ui .table-wrap {
  border-radius: calc(var(--radius) - 2px);
}
body.cuadra-ui .table-wrap.card {
  overflow: hidden;
}
body.cuadra-ui .badge,
body.cuadra-ui .coverage-badge,
body.cuadra-ui .status-indicator,
body.cuadra-ui .metric-pill {
  border-radius: 999px;
  font-weight: 700;
}
body.cuadra-ui .badge {
  padding: 6px 11px;
  font-size: .78rem;
}
body.cuadra-ui .badge-info    { background:#edf2ff; color:#3256c8; }
body.cuadra-ui .badge-success { background:#e9fbf4; color:#127a4f; }
body.cuadra-ui .badge-warning { background:#fff6df; color:#a86809; }
body.cuadra-ui .badge-danger  { background:#feefed; color:#bb3d2d; }
body.cuadra-ui .badge-muted   { background:#f2f5f9; color:#5e6f84; }

body.cuadra-ui .status-tabs {
  gap: 10px;
  margin-bottom: 18px;
}
body.cuadra-ui .status-tab {
  padding: 10px 15px;
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(213, 222, 236, .9);
  color: var(--muted);
}
body.cuadra-ui .status-tab.is-active {
  background: linear-gradient(135deg, var(--primary), #5b73ff);
  color: #fff;
}
body.cuadra-ui .tab-count {
  background: rgba(12, 18, 33, .08);
}
body.cuadra-ui .status-tab.is-active .tab-count { background: rgba(255,255,255,.22); }

body.cuadra-ui .alert {
  border-radius: 16px;
  box-shadow: var(--shadow-card);
}

.page-hero {
  display:grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, .85fr);
  gap: 18px;
  margin-bottom: 18px;
}
.page-hero-card {
  position: relative;
  overflow: hidden;
}
.page-hero-card::before {
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(135deg, rgba(47,92,255,.10), rgba(124,58,237,.08) 62%, transparent);
  pointer-events:none;
}
.page-hero-card > * { position: relative; z-index: 1; }
.page-hero-title {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
  margin-bottom: 16px;
}
.eyebrow {
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(47,92,255,.08);
  color: var(--primary);
  font-size: .76rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 10px;
}
.hero-copy p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}
.quick-links {
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  margin-top: 18px;
}
.quick-link {
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 10px 13px;
  border-radius: 14px;
  background: rgba(255,255,255,.74);
  border: 1px solid rgba(214, 222, 236, .9);
  color: var(--text);
  font-weight: 700;
}
.quick-link:hover {
  border-color: rgba(47,92,255,.24);
  color: var(--primary);
}
.hero-metrics {
  display:grid;
  gap: 12px;
}
.hero-metric {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(214, 222, 236, .88);
}
.hero-metric strong {
  font-size: 1.35rem;
  line-height: 1;
}
.hero-metric span {
  display:block;
  color: var(--muted);
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 800;
}
.metric-strip {
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}
.metric-pill {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 14px;
  padding: 14px 16px;
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(213, 222, 236, .92);
  color: var(--text);
}
.metric-pill strong {
  font-size: 1.45rem;
  line-height: 1;
}
.metric-pill span {
  color: var(--muted);
  font-size: .82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.metric-pill.alert { border-color: rgba(194, 122, 16, .24); }
.metric-pill.danger { border-color: rgba(192, 57, 43, .24); }
.metric-pill.success { border-color: rgba(31, 143, 95, .24); }

.surface-subtle {
  background: linear-gradient(180deg, rgba(255,255,255,.86), rgba(248,250,255,.95));
}
.panel-note {
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px dashed rgba(47,92,255,.22);
  color: var(--muted);
  background: rgba(47,92,255,.035);
  line-height: 1.55;
}
.table-title {
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap: 12px;
  margin-bottom: 14px;
}
.table-title p,
.table-title h2,
.table-title h3 { margin: 0; }

.td-strong {
  font-weight: 700;
  color: var(--text);
}
.status-indicator {
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 7px 11px;
  font-size: .77rem;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.status-indicator::before {
  content:"";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: currentColor;
}
.status-ok {
  background:#ebfbf4;
  color:#187f56;
}
.status-low {
  background:#fff6e6;
  color:#ad6b07;
}
.status-critical {
  background:#feefed;
  color:#b73c2b;
}

.empty-state {
  text-align:center;
  padding: 34px 24px;
  border-radius: 22px;
  border: 1px dashed var(--border);
  background: rgba(255,255,255,.78);
  color: var(--muted);
}
.empty-state strong {
  display:block;
  color: var(--text);
  font-size: 1.05rem;
  margin-bottom: 8px;
}

.notif-dashboard-banner .card {
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(247,250,255,.95));
  border-left-width: 0 !important;
}

.request-row-pending td:first-child { border-left: 4px solid #f59e0b; }
.request-row-active td:first-child { border-left: 4px solid #4f7cff; }
.request-row-done td:first-child { border-left: 4px solid #1f8f5f; }
.request-card-meta span { display:inline-flex; align-items:center; gap:6px; }

@media (max-width: 1180px) {
  .page-hero,
  .metric-strip { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 920px) {
  body.cuadra-ui .app-shell { grid-template-columns: 1fr; }
  body.cuadra-ui .sidebar { position: static; min-height: auto; }
  body.cuadra-ui .main-content { padding: 18px 18px 28px; }
  body.cuadra-ui .topbar-panel { padding: 18px; }
  .page-hero,
  .metric-strip { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  body.cuadra-ui .topbar-panel {
    border-radius: 22px;
  }
  body.cuadra-ui .topbar-actions {
    width: 100%;
    justify-content: stretch;
  }
  body.cuadra-ui .topbar-actions .btn,
  body.cuadra-ui .topbar-actions .btn.secondary {
    flex: 1 1 100%;
    justify-content: center;
  }
  body.cuadra-ui .card,
  body.cuadra-ui .topbar-panel {
    padding: 16px;
  }
  body.cuadra-ui td, body.cuadra-ui th { padding: 11px 10px; }
}


/* ── v1.1.0 functional UI ─────────────────────────────────── */
.filter-toolbar {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.filter-toolbar-main {
  display: grid;
  grid-template-columns: repeat(3, minmax(180px, 1fr));
  gap: 14px;
  flex: 1 1 720px;
}
.filter-field label {
  display: block;
  font-size: .82rem;
  color: var(--muted);
  font-weight: 700;
  margin-bottom: 6px;
}
.filter-field input,
.filter-field select {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #fff;
  padding: 11px 13px;
  font: inherit;
  color: var(--text);
}
.filter-field input:focus,
.filter-field select:focus {
  outline: none;
  border-color: var(--primary);
}
.btn.ghost {
  background: transparent;
  border: 1px dashed var(--border);
  color: var(--muted);
  box-shadow: none;
}
.btn.ghost:hover {
  background: #fff;
  color: var(--text);
}
.segmented-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.segmented-tab {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  border-radius: 999px;
  background: #f3f6fb;
  color: var(--text);
  font-size: .9rem;
  font-weight: 600;
}
.segmented-tab span {
  display: inline-flex;
  min-width: 22px;
  height: 22px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(31, 111, 235, .08);
  color: var(--primary);
  font-size: .8rem;
}
.segmented-tab.is-active {
  background: var(--primary);
  color: #fff;
}
.segmented-tab.is-active span {
  background: rgba(255,255,255,.2);
  color: #fff;
}
.action-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.action-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: #fff;
}
.action-metric {
  font-weight: 800;
  font-size: 1rem;
  color: var(--text);
}
.mini-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
  gap: 12px;
}
.mini-kpi {
  padding: 14px 16px;
  border-radius: 16px;
  background: #fff;
  border: 1px solid var(--border);
}
.mini-kpi span {
  display: block;
  color: var(--muted);
  font-size: .82rem;
  margin-bottom: 6px;
}
.mini-kpi strong {
  font-size: 1.4rem;
}
.progress-track {
  height: 10px;
  border-radius: 999px;
  background: #e8eef7;
  overflow: hidden;
}
.progress-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--primary), #5ea0ff);
}
.timeline-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.timeline-item {
  display: grid;
  grid-template-columns: 20px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border-radius: 14px;
  background: #f8fbff;
  border: 1px solid var(--border);
}
.timeline-dot {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: #cdd8e6;
  box-shadow: 0 0 0 4px rgba(148, 163, 184, .15);
}
.timeline-item.is-done .timeline-dot {
  background: var(--success);
  box-shadow: 0 0 0 4px rgba(6, 118, 71, .12);
}
.page-summary-card {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
}
.page-summary-copy {
  flex: 1 1 340px;
}
.summary-grid.compact {
  display: grid;
  grid-template-columns: repeat(3, minmax(150px, 1fr));
  gap: 12px;
  flex: 1 1 420px;
}
.summary-grid.compact > div {
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: #fff;
}
.summary-grid.compact span {
  display: block;
  color: var(--muted);
  font-size: .8rem;
  margin-bottom: 5px;
}
.row-soft-alert {
  background: rgba(250, 173, 20, .06);
}
.empty-state.compact {
  padding: 20px;
}
@media (max-width: 980px) {
  .filter-toolbar-main,
  .mini-kpi-grid,
  .summary-grid.compact {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 720px) {
  .filter-toolbar-main,
  .mini-kpi-grid,
  .summary-grid.compact,
  .timeline-item {
    grid-template-columns: 1fr;
  }
  .page-summary-card {
    flex-direction: column;
  }
  .timeline-item {
    gap: 8px;
  }
}


/* ── v1.2.0 · eventos con autocompletado ─────────────────── */
.event-form-shell { display: grid; gap: 18px; margin-bottom: 24px; }
.event-form-toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.event-form-intro h2 { margin: 10px 0 8px; font-size: 1.55rem; }
.event-form-intro p,
.event-card-header p { margin: 0; color: var(--muted); max-width: 760px; line-height: 1.55; }
.event-form-toolbar-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.event-catalog-summary {
  min-width: 220px;
  background: linear-gradient(135deg, rgba(47,92,255,.08), rgba(124,58,237,.08));
  border: 1px solid rgba(47,92,255,.14);
  border-radius: 18px;
  padding: 14px 16px;
  display: grid;
  gap: 3px;
}
.event-catalog-summary strong { font-size: 1.45rem; line-height: 1; }
.event-catalog-summary span { font-weight: 700; color: var(--text); }
.event-catalog-summary small { color: var(--muted); line-height: 1.45; }

.event-form { display: grid; gap: 18px; }
.event-form-error {
  background: #fef3f2;
  border: 1px solid #fecdca;
  color: var(--danger);
  border-radius: 16px;
  padding: 14px 16px;
  font-weight: 600;
}
.event-form-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(280px, .9fr);
  gap: 18px;
  align-items: start;
}
.event-form-main { display: grid; gap: 18px; }
.event-card { padding: 22px; }
.event-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 18px;
}
.event-card-header h3 { margin: 0 0 6px; font-size: 1.28rem; }
.event-card-header-split { flex-wrap: wrap; }
.event-basic-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(220px, .8fr);
  gap: 14px;
}
.event-full-span { grid-column: 1 / -1; }
.event-catalog-note {
  margin-bottom: 16px;
  background: rgba(47,92,255,.06);
  border: 1px solid rgba(47,92,255,.12);
  color: var(--text);
  border-radius: 16px;
  padding: 13px 15px;
  line-height: 1.55;
}
.event-products-list { display: grid; gap: 14px; }
.event-product-row {
  position: relative;
  border: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(246,247,251,.98), #fff);
  border-radius: 18px;
  padding: 18px;
  display: grid;
  gap: 12px;
}
.event-product-row.is-unlinked { border-color: #f7b267; }
.event-product-row.is-invalid { border-color: #f04438; box-shadow: 0 0 0 3px rgba(240,68,56,.08); }
.event-product-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) 120px 120px minmax(0, 1.25fr);
  gap: 12px;
  align-items: end;
}
.event-product-field { grid-column: 1 / 2; }
.event-product-comment { grid-column: 4 / 5; }
.event-autocomplete { position: relative; }
.event-product-input {
  padding-right: 44px;
  background-image: linear-gradient(transparent, transparent);
}
.event-autocomplete-list {
  position: absolute;
  inset: calc(100% + 8px) 0 auto 0;
  z-index: 20;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: 0 18px 32px rgba(15, 23, 42, .12);
  overflow: hidden;
}
.event-suggestion-item {
  width: 100%;
  border: none;
  background: #fff;
  display: grid;
  gap: 4px;
  text-align: left;
  padding: 12px 14px;
  cursor: pointer;
}
.event-suggestion-item + .event-suggestion-item { border-top: 1px solid #eef2f7; }
.event-suggestion-item:hover { background: #f8faff; }
.event-suggestion-main { font-weight: 700; color: var(--text); }
.event-suggestion-meta { color: var(--muted); font-size: .82rem; }
.event-product-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.event-product-source { color: var(--muted); font-size: .82rem; }
.event-remove-row {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--muted);
  font-size: 1rem;
  cursor: pointer;
}
.event-remove-row:hover { color: var(--danger); border-color: #fecdca; background: #fff5f4; }

.event-card-side { position: sticky; top: 26px; }
.event-areas-list { display: grid; gap: 10px; }
.event-area-pill {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 12px 14px;
  background: #fff;
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.event-area-pill:hover { border-color: rgba(47,92,255,.22); transform: translateY(-1px); }
.event-area-pill.is-checked {
  border-color: rgba(47,92,255,.45);
  box-shadow: 0 0 0 3px rgba(47,92,255,.08);
  background: linear-gradient(180deg, rgba(47,92,255,.05), #fff);
}
.event-area-pill input[type="checkbox"] {
  width: 17px;
  height: 17px;
  margin-top: 2px;
  accent-color: var(--primary);
}
.event-area-pill-text { display: grid; gap: 3px; }
.event-area-pill-text strong { color: var(--text); }
.event-area-pill-text small { color: var(--muted); line-height: 1.45; }
.event-side-tip {
  margin-top: 16px;
  padding: 14px 15px;
  border-radius: 16px;
  background: #f8fafc;
  color: var(--muted);
  line-height: 1.55;
}
.event-form-actions {
  justify-content: flex-end;
  gap: 12px;
  padding-top: 4px;
}

@media (max-width: 1180px) {
  .event-form-layout { grid-template-columns: 1fr; }
  .event-card-side { position: static; }
}
@media (max-width: 980px) {
  .event-product-grid { grid-template-columns: 1fr 1fr; }
  .event-product-comment,
  .event-product-field { grid-column: auto; }
}
@media (max-width: 720px) {
  .event-card { padding: 18px; }
  .event-basic-grid,
  .event-product-grid { grid-template-columns: 1fr; }
  .event-form-toolbar-actions { width: 100%; justify-content: space-between; }
  .event-catalog-summary { flex: 1 1 auto; min-width: 0; }
  .event-form-actions { justify-content: stretch; }
  .event-form-actions .btn { flex: 1 1 100%; text-align: center; }
}


/* ── v2.0.0 · clasificación formal + eventos operativos ─────────────────── */
.kind-choice-grid {
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.kind-choice {
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 14px 15px;
  background: rgba(255,255,255,.86);
  display:grid;
  gap: 4px;
  cursor:pointer;
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.kind-choice:hover { border-color: rgba(47,92,255,.22); transform: translateY(-1px); }
.kind-choice.is-active {
  border-color: rgba(47,92,255,.4);
  box-shadow: 0 0 0 3px rgba(47,92,255,.08);
  background: linear-gradient(180deg, rgba(47,92,255,.06), rgba(255,255,255,.96));
}
.kind-choice input { margin: 0 0 6px; accent-color: var(--primary); }
.kind-choice strong { color: var(--text); }
.kind-choice small { color: var(--muted); line-height: 1.5; }

.segmented-tabs-wrap { flex-wrap: wrap; }

.event-workbench { display:grid; gap: 18px; }
.event-row-actions { display:flex; gap: 10px; flex-wrap: wrap; }
.event-category-toolbar {
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  margin-bottom: 16px;
}
.event-category-chip {
  display:inline-flex;
  align-items:center;
  gap: 8px;
  border:1px solid var(--border);
  border-radius: 999px;
  padding: 9px 14px;
  background:#fff;
  color: var(--text);
  font-weight:700;
  cursor:pointer;
}
.event-category-chip span {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 22px;
  height: 22px;
  border-radius: 999px;
  background: rgba(47,92,255,.08);
  color: var(--primary);
  font-size: .78rem;
}
.event-category-chip.is-active {
  border-color: rgba(47,92,255,.4);
  color: var(--primary);
  box-shadow: 0 0 0 3px rgba(47,92,255,.08);
}
.event-inline-stats {
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.event-inline-stat {
  border:1px solid rgba(213, 222, 236, .92);
  border-radius: 16px;
  padding: 13px 14px;
  background: rgba(255,255,255,.86);
}
.event-inline-stat span {
  display:block;
  color: var(--muted);
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 700;
}
.event-inline-stat strong {
  display:block;
  margin-top: 8px;
  font-size: 1.35rem;
  line-height: 1;
}
.event-product-row {
  padding-right: 82px;
}
.event-row-inline-actions {
  position:absolute;
  right: 14px;
  top: 14px;
  display:flex;
  gap: 8px;
  align-items:center;
}
.event-mini-btn {
  border:1px solid var(--border);
  border-radius: 12px;
  background:#fff;
  color: var(--text);
  font-weight:700;
  padding: 8px 10px;
  cursor:pointer;
}
.event-mini-btn:hover { border-color: rgba(47,92,255,.24); color: var(--primary); }
.event-suggestion-item {
  position:relative;
}
.event-suggestion-item.is-active,
.event-suggestion-item:hover {
  background: #f8faff;
}
.event-suggestion-stock {
  margin-top: 4px;
}
.event-stock-badge {
  display:inline-flex;
  align-items:center;
  gap: 6px;
  padding: 5px 10px;
  border-radius: 999px;
  font-size: .76rem;
  font-weight: 700;
  background: #f8fafc;
  color: var(--muted);
  border: 1px solid rgba(213, 222, 236, .96);
}
.event-stock-badge.ok {
  background: rgba(31,143,95,.08);
  border-color: rgba(31,143,95,.18);
  color: #18794e;
}
.event-stock-badge.low {
  background: rgba(194,122,16,.08);
  border-color: rgba(194,122,16,.18);
  color: #9a6700;
}
.event-stock-badge.recipe {
  background: rgba(47,92,255,.06);
  border-color: rgba(47,92,255,.16);
  color: var(--primary);
}
.event-side-summary {
  display:grid;
  gap: 10px;
}
.event-side-summary-item {
  border:1px solid var(--border);
  border-radius: 16px;
  background: rgba(255,255,255,.9);
  padding: 12px 14px;
}
.event-side-summary-item span {
  display:block;
  color: var(--muted);
  font-size: .79rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 700;
}
.event-side-summary-item strong {
  display:block;
  margin-top: 6px;
  color: var(--text);
  font-size: 1.02rem;
}
.stock-create-form .hint-box p { margin-bottom: 0; }

@media (max-width: 980px) {
  .kind-choice-grid,
  .event-inline-stats { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  .kind-choice-grid,
  .event-inline-stats { grid-template-columns: 1fr; }
  .event-product-row { padding-right: 18px; }
  .event-row-inline-actions {
    position: static;
    justify-content: flex-end;
  }
}


/* ════════════════════════════════════════════════════════════
   Cuadra UI 2.0.1 · pulido de inputs y sidebar colapsable
   ════════════════════════════════════════════════════════════ */
body.cuadra-ui {
  --sidebar-current-width: 292px;
}
body.cuadra-ui.sidebar-collapsed {
  --sidebar-current-width: 88px;
}
body.cuadra-ui .app-shell {
  grid-template-columns: var(--sidebar-current-width) minmax(0, 1fr);
  transition: grid-template-columns .25s ease;
}
body.cuadra-ui .sidebar {
  width: 100%;
  min-width: 0;
  transition: width .25s ease, transform .25s ease;
}
body.cuadra-ui .main-content {
  min-width: 0;
  width: 100%;
}

body.cuadra-ui .form-group {
  display: grid;
  gap: 8px;
  min-width: 0;
}
body.cuadra-ui .form-group label {
  display: block;
  margin: 0;
  color: var(--text);
  font-size: .94rem;
  font-weight: 700;
  letter-spacing: -.01em;
}
body.cuadra-ui input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
body.cuadra-ui select,
body.cuadra-ui textarea {
  appearance: none;
  width: 100%;
  min-height: 48px;
  padding: 12px 14px;
  border: 1px solid rgba(197, 209, 227, .94);
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff, #fbfcff);
  color: var(--text);
  font: inherit;
  line-height: 1.45;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.94), 0 1px 2px rgba(15, 23, 42, .03);
  transition: border-color .16s ease, box-shadow .16s ease, background-color .16s ease, transform .16s ease;
}
body.cuadra-ui textarea {
  min-height: 112px;
  padding-top: 12px;
  resize: vertical;
}
body.cuadra-ui input::placeholder,
body.cuadra-ui textarea::placeholder,
body.cuadra-ui select:invalid {
  color: #90a0b5;
}
body.cuadra-ui input:hover:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([disabled]),
body.cuadra-ui select:hover:not([disabled]),
body.cuadra-ui textarea:hover:not([disabled]) {
  border-color: rgba(160, 177, 201, .96);
}
body.cuadra-ui input:focus:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
body.cuadra-ui select:focus,
body.cuadra-ui textarea:focus {
  outline: none;
  border-color: rgba(47, 92, 255, .52);
  background: #ffffff;
  box-shadow: 0 0 0 4px rgba(47, 92, 255, .10), 0 12px 28px rgba(15, 23, 42, .06);
}
body.cuadra-ui input[type="date"] {
  padding-right: 12px;
}
body.cuadra-ui input[type="number"] {
  font-variant-numeric: tabular-nums;
}
body.cuadra-ui .event-product-row input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
body.cuadra-ui .event-product-row textarea,
body.cuadra-ui .event-product-row select {
  min-height: 46px;
}
body.cuadra-ui .event-product-meta {
  align-items: center;
}
body.cuadra-ui .event-card,
body.cuadra-ui .hero-metric,
body.cuadra-ui .event-inline-stat,
body.cuadra-ui .event-side-summary-item {
  backdrop-filter: saturate(1.02);
}

@media (max-width: 920px) {
  body.cuadra-ui,
  body.cuadra-ui.sidebar-collapsed {
    --sidebar-current-width: 1fr;
  }
  body.cuadra-ui .app-shell {
    grid-template-columns: 1fr;
  }
}



/* ════════════════════════════════════════════════════════════
   Cuadra UI 2.1.1 · landing sin IA y navegación más legible
   ════════════════════════════════════════════════════════════ */
body.cuadra-ui {
  --surface-soft: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,255,.98));
  --surface-muted: #f7f9fc;
  --control-border-strong: rgba(193, 205, 223, .95);
  --control-ring: rgba(47, 92, 255, .12);
  --table-head: #f7f9fc;
  --table-hover: #f9fbff;
}

.page-toolbar {
  margin-bottom: 18px;
}
.page-toolbar.simple {
  display: block;
}
.page-toolbar.simple h2,
.page-toolbar.simple h1 {
  margin-bottom: 4px;
}

.section-card,
.form-shell-card {
  background: var(--surface-soft);
  border: 1px solid rgba(215, 223, 236, .92);
  border-radius: 24px;
  box-shadow: 0 14px 34px rgba(15, 23, 42, .05);
}

.form-shell-card {
  max-width: 920px;
  padding: 22px;
}
.form-stack {
  display: grid;
  gap: 14px;
}
.ui-grid {
  display: grid;
  gap: 14px;
  align-items: start;
}
.ui-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.ui-grid-3 {
  grid-template-columns: 1.2fr 1fr 1fr;
}
.recipe-grid-secondary {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.form-grid.app-form-grid {
  gap: 18px;
}
.section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.section-head.compact {
  margin-bottom: 10px;
}
.section-head strong {
  font-size: 1rem;
}
.table-section {
  display: grid;
  gap: 10px;
  margin-bottom: 18px;
}
.form-actions-bar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  flex-wrap: wrap;
  padding-top: 16px;
  margin-top: 6px;
  border-top: 1px solid rgba(220, 227, 234, .9);
}
.form-actions-bar .btn:first-child {
  margin-right: auto;
}
.hint-box,
.panel-note,
.soft-note {
  border-radius: 18px;
  border: 1px solid rgba(183, 198, 221, .42);
  background: linear-gradient(180deg, rgba(245,247,255,.96), rgba(255,255,255,.96));
  padding: 14px 16px;
}
.hint-box strong,
.panel-note strong,
.soft-note strong {
  color: var(--text);
}
.checkbox-row,
.checkbox-list {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}
.checkbox-row label,
.checkbox-list label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0;
}

body.cuadra-ui input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
body.cuadra-ui select,
body.cuadra-ui textarea {
  border-color: var(--control-border-strong);
  background: var(--surface-soft);
}
body.cuadra-ui textarea {
  min-height: 120px;
}
body.cuadra-ui select {
  padding-right: 40px;
  background-image:
    linear-gradient(45deg, transparent 50%, #90a0b5 50%),
    linear-gradient(135deg, #90a0b5 50%, transparent 50%),
    linear-gradient(180deg, rgba(255,255,255,.85), rgba(251,252,255,.95));
  background-position:
    calc(100% - 20px) calc(50% - 2px),
    calc(100% - 14px) calc(50% - 2px),
    0 0;
  background-size: 6px 6px, 6px 6px, 100% 100%;
  background-repeat: no-repeat;
}
body.cuadra-ui input:focus:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
body.cuadra-ui select:focus,
body.cuadra-ui textarea:focus {
  box-shadow: 0 0 0 4px var(--control-ring), 0 16px 34px rgba(15, 23, 42, .07);
}
body.cuadra-ui input[readonly],
body.cuadra-ui textarea[readonly] {
  background: #f5f7fb;
  color: #7b899c;
}

.btn,
.primary-submit,
.btn-submit,
.btn-enviar,
.btn-armar,
.btn-guardar,
.btn-merma {
  border-radius: 14px;
  font-weight: 700;
}
.primary-submit {
  min-height: 48px;
  box-shadow: 0 12px 28px rgba(31, 111, 235, .18);
}
.primary-submit.danger {
  background: linear-gradient(180deg, #ef5350, #db3f3c);
  box-shadow: 0 12px 28px rgba(191, 33, 30, .18);
}
.primary-submit.danger:hover {
  background: linear-gradient(180deg, #eb4b47, #c83330);
}

.table-shell {
  overflow: hidden;
  border-radius: 22px;
  border: 1px solid rgba(216, 225, 237, .95);
  background: rgba(255,255,255,.96);
  box-shadow: 0 10px 24px rgba(15, 23, 42, .05);
}
.table-wrap {
  overflow: auto;
  border: 1px solid rgba(224, 230, 240, .9);
  border-radius: 18px;
  background: #fff;
}
body.cuadra-ui table.data-table,
body.cuadra-ui .adj-table,
body.cuadra-ui .merma-hist,
body.cuadra-ui .sol-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}
body.cuadra-ui table.data-table thead th,
body.cuadra-ui .adj-table thead th,
body.cuadra-ui .merma-hist thead th,
body.cuadra-ui .sol-table thead th,
body.cuadra-ui table thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--table-head);
  border-bottom: 1px solid rgba(220, 227, 234, .96);
  color: #5c6c81;
  font-size: .76rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
}
body.cuadra-ui table tbody tr:hover td {
  background: var(--table-hover);
}
body.cuadra-ui table tbody td {
  border-bottom-color: rgba(228, 234, 243, .92);
}
body.cuadra-ui table tbody tr:last-child td {
  border-bottom: none;
}
body.cuadra-ui table td:first-child,
body.cuadra-ui table th:first-child {
  padding-left: 14px;
}
body.cuadra-ui table td:last-child,
body.cuadra-ui table th:last-child {
  padding-right: 14px;
}

.autocomplete-wrap {
  position: relative;
}
.autocomplete-input {
  padding-right: 42px !important;
}
.autocomplete-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: #ffffff;
  border: 1px solid rgba(186, 198, 219, .95);
  border-radius: 18px;
  box-shadow: 0 18px 42px rgba(15, 23, 42, .12);
  max-height: 280px;
  overflow-y: auto;
  z-index: 40;
  display: none;
}
.autocomplete-dropdown.open {
  display: block;
}
.autocomplete-item {
  padding: 12px 14px;
  cursor: pointer;
  font-size: .92rem;
  border-bottom: 1px solid rgba(228, 234, 243, .9);
}
.autocomplete-item:last-child {
  border-bottom: none;
}
.autocomplete-item:hover,
.autocomplete-item.selected {
  background: #eef4ff;
  color: var(--text);
}
.autocomplete-item small {
  display: inline-flex;
  margin-left: 8px;
  color: var(--muted);
  font-size: .78rem;
}

.req-section,
.sol-section,
.merma-form,
.depto-section,
.adjust-shell {
  padding: 20px;
}
.req-section h3,
.sol-section h3,
.merma-form h3 {
  margin: 0 0 14px;
  font-size: .85rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #5d6d81;
}
.r-field,
.m-field {
  display: grid;
  gap: 7px;
  margin-bottom: 14px;
}
.r-field label,
.m-field label {
  margin: 0;
  color: var(--text);
  font-size: .9rem;
  font-weight: 700;
}

.items-list,
#sol-list {
  display: grid;
  gap: 10px;
}
.item-row,
.sol-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 104px 82px 36px;
  gap: 10px;
  align-items: center;
  border: 1px solid rgba(216, 225, 237, .92);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(248,250,255,.9), rgba(255,255,255,.98));
  padding: 12px 14px;
}
.item-row-name,
.sol-row-name,
.adj-item-name {
  font-weight: 700;
}
.item-row-unit,
.sol-row-unit,
.adj-item-cur,
.stock-preview {
  color: var(--muted);
  font-size: .82rem;
}
.item-qty,
.qty-input,
.adj-input {
  min-height: 42px !important;
  text-align: center;
}
.item-del {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  border: 1px solid rgba(220, 227, 234, .95);
  background: #fff;
}
.item-del:hover {
  background: #fff3f2;
}
.empty-items,
.empty-sol,
.empty-bnd {
  text-align: center;
  padding: 28px 18px;
  border: 1px dashed rgba(197, 209, 227, .94);
  border-radius: 18px;
  color: var(--muted);
  background: rgba(249, 251, 255, .9);
}

.scope-tabs {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.scope-tab {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid rgba(207, 216, 228, .95);
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,248,252,.98));
  color: var(--muted);
  font-size: .85rem;
  font-weight: 700;
  cursor: pointer;
  transition: all .16s ease;
}
.scope-tab.active,
.scope-tab:hover {
  color: var(--primary);
  border-color: rgba(47, 92, 255, .28);
  box-shadow: 0 0 0 4px rgba(47, 92, 255, .08);
}
.btn-guardar {
  position: sticky;
  bottom: 16px;
  width: 100%;
  display: none;
}
.btn-guardar.visible {
  display: block;
}

.merma-layout {
  align-items: start;
}
.compact-number {
  max-width: 108px;
}
.compact-unit {
  max-width: 88px;
}
.saving-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(3, 10, 24, .56);
  z-index: 999;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: #fff;
  font-weight: 700;
}
.saving-overlay.show {
  display: flex;
}

@media (max-width: 980px) {
  .ui-grid-2,
  .ui-grid-3,
  .recipe-grid-secondary,
  .merma-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .item-row,
  .sol-row {
    grid-template-columns: minmax(0, 1fr) 88px 74px 34px;
  }
  .form-actions-bar {
    justify-content: stretch;
  }
  .form-actions-bar .btn,
  .form-actions-bar .primary-submit {
    width: 100%;
  }
  .form-actions-bar .btn:first-child {
    margin-right: 0;
  }
}


.pending-sol-card {
  margin-top: 18px;
}
.pending-sol-meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.scope-select,
.readonly-input {
  width: 100%;
}
.readonly-input {
  background: #f5f7fb;
  color: var(--muted);
}
.badge-pend {
  background: rgba(245,158,11,.12);
  color: #b45309;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: .75rem;
  font-weight: 700;
}
.depto-header {
  padding: 14px 18px;
  border-bottom: 1px solid rgba(220, 227, 234, .92);
  background: #f8faff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.depto-header h3 {
  margin: 0;
  font-size: .96rem;
}
.depto-header .count {
  color: var(--muted);
  font-size: .82rem;
  font-weight: 700;
}
.mis-sol-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(228,234,243,.92);
}
.mis-sol-item:last-child {
  border-bottom: none;
}
