:root {
  --bg: #f3f6fb;
  --surface: #ffffff;
  --surface-2: #f8fbff;
  --border: #d9e3f1;
  --text: #0f172a;
  --muted: #64748b;
  --primary: #0b2d52;
  --primary-2: #113f73;
  --accent: #c5a15d;
  --success: #0f9f6e;
  --warning: #d89b1d;
  --danger: #c53d4b;
  --shadow: 0 18px 42px rgba(15, 23, 42, 0.08);
  --radius: 22px;
}
*{box-sizing:border-box} html,body{margin:0;padding:0}
body{font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;background:linear-gradient(180deg,#f7f9fc 0%,#edf3fa 100%);color:var(--text);overflow-x:hidden}
a{color:inherit}
.app-layout{min-height:100vh;display:grid;grid-template-columns:300px 1fr}
.sidebar{position:sticky;top:0;height:100vh;padding:24px 18px;background:linear-gradient(180deg,#08203d 0%,#0b2d52 55%,#0d3662 100%);color:#fff;border-right:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:18px;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.22) transparent}
.sidebar-brand{display:flex;gap:14px;align-items:center;padding:10px 8px 16px}
.brand-logo{width:50px;height:50px;border-radius:18px;background:rgba(255,255,255,.09);display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.14);overflow:hidden}
.brand-logo-lg{width:62px;height:62px;border-radius:20px}
.brand-logo img{width:100%;height:100%;object-fit:cover}
.brand-overline{font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.62);margin-bottom:4px}
.brand-name{font-size:20px;font-weight:800;line-height:1.1}
.brand-caption{font-size:12px;color:rgba(255,255,255,.72);margin-top:4px;line-height:1.4}
.sidebar-nav{display:grid;gap:8px;flex:1;align-content:start;padding-right:4px}
.nav-group-title{margin:10px 10px 2px;font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.46)}
.nav-link{text-decoration:none;color:rgba(255,255,255,.86);padding:12px 14px;border-radius:16px;display:flex;align-items:center;gap:10px;border:1px solid transparent;transition:.18s ease;font-size:14px}
.nav-link:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-link.active{background:linear-gradient(135deg,rgba(255,255,255,.14),rgba(255,255,255,.08));border-color:rgba(255,255,255,.12);box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}

.sidebar::-webkit-scrollbar{width:10px}
.sidebar::-webkit-scrollbar-track{background:transparent}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:999px;border:2px solid transparent;background-clip:padding-box}
.sidebar::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.28);border:2px solid transparent;background-clip:padding-box}
.sidebar-foot{margin-top:0;display:grid;gap:12px;padding-top:6px}
.user-box{padding:12px 14px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08)}
.user-box small{display:block;color:rgba(255,255,255,.6);font-size:10px;text-transform:uppercase;letter-spacing:.12em}.user-box strong{display:block;font-size:13px;margin-top:3px}.user-box span{display:block;font-size:12px;color:rgba(255,255,255,.72);margin-top:2px}
.logout-btn{text-decoration:none;background:linear-gradient(135deg,#a83246,#7d2030);color:#fff;padding:12px 16px;border-radius:999px;font-size:13px;font-weight:700;text-align:center;box-shadow:0 12px 24px rgba(125,32,48,.22)}
.main-shell{min-width:0;max-width:100%;overflow-x:hidden}
.headerbar{display:flex;justify-content:space-between;align-items:center;padding:24px 28px 0}
.headerbar-title{font-size:26px;font-weight:800;color:var(--primary)}
.headerbar-subtitle{font-size:13px;color:var(--muted);margin-top:6px}
.header-chip{padding:10px 14px;border-radius:999px;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow);font-size:12px;color:var(--primary);font-weight:700}
.content-wrap{padding:24px 28px 36px;min-width:0;max-width:100%;overflow-x:hidden}
.page-header{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;margin-bottom:22px}.page-title{margin:0;font-size:30px;color:var(--primary)}.page-subtitle,.subtitle{margin:6px 0 0;color:var(--muted);font-size:14px}
.card,.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;max-width:100%}.grid-2{display:grid;grid-template-columns:1.35fr .95fr;gap:22px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.metric{padding:18px;border-radius:18px;color:#fff;min-height:116px;display:flex;flex-direction:column;justify-content:space-between}.metric small{text-transform:uppercase;letter-spacing:.12em;opacity:.82;font-size:10px}.metric strong{font-size:28px;line-height:1}.metric span{font-size:13px;opacity:.92}.metric.primary{background:linear-gradient(135deg,#103c73,#1b65ad)}.metric.success{background:linear-gradient(135deg,#0c7b57,#10a977)}.metric.warning{background:linear-gradient(135deg,#b57c0f,#ebb034)}.metric.danger{background:linear-gradient(135deg,#9d2f3f,#d64d5e)}.metric.dark{background:linear-gradient(135deg,#111827,#334155)}
.list-clean{list-style:none;padding:0;margin:0;display:grid;gap:10px}.list-clean li{padding:12px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:14px}
.kpi-table,table{width:100%;border-collapse:collapse;max-width:100%} table th,table td{padding:12px 14px;border-bottom:1px solid #edf2f7;text-align:left;font-size:13px;vertical-align:top} table thead th{background:#0c315e;color:#fff;font-size:12px;text-transform:uppercase;letter-spacing:.08em} table tbody tr:hover{background:#f8fbff}.table-scroll{overflow:auto}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;max-width:100%}.form-group{display:flex;flex-direction:column;gap:6px;min-width:0}.form-group label{font-size:12px;color:#334155;font-weight:700}.form-group input,.form-group select,.form-group textarea{width:100%;max-width:100%;border:1px solid #cfd8e3;background:#fff;border-radius:14px;padding:11px 13px;font-size:14px;color:var(--text);outline:none;transition:.15s ease}.form-group input[type=file]{padding:10px 12px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#8fb3dc;box-shadow:0 0 0 4px rgba(31,95,168,.08)}
.btn,button,.btn-primary,.btn-secondary{border:none;border-radius:999px;padding:11px 18px;font-size:13px;font-weight:700;cursor:pointer;text-decoration:none}.btn-primary,.btn.primary,button.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;box-shadow:0 12px 24px rgba(15,63,117,.18)}.btn-secondary,.btn.secondary{background:#fff;color:var(--primary);border:1px solid #cad5e4}
.footer-note{margin-top:30px;padding:16px 0 0;color:var(--muted);font-size:12px;border-top:1px solid #dce6f2}.badge{display:inline-flex;padding:5px 10px;border-radius:999px;font-size:11px;font-weight:700}.badge.success{background:#ddf9ee;color:#0f7e58}.badge.warning{background:#fff2d6;color:#ab7308}.badge.danger{background:#fde1e5;color:#a92e3f}.inline-stat{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px dashed #d9e1ec;font-size:13px}.inline-stat:last-child{border-bottom:0}
.section-title{margin:0 0 8px;font-size:18px;color:var(--primary)} .section-note{margin:0;color:var(--muted);font-size:13px}
@media (max-width:1180px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:1fr}.grid-2{grid-template-columns:1fr}.app-layout{grid-template-columns:88px 1fr}.sidebar-brand{padding-inline:0}.sidebar-brand>div:not(.brand-logo-lg){display:none}.nav-link span,.sidebar-foot .user-box,.sidebar-foot .sidebar-logout{display:none}.nav-link{justify-content:center;padding:13px}.headerbar{padding-top:18px}}
@media (max-width:820px){.app-layout{grid-template-columns:1fr}.sidebar{position:static;height:auto}.sidebar-foot .user-box,.sidebar-foot .sidebar-logout{display:block}.sidebar-brand>div:not(.brand-logo-lg),.nav-link span{display:block}.headerbar{padding:18px 18px 0}.content-wrap{padding:18px}}
@media (max-width:640px){.grid-4,.grid-3{grid-template-columns:1fr}.page-title{font-size:24px}.headerbar{flex-direction:column;align-items:flex-start;gap:12px}}


.form-grid.two-columns {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.field-block {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.field-block input,
.field-block select,
.field-block textarea {
    width: 100%;
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px solid rgba(148, 163, 184, .35);
    background: rgba(15, 23, 42, .03);
}

.full-span { grid-column: 1 / -1; }
.actions-row { display: flex; gap: 12px; align-items: center; }
.btn.btn-primary {
    border: 0;
    border-radius: 12px;
    padding: 12px 18px;
    font-weight: 700;
    cursor: pointer;
}
.chip-grid { display: flex; flex-wrap: wrap; gap: 10px; }
.soft-note {
    border: 1px dashed rgba(148, 163, 184, .45);
    border-radius: 14px;
    padding: 14px;
    background: rgba(255,255,255,.55);
}
@media (max-width: 980px) {
    .form-grid.two-columns { grid-template-columns: 1fr; }
}


.dashboard-cta{justify-content:center;min-width:210px;box-shadow:0 14px 30px rgba(11,50,93,.14)}
.btn-sm{padding:10px 14px;border-radius:12px;font-size:13px}
.btn-lg{padding:14px 18px;font-size:15px}
.chip-grid-compact{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));}
.compania-chip.sober{display:flex;flex-direction:column;align-items:flex-start;gap:4px;background:#fff;border:1px solid #d9e4f0;color:#16365f;padding:14px 14px 12px;border-radius:14px;box-shadow:none}
.compania-chip.sober .compania-chip-name{font-weight:700}
.compania-chip.sober small{color:#6b7d94;font-size:11px;letter-spacing:.02em}
.action-icons{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.action-icons a,.action-icons .muted-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;border:1px solid #dbe5f1;background:#fff;text-decoration:none;font-size:16px}
.action-icons a:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(11,50,93,.08)}
.muted-icon{opacity:.35}
