/* ============================================================
   SELVA YASUNÍ — Portal de Informe y Auditoría
   Sistema de diseño corporativo
   ============================================================ */
:root{
  --azul:#1F9ECE;
  --azul-osc:#14598A;
  --dorado:#C9A227;
  --verde:#3DAE6E;
  --tinta:#0f2230;
  --gris:#5b6b76;
  --linea:#e6ebef;
  --fondo:#f4f7f9;
  --panel:#ffffff;
  --rojo:#d64550;
  --naranja:#e08a1e;
  --sombra:0 1px 3px rgba(16,40,55,.06),0 8px 24px rgba(16,40,55,.06);
  --radio:14px;
  --sidebar:264px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter','Segoe UI',system-ui,-apple-system,sans-serif;
  background:var(--fondo);color:var(--tinta);
  font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;
}
a{color:var(--azul-osc);text-decoration:none}
h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.01em}

/* ---------- Layout ---------- */
.app{display:flex;min-height:100vh}
.sidebar{
  width:var(--sidebar);flex:0 0 var(--sidebar);
  background:linear-gradient(170deg,var(--azul-osc) 0%,#0e466e 60%,#0b3a5c 100%);
  color:#fff;position:fixed;top:0;bottom:0;left:0;display:flex;flex-direction:column;
  z-index:20;
}
.sidebar .brand{padding:22px 22px 14px;border-bottom:1px solid rgba(255,255,255,.12)}
.sidebar .brand img{width:100%;max-width:170px;display:block}
.sidebar .brand .lema{font-size:11px;color:var(--dorado);margin-top:8px;font-weight:600;letter-spacing:.02em}
.nav{padding:14px 12px;flex:1;overflow-y:auto}
.nav .grp{font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.45);margin:14px 12px 6px}
.nav a{
  display:flex;align-items:center;gap:11px;color:rgba(255,255,255,.82);
  padding:10px 13px;border-radius:10px;font-weight:500;margin-bottom:2px;transition:.15s;
}
.nav a .ic{width:19px;height:19px;flex:0 0 19px;opacity:.85}
.nav a:hover{background:rgba(255,255,255,.08);color:#fff}
.nav a.active{background:var(--azul);color:#fff;box-shadow:0 4px 14px rgba(31,158,206,.4)}
.nav a.active .ic{opacity:1}
.sidebar .foot{padding:14px 18px;border-top:1px solid rgba(255,255,255,.12);font-size:11.5px;color:rgba(255,255,255,.6)}
.sidebar .foot a{color:#fff;font-weight:600}

.main{margin-left:var(--sidebar);flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{
  background:var(--panel);border-bottom:1px solid var(--linea);
  padding:16px 30px;display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:10;
}
.topbar .tt h1{font-size:20px}
.topbar .tt p{margin:2px 0 0;color:var(--gris);font-size:12.5px}
.topbar .acc{display:flex;align-items:center;gap:12px}
.content{padding:26px 30px 50px}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex;align-items:center;gap:7px;border:1px solid var(--linea);
  background:#fff;color:var(--tinta);padding:9px 15px;border-radius:9px;
  font-size:13px;font-weight:600;cursor:pointer;transition:.15s;
}
.btn:hover{border-color:var(--azul);color:var(--azul-osc)}
.btn-primary{background:var(--azul);border-color:var(--azul);color:#fff}
.btn-primary:hover{background:var(--azul-osc);border-color:var(--azul-osc);color:#fff}
.btn-pdf{background:var(--rojo);border-color:var(--rojo);color:#fff}
.btn-pdf:hover{background:#b9303b;border-color:#b9303b;color:#fff}
.btn-ghost{background:transparent}

/* ---------- Tarjetas KPI ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:22px}
.kpi{
  background:var(--panel);border:1px solid var(--linea);border-radius:var(--radio);
  padding:18px 18px 16px;box-shadow:var(--sombra);position:relative;overflow:hidden;
}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--azul)}
.kpi.k-dorado::before{background:var(--dorado)}
.kpi.k-verde::before{background:var(--verde)}
.kpi.k-rojo::before{background:var(--rojo)}
.kpi.k-osc::before{background:var(--azul-osc)}
.kpi .lab{font-size:11.5px;color:var(--gris);text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.kpi .val{font-size:25px;font-weight:800;margin:7px 0 2px;letter-spacing:-.02em}
.kpi .sub{font-size:12px;color:var(--gris)}
.kpi .sub b{color:var(--verde)}
.kpi .sub.neg b{color:var(--rojo)}

/* ---------- Paneles ---------- */
.panel{background:var(--panel);border:1px solid var(--linea);border-radius:var(--radio);box-shadow:var(--sombra);margin-bottom:22px}
.panel>.hd{padding:16px 20px;border-bottom:1px solid var(--linea);display:flex;align-items:center;justify-content:space-between}
.panel>.hd h3{font-size:15px}
.panel>.hd .badge{font-size:11px;color:var(--gris)}
.panel>.bd{padding:18px 20px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:1100px){.grid-2,.grid-3{grid-template-columns:1fr}}

/* ---------- Tablas ---------- */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{
  text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  color:var(--gris);font-weight:700;padding:10px 12px;border-bottom:2px solid var(--linea);white-space:nowrap;
}
.tbl td{padding:10px 12px;border-bottom:1px solid var(--linea)}
.tbl tr:last-child td{border-bottom:0}
.tbl tbody tr:hover{background:#f8fbfd}
.tbl .r{text-align:right;font-variant-numeric:tabular-nums}
.tbl .c{text-align:center}
.tbl tfoot td{font-weight:800;border-top:2px solid var(--linea);background:#fafcfe}

/* ---------- Pills / chips ---------- */
.pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700}
.pill-verde{background:#e6f5ee;color:#1f7a4d}
.pill-rojo{background:#fceaec;color:#b9303b}
.pill-azul{background:#e6f4fb;color:#14598A}
.pill-dorado{background:#fbf3da;color:#94781a}
.pill-gris{background:#eef2f4;color:#5b6b76}

/* ---------- Filtros ---------- */
.filtros{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}
.filtros .f{display:flex;flex-direction:column;gap:4px}
.filtros label{font-size:11px;font-weight:700;color:var(--gris);text-transform:uppercase;letter-spacing:.03em}
.filtros select,.filtros input{
  border:1px solid var(--linea);border-radius:8px;padding:8px 11px;font-size:13px;
  background:#fff;color:var(--tinta);min-width:140px;font-family:inherit;
}
.filtros select:focus,.filtros input:focus{outline:none;border-color:var(--azul)}

/* ---------- Charts ---------- */
.chart-wrap{position:relative;height:300px}
.chart-wrap.sm{height:240px}

/* ---------- Auditoría ---------- */
.finding{border:1px solid var(--linea);border-radius:12px;padding:16px 18px;margin-bottom:14px;background:#fff;border-left-width:5px}
.finding.sev-critico{border-left-color:var(--rojo)}
.finding.sev-medio{border-left-color:var(--naranja)}
.finding.sev-info{border-left-color:var(--azul)}
.finding .ft{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}
.finding .ft h4{font-size:14.5px}
.finding .desc{color:var(--gris);font-size:13px;margin-bottom:8px}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(150deg,var(--azul-osc),#0b3a5c);padding:20px}
.login-card{background:#fff;border-radius:20px;box-shadow:0 30px 70px rgba(0,0,0,.35);
  width:100%;max-width:400px;padding:38px 36px;text-align:center}
.login-card img{width:200px;margin:0 auto 6px}
.login-card .lema{color:var(--dorado);font-size:12px;font-weight:700;margin-bottom:24px}
.login-card h2{font-size:18px;margin-bottom:4px}
.login-card .hint{color:var(--gris);font-size:13px;margin-bottom:22px}
.login-card .field{text-align:left;margin-bottom:14px}
.login-card label{display:block;font-size:12px;font-weight:700;color:var(--gris);margin-bottom:5px}
.login-card input{width:100%;border:1px solid var(--linea);border-radius:10px;padding:12px 13px;font-size:14px}
.login-card input:focus{outline:none;border-color:var(--azul)}
.login-card .btn-primary{width:100%;justify-content:center;padding:13px;font-size:15px;margin-top:8px}
.login-err{background:#fceaec;color:#b9303b;border-radius:10px;padding:10px;font-size:13px;margin-bottom:16px;font-weight:600}
.login-foot{margin-top:22px;color:var(--gris);font-size:11px}

.muted{color:var(--gris)}
.mt0{margin-top:0}.mb0{margin-bottom:0}

/* ---------- Menú móvil ---------- */
.menu-btn{display:none;align-items:center;justify-content:center;width:40px;height:40px;
  border:1px solid var(--linea);background:#fff;border-radius:10px;cursor:pointer;color:var(--azul-osc);flex:0 0 auto}
.menu-btn svg{width:22px;height:22px}
.scrim{display:none;position:fixed;inset:0;background:rgba(8,28,42,.5);z-index:18}
.scrim.show{display:block}

/* ============================================================
   RESPONSIVE — Tablet y celular
   ============================================================ */
@media (max-width:1024px){
  .grid-3{grid-template-columns:1fr 1fr}
}
@media (max-width:860px){
  :root{--sidebar:264px}
  .menu-btn{display:inline-flex}
  .sidebar{transform:translateX(-100%);transition:transform .25s ease;box-shadow:0 0 40px rgba(0,0,0,.4)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0}
  .topbar{padding:12px 16px;gap:10px;flex-wrap:wrap}
  .topbar .tt{flex:1 1 auto;min-width:0}
  .topbar .tt h1{font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .topbar .tt p{display:none}
  .acc{gap:8px;flex-wrap:wrap}
  .acc .btn{padding:8px 11px;font-size:12px}
  .content{padding:18px 16px 44px}
  .sec-intro{font-size:12.5px}
  /* KPIs: 2 por fila en celular */
  .kpi-grid{grid-template-columns:1fr 1fr;gap:12px}
  .kpi .val{font-size:21px}
  .grid-2,.grid-3{grid-template-columns:1fr;gap:16px}
  /* Tablas con scroll horizontal */
  .panel > .bd{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .tbl{min-width:520px}
  /* Filtros a ancho completo */
  .filtros{gap:10px}
  .filtros .f{flex:1 1 140px}
  .filtros select,.filtros input{min-width:0;width:100%}
  .panel > .hd{flex-wrap:wrap;gap:6px}
}
@media (max-width:480px){
  .kpi-grid{grid-template-columns:1fr}
  .acc .btn .lbl{display:none}
  .login-card{padding:30px 22px}
  .login-card img{width:170px}
}
.sec-intro{color:var(--gris);font-size:13.5px;margin:-6px 0 20px;max-width:900px}
.note{background:#f8fbfd;border:1px dashed var(--linea);border-radius:10px;padding:12px 14px;font-size:12.5px;color:var(--gris)}
.bar-mini{height:7px;border-radius:4px;background:#eef2f4;overflow:hidden}
.bar-mini > span{display:block;height:100%;background:var(--azul)}
