/* ============================================================
   Diagnóstico fiscal-patrimonial — tema claro refinado
   Display: Fraunces (serif) · Texto: Hanken Grotesk
   ============================================================ */
:root{
  --font-serif:'Fraunces','Georgia',serif;
  --font-sans:'Hanken Grotesk','Segoe UI',system-ui,-apple-system,sans-serif;

  --bg:#eef3f5;
  --surface:#ffffff;
  --ink:#16242e;
  --muted:#5d6e7a;
  --faint:#8a98a4;
  --line:#e3eaee;

  --brand:#0e4b57;
  --brand-2:#2b7c8c;
  --accent:#c0883a;

  --ok:#1f8a4e;  --ok-bg:#e8f4ec;  --ok-bd:#c2e2cd;
  --warn:#a9701a; --warn-bg:#fbf1dc; --warn-bd:#eed8a8;
  --bad:#b5392c;  --bad-bg:#fbe9e6;  --bad-bd:#f1cabf;

  --r:14px; --r-lg:20px;
  --sh-sm:0 1px 2px rgba(20,40,50,.06);
  --sh:0 10px 30px -14px rgba(14,75,87,.28);
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:
    radial-gradient(900px 480px at 88% -8%, rgba(43,124,140,.10), transparent 60%),
    radial-gradient(700px 460px at -6% 8%, rgba(192,136,58,.08), transparent 55%),
    var(--bg);
  color:var(--ink);
  font-family:var(--font-sans);
  font-size:15px; line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--brand-2);text-decoration:none}
a:hover{color:var(--brand);text-decoration:underline}
h1,h2,h3{font-family:var(--font-serif);font-weight:560;letter-spacing:-.01em}

/* ---------- Topbar ---------- */
.topbar{
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 28px;gap:20px;flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:13px}
.logo{
  width:42px;height:42px;border-radius:12px;color:#fff;font-weight:700;
  display:flex;align-items:center;justify-content:center;letter-spacing:.5px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2) 70%,var(--accent));
  box-shadow:var(--sh-sm);
}
.t1{font-family:var(--font-serif);font-weight:600;color:var(--brand);font-size:17px;line-height:1.1}
.t2{font-size:11.5px;color:var(--faint);letter-spacing:.02em}
.userbox{display:flex;align-items:center;gap:14px}
.uname{font-weight:600;color:var(--brand);font-size:13.5px}

/* ---------- Nav ---------- */
.mainnav{
  background:rgba(255,255,255,.7);
  border-bottom:1px solid var(--line);
  padding:0 24px;display:flex;gap:6px;flex-wrap:wrap;
}
.mainnav a{
  padding:14px 14px 12px;color:var(--muted);font-weight:600;font-size:14px;
  border-bottom:2.5px solid transparent;transition:color .15s,border-color .15s;
}
.mainnav a:hover{color:var(--brand);text-decoration:none}
.mainnav a.active{color:var(--brand);border-bottom-color:var(--accent)}

/* ---------- Layout ---------- */
.wrap{max-width:1080px;margin:30px auto;padding:0 22px}
h1{font-size:25px;color:var(--brand);margin:0 0 4px}
h2{font-size:18px;color:var(--brand);margin:0 0 16px}
.sub{color:var(--muted);margin:0 0 20px;font-size:14px}

/* ---------- Flash ---------- */
.flash{padding:12px 16px;border-radius:11px;margin-bottom:20px;font-weight:600;font-size:14px;animation:rise .4s ease both}
.flash-ok{background:var(--ok-bg);color:var(--ok);border:1px solid var(--ok-bd)}
.flash-err{background:var(--bad-bg);color:var(--bad);border:1px solid var(--bad-bd)}

