/* =====================================================================
   Estilos base de la intranet — versión inicial.
   Toma la estética del prototipo (Fraunces + paleta tierra/verde).
   Amplíala según vayas construyendo cada módulo.
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&family=Archivo:wght@400;500;600;700&display=swap');

:root{
  --ink:#1a1d1a; --paper:#f4f1ea; --panel:#fbfaf6; --line:#d9d3c5;
  --line-soft:#e7e2d6; --accent:#2f5d3a; --accent-soft:#e3ece1;
  --amber:#a8741a; --red:#9c3a32; --muted:#6b685e;
  --shadow:0 1px 2px rgba(26,29,26,.06),0 4px 16px rgba(26,29,26,.05);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Archivo',sans-serif;background:var(--paper);color:var(--ink);font-size:14px;line-height:1.5}

/* ---- Login ---- */
.login-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(circle at 20% 30%,rgba(47,93,58,.5),transparent 45%),
             radial-gradient(circle at 80% 70%,rgba(168,116,26,.3),transparent 45%),#1a1d1a}
.login-card{background:var(--panel);border-radius:18px;width:100%;max-width:380px;padding:34px 32px;box-shadow:0 24px 70px rgba(0,0,0,.45)}
.login-brand{text-align:center;margin-bottom:24px}
.login-brand h1{font-family:'Fraunces',serif;font-size:28px;font-weight:600}
.login-brand span{font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted)}
.lf-label{font-size:12px;font-weight:600;color:var(--muted);display:block;margin:14px 0 5px}
.lf-input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:14px;background:var(--paper)}
.lf-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.lf-btn{width:100%;justify-content:center;padding:12px;font-size:14px;margin-top:18px}
.login-error{background:#f1ddd9;border:1px solid #e0b5ae;color:#9c3a32;padding:10px;border-radius:8px;font-size:13px;margin-bottom:10px}
.login-foot{text-align:center;font-size:11px;color:var(--muted);margin-top:22px;padding-top:16px;border-top:1px solid var(--line-soft)}

/* ---- Layout ---- */
.app{display:flex;min-height:100vh}
.sidebar{width:248px;background:var(--ink);color:#cfcabd;padding:22px 0;display:flex;flex-direction:column;flex-shrink:0;min-height:100vh}
.brand{padding:0 22px 18px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:12px}
.brand-logo{max-height:42px;margin-bottom:8px}
.brand h1{font-family:'Fraunces',serif;font-size:21px;color:#fff;font-weight:500}
.brand span{font-size:11px;color:#8a8678;text-transform:uppercase;letter-spacing:.8px}
nav{flex:1;padding:0 12px}
.nav-label{font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:#6f6c61;padding:14px 10px 6px;font-weight:600}
.nav-item{display:block;padding:9px 10px;border-radius:7px;color:#cfcabd;text-decoration:none;font-size:13.5px;font-weight:500;transition:background .15s}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-item.active{background:var(--accent);color:#fff}
.sidebar-foot{padding:14px 22px 0;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px;font-size:12px;color:#8a8678}
.avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:700;font-size:12px}
.sf-name{flex:1;color:#fff;font-weight:600;font-size:12.5px}
.sf-logout{color:#8a8678;text-decoration:none;font-size:12px}
.sf-logout:hover{color:#fff}
.main{flex:1;min-width:0}
.topbar{height:60px;background:var(--panel);border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 28px}
.content{padding:28px;max-width:1280px}

/* ---- Componentes ---- */
.page-head{margin-bottom:22px;display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap}
.page-head h2{font-family:'Fraunces',serif;font-size:28px;font-weight:500}
.page-head p{color:var(--muted);font-size:13.5px;margin-top:3px}
.kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}
.kpi{background:var(--panel);border:1px solid var(--line-soft);border-radius:12px;padding:18px;box-shadow:var(--shadow)}
.kpi .label{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-weight:600}
.kpi .num{font-family:'Fraunces',serif;font-size:30px;font-weight:500;margin-top:6px}
.panel-card{background:var(--panel);border:1px solid var(--line-soft);border-radius:12px;box-shadow:var(--shadow);overflow:hidden}
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:600;padding:11px 18px;border-bottom:1px solid var(--line-soft);background:#f7f4ed}
td{padding:12px 18px;border-bottom:1px solid var(--line-soft);font-size:13.5px}
tbody tr{cursor:pointer}
tbody tr:hover{background:#f7f4ed}
.tag{display:inline-block;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:20px;background:var(--accent-soft);color:var(--accent)}
.btn{background:var(--accent);color:#fff;border:none;padding:9px 15px;border-radius:8px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:7px}
.btn:hover{background:#264a2f}
code{background:#f4f4f4;padding:2px 6px;border-radius:4px;font-size:.9em}

@media(max-width:900px){.sidebar{display:none}.kpi-row{grid-template-columns:1fr 1fr}}
