:root{--verde:#1D9E75;--verde-claro:#E1F5EE;--azul:#185FA5;--azul-claro:#E6F1FB;--rojo:#E24B4A;--rojo-claro:#FCEBEB;--amber:#BA7517;--amber-claro:#FAEEDA;--purple-claro:#EEEDFE;--teal-claro:#E1F5EE;--borde:#E0DDD5;--texto:#1a1a18;--texto-sec:#5F5E5A;--blanco:#fff;--fondo:#F5F4F0}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:14px;color:var(--texto);background:var(--fondo)}
a{color:inherit;text-decoration:none}
svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8;flex-shrink:0}
.app-wrap{display:flex;min-height:100vh}
.sidebar{width:210px;background:var(--blanco);border-right:1px solid var(--borde);display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto}
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{background:var(--blanco);border-bottom:1px solid var(--borde);padding:10px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}
.content{padding:20px 24px;flex:1}
.logo{padding:16px;border-bottom:1px solid var(--borde);display:flex;align-items:center;gap:10px}
.logo-name{font-weight:600;font-size:14px}.logo-sub{font-size:11px;color:var(--texto-sec)}
.nav-section{padding:8px 0}.nav-label{font-size:10px;color:#aaa;padding:6px 16px 2px;text-transform:uppercase;letter-spacing:.5px}
.nav-link{display:flex;align-items:center;gap:9px;padding:8px 16px;color:var(--texto-sec);font-size:13px;border-left:2px solid transparent}
.nav-link:hover{background:var(--fondo);color:var(--texto)}
.nav-link.active{background:var(--azul-claro);color:var(--azul);border-left-color:var(--azul);font-weight:500}
.sidebar-footer{margin-top:auto;padding:12px 16px;border-top:1px solid var(--borde)}
.user-chip{display:flex;align-items:center;gap:8px}
.avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}
.av-purple{background:var(--purple-claro);color:#534AB7}.av-blue{background:var(--azul-claro);color:var(--azul)}
.av-teal{background:var(--teal-claro);color:#0F6E56}.av-amber{background:var(--amber-claro);color:var(--amber)}.av-gray{background:#F1EFE8;color:#5F5E5A}
.page-title{font-size:15px;font-weight:600}.topbar-right{display:flex;align-items:center;gap:10px}
.alert-chip{background:var(--rojo-claro);color:var(--rojo);font-size:11px;padding:3px 10px;border-radius:20px;font-weight:500}
.card{background:var(--blanco);border:1px solid var(--borde);border-radius:10px;padding:16px;margin-bottom:14px}
.card-title{font-size:13px;font-weight:600;margin-bottom:12px}.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:16px}
.kpi{background:var(--blanco);border:1px solid var(--borde);border-radius:8px;padding:14px}
.kpi-label{font-size:11px;color:var(--texto-sec);margin-bottom:4px}.kpi-val{font-size:22px;font-weight:600}
.kpi-delta{font-size:11px;color:var(--texto-sec);margin-top:3px}.kpi-delta.up{color:var(--verde)}.kpi-delta.down{color:var(--rojo)}
.row2{display:grid;grid-template-columns:1.4fr 1fr;gap:14px}.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;font-weight:500;font-size:11px;color:var(--texto-sec);padding:6px 8px;border-bottom:1px solid var(--borde)}
td{padding:7px 8px;border-bottom:1px solid var(--borde);vertical-align:middle}
tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--fondo)}
.badge{display:inline-block;font-size:10px;padding:2px 8px;border-radius:20px;font-weight:500;white-space:nowrap}
.badge-green{background:#EAF3DE;color:#27500A}.badge-red{background:var(--rojo-claro);color:#791F1F}
.badge-amber{background:var(--amber-claro);color:#633806}.badge-blue{background:var(--azul-claro);color:#0C447C}
.badge-gray{background:#F1EFE8;color:#5F5E5A}.badge-teal{background:var(--teal-claro);color:#0F6E56}.badge-purple{background:var(--purple-claro);color:#534AB7}
.form-group{margin-bottom:14px}
label{display:block;font-size:12px;color:var(--texto-sec);margin-bottom:4px}
input[type=text],input[type=number],input[type=date],input[type=email],input[type=password],select,textarea{width:100%;padding:8px 10px;border:1px solid var(--borde);border-radius:6px;font-size:13px;font-family:inherit;background:var(--blanco);color:var(--texto)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--azul);box-shadow:0 0 0 3px rgba(24,95,165,.1)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:6px;font-size:13px;cursor:pointer;border:1px solid var(--borde);background:var(--blanco);color:var(--texto);font-family:inherit;text-decoration:none;white-space:nowrap}
.btn:hover{background:var(--fondo)}.btn-primary{background:var(--azul);color:#fff;border-color:var(--azul)}.btn-primary:hover{background:#0C447C}
.btn-success{background:var(--verde);color:#fff;border-color:var(--verde)}.btn-danger{background:var(--rojo);color:#fff;border-color:var(--rojo)}
.btn-sm{font-size:11px;padding:3px 8px}.btn-group{display:flex;gap:8px;flex-wrap:wrap}
.alert{padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:14px}
.alert-success{background:#EAF3DE;color:#27500A;border:1px solid #C0DD97}.alert-danger{background:var(--rojo-claro);color:#791F1F;border:1px solid #F7C1C1}
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;align-items:center}.filters input,.filters select{width:auto;min-width:140px}
.progress-wrap{background:var(--fondo);border-radius:6px;height:8px;overflow:hidden;margin:6px 0}
.progress-bar{height:100%;background:var(--verde);border-radius:6px}
.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--fondo)}
.login-card{background:var(--blanco);border:1px solid var(--borde);border-radius:12px;padding:36px 32px;width:360px}
.text-verde{color:var(--verde)}.text-rojo{color:var(--rojo)}.text-amber{color:var(--amber)}.text-sec{color:var(--texto-sec)}
.fw-500{font-weight:500}.fw-600{font-weight:600}.ta-right{text-align:right}.mt-8{margin-top:8px}.mb-0{margin-bottom:0}
@media(max-width:768px){.sidebar{display:none}.row2,.row3,.form-row,.form-row3{grid-template-columns:1fr}.kpi-grid{grid-template-columns:1fr 1fr}}