/* ---------- Alertas ---------- */
.alertas{display:flex;flex-direction:column;gap:11px;margin-bottom:24px}
.alerta{
  padding:13px 18px;border-radius:12px;font-size:14px;border:1px solid;
  position:relative;padding-left:20px;background:var(--surface);box-shadow:var(--sh-sm);
  animation:rise .45s ease both;
}
.alerta::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;border-radius:12px 0 0 12px}
.alerta b{font-weight:700}
.alerta a{font-weight:700}
.alerta-rojo{border-color:var(--bad-bd);color:#7d2a20}
.alerta-rojo::before{background:var(--bad)}
.alerta-ambar{border-color:var(--warn-bd);color:#7a5314}
.alerta-ambar::before{background:var(--warn)}
.alerta-verde{border-color:var(--ok-bd);color:#185f37}
.alerta-verde::before{background:var(--ok)}

/* ---------- KPIs ---------- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}
.kpi{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:20px 18px;box-shadow:var(--sh-sm);position:relative;overflow:hidden;
  animation:rise .5s ease both;
}
.kpi::after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--brand-2);opacity:.7}
.kpi-ok::after{background:var(--ok)} .kpi-pend::after{background:var(--warn)} .kpi-pct::after{background:var(--accent)}
.kpi-num{font-family:var(--font-serif);font-size:29px;font-weight:600;color:var(--brand);font-variant-numeric:tabular-nums;line-height:1.1}
.kpi-lbl{font-size:12px;color:var(--muted);margin-top:6px;text-transform:uppercase;letter-spacing:.04em}
.kpi-ok .kpi-num{color:var(--ok)} .kpi-pend .kpi-num{color:var(--warn)} .kpi-pct .kpi-num{color:var(--accent)}

/* ---------- Progress ---------- */
.progress{height:11px;background:#dfe7eb;border-radius:20px;overflow:hidden;margin-bottom:8px}
.progress-bar{height:100%;background:linear-gradient(90deg,var(--brand-2),var(--brand));border-radius:20px;transition:width .5s ease}

/* ---------- Cards ---------- */
.cards{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:22px 24px;margin-bottom:18px;box-shadow:var(--sh-sm);animation:rise .5s ease both;
}
.card h2{margin-bottom:14px}
.opinion{padding:11px 15px;border-radius:10px;font-size:14.5px}
.op-neg{background:var(--bad-bg);color:#7d2a20} .op-pos{background:var(--ok-bg);color:#185f37}
.meta-obj{color:var(--muted);margin:12px 0 0;font-size:14px}
.meta-ok{color:var(--ok);font-weight:600;margin:12px 0 0}

/* ---------- Gráficas (altura fija: evita el crecimiento infinito) ---------- */
.chart-wrap{position:relative;height:280px;width:100%}
.chart-wrap canvas{position:absolute;inset:0}

/* ---------- Tablas ---------- */
.grid{
  width:100%;border-collapse:separate;border-spacing:0;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:22px;box-shadow:var(--sh-sm);
}
.grid th{
  background:#f3f7f8;color:var(--brand);text-align:left;padding:12px 14px;
  font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  border-bottom:1px solid var(--line);
}
.grid td{padding:12px 14px;border-top:1px solid var(--line);font-size:14px;font-variant-numeric:tabular-nums}
.grid tbody tr:hover td{background:#f7fafb}
.grid .r{text-align:right} .grid .c{text-align:center}
.grid.mini th,.grid.mini td{padding:9px 12px;font-size:13px}
.empty{color:var(--faint);text-align:center;padding:20px}

/* ---------- Badges ---------- */
.badge{display:inline-block;padding:3px 11px;border-radius:20px;font-size:11.5px;font-weight:700;letter-spacing:.02em}
.badge-ok{background:var(--ok-bg);color:var(--ok)}
.badge-pend{background:var(--warn-bg);color:var(--warn)}
.badge-bad{background:var(--bad-bg);color:var(--bad)}

/* ---------- Botones ---------- */
.btn{
  display:inline-block;padding:10px 17px;border-radius:10px;border:1px solid var(--line);
  background:var(--surface);color:var(--ink);font-weight:600;cursor:pointer;font-size:14px;
  font-family:var(--font-sans);transition:transform .12s,box-shadow .15s,border-color .15s;
}
.btn:hover{text-decoration:none;border-color:var(--brand-2);transform:translateY(-1px);box-shadow:var(--sh-sm)}
.btn-primary{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;border-color:transparent}
.btn-primary:hover{box-shadow:var(--sh)}
.btn-ghost{background:transparent;color:var(--muted)}
.btn-mini{padding:6px 11px;font-size:12.5px;border-radius:8px}
.btn-ok{background:var(--ok-bg);color:var(--ok);border-color:var(--ok-bd)}
.btn-bad{background:var(--bad-bg);color:var(--bad);border-color:var(--bad-bd)}
.btn-block{width:100%;display:block;text-align:center}
.acciones{display:flex;gap:7px;justify-content:center;align-items:center;flex-wrap:wrap}
.inline{display:inline}

/* ---------- Filtros ---------- */
.filtros{display:flex;gap:16px;align-items:flex-end;margin-bottom:18px;flex-wrap:wrap}
.filtros label{font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:5px;font-weight:600}
.filtros select{padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:var(--surface);min-width:150px;font-family:var(--font-sans)}

/* ---------- Formularios ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid label{display:flex;flex-direction:column;gap:6px;font-size:12.5px;color:var(--muted);font-weight:600}
.form-grid input,.form-grid select{
  padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:#fcfdfe;
  font-size:14px;color:var(--ink);font-family:var(--font-sans);transition:border-color .15s,box-shadow .15s;
}
.form-grid input:focus,.form-grid select:focus{outline:none;border-color:var(--brand-2);box-shadow:0 0 0 3px rgba(43,124,140,.12)}
.col-2{grid-column:1 / -1}
.form-actions{display:flex;gap:10px;margin-top:6px}
.chk{flex-direction:row !important;align-items:center;gap:9px !important}
.chk input{width:auto}

/* ---------- Paneles de datos (CSF) ---------- */
.datos2{display:grid;grid-template-columns:1fr 1fr;gap:14px 28px}
.datos2 div{font-size:14px}
.datos2 div span{display:block;font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px;font-weight:600}
.datos2 .col-2{grid-column:1 / -1}
.editor{margin-top:18px;border-top:1px dashed var(--line);padding-top:12px}
.editor summary{cursor:pointer;color:var(--brand-2);font-weight:600;font-size:14px}

.lista{margin:0;padding-left:18px}
.lista li{margin-bottom:9px;line-height:1.5}
.lista li::marker{color:var(--accent)}
.quick{display:flex;flex-wrap:wrap;gap:10px}
.nota{color:var(--faint);font-size:12.5px;margin-top:12px}

/* ---------- Modal ---------- */
.modal{display:none;position:fixed;inset:0;background:rgba(16,36,46,.5);z-index:50;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.modal.show{display:flex}
.modal-box{background:var(--surface);border-radius:var(--r-lg);padding:26px;width:min(440px,92vw);box-shadow:var(--sh);animation:pop .25s ease both}
.modal-box h3{margin:0 0 4px;color:var(--brand)}
.modal-box label{display:flex;flex-direction:column;gap:6px;font-size:12.5px;color:var(--muted);font-weight:600;margin-bottom:13px}
.modal-box input{padding:10px 12px;border:1px solid var(--line);border-radius:10px}

/* ---------- Footer ---------- */
.foot{text-align:center;color:var(--faint);font-size:12px;padding:30px 0 46px}

/* ---------- Login ---------- */
.login-bg{
  min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:
    radial-gradient(680px 420px at 18% 12%, rgba(43,124,140,.16), transparent 60%),
    radial-gradient(620px 420px at 86% 88%, rgba(192,136,58,.14), transparent 60%),
    linear-gradient(160deg,#f3f7f8,#e7eef1);
}
.login-card{
  background:var(--surface);border:1px solid var(--line);border-radius:24px;
  padding:40px 36px;width:min(420px,94vw);box-shadow:0 30px 70px -30px rgba(14,75,87,.45);
  text-align:center;animation:rise .5s ease both;
}
.login-logo{
  width:60px;height:60px;border-radius:17px;color:#fff;font-weight:700;font-size:22px;letter-spacing:.5px;
  display:flex;align-items:center;justify-content:center;margin:0 auto 18px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2) 65%,var(--accent));
  box-shadow:0 12px 28px -10px rgba(14,75,87,.55);
}
.login-card h1{font-size:22px;margin:0 0 2px}
.login-card .sub{margin-bottom:6px}
.login-form{text-align:left;margin-top:20px;display:flex;flex-direction:column;gap:14px}
.login-form label{font-size:12.5px;color:var(--muted);font-weight:600;display:flex;flex-direction:column;gap:6px}
.login-form input{padding:12px 14px;border:1px solid var(--line);border-radius:11px;font-size:15px;background:#fcfdfe;font-family:var(--font-sans);transition:border-color .15s,box-shadow .15s}
.login-form input:focus{outline:none;border-color:var(--brand-2);box-shadow:0 0 0 3px rgba(43,124,140,.14)}
.login-form .btn-primary{padding:13px;font-size:15px;margin-top:4px}
.login-foot{margin-top:18px;color:var(--faint);font-size:12px}

/* ---------- Animaciones ---------- */
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes pop{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
@media (prefers-reduced-motion:reduce){*{animation:none !important;transition:none !important}}

@media(max-width:760px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .cards{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .wrap{margin:20px auto}
}
