:root {
  --bg: #f4f7fc;
  --panel: rgba(255,255,255,.92);
  --text: #1f2940;
  --muted: #5f6d87;
  --red: #d7262d;
  --red-dark: #b31b21;
  --blue: #173f97;
  --blue-dark: #0f2f77;
  --blue-soft: #edf3ff;
  --red-soft: #fff1f2;
  --line: rgba(23,63,151,.12);
  --shadow: 0 20px 60px rgba(20,45,98,.12);
  --radius: 22px;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(215,38,45,.12), transparent 26rem),
    radial-gradient(circle at top right, rgba(23,63,151,.10), transparent 28rem),
    linear-gradient(180deg, #ffffff 0%, var(--bg) 100%);
  min-height: 100vh;
}

a { color: inherit; text-decoration: none; }
.login-shell,
.app-shell { width: min(1220px, calc(100% - 32px)); margin: 0 auto; }

.login-shell { min-height: 100vh; display: grid; place-items: center; }
.login-card, .card, .toolbar, .table-wrap {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  backdrop-filter: blur(12px);
}
.login-card { width: min(540px, 100%); padding: 34px; }
.brand-row { gap: 16px; }
.brand-logo-wrap {
  width: 92px; height: 92px; border-radius: 24px; background: #fff;
  display: grid; place-items: center; box-shadow: 0 14px 28px rgba(23,63,151,.14);
  border: 1px solid rgba(23,63,151,.08);
  flex: 0 0 auto;
}
.login-logo-wrap { width: 108px; height: 108px; }
.brand-logo {
  display:block; width: 84%; height: 84%; object-fit: contain;
}
.logo-row { display:flex; align-items:center; gap:14px; margin-bottom:18px; }
.org { color: var(--muted); font-size: .93rem; line-height: 1.35; margin-top: 3px; }
h1 { margin: 0; font-size: clamp(1.7rem, 3vw, 2.45rem); line-height: 1.05; color: var(--blue-dark); }
h2 { margin: 0 0 14px; font-size: 1.25rem; color: var(--blue-dark); }
h3 { margin: 0 0 10px; color: var(--blue-dark); }
p { color: var(--muted); line-height: 1.55; }

