*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--green-50:#e6f1fb;--green-100:#b5d4f4;--green-500:#0ea5e9;--green-700:#0369a1;--blue-50:#e6f1fb;--blue-500:#378add;--blue-700:#185fa5;--amber-50:#faeeda;--amber-700:#854f0b;--red-50:#fcebeb;--red-700:#a32d2d;--gray-50:#f8f9fa;--gray-100:#f1f3f5;--gray-200:#e9ecef;--gray-300:#dee2e6;--gray-400:#ced4da;--gray-500:#adb5bd;--gray-600:#6c757d;--gray-700:#495057;--gray-800:#343a40;--gray-900:#212529;--sidebar-w:230px;--topbar-h:52px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a}body{color:var(--gray-800);background:var(--gray-100);height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;overflow:hidden}.login-page{background:#060f1a;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#0ea5e92e 0%,#0000 70%);border-radius:50%;width:500px;height:500px;position:absolute;top:-100px;left:-100px}.login-page:after{content:"";pointer-events:none;background:radial-gradient(circle,#22d3ee1f 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-80px;right:-60px}.login-card{z-index:1;-webkit-backdrop-filter:blur(20px);text-align:center;background:#0d2540bf;border:1px solid #22d3ee2e;border-radius:16px;flex-direction:column;align-items:center;width:380px;padding:40px 32px 32px;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 60px #00000080,0 0 0 1px #22d3ee0f}.login-card:before{content:"";pointer-events:none;background:radial-gradient(circle,#0ea5e940 0%,#0ea5e900 70%);border-radius:50%;width:340px;height:240px;position:absolute;top:-120px;left:50%;transform:translate(-50%)}.login-logo{flex-direction:column;align-items:center;gap:0;margin-bottom:0;display:flex;position:relative}.login-logo-icon{background:linear-gradient(135deg, var(--green-500), var(--green-700));border-radius:var(--radius-lg);color:#fff;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:14px;font-size:28px;display:flex;box-shadow:0 8px 24px #0ea5e959}.login-logo-img{object-fit:contain;border-radius:var(--radius-lg);background:#fff;width:64px;height:64px;margin-bottom:14px;box-shadow:0 8px 24px #0ea5e940}.login-logo-text{color:#f1f5f9;font-size:17px;font-weight:500}.login-logo-sub{color:#ffffff73;margin-top:2px;font-size:12px}.login-title{color:#f1f5f9;margin-top:22px;margin-bottom:4px;font-size:20px;font-weight:500;position:relative}.login-sub{color:#ffffff80;margin-bottom:24px;font-size:13px;position:relative}.login-card form{width:100%;position:relative}.login-card .form-group{text-align:left}.login-card .form-label{color:#ffffff8c}.login-card .form-input{color:#f1f5f9;background:#ffffff0f;border:.5px solid #ffffff1a;border-radius:10px;height:42px}.login-card .form-input::placeholder{color:#ffffff4d}.login-card .form-input:focus{border-color:var(--green-500);box-shadow:0 0 0 3px #0ea5e926}.login-card .btn-primary{background:linear-gradient(135deg, var(--green-500), var(--green-700));border-color:#0000;border-radius:10px;height:44px;font-weight:500;box-shadow:0 8px 20px #0ea5e94d}.login-card .btn-primary:hover{filter:brightness(1.08)}.login-card .error-msg{color:#f09595;text-align:left;background:#e24b4a1f}.login-foot{color:#ffffff59;margin-top:18px;font-size:12px;position:relative}.form-group{margin-bottom:16px}.form-label{color:var(--gray-600);margin-bottom:5px;font-size:12px;font-weight:500;display:block}.form-input{border:1px solid var(--gray-300);border-radius:var(--radius-sm);width:100%;color:var(--gray-800);background:#fff;outline:none;padding:8px 11px;font-size:13px;transition:border .15s}.form-input:focus{border-color:var(--green-500);box-shadow:0 0 0 3px #0ea5e91a}.form-select{border:1px solid var(--gray-300);border-radius:var(--radius-sm);width:100%;color:var(--gray-800);background:#fff;outline:none;padding:8px 11px;font-size:13px}textarea.form-input{resize:vertical;min-height:72px}.btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--gray-300);color:var(--gray-700);white-space:nowrap;background:#fff;align-items:center;gap:5px;padding:8px 14px;font-size:13px;font-weight:500;transition:all .12s;display:inline-flex}.btn:hover{background:var(--gray-100)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--green-500);color:#fff;border-color:var(--green-500)}.btn-primary:hover{background:var(--green-700);border-color:var(--green-700)}.btn-danger{background:var(--red-50);color:var(--red-700);border-color:#f09595}.btn-blue{background:var(--blue-50);color:var(--blue-700);border-color:#9dc6ef}.btn-full{justify-content:center;width:100%}.btn-sm{padding:4px 9px;font-size:12px}.btn-icon{padding:5px 8px}.error-msg{background:var(--red-50);color:var(--red-700);border-radius:var(--radius-sm);margin-bottom:16px;padding:10px 14px;font-size:13px}.success-msg{background:var(--green-50);color:var(--green-700);border-radius:var(--radius-sm);margin-bottom:16px;padding:10px 14px;font-size:13px}.app-layout{height:100vh;display:flex}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:#0f2d4a;border-right:none;flex-direction:column;display:flex;overflow-y:auto}.sidebar-header{border-bottom:1px solid #ffffff14;padding:16px 14px 13px}.sidebar-logo{align-items:center;gap:8px;display:flex}.sidebar-logo-icon{border-radius:var(--radius-sm);color:#042830;background:#0ea5e9;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.sidebar-logo-text{color:#f1f5f9;font-size:13px;font-weight:600}.sidebar-section{color:#ffffff52;letter-spacing:.08em;text-transform:uppercase;padding:13px 14px 3px;font-size:10px;font-weight:700}.nav-item{border-radius:var(--radius-sm);color:#ffffffa6;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:calc(100% - 10px);margin:1px 5px;padding:7px 11px;font-size:13px;transition:all .12s;display:flex}.nav-item:hover{color:#fff;background:#ffffff12}.nav-item.active{color:#22d3ee;background:#22d3ee26;font-weight:500}.nav-badge{color:#042830;background:#22d3ee;border-radius:10px;margin-left:auto;padding:1px 7px;font-size:10px;font-weight:600}.sidebar-bottom{border-top:1px solid #ffffff14;margin-top:auto;padding:10px 5px}.sidebar-user{color:#fff6;padding:8px 11px;font-size:12px}.sidebar-user strong{color:#fffc;margin-bottom:1px;font-size:13px;display:block}.main-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{border-bottom:1px solid var(--gray-200);height:var(--topbar-h);background:#fff;flex-shrink:0;align-items:center;gap:12px;padding:0 22px;display:flex}.topbar-title{flex:1;font-size:15px;font-weight:600}.topbar-avatar{background:var(--green-50);width:32px;height:32px;color:var(--green-700);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.content-area{flex:1;padding:18px 22px;overflow-y:auto}.card{border:1px solid var(--gray-200);border-radius:var(--radius-lg);background:#fff;margin-bottom:14px;overflow:hidden}.card-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;gap:10px;padding:13px 16px;display:flex}.card-title{color:var(--gray-800);font-size:14px;font-weight:600}.stat-grid{grid-template-columns:repeat(4,1fr);gap:11px;margin-bottom:16px;display:grid}.stat-card{border:1px solid var(--gray-200);border-radius:var(--radius-lg);background:#fff;padding:15px;position:relative}.stat-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:34px;height:34px;font-size:18px;display:flex;position:absolute;top:13px;right:13px}.stat-label{color:var(--gray-500);margin-bottom:5px;font-size:11px}.stat-value{color:var(--gray-800);font-size:26px;font-weight:700;line-height:1}.stat-sub{color:var(--gray-400);margin-top:4px;font-size:11px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead th{text-align:left;color:var(--gray-500);background:var(--gray-50);border-bottom:1px solid var(--gray-200);white-space:nowrap;padding:9px 13px;font-size:11px;font-weight:600}tbody td{border-bottom:1px solid var(--gray-100);vertical-align:middle;color:var(--gray-800);padding:9px 13px}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--gray-50)}.badge{white-space:nowrap;border:1px solid #0000;border-radius:20px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-green{color:#0d7a52;background:#e6f9f2;border-color:#a3dfc7}.badge-blue{color:#1a5ea8;background:#ebf4ff;border-color:#a8cffb}.badge-amber{color:#925c0a;background:#fff8e6;border-color:#f9d98a}.badge-red{color:#a12828;background:#fef0f0;border-color:#f5aaaa}.badge-gray{background:var(--gray-100);color:var(--gray-600);border-color:var(--gray-300)}.filter-bar{border-bottom:1px solid var(--gray-200);flex-wrap:wrap;align-items:center;gap:7px;padding:11px 14px;display:flex}.filter-chip{border:1px solid var(--gray-300);color:var(--gray-600);cursor:pointer;background:#fff;border-radius:20px;padding:4px 11px;font-size:12px;font-weight:500;transition:all .12s}.filter-chip:hover{border-color:var(--green-500);color:var(--green-700)}.filter-chip.active{background:var(--green-50);color:var(--green-700);border-color:var(--green-100)}.alert{border-radius:var(--radius-sm);align-items:flex-start;gap:9px;margin-bottom:8px;padding:10px 13px;font-size:13px;display:flex}.alert-red{background:var(--red-50);color:var(--red-700)}.alert-warn{background:var(--amber-50);color:var(--amber-700)}.alert-info{background:var(--blue-50);color:var(--blue-700)}.loading{color:var(--gray-400);justify-content:center;align-items:center;gap:8px;padding:40px;font-size:14px;display:flex}.empty-state{color:var(--gray-400);flex-direction:column;justify-content:center;align-items:center;padding:44px 20px;display:flex}.empty-state-icon{margin-bottom:10px;font-size:36px}.empty-state p{font-size:13px}.row-2{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;display:grid}.bar-chart{padding:14px 16px}.bar-row{align-items:center;gap:9px;margin-bottom:9px;font-size:12px;display:flex}.bar-label{width:100px;color:var(--gray-500);text-align:right;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.bar-track{background:var(--gray-100);border-radius:4px;flex:1;height:10px}.bar-fill{border-radius:4px;height:10px;transition:width .6s}.bar-val{width:28px;color:var(--gray-600);font-weight:600}.modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-lg);width:700px;max-width:96vw;max-height:92vh;box-shadow:var(--shadow-md);background:#fff;overflow-y:auto}.modal-header{border-bottom:1px solid var(--gray-200);z-index:1;cursor:grab;-webkit-user-select:none;user-select:none;background:#fff;justify-content:space-between;align-items:center;padding:16px 18px;display:flex;position:sticky;top:0}.modal-header:active{cursor:grabbing}.modal-title{font-size:15px;font-weight:600}.modal-close{cursor:pointer;color:var(--gray-400);background:0 0;border:none;padding:0 4px;font-size:22px;line-height:1}.modal-close:hover{color:var(--gray-700)}.form-grid{grid-template-columns:1fr 1fr;gap:13px;padding:18px;display:grid}.form-col-full{grid-column:1/-1}.form-actions{justify-content:flex-end;gap:8px;padding:0 18px 18px;display:flex}.form-section-title{color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--gray-200);grid-column:1/-1;margin-top:4px;padding-bottom:6px;font-size:11px;font-weight:700}.pagination{color:var(--gray-500);border-top:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:11px 14px;font-size:12px;display:flex}.page-btns{gap:3px;display:flex}.checklist-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.checklist-item{border-radius:var(--radius-sm);border:1px solid var(--gray-200);cursor:pointer;align-items:center;gap:8px;padding:7px 10px;font-size:13px;transition:all .12s;display:flex}.checklist-item:hover{border-color:var(--green-500);background:var(--green-50)}.checklist-item.checked{border-color:var(--green-500);background:var(--green-50);color:var(--green-700)}.checklist-item input{width:15px;height:15px;accent-color:var(--green-500);cursor:pointer}.acta-preview{background:#fff;max-width:700px;margin:0 auto;padding:30px;font-family:Times New Roman,serif;font-size:13px;line-height:1.6}.acta-header{text-align:center;margin-bottom:20px}.acta-header h2{text-transform:uppercase;font-size:16px;font-weight:700}.acta-header p{color:#555;font-size:12px}.acta-section{margin-bottom:14px}.acta-section h3{border-bottom:1px solid #333;margin-bottom:8px;padding-bottom:3px;font-size:13px;font-weight:700}.acta-row{gap:10px;margin-bottom:5px;font-size:12px;display:flex}.acta-label{min-width:140px;font-weight:700}.acta-firmas{grid-template-columns:1fr 1fr;gap:40px;margin-top:40px;display:grid}.firma-box{text-align:center}.firma-linea{border-top:1px solid #333;margin-bottom:6px;padding-top:6px;font-size:12px}.empleado-detalle{padding:18px}.empleado-header{border-bottom:1px solid var(--gray-200);align-items:center;gap:14px;margin-bottom:18px;padding-bottom:14px;display:flex}.empleado-avatar{background:var(--green-50);width:52px;height:52px;color:var(--green-700);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:20px;font-weight:700;display:flex}.empleado-info h3{font-size:16px;font-weight:600}.empleado-info p{color:var(--gray-500);font-size:13px}.dias-badge{border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.dias-ok{background:var(--green-50);color:var(--green-700)}.dias-warn{background:var(--amber-50);color:var(--amber-700)}.dias-danger{background:var(--red-50);color:var(--red-700)}@media print{.app-layout,.login-page{display:none!important}.modal-overlay{background:0 0!important;padding:0!important;display:block!important;position:static!important}.modal{box-shadow:none!important;border:none!important;border-radius:0!important;width:100%!important;max-width:100%!important;margin:0!important;padding:0!important}.modal-header,.form-actions,.modal-close{display:none!important}.acta-preview{padding:10px!important}body{background:#fff!important;overflow:visible!important}}.sidebar-overlay,.hamburger-btn{display:none}@media (width<=900px){.stat-grid{grid-template-columns:repeat(2,1fr)}.row-2{grid-template-columns:1fr}}@media (width<=768px){body{overflow:auto}.app-layout{flex-direction:column;height:auto;min-height:100vh}.sidebar{z-index:1000;width:260px;min-width:260px;height:100vh;transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:4px 0 20px #00000059}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{z-index:999;background:#00000073;position:fixed;inset:0;display:block!important}.topbar{padding:0 14px}.topbar-title{font-size:14px}.hamburger-btn{cursor:pointer;color:#f1f5f9;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:22px;display:flex!important}.main-area{width:100%;overflow:visible}.page-content{padding:12px;overflow:visible}.stat-grid{grid-template-columns:repeat(2,1fr);gap:10px}.row-2{grid-template-columns:1fr}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}table{min-width:unset;width:100%}.hide-mobile{display:none!important}.show-mobile{display:inline-block!important}.table-wrap table th:last-child,.table-wrap table td:last-child{z-index:1;background:#fff;position:sticky;right:0;box-shadow:-2px 0 6px #00000014}.table-wrap table thead th:last-child{background:#f8f9fa}.table-wrap td:last-child>div{flex-wrap:nowrap!important;gap:2px!important}.table-wrap td:last-child .btn-sm{padding:4px 6px!important;font-size:11px!important}.form-grid{grid-template-columns:1fr!important}.form-col-full{grid-column:1!important}.modal-backdrop{align-items:flex-end;padding:0}.modal-box{border-radius:16px 16px 0 0;max-height:92vh;overflow-y:auto;width:100%!important;max-width:100%!important}.login-card{width:92vw;padding:32px 20px 24px}.filter-bar{flex-wrap:wrap;gap:8px}.filter-bar .btn{padding:6px 10px;font-size:12px}.card{margin-bottom:12px}.card-header{flex-wrap:wrap;gap:8px}}@media (width<=400px){.stat-grid{grid-template-columns:1fr}.login-card{border-radius:0;justify-content:center;width:100vw;min-height:100vh}}
