/* BPC Platform — Design System "Norma Técnica" (Dirección 01, elegida 12-jun-2026) */
:root{
  --bg:#f6f8fa;
  --surface:#ffffff;
  --border:#d9e1e8;
  --primary:#1a3a5c;
  --primary-deep:#122a44;
  --accent:#f0a500;
  --ink:#1c2b3a;
  --muted:#5d6b7a;
  --faint:#8a96a3;
  --mono:'IBM Plex Mono',monospace;
  --st-yellow:#b58900; --st-yellow-bg:#fdf6d8;
  --st-blue:#1565c0;   --st-blue-bg:#e3effc;
  --st-orange:#c2581a; --st-orange-bg:#fdeadd;
  --st-green:#2e7d32;  --st-green-bg:#e6f4e8;
  --st-red:#c62828;    --st-red-bg:#fdecea;
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--bg);font-family:'Inter',sans-serif;color:var(--ink);-webkit-font-smoothing:antialiased;font-size:14px}
code,.mono{font-family:var(--mono)}

/* ===== App shell ===== */
.app{display:grid;grid-template-columns:236px 1fr;min-height:100vh}
.sidebar{background:var(--primary);color:#c7d4e2;display:flex;flex-direction:column;border-right:1px solid var(--primary-deep)}
.logo{padding:22px 20px 20px;border-bottom:1px solid rgba(255,255,255,.10)}
.logo .name{font-weight:800;font-size:17px;letter-spacing:.18em;color:#fff}
.logo .name span{color:var(--accent)}
.logo .tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;color:#7e93a9;margin-top:3px;text-transform:uppercase}
.nav{padding:14px 10px;flex:1}
.nav a{display:flex;align-items:center;gap:10px;padding:9px 12px;margin-bottom:2px;color:#c7d4e2;text-decoration:none;font-size:13.5px;font-weight:500;border-radius:4px;border-left:3px solid transparent}
.nav a:hover{background:rgba(255,255,255,.06)}
.nav a.active{background:rgba(255,255,255,.12);color:#fff;font-weight:600;border-left:3px solid var(--accent)}
.nav a.disabled{opacity:.45;cursor:default;pointer-events:none}
.nav .fase{margin-left:auto;font-family:var(--mono);font-size:9px;background:rgba(255,255,255,.12);padding:2px 6px;border-radius:3px;letter-spacing:.06em}
.userbox{border-top:1px solid rgba(255,255,255,.10);padding:14px 16px;display:flex;align-items:center;gap:10px}
.userbox .avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);color:var(--primary-deep);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex:none}
.userbox .who{flex:1;min-width:0}
.userbox .who .n{color:#fff;font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.userbox .who .r{font-size:10.5px;color:#7e93a9}
.userbox a{color:#7e93a9;font-size:11px;text-decoration:none}
.userbox a:hover{color:#fff}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:14px 28px;display:flex;align-items:center;gap:16px}
.topbar h1{font-size:18px;font-weight:700;color:var(--primary)}
.topbar .crumb{font-family:var(--mono);font-size:10.5px;color:var(--faint);letter-spacing:.08em;text-transform:uppercase}
.topbar .spacer{flex:1}
.content{padding:24px 28px;display:flex;flex-direction:column;gap:20px}

/* ===== Componentes ===== */
.btn{display:inline-flex;align-items:center;gap:7px;border:none;cursor:pointer;font-family:'Inter',sans-serif;font-weight:600;font-size:13px;padding:9px 16px;border-radius:5px;text-decoration:none}
.btn-primary{background:var(--accent);color:var(--primary-deep)}
.btn-primary:hover{filter:brightness(1.05)}
.btn-ghost{background:transparent;color:var(--primary);border:1px solid var(--border)}

.card{background:var(--surface);border:1px solid var(--border);border-radius:6px}
.card .card-head{padding:13px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.card .card-head h2{font-size:13px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.07em}
.card .card-body{padding:18px}

.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:16px 18px}
.kpi .v{font-family:var(--mono);font-size:26px;font-weight:600;color:var(--primary)}
.kpi .l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}

table.data{width:100%;border-collapse:collapse;font-size:13px}
table.data th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.09em;color:var(--faint);font-weight:600;padding:10px 14px;border-bottom:1px solid var(--border);background:#fbfcfd}
table.data td{padding:10px 14px;border-bottom:1px solid #ecf1f5;vertical-align:middle}
table.data tr:nth-child(even) td{background:#fbfcfd}
table.data td.mono{font-family:var(--mono);font-size:12px}

.chip{display:inline-block;font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:3px 9px;border-radius:3px;border:1px solid}
.chip-yellow{color:var(--st-yellow);background:var(--st-yellow-bg);border-color:var(--st-yellow)}
.chip-blue{color:var(--st-blue);background:var(--st-blue-bg);border-color:var(--st-blue)}
.chip-orange{color:var(--st-orange);background:var(--st-orange-bg);border-color:var(--st-orange)}
.chip-green{color:var(--st-green);background:var(--st-green-bg);border-color:var(--st-green)}
.chip-red{color:var(--st-red);background:var(--st-red-bg);border-color:var(--st-red)}
.chip-gray{color:var(--muted);background:#eef2f5;border-color:#c6d0d9}

/* ===== Login ===== */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.login-card{width:380px;background:var(--surface);border:1px solid var(--border);border-radius:6px;overflow:hidden}
.login-head{background:var(--primary);padding:26px 28px}
.login-head .name{font-weight:800;font-size:19px;letter-spacing:.18em;color:#fff}
.login-head .name span{color:var(--accent)}
.login-head .tag{font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:#7e93a9;margin-top:4px;text-transform:uppercase}
.login-body{padding:26px 28px 30px}
.field{margin-bottom:16px}
.field label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px}
.field input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:5px;font-size:14px;font-family:'Inter',sans-serif;color:var(--ink);background:#fbfcfd}
.field input:focus{outline:2px solid var(--primary);outline-offset:-1px;background:#fff}
.login-error{font-size:12.5px;color:var(--st-red);background:var(--st-red-bg);border:1px solid var(--st-red);border-radius:4px;padding:8px 12px;margin-bottom:16px}
.login-foot{font-family:var(--mono);font-size:9.5px;color:var(--faint);text-align:center;padding:0 28px 22px;letter-spacing:.08em;text-transform:uppercase}

/* ===== Configuración ===== */
.nav-sep{border-top:1px solid rgba(255,255,255,.10);margin:10px 4px}
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border)}
.tabs a{padding:9px 18px;font-size:13px;font-weight:600;color:var(--muted);text-decoration:none;border:1px solid transparent;border-bottom:none;border-radius:5px 5px 0 0}
.tabs a.on{background:var(--surface);color:var(--primary);border-color:var(--border);margin-bottom:-1px}
.flash{font-size:13px;color:var(--st-green);background:var(--st-green-bg);border:1px solid var(--st-green);border-radius:4px;padding:9px 14px}
.form-row{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}
.form-row .field{margin-bottom:0;min-width:170px}
input.inline,select.inline{padding:6px 9px;border:1px solid var(--border);border-radius:4px;font-size:13px;font-family:'Inter',sans-serif;color:var(--ink);background:#fbfcfd;width:100%}
input.inline.mono{font-family:var(--mono);font-size:12px}
input.inline:focus,select.inline:focus{outline:2px solid var(--primary);outline-offset:-1px;background:#fff}
select{padding:10px 12px;border:1px solid var(--border);border-radius:5px;font-size:13.5px;font-family:'Inter',sans-serif;background:#fbfcfd;width:100%}
.hint{font-size:12px;color:var(--faint)}
.hint .mono{font-size:11px}
