:root {
  color-scheme: light;
  --app-bg:#f4f7fb;
  --app-bg-soft:#eef4fb;
  --surface:#ffffff;
  --surface-soft:#f8fbff;
  --sidebar:#061936;
  --sidebar-2:#082450;
  --sidebar-active:#0b6bff;
  --primary:#0b6bff;
  --primary-2:#155eef;
  --primary-soft:#eaf2ff;
  --cyan:#13b5d8;
  --green:#12b76a;
  --green-soft:#ecfdf3;
  --orange:#f79009;
  --orange-soft:#fffaeb;
  --red:#f04438;
  --red-soft:#fef3f2;
  --purple:#7a5af8;
  --purple-soft:#f4f3ff;
  --text:#101828;
  --text-2:#344054;
  --muted:#667085;
  --muted-2:#98a2b3;
  --border:#e4e7ec;
  --border-strong:#cbd5e1;
  --shadow-xs:0 1px 2px rgba(16,24,40,.05);
  --shadow-sm:0 8px 20px rgba(16,24,40,.06);
  --shadow-md:0 16px 38px rgba(16,24,40,.10);
  --radius-sm:10px;
  --radius:18px;
  --radius-lg:24px;
  --sidebar-width:280px;
  --header-height:74px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--app-bg);-webkit-text-size-adjust:100%}