.alert {
  padding: 12px 14px; border-radius: 14px; margin: 14px 0;
  background: #fff2f2; color: #8d1519; border: 1px solid #f0c5c7;
}
.success { background: #eff8ff; color: #19467f; border-color: #cfe0ff; }

label { display:block; font-size:.9rem; color: #31425f; margin: 12px 0 6px; font-weight: 650; }
input, select, textarea {
  width:100%; border:1px solid var(--line); border-radius:14px; padding:12px 13px;
  background:#fff; color:var(--text); outline:none; font: inherit;
}
textarea { min-height: 100px; resize: vertical; }
input:focus, select:focus, textarea:focus {
  border-color: rgba(23,63,151,.45); box-shadow: 0 0 0 4px rgba(23,63,151,.08);
}

button, .btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border:1px solid rgba(23,63,151,.28); border-radius: 999px; padding: 11px 18px; font-weight: 750;
  background: transparent; color: var(--blue); cursor:pointer; font-size:.95rem;
  box-shadow: none;
}
button:hover, .btn:hover { background: rgba(23,63,151,.06); border-color: rgba(23,63,151,.42); }
.btn.secondary {
  background: transparent; color: var(--blue); border: 1px solid rgba(23,63,151,.22); box-shadow:none;
}
.btn.ghost { background: transparent; color: var(--blue); border: 1px solid transparent; box-shadow:none; }
.btn.danger { background: transparent; color:#991b1b; border-color: rgba(153,27,27,.34); }
.btn.danger:hover { background: rgba(153,27,27,.06); }
.actions { display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-top:18px; }

.topbar {
  margin: 18px 0 22px; display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.nav { display:flex; flex-wrap:wrap; gap:8px; }
.nav a {
  padding:10px 14px; border:1px solid var(--line); border-radius:999px; background:rgba(255,255,255,.8);
  color:#2a467f; font-weight:700;
}
.nav a.active, .nav a:hover {
  background: rgba(23,63,151,.06); color: var(--blue-dark); border-color: rgba(23,63,151,.26);
}
.user-box { text-align:right; color: var(--muted); font-size:.9rem; }
.user-box strong { color: var(--blue-dark); }

.grid { display:grid; gap:18px; }
.grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.card { padding:22px; }
.toolbar { padding:18px; margin-bottom:18px; }
.form-row { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:14px; }
.block-item { border:1px solid var(--line); border-radius:18px; padding:18px; margin:14px 0; background:rgba(255,255,255,.78); }
.block-head { display:flex; justify-content:space-between; align-items:center; gap:12px; }
.muted { color: var(--muted); font-size:.92rem; }

.table-wrap { overflow:auto; }
table { width:100%; border-collapse:collapse; min-width: 860px; }
th, td { text-align:left; padding:12px 14px; border-bottom:1px solid var(--line); vertical-align:top; }
th {
  font-size:.82rem; color:#39558c; text-transform:uppercase; letter-spacing:.04em; background:rgba(237,243,255,.8);
}
tr:hover td { background: rgba(23,63,151,.03); }
.badge { display:inline-flex; align-items:center; border-radius:999px; padding:5px 10px; font-size:.78rem; font-weight:800; background:#fff1f2; color:#a51d23; }
.badge.ok { background:#edf6ff; color:#1f4b86; }

.search-results { margin-top:12px; display:grid; gap:10px; }
.result-item {
  padding:14px; border:1px solid var(--line); border-radius:16px; background:#fff; cursor:pointer;
}
.result-item:hover { border-color: rgba(23,63,151,.35); box-shadow:0 10px 20px rgba(23,63,151,.08); }
.result-item strong { color: var(--blue-dark); }

.preview-frame {
  border:1px solid var(--line); border-radius:18px; background:#fff; min-height:480px; overflow:hidden;
}
.preview-frame iframe { width:100%; height:620px; border:0; }

.stat-card {
  background: rgba(255,255,255,.92);
  color: var(--text); border-radius: 22px; padding: 24px; box-shadow: var(--shadow);
  border:1px solid var(--line);
}
.stat-card h2 { color: var(--blue-dark); margin:0; font-size:2rem; margin-bottom:8px; }
.stat-card p { color: var(--muted); margin:0; }
.inline-note {
  display:inline-flex; gap:8px; align-items:center; padding:8px 12px; border-radius:999px;
  background: var(--blue-soft); color: var(--blue-dark); font-size:.88rem; font-weight:700;
}
.file-chip {
  display:inline-flex; gap:8px; align-items:center; padding:10px 14px; border-radius:14px;
  background: #fff; border:1px solid var(--line); color: var(--blue-dark); font-weight:650;
}

/* Interfaz de captura ampliada */
.entry-card { max-width: 1180px; margin: 0 auto 36px; padding: 30px; }
.entry-title-row { display:flex; justify-content:space-between; align-items:flex-start; gap:18px; margin-bottom: 10px; }
.large-form label { font-size:1rem; margin-top: 16px; }
.large-form input,
.large-form textarea,
.large-form select { font-size:1.08rem; padding:16px 17px; border-radius:18px; }
.large-form textarea { min-height: 160px; line-height: 1.45; }
.folio-panel {
  padding: 18px; border:1px solid var(--line); border-radius:20px; background: rgba(255,255,255,.72); margin: 18px 0;
}
.folio-input { font-size:1.25rem !important; font-weight:800; letter-spacing:.02em; }
.reason-panel { padding: 18px; border:1px solid #f0cccc; border-radius:20px; background:#fff8f8; margin: 18px 0; }
.capture-block { padding:24px; }
.capture-grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:18px; }
.capture-grid .names-field { grid-column: 1 / -1; }
.sticky-actions {
  position: sticky; bottom: 0; z-index:5; background: rgba(255,255,255,.94); padding: 16px;
  border:1px solid var(--line); border-radius:20px; backdrop-filter: blur(12px);
}
.search-live-input { max-width: 720px; font-size:1.02rem; }
.table-actions { display:flex; flex-wrap:wrap; gap:8px; }
.small-text { font-size:.82rem; color: var(--muted); }

@media (max-width: 800px) {
  .topbar { align-items:flex-start; flex-direction:column; }
  .user-box { text-align:left; }
  .grid.two, .grid.three, .form-row { grid-template-columns: 1fr; }
  .login-card, .card, .toolbar { padding:18px; }
  table { min-width: 760px; }
  .nav a { font-size:.9rem; padding:9px 12px; }
  .entry-title-row { flex-direction:column; }
  .entry-card { padding:20px; }
  .capture-grid { grid-template-columns:1fr; }
  .large-form input,
  .large-form textarea,
  .large-form select { font-size:1rem; padding:14px; }
  .sticky-actions { position: static; }
  .brand-logo-wrap { width: 82px; height: 82px; }
}

.checkline { display:flex; align-items:center; gap:8px; margin:8px 0; font-weight:650; color: var(--text); }
.checkline input { width:auto; }

.change-list { margin:0; padding-left: 18px; }
.change-list li { margin: 6px 0; color: var(--text); }
.change-old { color: #8d1519; font-weight: 650; }
.change-new { color: #1f4b86; font-weight: 650; }
.code-block {
  white-space: pre-wrap; max-width: 420px; font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: .82rem; background: #f8fbff; border: 1px solid var(--line); padding: 12px; border-radius: 12px;
}

.bar-chart { display:grid; gap:14px; margin-top:16px; }
.bar-row { display:grid; grid-template-columns:minmax(180px, 280px) 1fr 64px; gap:12px; align-items:center; }
.bar-label { font-weight:700; color: var(--blue-dark); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.bar-track { height:18px; border-radius:999px; background:rgba(23,63,151,.08); border:1px solid rgba(23,63,151,.12); overflow:hidden; }
.bar-fill { height:100%; border-radius:999px; background:linear-gradient(90deg, rgba(23,63,151,.78), rgba(215,38,45,.70)); }
.bar-number { text-align:right; font-weight:800; color:var(--blue-dark); }
@media (max-width: 800px) {
  .bar-row { grid-template-columns:1fr; gap:7px; }
  .bar-number { text-align:left; }
}
