:root{
  --navy:#0A2E5C;
  --blue:#0D4FA3;
  --cyan:#00AEEF;
  --bg:#F4F7FB;
  --panel:#FFFFFF;
  --text:#1F2A37;
  --muted:#5B6777;
  --line:#D9E1EA;
  --line-soft:#E9EEF5;
  --success:#15803D;
  --danger:#DC2626;
  --warning:#D97706;
  --shadow:0 22px 60px rgba(10,46,92,.08);
  --shadow-soft:0 10px 32px rgba(10,46,92,.06);
  --radius:22px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:linear-gradient(180deg,#f7f9fc 0%,#f3f7fb 100%);color:var(--text)}
a{color:var(--blue);text-decoration:none}
input,select,textarea,button{font:inherit}
button{cursor:pointer}
img{max-width:100%;display:block}
.app-shell{display:grid;grid-template-columns:300px 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,#07274c 0%,#0A2E5C 42%,#072547 100%);color:#fff;padding:24px 18px;position:sticky;top:0;height:100vh;overflow:auto;border-right:1px solid rgba(255,255,255,.08)}
.sidebar-top{margin-bottom:18px}
.brand-lockup{display:flex;gap:14px;align-items:center}
.brand-lockup-login{align-items:flex-start}
.brand-logo{height:auto}
.sidebar-logo{width:124px;flex:0 0 auto;filter:drop-shadow(0 6px 18px rgba(0,0,0,.22))}
.login-logo{width:162px;flex:0 0 auto;filter:drop-shadow(0 10px 24px rgba(0,0,0,.25))}
.brand-title{font-weight:900;font-size:20px;letter-spacing:-.03em}
.brand-subtitle{font-size:12px;color:rgba(255,255,255,.72);margin-top:2px}
.brand-divider{height:1px;background:linear-gradient(90deg,rgba(255,255,255,.18),transparent);margin:18px 0 8px}
.nav{display:grid;gap:7px}
.nav a{position:relative;color:rgba(255,255,255,.78);padding:13px 14px 13px 16px;border-radius:16px;font-weight:800;font-size:14px;transition:.2s ease;background:transparent}
.nav a::before{content:"";position:absolute;left:0;top:11px;bottom:11px;width:3px;border-radius:999px;background:transparent}
.nav a:hover{background:rgba(255,255,255,.08);color:#fff;transform:translateX(1px)}
.nav a.active{background:linear-gradient(90deg,rgba(255,255,255,.14),rgba(255,255,255,.08));color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
.nav a.active::before{background:var(--cyan)}
.sidebar-footer{margin-top:28px;padding:16px;border:1px solid rgba(255,255,255,.12);border-radius:18px;background:rgba(255,255,255,.05);color:rgba(255,255,255,.78);font-size:12px}
.sidebar-footer-company{margin-top:8px;color:rgba(255,255,255,.62)}
.small-label{font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:rgba(255,255,255,.48);margin-bottom:5px}
.main{min-width:0}
.topbar{height:96px;background:rgba(255,255,255,.86);backdrop-filter:blur(18px);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 30px;position:sticky;top:0;z-index:10}
.page-head{display:grid;gap:2px}
.topbar h1{margin:0;font-size:34px;letter-spacing:-.045em;line-height:1.03}
.topbar p{margin:0;color:var(--muted);font-size:16px}
.eyebrow{font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase}
.muted-eyebrow{color:#6A7B90}
.mobile-menu{display:none;border:0;background:var(--navy);color:#fff;border-radius:12px;padding:9px 12px;box-shadow:var(--shadow-soft)}
.user-pill{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 12px 8px 10px;box-shadow:var(--shadow-soft)}
.avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;display:grid;place-items:center;font-weight:900;box-shadow:0 8px 24px rgba(10,46,92,.16)}
.user-pill strong{display:block;font-size:14px}
.user-pill span{display:block;font-size:11px;color:var(--muted);text-transform:lowercase}
.logout-link{font-size:12px;font-weight:800;color:var(--danger);margin-left:10px;padding-left:10px;border-left:1px solid var(--line)}
.content{padding:28px 30px 48px}
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.inline-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.inline-form input,.inline-form select,.form-grid input,.form-grid select,.form-grid textarea,.card input,.card select,.card textarea{width:100%;border:1px solid var(--line);border-radius:14px;padding:12px 13px;background:#fff;color:var(--text);outline:none;transition:.2s ease;box-shadow:none}
.inline-form input:focus,.inline-form select:focus,.form-grid input:focus,.form-grid select:focus,.form-grid textarea:focus,.card input:focus,.card select:focus,.card textarea:focus{border-color:rgba(0,174,239,.55);box-shadow:0 0 0 4px rgba(0,174,239,.11)}
.btn{border:1px solid var(--line);background:#fff;color:var(--text);padding:11px 16px;border-radius:14px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;transition:.2s ease;box-shadow:0 2px 10px rgba(15,23,42,.03)}
.btn:hover{border-color:#c8d2df;transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;border-color:transparent;box-shadow:0 16px 32px rgba(10,46,92,.18)}
.btn-primary:hover{filter:brightness(1.03)}
.btn-small{padding:8px 11px;border-radius:11px;font-size:12px}
.full{width:100%}
.kpi-grid{display:grid;grid-template-columns:repeat(7,minmax(150px,1fr));gap:16px;margin-bottom:18px}
.kpi-grid.compact{grid-template-columns:repeat(4,1fr)}
.kpi{position:relative;background:linear-gradient(180deg,#fff 0%,#fcfdff 100%);border:1px solid var(--line-soft);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-soft);overflow:hidden}
.kpi::after{content:"";position:absolute;left:0;top:0;height:4px;width:100%;background:linear-gradient(90deg,var(--navy),var(--cyan));opacity:.85}
.kpi span{display:block;color:#617184;font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:900;line-height:1.5}
.kpi strong{display:block;margin-top:12px;font-size:38px;line-height:1;letter-spacing:-.05em;color:var(--navy)}
.kpi.danger::after{background:linear-gradient(90deg,#ef4444,#f87171)}
.kpi.warning::after{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
.card{background:var(--panel);border:1px solid var(--line-soft);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);margin-bottom:18px}
.card h2{margin:0 0 5px;font-size:28px;letter-spacing:-.035em;color:var(--navy)}
.card p{margin:0;color:var(--muted)}
.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:18px}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px;background:#fff}
table{width:100%;border-collapse:collapse;background:#fff}
th,td{padding:14px 15px;border-bottom:1px solid var(--line-soft);text-align:left;vertical-align:middle}
th{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:#46607f;background:#f7fafe;font-weight:800}
td{font-size:14px}
tr:last-child td{border-bottom:0}
tbody tr:hover td{background:#fbfdff}
.muted{color:var(--muted);font-size:13px}
.empty{text-align:center;color:var(--muted);padding:34px!important}
.actions{display:flex;gap:8px;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:7px 10px;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.04em;background:#eef2ff;color:#3730a3}
.badge-activo,.badge-listo,.badge-pagado,.badge-enviado,.badge-cerrado,.badge-revisado,.badge-recibido,.badge-declarado{background:#dcfce7;color:#166534}
.badge-pendiente,.badge-solicitado,.badge-borrador,.badge-no_generado,.badge-no_iniciado,.badge-en_preparacion{background:#fef3c7;color:#92400e}
.badge-critico,.badge-atrasado,.badge-observado,.badge-suspendido{background:#fee2e2;color:#991b1b}
.badge-en_proceso,.badge-en_revision,.badge-convenio,.badge-revision_comercial{background:#dbeafe;color:#1e40af}
.badge-no_aplica,.badge-pausado,.badge-terminado,.badge-inactivo,.badge-archivado{background:#f1f5f9;color:#475569}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.form-grid.one{grid-template-columns:1fr}.small-grid{grid-template-columns:280px 1fr}
.form-grid label,.card label{display:grid;gap:7px;font-size:13px;font-weight:800;color:#334155}
.form-section{border-bottom:1px solid var(--line);padding-bottom:10px;margin-top:6px}.form-section h2{margin:0}.form-section p{margin:4px 0 0}
.full{grid-column:1/-1}.form-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}
.profile-grid{display:grid;grid-template-columns:1fr 330px;gap:18px}
.profile-title{display:flex;gap:14px;align-items:center;margin-bottom:20px}
.client-initial{width:62px;height:62px;border-radius:20px;background:linear-gradient(135deg,var(--navy),var(--cyan));color:#fff;display:grid;place-items:center;font-weight:900;font-size:26px;box-shadow:0 16px 36px rgba(10,46,92,.15)}
.info-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.info-grid div{background:#f8fafc;border:1px solid var(--line);border-radius:16px;padding:13px}.info-grid span{display:block;color:var(--muted);font-size:12px;margin-bottom:5px}.info-grid strong{font-size:14px}
.note-box{margin-top:16px;background:#f8fafc;border:1px solid var(--line);padding:14px;border-radius:16px;color:#334155}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}.two-col.uneven{grid-template-columns:360px 1fr}
.mini-list{display:grid;gap:10px}.mini-list>div{padding:12px;border:1px solid var(--line);border-radius:15px;background:#fff}.mini-list strong{display:block}.mini-list span{display:flex;align-items:center;gap:8px;margin-top:6px}
.timeline{display:grid;gap:12px}.timeline>div{border-left:3px solid var(--cyan);padding:2px 0 2px 14px}.timeline span{display:block;color:var(--muted);font-size:12px}.timeline strong{display:block;margin:3px 0}.timeline p{margin:0}
.progress{height:9px;background:#e2e8f0;border-radius:999px;overflow:hidden;min-width:140px}.progress span{display:block;height:100%;background:linear-gradient(90deg,var(--blue),var(--cyan));border-radius:999px}
.table-select{min-width:145px}.flash-wrap{padding:18px 30px 0}.flash{border-radius:14px;padding:12px 14px;margin-bottom:10px;border:1px solid var(--line);font-weight:800}.flash-success{background:#dcfce7;color:#166534;border-color:#bbf7d0}.flash-error{background:#fee2e2;color:#991b1b;border-color:#fecaca}
.file-link{align-self:end;padding:12px;background:#f8fafc;border-radius:14px}.login-body{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 0% 0%,rgba(0,174,239,.2),transparent 28%),radial-gradient(circle at 100% 100%,rgba(13,79,163,.14),transparent 30%),linear-gradient(135deg,#082345 0%,#0A2E5C 46%,#04162b 100%)}
.login-wrap{width:min(1180px,calc(100% - 36px));display:grid;grid-template-columns:1.08fr .92fr;gap:22px}
.login-panel{border-radius:32px;padding:38px;box-shadow:0 30px 90px rgba(0,0,0,.26)}
.login-copy{background:linear-gradient(160deg,rgba(255,255,255,.12),rgba(255,255,255,.06));border:1px solid rgba(255,255,255,.14);color:#fff;min-height:580px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.login-copy::after{content:"";position:absolute;right:-80px;top:-80px;width:260px;height:260px;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 62%);pointer-events:none}
.login-copy-body{max-width:620px}
.login-copy h1{font-size:62px;line-height:.94;letter-spacing:-.07em;margin:18px 0 18px;max-width:680px}
.login-copy p{font-size:18px;line-height:1.6;color:rgba(255,255,255,.78);max-width:580px}
.login-copy-footer{display:grid;gap:14px}
.login-metrics{display:flex;gap:10px;flex-wrap:wrap}.login-metrics span{padding:10px 12px;border-radius:999px;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.08);font-weight:900}
.login-footer-note{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.58)}
.login-form{background:#fff;border:1px solid #e4ebf3}
.login-form h2{font-size:38px;margin:8px 0 8px;line-height:1.05;letter-spacing:-.04em;color:var(--navy)}
.login-form label{display:block;font-size:13px;font-weight:800;color:#334155;margin-top:18px}.login-form input{width:100%;border:1px solid var(--line);border-radius:15px;padding:14px 15px;margin-top:7px;background:#fff}
.password-field{display:flex;gap:8px}.password-field input{flex:1}.password-field button{margin-top:7px;border:1px solid var(--line);background:#f7fafc;border-radius:15px;padding:0 16px;font-weight:900;color:var(--navy)}
.login-help{margin-top:16px;padding:13px 14px;border-radius:16px;background:#f8fafc;border:1px solid var(--line-soft);color:#475569;font-size:13px}
@media(max-width:1280px){.kpi-grid{grid-template-columns:repeat(4,1fr)}.login-copy h1{font-size:54px}}
@media(max-width:1180px){.kpi-grid{grid-template-columns:repeat(3,1fr)}.info-grid{grid-template-columns:repeat(2,1fr)}.profile-grid,.two-col,.two-col.uneven{grid-template-columns:1fr}}
@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;z-index:30;transform:translateX(-100%);transition:.25s ease;width:292px}.sidebar.open{transform:translateX(0)}.mobile-menu{display:inline-flex}.topbar{height:auto;min-height:84px;align-items:flex-start;padding:18px;gap:12px}.user-pill{display:none}.content,.flash-wrap{padding-left:18px;padding-right:18px}.kpi-grid,.kpi-grid.compact,.form-grid,.small-grid,.info-grid{grid-template-columns:1fr}.login-wrap{grid-template-columns:1fr}.login-copy{min-height:auto}.login-copy h1{font-size:38px;margin:20px 0 14px}.toolbar{align-items:stretch}.inline-form,.toolbar .btn{width:100%}}


/* V1.3 · Formularios inteligentes */
select {
  appearance: auto;
}
.form-section p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 13px;
}
.inline-form select {
  min-width: 190px;
}
.inline-form input[type="search"] {
  min-width: 260px;
}
.card.form-grid .form-section {
  margin-top: 8px;
  padding-top: 4px;
}
.card.form-grid .form-section:not(:first-child) {
  margin-top: 18px;
}
input[list]::-webkit-calendar-picker-indicator {
  opacity: .75;
}


/* V1.3.1 · Multi-servicios y CLP sin decimales */
.multi-select {
  min-height: 162px;
  padding-top: 10px;
}
.multi-select option {
  padding: 8px 10px;
}
.field-hint {
  display: inline-flex;
  margin-left: 6px;
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
}
.field-help {
  margin-top: -2px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}