body{margin:0;min-height:100vh;overflow-x:hidden;font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:radial-gradient(circle at 18% 0%,rgba(11,107,255,.08),transparent 34%),linear-gradient(180deg,#f9fbff 0%,var(--app-bg) 46%,#edf3fb 100%);color:var(--text);font-size:14px;line-height:1.45}
a{color:var(--primary);text-decoration:none;transition:color .18s ease,filter .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease,transform .18s ease}
a:hover{color:var(--primary-2)}
img{max-width:100%;height:auto}
button,input,select,textarea{font:inherit}

/* App Layout */
.app-shell{min-height:100vh;display:grid;grid-template-columns:var(--sidebar-width) minmax(0,1fr);background:transparent}
.sidebar{position:sticky;top:0;height:100vh;overflow-y:auto;overflow-x:hidden;padding:20px 16px;background:linear-gradient(180deg,var(--sidebar) 0%,#031126 100%);border-right:1px solid rgba(255,255,255,.08);box-shadow:18px 0 50px rgba(9,30,66,.16);z-index:30;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.24) transparent}
.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.20);border-radius:999px}.sidebar::-webkit-scrollbar-track{background:transparent}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(16,24,40,.46);backdrop-filter:blur(3px);z-index:25}
.brand-block{display:flex;align-items:center;min-height:66px;padding:4px 8px 18px;margin-bottom:12px;border-bottom:1px solid rgba(255,255,255,.10)}
.brand-block img{width:198px;max-height:58px;object-fit:contain;object-position:left center;filter:drop-shadow(0 10px 24px rgba(0,0,0,.22))}
.side-nav{display:flex;flex-direction:column;gap:8px;padding:4px 0 10px}
.side-group{display:flex;flex-direction:column;gap:8px}
.side-subnav{display:none;flex-direction:column;gap:6px;margin:0 0 4px 44px;padding-left:10px;border-left:1px solid rgba(255,255,255,.12)}
.side-group.open .side-subnav{display:flex}
.side-link,.sub-link,.main-menu-button{display:flex;align-items:center;gap:12px;min-height:46px;width:100%;padding:11px 12px;border-radius:14px;color:#e7eefc;background:transparent;border:1px solid transparent;font-weight:750;letter-spacing:-.01em;white-space:nowrap;line-height:1.15}
.side-link span:not(.side-icon):not(.side-caret){overflow:hidden;text-overflow:ellipsis}
.side-icon{width:28px;height:28px;flex:0 0 28px;display:grid;place-items:center;border-radius:10px;color:#dbeafe;background:rgba(255,255,255,.07);font-size:16px;line-height:1}
.side-caret{margin-left:auto;color:#9cc3ff;font-size:14px}
.side-link.active,.side-link:hover,.main-menu-button:hover{color:#fff;background:linear-gradient(135deg,var(--sidebar-active),#1d9bf0);border-color:rgba(255,255,255,.16);box-shadow:0 12px 26px rgba(11,107,255,.24)}
.side-link.active .side-icon,.side-link:hover .side-icon,.main-menu-button:hover span:first-child{background:rgba(255,255,255,.18);color:#fff}
.sub-link{min-height:38px;padding:9px 10px;font-size:12.5px;color:#d3ddf0;border-radius:12px;background:rgba(255,255,255,.04)}
.sub-link:hover,.sub-link.active{color:#fff;background:rgba(11,107,255,.34);border-color:rgba(255,255,255,.12)}
.main-menu-button{margin-top:8px;background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.09);justify-content:center}
.sidebar-card{margin-top:16px;padding:16px;border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.10);color:#eef5ff;display:grid;gap:4px;box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.sidebar-card strong{font-size:14px}.sidebar-card span,.sidebar-card small{color:#b9c8df}.sidebar-card small{font-size:12px}
.app-content{min-width:0;display:flex;flex-direction:column;position:relative}
.app-header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 28px;background:rgba(255,255,255,.86);border-bottom:1px solid var(--border);backdrop-filter:blur(14px);position:sticky;top:0;z-index:20;box-shadow:var(--shadow-xs)}
.header-title{display:flex;align-items:center;gap:12px;color:var(--text-2);font-weight:800;min-width:0}
.header-title span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pulse-dot{width:10px;height:10px;border-radius:999px;background:var(--green);box-shadow:0 0 0 5px rgba(18,183,106,.12)}
.mobile-menu-toggle{display:none;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:20px;cursor:pointer;box-shadow:var(--shadow-xs)}
.header-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap;min-width:0}
.header-icon{width:40px;height:40px;display:grid;place-items:center;border:1px solid var(--border);border-radius:999px;color:var(--text-2);background:var(--surface);font-weight:900;box-shadow:var(--shadow-xs)}
.user-chip{display:flex;align-items:center;gap:10px;max-width:min(360px,42vw);padding:7px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-xs);min-width:0}
.user-chip>div{min-width:0}.user-chip strong{display:block;max-width:190px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text);font-size:13px}.user-chip small{display:block;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted);font-size:11px}.avatar{width:34px;height:34px;flex:0 0 34px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#0b6bff,#13b5d8);color:#fff;font-weight:900;box-shadow:0 10px 20px rgba(11,107,255,.18)}
.container{width:min(100%,1540px);margin:0 auto;padding:28px;min-width:0}
.footer{padding:12px 28px 22px;color:var(--muted);display:flex;justify-content:space-between;align-items:center;gap:16px;font-size:12px;flex-wrap:wrap}

/* Common surfaces */
.card,.panel,.metric-card,.kpi,.table-card,.form-card,.panel-card,.dashboard-card,.info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);min-width:0}
.card,.panel,.table-card,.form-card,.panel-card,.dashboard-card{padding:22px;margin-bottom:22px}
.card:hover,.panel:hover,.kpi-card:hover,.kpi:hover,.metric-card:hover{box-shadow:var(--shadow-md)}
.hero,.page-hero,.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:22px;margin-bottom:20px;flex-wrap:wrap}
.hero h1,.page-title{margin:0 0 8px;font-size:clamp(30px,3vw,46px);line-height:1.08;letter-spacing:-.035em;color:var(--text)}
.hero p,.page-hero p,.page-head p{margin:0;color:var(--muted);font-size:clamp(15px,1.3vw,17px);max-width:980px;line-height:1.5}
h1,h2,h3{color:var(--text);letter-spacing:-.025em} h1{font-size:clamp(28px,3vw,42px);line-height:1.1} h2{font-size:clamp(20px,2vw,28px)} h3{font-size:clamp(16px,1.5vw,20px)}
.section-title{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px;flex-wrap:wrap}
.section-title h2,.card h2,.card h3,.panel-card h3,.dashboard-card h2{margin:0 0 6px}.section-title span,.muted{color:var(--muted)}
.big-number{font-size:clamp(28px,3vw,40px);font-weight:900;color:var(--primary);line-height:1.08;letter-spacing:-.03em}
.small,.metric-note{font-size:12px;color:var(--muted)}
.notice,.alert{padding:14px 16px;border-radius:14px;margin-bottom:14px;background:var(--primary-soft);border:1px solid #b9d7ff;color:#153e75}
.notice.ok,.alert.success{background:var(--green-soft);border-color:#abefc6;color:#067647}.notice.error,.alert.error{background:var(--red-soft);border-color:#fecdca;color:#b42318}.warning{background:var(--orange-soft);border-color:#fedf89;color:#b54708}
.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.page-tools{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:10px 16px;border-radius:13px;background:linear-gradient(135deg,var(--primary),#168bff);color:#fff;border:1px solid transparent;cursor:pointer;box-shadow:0 10px 22px rgba(11,107,255,.20);font-weight:850;line-height:1.1;text-decoration:none;white-space:nowrap}
.btn:hover{color:#fff;filter:brightness(1.04);transform:translateY(-1px);box-shadow:0 14px 30px rgba(11,107,255,.24)}
.btn.ghost,.btn.secondary,.auth-btn.secondary{background:var(--surface);color:var(--text-2);border:1px solid var(--border);box-shadow:var(--shadow-xs)}
.btn.ghost:hover,.btn.secondary:hover{color:var(--primary);border-color:#b9d7ff;background:#f8fbff;box-shadow:var(--shadow-sm)}
.btn.small,.small-btn{min-height:36px;padding:8px 12px;font-size:12px;border-radius:11px}.btn.danger,.danger{background:linear-gradient(135deg,#d92d20,#f04438);color:#fff;border-color:transparent}.btn.primary{background:linear-gradient(135deg,var(--primary),#168bff);color:#fff}

/* Badges */
.badge,.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:var(--primary-soft);border:1px solid #b9d7ff;color:#175cd3;font-weight:850;font-size:12px;white-space:nowrap}
.badge.green,.success,.pill.green{background:var(--green-soft);border-color:#abefc6;color:#067647}.badge.orange,.pill.orange{background:var(--orange-soft);border-color:#fedf89;color:#b54708}.badge.red,.error,.pill.red{background:var(--red-soft);border-color:#fecdca;color:#b42318}.badge.gray,.pill.gray{background:#f2f4f7;border-color:#e4e7ec;color:#475467}.badge.blue,.pill.blue{background:var(--primary-soft);border-color:#b9d7ff;color:#175cd3}.badge.purple,.pill.purple{background:var(--purple-soft);border-color:#d9d6fe;color:#5925dc}
.dot{width:9px;height:9px;border-radius:999px;display:inline-block;background:var(--primary)}.dot.green{background:var(--green)}.dot.cyan{background:var(--cyan)}.dot.purple{background:var(--purple)}.dot.orange{background:var(--orange)}.dot.red{background:var(--red)}

/* Forms */
label{display:block;margin-bottom:8px;color:var(--text-2);font-weight:800;font-size:13px}
input,select,textarea{width:100%;min-width:0;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:12px;padding:11px 12px;outline:none;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease;-webkit-appearance:none;appearance:none}
select{background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 13px) calc(50% - 3px);background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:34px}
input:focus,select:focus,textarea:focus{border-color:#84caff;box-shadow:0 0 0 4px rgba(11,107,255,.12);background:#fff} textarea{min-height:110px;resize:vertical}.field{margin-bottom:16px}.field small{display:block;margin-top:6px;color:var(--muted)}
form .row,.form-grid,.row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;align-items:start}.filter-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;align-items:end}.filter-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.inline-form{display:flex;gap:10px;align-items:end;flex-wrap:wrap}.subtle-divider{height:1px;background:var(--border);margin:18px 0}.box{padding:16px;border:1px solid var(--border);border-radius:14px;background:var(--surface-soft)}

/* Tables */
.table-scroll,.table-wrap{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:16px}
table{width:100%;border-collapse:separate;border-spacing:0;min-width:760px}
th,td{padding:13px 14px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top;color:var(--text-2)}
th{position:sticky;top:0;background:#f8fafc;color:#475467;font-size:12px;text-transform:uppercase;letter-spacing:.04em;z-index:1}td strong{color:var(--text)}tr:hover td{background:#fbfdff}tbody tr:last-child td{border-bottom:0}.responsive-table{min-width:860px}
.table-wrap table,.table-scroll table{background:var(--surface)}

/* Dashboard / metrics */
.section-tabs{display:flex;gap:8px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:8px;margin:0 0 18px;box-shadow:var(--shadow-xs)}
.section-tabs a{flex:1;min-width:130px;text-align:center;padding:10px 12px;border-radius:12px;color:var(--text-2);font-weight:850;border:1px solid transparent;background:transparent}.section-tabs a.active,.section-tabs a:hover{background:var(--primary-soft);color:var(--primary);border-color:#b9d7ff}
.kpi-grid,.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin:18px 0 22px}.cards-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.grid{display:grid;gap:18px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-5{grid-template-columns:repeat(5,minmax(0,1fr))}
.kpi-card,.kpi,.metric-card{position:relative;overflow:hidden;min-height:126px;padding:20px;border-radius:20px;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm)}
.kpi-card::before,.kpi::before,.metric-card::before{content:"";position:absolute;right:16px;top:16px;width:54px;height:54px;border-radius:18px;background:var(--primary-soft);opacity:.86}.kpi-card::after,.kpi::after,.metric-card::after{content:"";position:absolute;right:34px;top:33px;width:18px;height:18px;border-radius:999px;background:var(--primary);box-shadow:0 0 0 8px rgba(11,107,255,.10)}
.kpi-card span,.metric-label,.kpi .label{display:block;color:var(--muted);font-weight:850;font-size:12px;letter-spacing:.04em;text-transform:uppercase;position:relative;z-index:1;max-width:calc(100% - 66px)}
.kpi-card strong,.kpi .value,.metric-value{display:block;color:var(--text);font-size:clamp(24px,2.4vw,36px);font-weight:950;letter-spacing:-.035em;line-height:1.08;margin:12px 0 8px;position:relative;z-index:1;overflow-wrap:anywhere}.kpi-card small,.metric-trend,.metric-note{color:var(--muted);font-size:12.5px;position:relative;z-index:1}.kpi-card small::first-letter{color:inherit}
.kpi-card.accent-cyan::before,.accent-cyan::before{background:#ecfeff}.kpi-card.accent-cyan::after,.accent-cyan::after{background:var(--cyan);box-shadow:0 0 0 8px rgba(19,181,216,.12)}.kpi-card.accent-green::before,.accent-green::before{background:var(--green-soft)}.kpi-card.accent-green::after,.accent-green::after{background:var(--green);box-shadow:0 0 0 8px rgba(18,183,106,.12)}.kpi-card.accent-purple::before,.accent-purple::before{background:var(--purple-soft)}.kpi-card.accent-purple::after,.accent-purple::after{background:var(--purple);box-shadow:0 0 0 8px rgba(122,90,248,.12)}.kpi-card.accent-orange::before,.accent-orange::before{background:var(--orange-soft)}.kpi-card.accent-orange::after,.accent-orange::after{background:var(--orange);box-shadow:0 0 0 8px rgba(247,144,9,.12)}.kpi-card.accent-blue::before,.accent-blue::before{background:var(--primary-soft)}.kpi-card.accent-blue::after,.accent-blue::after{background:var(--primary)}
.dashboard-grid{display:grid;gap:16px}.dashboard-grid.three-panels{grid-template-columns:minmax(0,1.35fr) minmax(290px,.75fr) minmax(290px,.75fr)}.dashboard-grid.four-panels{grid-template-columns:repeat(4,minmax(0,1fr))}.dashboard-grid.bottom-panels{grid-template-columns:repeat(3,minmax(0,1fr))}.span-2{grid-column:span 2}.compact-card{min-height:140px}
.metric-row,.indicator-row,.detail-item{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}.metric-row:last-child,.indicator-row:last-child,.detail-item:last-child{border-bottom:0}.metric-row strong,.indicator-row strong{color:var(--text);overflow-wrap:anywhere}
.progress,.mini-bar{height:9px;border-radius:999px;background:#eef2f6;overflow:hidden;margin-bottom:12px}.progress span,.mini-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),#13b5d8)}.progress.mutedbar span{background:linear-gradient(90deg,var(--orange),#fdb022)}
.simple-chart{width:100%;height:250px;border-radius:16px;background:linear-gradient(180deg,#f8fbff,#ffffff);border:1px solid var(--border);padding:18px;display:flex;align-items:flex-end;gap:14px;min-width:0;overflow:hidden}.simple-chart p{margin:auto;color:var(--muted)}.bar-wrap{flex:1;min-width:42px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:8px;height:100%}.bar{width:100%;max-width:44px;border-radius:14px 14px 8px 8px;background:linear-gradient(180deg,#0b6bff,#84caff);box-shadow:0 12px 22px rgba(11,107,255,.16)}.bar-wrap small{color:var(--muted);font-size:12px}
.bar-chart{display:grid;gap:12px}.bar-row{display:grid;grid-template-columns:minmax(140px,.7fr) minmax(140px,1fr) auto;align-items:center;gap:12px}.bar-label{color:var(--text-2);font-weight:750}.bar-track{height:10px;border-radius:999px;background:#eef2f6;overflow:hidden}.bar-track span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--cyan))}.bar-value{font-weight:850;color:var(--text);white-space:nowrap}
.donut-css{width:168px;height:168px;border-radius:50%;background:conic-gradient(var(--green) 0 calc(var(--p, 0) * 1%), #eef2f6 0);display:grid;place-items:center;margin:0 auto;position:relative}.donut-css::before{content:'';width:96px;height:96px;border-radius:50%;background:var(--surface);display:block;position:absolute;box-shadow:inset 0 0 0 1px var(--border)}.donut-css b,.donut-css span{position:relative;z-index:1;display:block;text-align:center}.donut-css b{font-size:28px;color:var(--text)}.donut-css span{font-size:12px;color:var(--muted)}
.chart-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.legend,.indicator-list,.detail-list{display:grid;gap:8px}.four-panels,.bottom-panels{align-items:stretch}

/* Payroll / visual fixes */
.payroll-layout{display:grid;grid-template-columns:minmax(0,2.1fr) minmax(320px,.9fr);gap:18px;align-items:start}.payroll-layout>*,.dashboard-grid>*{min-width:0}.info-card{position:relative;overflow:hidden;padding:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:16px}.info-card h3{display:flex;align-items:center;gap:9px;margin:0 0 10px}.info-visual{float:none;display:grid;place-items:center;margin:0 0 14px auto;width:82px;height:82px;border-radius:22px;background:linear-gradient(135deg,var(--primary-soft),var(--purple-soft));border:1px solid var(--border);font-size:38px;color:var(--primary)}
.line-chart canvas,.svg-chart,canvas{max-width:100%!important}.floating-note,.floating-window,.popover,.dropdown-panel{position:static!important;inset:auto!important;z-index:auto!important;max-width:100%!important}.modal,.modal-content,.dialog{max-width:min(720px,calc(100vw - 32px));max-height:calc(100dvh - 48px);overflow:auto;border-radius:var(--radius-lg)}

/* Utility */
.primary{color:var(--primary)}.blue{color:var(--primary)}.green{color:var(--green)}.cyan{color:var(--cyan)}.purple{color:var(--purple)}.orange{color:var(--orange)}.red{color:var(--red)}.value{font-weight:950;color:var(--text)}.label{color:var(--muted);font-weight:750}.copy-link{word-break:break-all}.cert-actions,.reset-inline,.pill-list{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.cert-head,.cert-meta{display:flex;gap:14px;align-items:flex-start;justify-content:space-between;flex-wrap:wrap}.cert-body{padding:18px;border:1px solid var(--border);border-radius:16px;background:var(--surface-soft)}.cert-signature{margin-top:28px}.cert-line{width:220px;height:1px;background:var(--border);margin-bottom:8px}.page-eyebrow{color:var(--primary);font-weight:900;text-transform:uppercase;letter-spacing:.1em;font-size:12px}.dashboard-priority{border:1px solid #b9d7ff;background:var(--primary-soft);border-radius:18px;padding:16px}

/* Responsive */
@media (max-width:1360px){
  :root{--sidebar-width:248px}
  .brand-block img{width:176px}.container{padding:24px}.app-header{padding-inline:22px}.kpi-grid,.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-grid.three-panels,.dashboard-grid.four-panels,.dashboard-grid.bottom-panels,.payroll-layout,.grid-4,.grid-5{grid-template-columns:repeat(2,minmax(0,1fr))}.span-2{grid-column:1 / -1}.user-chip small{display:none}
}
@media (max-width:1100px){
  .app-shell{display:block}.mobile-menu-toggle{display:inline-flex}.sidebar{position:fixed;left:0;top:0;bottom:0;height:100dvh;width:min(86vw,310px);transform:translateX(-104%);transition:transform .22s ease;box-shadow:24px 0 60px rgba(15,23,42,.28)}body.sidebar-open .sidebar{transform:translateX(0)}body.sidebar-open .sidebar-overlay{display:block}.app-header{position:sticky;height:auto;min-height:68px}.header-title .pulse-dot{display:none}.container{padding:22px 16px}.header-main-btn{display:none}.footer{padding-inline:16px}.filter-grid,.grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:820px){
  body{font-size:13.5px}.app-header{align-items:flex-start;flex-direction:column}.header-title,.header-actions{width:100%}.header-actions{justify-content:flex-start}.user-chip{max-width:100%;border-radius:14px}.hero,.page-hero,.page-head,.section-title,.footer{flex-direction:column;align-items:flex-start}.actions,.page-tools{width:100%}.actions .btn,.page-tools .btn{flex:1 1 auto}.kpi-grid,.metric-grid,.cards-grid,.dashboard-grid.three-panels,.dashboard-grid.four-panels,.dashboard-grid.bottom-panels,.payroll-layout,.grid-2,.grid-3,.grid-4,.grid-5,form .row,.form-grid,.row,.filter-grid{grid-template-columns:1fr!important}.section-tabs a{min-width:calc(50% - 8px);flex:0 0 calc(50% - 8px)}.simple-chart{overflow-x:auto;align-items:flex-end}.bar-wrap{min-width:46px}.bar-row{grid-template-columns:1fr;gap:8px}.table-wrap table,.table-scroll table,.responsive-table{min-width:0}.responsive-table thead,.table-wrap table thead{display:none}.responsive-table,.responsive-table tbody,.responsive-table tr,.responsive-table td,.table-wrap table,.table-wrap table tbody,.table-wrap table tr,.table-wrap table td{display:block;width:100%}.responsive-table tr,.table-wrap table tr{border:1px solid var(--border);border-radius:16px;margin:0 0 12px;padding:8px;background:var(--surface);box-shadow:var(--shadow-xs)}.responsive-table td,.table-wrap table td{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border);padding:10px}.responsive-table td:last-child,.table-wrap table td:last-child{border-bottom:0}.responsive-table td::before,.table-wrap table td::before{content:attr(data-label);font-weight:900;color:var(--muted);min-width:42%;text-align:left}.responsive-table td:empty::after,.table-wrap table td:empty::after{content:"-";color:var(--muted)}
}
@media (max-width:560px){
  .container{padding:18px 12px}.app-header{padding:12px}.hero h1{font-size:30px}.section-tabs a{min-width:100%;flex-basis:100%}.kpi-card,.kpi,.metric-card,.card,.panel,.panel-card{padding:18px;border-radius:16px}.kpi-card strong,.kpi .value,.metric-value{font-size:clamp(22px,8vw,32px)}.actions .btn,.page-tools .btn,.filter-actions .btn{width:100%;flex-basis:100%}.header-icon{width:38px;height:38px}.user-chip{width:100%}.footer{font-size:11px}.brand-block img{width:170px}
}

/* V6 · Pre-nómina Colombia */
.payroll-flow-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:0 0 22px}
.flow-step{display:flex;align-items:center;gap:12px;padding:16px;border-radius:18px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-xs);min-width:0}
.flow-step span{width:34px;height:34px;flex:0 0 34px;display:grid;place-items:center;border-radius:12px;background:var(--primary-soft);color:var(--primary);font-weight:900}
.flow-step strong{display:block;color:var(--text);font-size:13px;line-height:1.2}.flow-step small{display:block;color:var(--muted);font-size:11px;line-height:1.25;margin-top:2px}
.payroll-prenomina-grid{align-items:start}.stack-form{display:grid;gap:14px}.soft-details{border:1px solid var(--border);border-radius:16px;padding:12px 14px;background:var(--surface-soft)}
.soft-details summary{cursor:pointer;font-weight:850;color:var(--text-2);outline:none}.soft-details .row{margin-top:12px}.small-note{font-size:12px;padding:12px 14px}.notice.info{background:var(--primary-soft);border-color:#bfd7ff;color:#1849a9}
.compact-table table th,.compact-table table td{padding:12px 10px}.payroll-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.metric-value.small-value{font-size:22px;line-height:1.15}
.payroll-table-wrap{max-height:none;overflow:auto;border-radius:18px;border:1px solid var(--border)}.payroll-table{min-width:1450px}.payroll-table th{position:sticky;top:0;z-index:2;background:var(--surface-soft)}
.payroll-table td{vertical-align:top}.hours-cell{display:grid;grid-template-columns:repeat(2,minmax(110px,1fr));gap:8px;min-width:280px}.hours-cell label,.payroll-table td label{display:grid;gap:4px;font-size:11px;color:var(--muted);font-weight:800;line-height:1.2}.hours-cell input,.payroll-table td input{width:100%;min-height:34px;padding:7px 9px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:12px}.payroll-table textarea{width:170px;min-height:96px;resize:vertical;border:1px solid var(--border);border-radius:12px;padding:9px;background:var(--surface);color:var(--text);font-size:12px}
.payroll-table input:disabled,.payroll-table textarea:disabled{background:#f2f4f7;color:var(--muted);cursor:not-allowed}.btn.danger{background:linear-gradient(135deg,var(--red),#d92d20);color:#fff;border-color:transparent}.btn.danger:hover{filter:brightness(.97)}
@media (max-width:1180px){.payroll-flow-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.payroll-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:760px){.payroll-flow-grid,.payroll-kpi-grid{grid-template-columns:1fr}.flow-step{align-items:flex-start}.hours-cell{grid-template-columns:1fr}.payroll-table{min-width:1180px}.payroll-prenomina-grid{grid-template-columns:1fr}.soft-details .row{grid-template-columns:1fr}}

/* V7 · Pre-nómina Colombia avanzada */
.employee-select-list{display:grid;gap:12px;max-height:520px;overflow:auto;padding-right:4px}
.employee-select-card{border:1px solid var(--border);background:linear-gradient(180deg,#fff,#f8fbff);border-radius:16px;padding:14px;box-shadow:0 8px 20px rgba(16,24,40,.04)}
.check-line{display:flex;align-items:center;gap:8px;margin:0;color:var(--text);font-weight:700}
.check-line input[type="checkbox"]{width:18px;height:18px;accent-color:var(--primary)}
.small-check{font-weight:600;font-size:.9rem;align-self:end;margin-bottom:10px}
.mini-row{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-top:10px}
.payroll-employee-list{display:grid;gap:18px}
.employee-payroll-card{border:1px solid var(--border);border-radius:22px;background:#fff;box-shadow:var(--shadow-soft);padding:18px;overflow:hidden}
.employee-payroll-card.is-excluded{opacity:.72;background:#f8fafc}
.employee-payroll-card.is-excluded .net-pill{background:#f1f5f9;color:#64748b}
.employee-payroll-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;border-bottom:1px solid var(--border);padding-bottom:14px;margin-bottom:14px}
.net-pill{min-width:190px;background:#ecfdf3;border:1px solid #bbf7d0;color:#067647;border-radius:16px;padding:12px;text-align:right}
.net-pill span{display:block;color:#667085;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.net-pill strong{display:block;font-size:1.2rem;margin-top:2px}
.net-pill a{display:inline-block;margin-top:6px;font-size:.82rem;font-weight:800;color:#0b6bff;text-decoration:none}
.payroll-input-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:14px}
.input-panel{border:1px solid var(--border);border-radius:16px;background:#fbfdff;padding:14px}
.input-panel h3{margin:0 0 10px;font-size:.95rem;color:#0f172a}
.input-panel .field label{font-size:.78rem}
.input-panel input,.input-panel textarea,.employee-select-card input{min-height:38px}
.input-panel textarea{min-height:76px}
.payroll-breakdown{border:1px solid var(--border);border-radius:16px;overflow:hidden;background:#fff}
.payroll-breakdown table{width:100%;border-collapse:collapse;margin:0}
.payroll-breakdown th,.payroll-breakdown td{padding:10px 12px;border-bottom:1px solid var(--border);text-align:left}
.payroll-breakdown th{width:44%;background:#f8fafc;color:#334155;font-weight:800}
.payroll-breakdown td{text-align:right;font-weight:700;color:#101828}
.payroll-breakdown tr:last-child th,.payroll-breakdown tr:last-child td{border-bottom:0}
.payroll-breakdown .net-row th,.payroll-breakdown .net-row td{background:#ecfdf3;color:#067647;font-size:1.05rem}
.pay-slip{max-width:900px;margin:40px auto}
.pay-slip-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;border-bottom:1px solid var(--border);padding-bottom:16px;margin-bottom:16px}
.print-body{background:#f6f8fb}
@media (max-width: 1100px){.payroll-input-grid{grid-template-columns:1fr}.employee-payroll-head{flex-direction:column}.net-pill{text-align:left;min-width:0;width:100%}}
@media (max-width: 720px){.employee-select-list{max-height:none}.employee-payroll-card{padding:14px;border-radius:18px}.mini-row{grid-template-columns:1fr}.payroll-breakdown th,.payroll-breakdown td{display:block;width:100%;text-align:left}.payroll-breakdown td{padding-top:0}.pay-slip-head{flex-direction:column}}

/* V8 Nómina Colombia avanzada */
.novelty-row,
.legal-row,
.legal-benefit-switches {
  align-items: end;
}
.employee-select-card .novelty-row,
.employee-select-card .legal-row {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--color-border, #e5e7eb);
}
.payroll-input-grid .input-panel h3 {
  margin-bottom: 10px;
}
.payroll-breakdown table tr th,
.payroll-breakdown table tr td {
  vertical-align: middle;
}
@media (max-width: 768px) {
  .legal-benefit-switches .check-line,
  .legal-row .check-line,
  .novelty-row .field {
    width: 100%;
  }
}

/* V9 · Corrección auxilio transporte y mejor identificación visual por empleado */
.employee-payroll-card{
  padding:0;
  border-radius:24px;
  background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);
}
.employee-payroll-head-v9{
  position:sticky;
  top:0;
  z-index:3;
  margin:0;
  padding:16px 18px;
  border-bottom:1px solid rgba(11,107,255,.18);
  background:linear-gradient(135deg,#082450 0%,#0b3b78 50%,#0b6bff 100%);
  color:#ffffff;
  box-shadow:0 12px 26px rgba(16,24,40,.14);
}
.employee-payroll-head-v9 .check-line,
.employee-payroll-head-v9 .employee-name-line,
.employee-payroll-head-v9 .employee-name-line strong{
  color:#ffffff;
}
.employee-payroll-head-v9 .check-line input[type="checkbox"]{
  accent-color:#ffffff;
}
.employee-identity{
  min-width:0;
  display:grid;
  gap:8px;
}
.employee-name-line{
  font-size:1.08rem;
  letter-spacing:.01em;
}
.employee-avatar{
  width:36px;
  height:36px;
  flex:0 0 36px;
  display:inline-grid;
  place-items:center;
  border-radius:14px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.34);
  color:#ffffff;
  font-weight:900;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18);
}
.employee-meta-row{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  color:rgba(255,255,255,.85);
  font-size:.84rem;
}
.employee-meta-row span:not(.employee-chip){
  padding:4px 9px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.13);
}
.employee-chip{
  padding:4px 10px;
  border-radius:999px;
  font-weight:800;
  font-size:.76rem;
}
.employee-chip.warning{
  background:#fffaeb;
  color:#b54708;
  border:1px solid #fedf89;
}
.employee-chip.muted-chip{
  background:#f2f4f7;
  color:#475467;
  border:1px solid #d0d5dd;
}
.employee-payroll-head-v9 .net-pill{
  background:rgba(236,253,243,.96);
  border-color:rgba(187,247,208,.92);
  box-shadow:0 10px 22px rgba(6,118,71,.16);
}
.employee-payroll-card .payroll-input-grid,
.employee-payroll-card .payroll-breakdown{
  margin:16px 18px;
}
.employee-payroll-card.is-excluded .employee-payroll-head-v9{
  background:linear-gradient(135deg,#475467 0%,#667085 100%);
}
.employee-payroll-card.is-excluded{
  opacity:1;
}
@media (max-width: 1100px){
  .employee-payroll-head-v9{position:relative;top:auto;}
}
@media (max-width: 720px){
  .employee-payroll-card .payroll-input-grid,
  .employee-payroll-card .payroll-breakdown{
    margin:14px;
  }
  .employee-payroll-head-v9{
    padding:14px;
  }
  .employee-name-line{
    align-items:flex-start;
  }
  .employee-meta-row{
    gap:6px;
  }
}

/* V10 · Ajustes visuales de tarjetas, aprobación y comprobantes */
.approval-destination-box{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;padding:16px;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,#f8fbff,#ffffff)}
.mini-label{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:800;margin-bottom:6px}
.compact-stack{gap:12px}.soft-separator{border:0;border-top:1px solid var(--border);margin:18px 0}
.employee-payroll-head-v10{position:sticky;top:0;z-index:3;margin:0;padding:18px;border-bottom:1px solid rgba(11,107,255,.18);background:linear-gradient(135deg,#082450 0%,#0b3b78 55%,#0b6bff 100%);color:#fff;box-shadow:0 12px 26px rgba(16,24,40,.14)}
.employee-payroll-head-v10 .employee-name-line,.employee-payroll-head-v10 .employee-name-line strong,.employee-payroll-head-v10 .check-line{color:#fff}.employee-payroll-head-v10 .check-line input[type="checkbox"]{accent-color:#fff}
.employee-identity-v10{display:grid;gap:10px;min-width:0}.employee-name-stack{display:grid;gap:2px}.employee-name-stack small{color:rgba(255,255,255,.82);font-weight:600;font-size:.83rem}.employee-name-line{display:flex;align-items:center;gap:10px}
.employee-header-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;align-items:stretch}
.employee-mini-card{padding:12px;border-radius:16px;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(8px)}
.employee-mini-card span{display:block;font-size:.76rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.78)}
.employee-mini-card strong{display:block;font-size:1rem;color:#fff;margin-top:4px}.employee-mini-card small{display:block;color:rgba(255,255,255,.75);margin-top:3px;font-size:.74rem}
.net-pill-v10{display:flex;flex-direction:column;justify-content:center;min-width:220px;background:rgba(236,253,243,.96);border-color:rgba(187,247,208,.92);box-shadow:0 10px 22px rgba(6,118,71,.16)}
.employee-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;padding:16px 18px 0}.summary-chip-card{border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,#ffffff,#f8fbff);padding:14px;box-shadow:0 8px 24px rgba(15,23,42,.04)}
.summary-chip-card span{display:block;color:#667085;font-size:.79rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.summary-chip-card strong{display:block;margin-top:6px;color:#101828;font-size:1.08rem}.summary-chip-card small{display:block;margin-top:4px;color:#667085;font-size:.8rem}
.payroll-breakdown-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:0 18px 18px}.breakdown-card{overflow:hidden}.breakdown-title{padding:12px 14px;background:#f8fbff;border-bottom:1px solid var(--border);font-weight:900;color:#0f172a}
.pay-slip .breakdown-title{border-top-left-radius:12px;border-top-right-radius:12px}.pay-slip .payroll-breakdown{border-radius:18px}
.employee-payroll-card.is-excluded .employee-payroll-head-v10{background:linear-gradient(135deg,#475467 0%,#667085 100%)}
@media (max-width:1180px){.employee-header-kpis,.employee-summary-grid,.payroll-breakdown-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:980px){.employee-payroll-head-v10{position:relative;top:auto}.employee-header-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:720px){.employee-payroll-head-v10{padding:14px}.employee-header-kpis,.employee-summary-grid,.payroll-breakdown-grid{grid-template-columns:1fr}.employee-summary-grid{padding:14px 14px 0}.payroll-breakdown-grid{margin:0 14px 14px}.net-pill-v10{min-width:0}}

/* V11 · Asignación porcentual de empleados a proyectos y costeo real */
.payroll-allocation-layout{align-items:start}.allocation-preset-note{padding:12px 14px;border:1px solid #bfd7ff;border-radius:14px;background:#eff6ff;color:#1849a9;font-size:12px;font-weight:700}.allocation-summary-list{display:grid;gap:10px;max-height:520px;overflow:auto;padding-right:4px}.allocation-summary-card{display:flex;justify-content:space-between;gap:14px;align-items:center;padding:13px 14px;border-radius:16px;border:1px solid var(--border);background:#fff;box-shadow:0 8px 20px rgba(16,24,40,.04)}.allocation-summary-card strong{display:block;color:#101828}.allocation-summary-card span{display:block;color:#667085;font-size:12px;margin-top:2px}.allocation-pct{font-size:18px;font-weight:900;color:#101828}.allocation-summary-card.green{background:#ecfdf3;border-color:#abefc6}.allocation-summary-card.orange{background:#fffaeb;border-color:#fedf89}.allocation-summary-card.red{background:#fef3f2;border-color:#fecdca}.allocation-summary-card.gray{background:#f8fafc;border-color:#eaecf0}.allocation-percent-badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 11px;border-radius:999px;background:#eff6ff;border:1px solid #bfd7ff;color:#175cd3;font-weight:900}.cost-sync-note{padding:12px 14px;border:1px solid #abefc6;border-radius:14px;background:#ecfdf3;color:#067647;font-size:12px;font-weight:700}.btn.danger{background:linear-gradient(135deg,var(--red),#d92d20);color:#fff;border-color:transparent}
@media (max-width:820px){.allocation-summary-card{align-items:flex-start;flex-direction:column}.allocation-pct{font-size:22px}}

/* V14 · Selección quincenal/mensual y neto en historial */
.payroll-candidate-card{transition:opacity .18s ease, transform .18s ease, border-color .18s ease}
.payroll-candidate-card[style*="display: none"]{display:none!important}
.payroll-candidate-card .badge{margin-left:8px}
#payrollSelectionNotice{border-left:4px solid var(--primary)}
.table-wrap h2 + .muted{margin-top:-4px;margin-bottom:14px}
@media (max-width: 760px){
  .payroll-candidate-card .check-line{align-items:flex-start;flex-wrap:wrap}
  .payroll-candidate-card .badge{margin-left:0}
}

/* V14.2 · Nómina Inicio estable */
.payroll-help-steps{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.payroll-mini-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.payroll-mini-metrics .metric-card{min-height:auto}.payroll-mini-metrics .small-value{font-size:clamp(18px,2vw,24px)}
@media(max-width:760px){.payroll-help-steps,.payroll-mini-metrics{grid-template-columns:1fr}}

/* V15 · Roles de usuario y nómina legal avanzada */
.role-inline{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.role-inline select{min-width:150px}.payslip-send-form{margin-top:8px}.payslip-send-form .small-btn{font-size:12px;padding:7px 10px;border-radius:10px}.legal-row .field label,.legal-benefit-switches .field label{white-space:normal}.payroll-legal-note{border:1px solid var(--border);background:#f8fbff;border-radius:16px;padding:12px;color:var(--muted);font-size:12px}.employee-payroll-head-v10 .payslip-send-form{display:block}.employee-payroll-head-v10 .payslip-send-form button{width:100%;margin-top:6px}.cash-vacation-hint{font-size:12px;color:var(--muted);margin-top:4px}.users-role-card{border:1px solid var(--border);border-radius:16px;padding:12px;background:#fff}
@media (max-width:760px){.role-inline select,.role-inline .btn{width:100%}.payslip-send-form .small-btn{width:100%}}

/* V16 · Facturación: KPIs correctos por moneda y refresco liviano */
.invoice-kpi-grid .kpi-card strong.kpi-multiline{
  display:grid;
  gap:3px;
  font-size:clamp(18px,2.1vw,28px);
  line-height:1.08;
}
.kpi-money-line{
  display:block;
  white-space:nowrap;
}
.notice.info{
  background:var(--primary-soft,#eff6ff);
  border-color:#bfd7ff;
  color:#1849a9;
}
#refreshInvoiceKpis:disabled{
  opacity:.7;
  cursor:wait;
}
@media (max-width:760px){
  .invoice-kpi-grid .kpi-card strong.kpi-multiline{
    font-size:22px;
  }
}

/* V17 · Facturación organizada por fecha y cuentas por pagar a partners */
.invoice-kpi-grid-v17{grid-template-columns:repeat(6,minmax(0,1fr));}
.kpi-card.accent-orange::after{background:#fff7ed;color:#f97316;content:'◍';}
.kpi-card.accent-red::after{background:#fef3f2;color:#f04438;content:'◆';}
.partner-payable-card{margin-top:18px;}
.partner-payable-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;}
.partner-payable-item{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;padding:14px;border:1px solid var(--border);border-radius:16px;background:linear-gradient(180deg,#fff,#f8fbff);box-shadow:var(--shadow-xs);}
.partner-payable-item strong{display:block;color:var(--text);font-weight:900;}
.partner-payable-item small{display:block;color:var(--muted);font-size:12px;margin-top:4px;}
.partner-payable-amount{text-align:right;font-weight:900;color:#b42318;white-space:nowrap;}
.partner-payable-amount small{font-weight:700;color:var(--muted);white-space:normal;}
.invoice-month-row td{background:#eef4ff!important;color:#175cd3!important;font-weight:900;border-top:2px solid #dbe7ff;border-bottom:1px solid #c7dcff;padding:12px 14px!important;}
.invoice-month-row strong{display:flex;align-items:center;gap:8px;}
.invoice-month-row strong::before{content:'📅';font-size:14px;}
@media (max-width:1320px){.invoice-kpi-grid-v17{grid-template-columns:repeat(3,minmax(0,1fr));}}
@media (max-width:760px){.invoice-kpi-grid-v17{grid-template-columns:1fr;}.partner-payable-item{flex-direction:column}.partner-payable-amount{text-align:left}.invoice-month-row td{display:block;width:100%;}}

/* V19 · Facturación financiera: partners, proyectos, nómina y rentabilidad */
.invoice-kpi-grid-v19{grid-template-columns:repeat(4,minmax(0,1fr));align-items:stretch}.invoice-kpi-grid-v19 .kpi-card strong{line-height:1.15}.kpi-money-line{display:block;white-space:nowrap}.financial-grid-v19{align-items:start;margin-top:18px}.partner-payable-grid-v19{display:grid;gap:12px}.partner-payable-grid-v19 .partner-payable-item{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;border:1px solid var(--border);background:linear-gradient(180deg,#fff,#f8fbff);border-radius:18px;padding:14px;box-shadow:var(--shadow-xs)}.partner-payable-grid-v19 .partner-payable-item strong{display:block;color:var(--text)}.partner-payable-grid-v19 .partner-payable-item small{display:block;color:var(--muted);margin-top:3px;line-height:1.35}.partner-payable-amount{text-align:right;font-weight:900;color:var(--text);min-width:160px}.text-success{color:#067647}.text-danger{color:#b42318}.compact-table table td,.compact-table table th{padding:10px 12px}.partner-required-highlight select{border-color:#f79009!important;background:#fffcf5}.partner-required-highlight label{color:#b54708}.invoice-month-row td{background:#f8fbff!important;color:#0f172a;font-weight:900;border-top:1px solid var(--border)}
@media (max-width:1280px){.invoice-kpi-grid-v19{grid-template-columns:repeat(2,minmax(0,1fr))}.financial-grid-v19{grid-template-columns:1fr!important}}
@media (max-width:720px){.invoice-kpi-grid-v19{grid-template-columns:1fr}.partner-payable-grid-v19 .partner-payable-item{flex-direction:column}.partner-payable-amount{text-align:left;min-width:0}}



/* V19.1 · Corrección facturas partner sin partner/proyecto */
.validation-action-box{display:flex;justify-content:space-between;gap:14px;align-items:center}
.validation-action-box .actions{margin:0}
.partner-fix-list{display:grid;gap:16px}
.partner-fix-card{border:1px solid var(--border);border-radius:20px;background:linear-gradient(180deg,#fff,#f8fbff);box-shadow:var(--shadow-xs);padding:18px;display:grid;gap:14px}
.partner-fix-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;border-bottom:1px solid var(--border);padding-bottom:12px}
.partner-fix-head strong{display:block;font-size:1rem;color:var(--text)}
.partner-fix-head span:not(.badge){display:block;color:var(--muted);font-size:.88rem;margin-top:4px}
.partner-fix-current{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.partner-fix-current div{border:1px solid var(--border);border-radius:14px;background:#fff;padding:10px}
.partner-fix-current span{display:block;color:var(--muted);font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.partner-fix-current strong{display:block;margin-top:4px;color:var(--text);font-size:.9rem}
@media (max-width:900px){.validation-action-box,.partner-fix-head{flex-direction:column;align-items:flex-start}.partner-fix-current{grid-template-columns:1fr 1fr}}
@media (max-width:620px){.partner-fix-current{grid-template-columns:1fr}}

/* V20 · Mejoras visuales Control de Facturación: nómina por proyecto y scroll superior */
.invoice-kpi-card-detailed{
  min-height: 190px;
  display: flex;
  flex-direction: column;
}
.invoice-kpi-card-detailed strong{
  margin-bottom: 6px;
}
.kpi-detail-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  margin:8px 0 10px;
  position:relative;
  z-index:1;
}
.kpi-detail-list div{
  padding:9px 10px;
  border-radius:14px;
  background:#f8fbff;
  border:1px solid var(--border);
}
.kpi-detail-list b{
  display:block;
  color:var(--text);
  font-size:1rem;
  line-height:1;
}
.kpi-detail-list small{
  display:block;
  margin-top:4px;
  color:var(--muted);
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.04em;
  font-size:.68rem;
}
.kpi-breakdown-list{
  display:grid;
  gap:6px;
  margin-top:auto;
  position:relative;
  z-index:1;
  padding-top:8px;
  border-top:1px dashed var(--border);
}
.kpi-breakdown-list>span{
  color:var(--muted);
  font-weight:900;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.kpi-breakdown-list div{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:flex-start;
}
.kpi-breakdown-list div small{
  color:var(--text-2);
  font-size:.76rem;
  line-height:1.25;
  max-width:58%;
}
.kpi-breakdown-list div strong{
  font-size:.82rem!important;
  margin:0!important;
  line-height:1.25!important;
  white-space:nowrap;
  text-align:right;
}
.kpi-breakdown-list em,
.kpi-empty-note{
  color:var(--muted);
  font-size:.78rem;
  font-style:normal;
  position:relative;
  z-index:1;
}
.payroll-cost-detail-card{
  margin:18px 0;
}
.payroll-project-cost-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:12px;
}
.payroll-project-cost-item{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:flex-start;
  padding:14px;
  border:1px solid var(--border);
  border-radius:18px;
  background:linear-gradient(180deg,#ffffff,#f8fbff);
  box-shadow:var(--shadow-xs);
}
.payroll-project-cost-item strong,
.payroll-project-cost-item b{
  display:block;
  color:var(--text);
}
.payroll-project-cost-item span,
.payroll-project-cost-item small{
  display:block;
  color:var(--muted);
  font-size:.8rem;
  margin-top:4px;
  line-height:1.35;
}
.payroll-project-cost-item>div:last-child{
  text-align:right;
  min-width:132px;
}
.scroll-x-top{
  max-width:100%;
  overflow-x:auto;
  overflow-y:hidden;
  height:15px;
  margin:4px 0 8px;
  border-radius:999px;
  background:#f8fafc;
  border:1px solid var(--border);
  -webkit-overflow-scrolling:touch;
}
.scroll-x-top-inner{
  height:1px;
}
.table-scroll{
  scrollbar-gutter:stable;
  border:1px solid var(--border);
  border-radius:16px;
}
.table-scroll table{
  margin:0;
}
.scroll-x-top::-webkit-scrollbar,
.table-scroll::-webkit-scrollbar{
  height:12px;
}
.scroll-x-top::-webkit-scrollbar-track,
.table-scroll::-webkit-scrollbar-track{
  background:#eef2f6;
  border-radius:999px;
}
.scroll-x-top::-webkit-scrollbar-thumb,
.table-scroll::-webkit-scrollbar-thumb{
  background:#9bb7df;
  border-radius:999px;
  border:2px solid #eef2f6;
}
.scroll-x-top::-webkit-scrollbar-thumb:hover,
.table-scroll::-webkit-scrollbar-thumb:hover{
  background:#6f8fc0;
}
@media (max-width:760px){
  .invoice-kpi-card-detailed{min-height:auto}
  .kpi-detail-list{grid-template-columns:1fr 1fr}
  .kpi-breakdown-list div{flex-direction:column;gap:2px}
  .kpi-breakdown-list div small{max-width:100%}
  .kpi-breakdown-list div strong{text-align:left!important;white-space:normal}
  .payroll-project-cost-item{flex-direction:column}
  .payroll-project-cost-item>div:last-child{text-align:left;min-width:0}
}

/* V21 · Asistente automático de prestaciones y horas extra */
.legal-calendar-assistant{display:flex;gap:14px;align-items:flex-start;padding:16px 18px;border:1px solid #bfd7ff;border-radius:18px;background:linear-gradient(135deg,#eff6ff,#ffffff);box-shadow:0 8px 22px rgba(29,78,216,.06)}
.legal-calendar-assistant .assistant-icon{width:38px;height:38px;flex:0 0 38px;display:grid;place-items:center;border-radius:13px;background:#0b6bff;color:#fff;font-weight:900;box-shadow:0 8px 18px rgba(11,107,255,.22)}
.legal-calendar-assistant strong{display:block;color:#12305f;font-size:15px}.legal-calendar-assistant p{margin:4px 0 0;color:#475467;font-size:13px;line-height:1.45}
.employee-subsection{margin-top:14px;padding:14px;border:1px solid var(--border);border-radius:18px;background:#fff}
.subsection-heading{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:12px}.subsection-heading strong{display:block;color:#101828}.subsection-heading small{display:block;color:#667085;margin-top:3px;line-height:1.35}
.benefit-option-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.benefit-option-card{display:grid;gap:10px;padding:14px;border:1px solid #dbe7ff;border-radius:16px;background:linear-gradient(180deg,#f8fbff,#fff);transition:.18s ease}
.benefit-option-card:has(input[type="checkbox"]:checked){border-color:#84adff;background:linear-gradient(180deg,#eff6ff,#fff);box-shadow:0 8px 18px rgba(11,107,255,.08)}
.benefit-option-card .field{margin:0}.benefit-option-card small{color:#667085;line-height:1.35}
.benefit-preview{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:10px 11px;border-radius:12px;background:#f2f4f7}.benefit-preview span{font-size:11px;color:#667085;text-transform:uppercase;font-weight:800;letter-spacing:.04em}.benefit-preview strong{color:#101828;font-size:14px}
.overtime-create-section{background:linear-gradient(180deg,#fff,#fffbf5);border-color:#fedf89}.overtime-input-grid{display:grid;grid-template-columns:repeat(4,minmax(135px,1fr));gap:10px}.overtime-input-grid .field{margin:0}.overtime-input-grid small{display:block;color:#667085;margin-top:4px;font-size:11px}.overtime-preview-total{min-width:170px;padding:10px 12px;border-radius:14px;background:#fff7ed;border:1px solid #fed7aa;text-align:right}.overtime-preview-total span{display:block;font-size:11px;text-transform:uppercase;color:#9a3412;font-weight:800}.overtime-preview-total strong{display:block;margin-top:2px;color:#9a3412;font-size:17px}
.payroll-candidate-card{scroll-margin-top:88px}.payroll-candidate-card .legal-auto-section,.payroll-candidate-card .overtime-create-section{box-shadow:0 6px 16px rgba(16,24,40,.03)}
.payroll-candidate-card input:disabled{background:#f2f4f7!important;color:#98a2b3!important;cursor:not-allowed}
@media (max-width:1180px){.benefit-option-grid{grid-template-columns:1fr}.overtime-input-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:720px){.legal-calendar-assistant,.subsection-heading{flex-direction:column}.overtime-preview-total{width:100%;text-align:left}.overtime-input-grid{grid-template-columns:1fr}.employee-subsection{padding:12px}.benefit-option-card{padding:12px}}

/* V22 · Prestaciones con horas variables y corrección de sobreposición */
.payroll-main-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(300px,360px);
  gap:20px;
  align-items:start;
}
.payroll-builder-card,
.payroll-create-form,
.employee-select-list,
.payroll-candidate-card,
.employee-subsection,
.benefit-option-grid,
.benefit-option-card,
.benefit-variable-grid,
.benefit-variable-panel,
.benefit-variable-inputs,
.overtime-input-grid,
.payroll-input-grid,
.input-panel{
  min-width:0;
  max-width:100%;
  box-sizing:border-box;
}
.payroll-candidate-card{
  overflow:hidden;
  padding:16px;
}
.payroll-candidate-card .row,
.payroll-candidate-card .mini-row{
  min-width:0;
  width:100%;
}
.payroll-candidate-card input,
.payroll-candidate-card select,
.payroll-candidate-card textarea,
.input-panel input,
.input-panel select,
.input-panel textarea{
  width:100%;
  max-width:100%;
  box-sizing:border-box;
}
.benefit-option-grid{
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
}
.benefit-option-card{
  overflow:hidden;
}
.benefit-variable-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin-top:12px;
}
.benefit-variable-panel{
  border:1px solid #d0dfff;
  border-radius:16px;
  background:linear-gradient(180deg,#ffffff,#f8fbff);
  padding:0;
  overflow:hidden;
}
.benefit-variable-panel summary{
  cursor:pointer;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:3px;
  padding:13px 14px;
  background:#f4f8ff;
  border-bottom:1px solid transparent;
  color:#12305f;
  font-weight:850;
}
.benefit-variable-panel[open] summary{border-bottom-color:#dbe7ff}
.benefit-variable-panel summary::-webkit-details-marker{display:none}
.benefit-variable-panel summary small{
  color:#667085;
  font-weight:600;
  line-height:1.35;
}
.benefit-variable-inputs{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(125px,1fr));
  gap:10px;
  padding:13px;
}
.benefit-variable-inputs .field{margin:0}
.variable-summary{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  padding:0 13px 13px;
}
.variable-summary>div{
  padding:10px;
  border-radius:12px;
  background:#eef4ff;
  border:1px solid #d7e5ff;
  min-width:0;
}
.variable-summary span{
  display:block;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:#475467;
  font-weight:850;
}
.variable-summary strong{
  display:block;
  margin-top:4px;
  color:#12305f;
  overflow-wrap:anywhere;
}
.overtime-input-grid{
  grid-template-columns:repeat(auto-fit,minmax(155px,1fr));
}
.subsection-heading{
  flex-wrap:wrap;
}
.benefit-variable-edit{
  grid-column:1 / -1;
}
.benefit-variable-edit .benefit-variable-panel+ .benefit-variable-panel{
  margin-top:10px;
}
.payroll-breakdown th,
.payroll-breakdown td{
  overflow-wrap:anywhere;
}
@media (max-width:1400px){
  .payroll-main-grid{grid-template-columns:1fr}
}
@media (max-width:960px){
  .benefit-variable-grid{grid-template-columns:1fr}
}
@media (max-width:620px){
  .payroll-candidate-card{padding:12px}
  .benefit-variable-inputs,
  .variable-summary{grid-template-columns:1fr}
  .benefit-variable-panel summary{padding:12px}
}

/* V23 · Excepción manual controlada enero/febrero 2026 */
.manual-exception-box{
  display:grid;
  gap:10px;
  margin-top:12px;
  padding:14px;
  border:1px solid #fedf89;
  border-radius:16px;
  background:linear-gradient(180deg,#fffaeb 0%,#fffdf5 100%);
  box-shadow:0 8px 22px rgba(181,71,8,.06);
}
.manual-exception-box[hidden]{display:none!important}
.manual-exception-title{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.manual-exception-title strong{color:#7a2e0e}
.manual-exception-box .field{min-width:0}
.manual-exception-box input[type="number"]{background:#fff;border-color:#f7c65f}
.manual-exception-edit{grid-column:1/-1;background:#fffdf7;border-color:#fedf89}
.manual-exception-edit .manual-exception-box + .manual-exception-box{margin-top:14px}
@media (max-width:760px){
  .manual-exception-title{align-items:flex-start}
  .manual-exception-edit{grid-column:auto}
}

/* V23.1 · Corrección de generación de pre-nómina y mensajes visibles */
.payroll-generate-btn{
  position:relative;
  z-index:5;
  min-height:48px;
  width:100%;
  justify-content:center;
  font-size:1rem;
  font-weight:900;
  cursor:pointer;
}
.payroll-generate-btn:disabled{cursor:wait;opacity:.8}
.payroll-generate-btn.is-loading::before{
  content:"";
  width:18px;
  height:18px;
  margin-right:9px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.45);
  border-top-color:#fff;
  animation:payroll-spin .8s linear infinite;
}
@keyframes payroll-spin{to{transform:rotate(360deg)}}
.payroll-submit-message{
  position:sticky;
  bottom:12px;
  z-index:12;
  padding:14px 16px;
  border-radius:14px;
  border:1px solid var(--border);
  box-shadow:0 12px 28px rgba(16,24,40,.15);
}
.payroll-submit-message.is-error{background:#fef3f2;border-color:#fecdca;color:#b42318}
.payroll-submit-message.is-processing{background:#eff8ff;border-color:#b2ddff;color:#175cd3}
.payroll-server-error{position:sticky;top:78px;z-index:20;box-shadow:0 12px 28px rgba(180,35,24,.18)}
.input-error{border-color:#f04438!important;box-shadow:0 0 0 3px rgba(240,68,56,.14)!important;background:#fffafa!important}
.payroll-create-form{position:relative;isolation:isolate}
@media(max-width:820px){.payroll-server-error{top:8px}.payroll-submit-message{bottom:8px}}

/* V24 · Deducciones automáticas de salud y pensión */
.employee-contribution-preview{margin:14px 0;padding:15px;border:1px solid #b7e4c7;border-radius:18px;background:linear-gradient(180deg,#f0fdf4 0%,#ffffff 100%);box-shadow:0 8px 24px rgba(16,185,129,.07)}
.contribution-preview-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:12px}.contribution-preview-head strong{display:block;color:#065f46}.contribution-preview-head small{display:block;color:#475467;margin-top:4px;line-height:1.35}
.contribution-preview-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:10px}.contribution-preview-grid>div{padding:11px 12px;border:1px solid #d1fae5;border-radius:14px;background:#fff}.contribution-preview-grid span{display:block;color:#667085;font-size:.76rem;font-weight:800;text-transform:uppercase;letter-spacing:.035em}.contribution-preview-grid strong{display:block;margin-top:5px;color:#065f46;font-size:1rem}
.deduction-policy-note{display:block;margin-top:4px;color:#667085;font-size:.72rem;font-weight:600;line-height:1.3;text-transform:none;letter-spacing:0}
@media (max-width:1050px){.contribution-preview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:650px){.contribution-preview-head{flex-direction:column}.contribution-preview-grid{grid-template-columns:1fr}}
