body{background:#f4f6f9;color:#1f2937}.app-topbar{min-height:58px}.sidebar{min-height:calc(100vh - 58px);background:#fff;border-right:1px solid #dee2e6}.sidebar a{display:block;padding:10px 12px;color:#212529;text-decoration:none;border-radius:8px}.sidebar a:hover{background:#f1f3f5}.card{border:0;box-shadow:0 1px 8px rgba(0,0,0,.06);border-radius:12px}.muted{color:#5b6b83}.clock-btn{height:78px;font-size:1.35rem;font-weight:700;border-radius:8px}.mobile-clock{max-width:760px;margin:auto}.digital-clock{font-size:4rem;font-weight:800;letter-spacing:2px;line-height:1;background:#111827;color:#fff;border-radius:20px;padding:22px 16px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08),0 8px 25px rgba(0,0,0,.15)}.digital-date{font-size:1.05rem;color:#6b7280;margin-top:8px}.status-pill{display:inline-block;border-radius:999px;padding:8px 14px;font-weight:700}.status-entry{background:#d1fae5;color:#065f46}.status-exit{background:#fee2e2;color:#991b1b}.status-pause_start{background:#fef3c7;color:#92400e}.status-pause_end{background:#cffafe;color:#155e75}.kpi{font-size:1.6rem;font-weight:800}.face-preview{max-height:130px;border-radius:10px;display:none;margin:auto}.table td,.table th{vertical-align:middle}@media(max-width:768px){.digital-clock{font-size:2.7rem}.clock-btn{height:66px;font-size:1.05rem}.sidebar{min-height:auto;border-right:0;border-bottom:1px solid #dee2e6}}
/* V1.4 public clock clean mode */
.public-clock{min-height:100vh;background:#eef2f7;color:#1f2937}.public-clock.theme-dark{background:#0f172a;color:#f8fafc}.public-clock.theme-auto{background:#eef2f7;color:#1f2937}@media (prefers-color-scheme: dark){.public-clock.theme-auto{background:#0f172a;color:#f8fafc}}
.public-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 14px}.public-card-wrap{width:100%;max-width:760px}.public-logo-title{font-size:1.35rem;font-weight:800}.public-clock.theme-dark .card,.public-clock.theme-auto .card{ }@media (prefers-color-scheme: dark){.public-clock.theme-auto .card{background:#111827;color:#f8fafc}}.public-clock.theme-dark .card{background:#111827;color:#f8fafc}.public-clock.theme-dark .muted,.public-clock.theme-dark .digital-date{color:#cbd5e1}.public-clock.theme-dark .form-control{background:#0b1220;color:#fff;border-color:#334155}.public-clock.theme-dark .form-control::placeholder{color:#94a3b8}.autocomplete-box{position:absolute;left:0;right:0;top:100%;z-index:50;background:#fff;border:1px solid #d1d5db;border-radius:10px;margin-top:4px;box-shadow:0 8px 24px rgba(0,0,0,.14);text-align:left;display:none;max-height:280px;overflow:auto}.autocomplete-item{padding:11px 14px;cursor:pointer}.autocomplete-item:hover{background:#f1f5f9}.public-clock.theme-dark .autocomplete-box{background:#111827;border-color:#334155}.public-clock.theme-dark .autocomplete-item:hover{background:#1e293b}
/* V1.8 hardening public clock */
#employeeResults{width:100%}.autocomplete-item{font-size:1.05rem}.public-clock input:-webkit-autofill{-webkit-box-shadow:0 0 0 1000px #fff inset!important}.public-clock.theme-dark input:-webkit-autofill{-webkit-box-shadow:0 0 0 1000px #0b1220 inset!important;-webkit-text-fill-color:#fff!important}
.clock-busy{margin:8px 0 12px;padding:10px;border-radius:8px;background:#e0f2fe;color:#075985;font-weight:700}.clock-action:disabled{opacity:.75}.public-clock input[readonly]{background:#fff}.public-clock.theme-dark input[readonly]{background:#0b1220;color:#fff}.public-clock input::-ms-reveal,.public-clock input::-ms-clear{display:none}

/* V2.3 fixes terminal público */
.public-clock .autocomplete-box{color:#1f2937;}
.public-clock.theme-dark .autocomplete-box{color:#f8fafc;}
.public-clock.theme-dark .autocomplete-item{color:#f8fafc;}
#employeeKeyVisible{pointer-events:auto!important;user-select:text!important;-webkit-user-select:text!important;background:#fff;color:#111827;}
.public-clock.theme-dark #employeeKeyVisible{background:#fff!important;color:#111827!important;border-color:#d1d5db!important;}
.public-clock.theme-dark #employeeSearch{background:#fff!important;color:#111827!important;border-color:#d1d5db!important;}
.public-clock.theme-dark #employeeSearch::placeholder,.public-clock.theme-dark #employeeKeyVisible::placeholder{color:#6b7280!important;}
@media(max-width:768px){.public-shell{align-items:flex-start;padding-top:22px}.public-logo-title{font-size:1.15rem}.public-card-wrap{max-width:100%}.digital-clock{font-size:3.2rem}.clock-btn{height:68px}.public-clock .row.g-2>.col-md-8,.public-clock .row.g-2>.col-md-4{width:100%;}.autocomplete-box{position:absolute;z-index:9999}}

/* V2.6 acabado visual panel */
main h1{font-weight:800;margin-bottom:18px}.admin-card,.card{border-radius:14px}.form-label{font-weight:600;color:#334155}.form-control,.form-select,.select2-container .select2-selection--single{border-radius:10px;min-height:42px}.select2-container--default .select2-selection--single{border:1px solid #ced4da}.select2-container--default .select2-selection--single .select2-selection__rendered{line-height:40px}.select2-container--default .select2-selection--single .select2-selection__arrow{height:40px}.table thead th{background:#f8fafc;color:#111827;font-weight:800}.employee-photo-preview{width:120px;height:120px;object-fit:cover;border-radius:16px;border:1px solid #dee2e6;background:#f8fafc}.public-clock .alert{border-radius:10px}.public-clock.theme-dark .alert-success{background:#064e3b;color:#d1fae5;border-color:#047857}.public-clock.theme-dark .alert-danger{background:#7f1d1d;color:#fee2e2;border-color:#b91c1c}.public-clock.theme-dark .autocomplete-box{background:#ffffff!important;color:#111827!important}.public-clock.theme-dark .autocomplete-item{color:#111827!important}.public-clock.theme-dark .autocomplete-item:hover{background:#e5e7eb!important}

/* V3.6 - Estados y contador vivo en registros/informes */
.status-badge{display:inline-flex;align-items:center;justify-content:center;min-width:105px;padding:.35rem .65rem;border-radius:999px;font-weight:700;font-size:.85rem;white-space:nowrap}
.status-working{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}
.status-paused{background:#fef3c7;color:#92400e;border:1px solid #fde68a}
.status-out{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.live-duration{font-weight:700;white-space:nowrap}

/* V4.2 estado de empleados: colores independientes de Bootstrap */
.status-badge{display:inline-flex;align-items:center;justify-content:center;min-width:105px;padding:.35rem .65rem;border-radius:999px;font-weight:700;font-size:.85rem;white-space:nowrap}
.status-working{background:#d1fae5!important;color:#065f46!important;border:1px solid #86efac!important}
.status-paused{background:#fef3c7!important;color:#92400e!important;border:1px solid #fcd34d!important}
.status-out{background:#fee2e2!important;color:#991b1b!important;border:1px solid #fca5a5!important}

/* V5.1 - Vista tipo Skello para seguimiento en vivo */
.skello-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}
.skello-card{background:#fff;border-radius:16px;box-shadow:0 1px 8px rgba(0,0,0,.06);padding:16px;border:1px solid #eef2f7}
.skello-card-top{display:flex;justify-content:flex-end;margin-bottom:8px}.skello-card-title{font-weight:800;font-size:1rem;margin-bottom:12px;color:#111827}.skello-card-metrics{display:grid;grid-template-columns:1fr 1fr;gap:10px}.skello-card-metrics small{display:block;color:#64748b;font-weight:600}.skello-card-metrics strong{font-size:1.15rem;color:#111827}.table thead th{white-space:nowrap}.btn-action-stack{display:flex;gap:6px;flex-wrap:wrap}.employee-clock-panel .digital-clock{font-size:3.2rem}@media(max-width:900px){.skello-card-metrics{grid-template-columns:1fr}.employee-clock-panel .digital-clock{font-size:2.4rem}}

/* V5.6.1 - Roles, horarios e impresión limpia */
.role-help-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.role-help-item{border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#f8fafc}.role-help-item strong{display:block;color:#111827}.role-help-item small{display:block;color:#64748b;margin:4px 0 8px}.role-help-item code{font-size:.78rem;color:#334155;background:#e2e8f0;border-radius:6px;padding:2px 6px}.weekly-calendar-table-wrap{overflow:auto}.weekly-calendar-table{min-width:980px}.weekly-calendar-table th,.weekly-calendar-table td{vertical-align:top}.weekly-calendar-table td{height:86px}.center-pill{display:inline-flex;border-radius:999px;padding:.25rem .55rem;font-weight:700;font-size:.78rem;border:1px solid transparent;white-space:nowrap}.schedule-block{border-radius:10px;padding:7px 8px;margin-bottom:6px;border-left:4px solid rgba(15,23,42,.25);background:#f8fafc}.schedule-block strong{display:block;font-size:.86rem;color:#111827}.schedule-block span,.schedule-block small{display:block;font-size:.76rem;color:#475569}.center-color-1{background:#e0f2fe!important;color:#075985!important;border-color:#7dd3fc!important}.center-color-2{background:#dcfce7!important;color:#166534!important;border-color:#86efac!important}.center-color-3{background:#fef3c7!important;color:#92400e!important;border-color:#fcd34d!important}.center-color-4{background:#fae8ff!important;color:#86198f!important;border-color:#e879f9!important}.center-color-5{background:#fee2e2!important;color:#991b1b!important;border-color:#fca5a5!important}.center-color-6{background:#ede9fe!important;color:#5b21b6!important;border-color:#c4b5fd!important}.center-color-7{background:#ccfbf1!important;color:#0f766e!important;border-color:#5eead4!important}.center-color-8{background:#e2e8f0!important;color:#334155!important;border-color:#cbd5e1!important}.print-only{display:none}.print-header{font-size:14px;color:#111827}.kpi-grid-v561{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:1rem}.kpi-card-v561{background:#fff;border:1px solid #eef2f7;border-radius:16px;padding:14px;box-shadow:0 1px 8px rgba(0,0,0,.05)}.kpi-card-v561 small{display:block;color:#64748b;font-weight:700}.kpi-card-v561 strong{display:block;font-size:1.45rem;color:#111827;line-height:1.2;margin-top:4px}@media(max-width:768px){.weekly-calendar-table{min-width:760px}.role-help-grid{grid-template-columns:1fr}}

/* V5.6.1-fix1 - Filtro por centro principal y colores por empleado en calendario semanal */
.employee-color-marker{display:inline-block;width:11px;height:11px;border-radius:999px;margin-right:7px;vertical-align:middle;border:1px solid rgba(15,23,42,.18)}
.schedule-block.employee-color-1{background:#e0f2fe!important;border-left-color:#0284c7!important}.employee-color-marker.employee-color-1{background:#38bdf8!important}
.schedule-block.employee-color-2{background:#dcfce7!important;border-left-color:#16a34a!important}.employee-color-marker.employee-color-2{background:#4ade80!important}
.schedule-block.employee-color-3{background:#fef3c7!important;border-left-color:#d97706!important}.employee-color-marker.employee-color-3{background:#fbbf24!important}
.schedule-block.employee-color-4{background:#fae8ff!important;border-left-color:#c026d3!important}.employee-color-marker.employee-color-4{background:#e879f9!important}
.schedule-block.employee-color-5{background:#fee2e2!important;border-left-color:#dc2626!important}.employee-color-marker.employee-color-5{background:#f87171!important}
.schedule-block.employee-color-6{background:#ede9fe!important;border-left-color:#7c3aed!important}.employee-color-marker.employee-color-6{background:#a78bfa!important}
.schedule-block.employee-color-7{background:#ccfbf1!important;border-left-color:#0d9488!important}.employee-color-marker.employee-color-7{background:#2dd4bf!important}
.schedule-block.employee-color-8{background:#e2e8f0!important;border-left-color:#475569!important}.employee-color-marker.employee-color-8{background:#94a3b8!important}
.schedule-block.employee-color-9{background:#ffedd5!important;border-left-color:#ea580c!important}.employee-color-marker.employee-color-9{background:#fb923c!important}
.schedule-block.employee-color-10{background:#dbeafe!important;border-left-color:#2563eb!important}.employee-color-marker.employee-color-10{background:#60a5fa!important}
.schedule-block.employee-color-11{background:#fce7f3!important;border-left-color:#db2777!important}.employee-color-marker.employee-color-11{background:#f472b6!important}
.schedule-block.employee-color-12{background:#ecfccb!important;border-left-color:#65a30d!important}.employee-color-marker.employee-color-12{background:#a3e635!important}

@media print{
  body.print-schedule-table *{visibility:hidden!important}body.print-schedule-table .schedule-table-print-area,body.print-schedule-table .schedule-table-print-area *{visibility:visible!important}body.print-schedule-table .schedule-table-print-area{position:absolute!important;left:0!important;top:0!important;width:100%!important;box-shadow:none!important;border:0!important}
  body.print-weekly-calendar *{visibility:hidden!important}body.print-weekly-calendar .weekly-calendar-print-area,body.print-weekly-calendar .weekly-calendar-print-area *{visibility:visible!important}body.print-weekly-calendar .weekly-calendar-print-area{position:absolute!important;left:0!important;top:0!important;width:100%!important;box-shadow:none!important;border:0!important}
  body.print-my-schedule *{visibility:hidden!important}body.print-my-schedule .employee-schedule-print-area,body.print-my-schedule .employee-schedule-print-area *{visibility:visible!important}body.print-my-schedule .employee-schedule-print-area{position:absolute!important;left:0!important;top:0!important;width:100%!important;box-shadow:none!important;border:0!important;padding:0!important}
  .no-print,.no-print *{display:none!important}.print-only{display:block!important}.sidebar,.app-topbar{display:none!important}main{width:100%!important;max-width:100%!important;flex:0 0 100%!important;padding:0!important}.card,.admin-card{box-shadow:none!important;border:0!important}.card-body{padding:0!important}table{width:100%!important;border-collapse:collapse!important;font-size:12px!important}th,td{border:1px solid #d1d5db!important;padding:6px!important}.weekly-calendar-table{min-width:0!important}.schedule-block{break-inside:avoid;page-break-inside:avoid}.center-pill,.schedule-block{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}

/* V5.6.1-fix2 - Vacaciones aprobadas visibles en calendario semanal */
.schedule-block.absence-block{background:#fff1f2!important;border-left-color:#e11d48!important;border-top:1px solid #fecdd3!important;border-right:1px solid #fecdd3!important;border-bottom:1px solid #fecdd3!important}
.schedule-block.absence-block strong{color:#9f1239!important}
.schedule-block.absence-block small{color:#9f1239!important;font-weight:700}
@media print{.schedule-block.absence-block{-webkit-print-color-adjust:exact;print-color-adjust:exact}}

/* V5.6.2 - Registros e informes estilo Skello, filtros avanzados e impresión limpia */
.kpi-grid-v562{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}
.skello-card.compact{padding:13px}.skello-card.compact .skello-card-title{margin-bottom:8px}.compact-table{font-size:.92rem}.compact-table th,.compact-table td{white-space:nowrap}.print-toolbar{position:relative;z-index:2}.record-action-badge,.gps-badge,.absence-status-badge{display:inline-flex;align-items:center;border-radius:999px;padding:.28rem .6rem;font-size:.78rem;font-weight:800;border:1px solid transparent;white-space:nowrap}.record-action-badge.action-entry{background:#d1fae5;color:#065f46;border-color:#86efac}.record-action-badge.action-exit{background:#fee2e2;color:#991b1b;border-color:#fca5a5}.record-action-badge.action-pause_start{background:#fef3c7;color:#92400e;border-color:#fcd34d}.record-action-badge.action-pause_end{background:#cffafe;color:#155e75;border-color:#67e8f9}.gps-badge.gps-ok{background:#dcfce7;color:#166534;border-color:#86efac}.gps-badge.gps-outside{background:#ffedd5;color:#9a3412;border-color:#fdba74}.gps-badge.gps-missing{background:#fee2e2;color:#991b1b;border-color:#fca5a5}.gps-badge.gps-not_required{background:#e2e8f0;color:#334155;border-color:#cbd5e1}.absence-status-badge.absence-approved{background:#dcfce7;color:#166534;border-color:#86efac}.report-daily-print-area,.report-employee-print-area,.report-center-print-area,.report-absence-print-area,.records-summary-print-area,.records-detail-print-area{overflow:hidden}@media(max-width:768px){.compact-table{font-size:.84rem}.print-toolbar .btn{width:100%}}
@media print{
  body.print-records-summary *{visibility:hidden!important}body.print-records-summary .records-summary-print-area,body.print-records-summary .records-summary-print-area *{visibility:visible!important}body.print-records-summary .records-summary-print-area{position:absolute!important;left:0!important;top:0!important;width:100%!important;box-shadow:none!important;border:0!important}
  body.print-records-detail *{visibility:hidden!important}body.print-records-detail .records-detail-print-area,body.print-records-detail .records-detail-print-area *{visibility:visible!important}body.print-records-detail .records-detail-print-area{position:absolute!important;left:0!important;top:0!important;width:100%!important;box-shadow:none!important;border:0!important}
  body.print-report-daily *{visibility:hidden!important}body.print-report-daily .report-daily-print-area,body.print-report-daily .report-daily-print-area *{visibility:visible!important}body.print-report-daily .report-daily-print-area{position:absolute!important;left:0!important;top:0!important;width:100%!important;box-shadow:none!important;border:0!important}
  body.print-report-employee *{visibility:hidden!important}body.print-report-employee .report-employee-print-area,body.print-report-employee .report-employee-print-area *{visibility:visible!important}body.print-report-employee .report-employee-print-area{position:absolute!important;left:0!important;top:0!important;width:100%!important;box-shadow:none!important;border:0!important}
  body.print-report-center *{visibility:hidden!important}body.print-report-center .report-center-print-area,body.print-report-center .report-center-print-area *{visibility:visible!important}body.print-report-center .report-center-print-area{position:absolute!important;left:0!important;top:0!important;width:100%!important;box-shadow:none!important;border:0!important}
  body.print-report-absence *{visibility:hidden!important}body.print-report-absence .report-absence-print-area,body.print-report-absence .report-absence-print-area *{visibility:visible!important}body.print-report-absence .report-absence-print-area{position:absolute!important;left:0!important;top:0!important;width:100%!important;box-shadow:none!important;border:0!important}
  .record-action-badge,.gps-badge,.absence-status-badge{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}

/* V5.6.4 - Empleados, centros y vacaciones más claros */
.employee-profile-card .status-badge{min-width:auto}.employee-summary-grid .kpi-card-v561 strong{font-size:1.1rem}.profile-mini-panel{height:100%;border:1px solid #eef2f7;background:#f8fafc;border-radius:14px;padding:12px}.profile-mini-panel h6{font-weight:800;color:#111827;margin-bottom:10px}.profile-mini-panel .small{line-height:1.35}.employee-mini-badge{display:inline-flex;align-items:center;gap:4px;border:1px solid #e2e8f0;background:#f8fafc;color:#0f172a;border-radius:999px;padding:.25rem .55rem;font-weight:700;font-size:.78rem;margin:0 .25rem .25rem 0;white-space:nowrap}.employee-mini-badge small{color:#64748b;font-weight:800}.center-employee-list{max-width:360px}.absences-print-area .badge,.employee-profile-card .badge,.center-employee-list .employee-mini-badge{-webkit-print-color-adjust:exact;print-color-adjust:exact}.employee-profile-card .btn,.center-employee-list+.btn{white-space:nowrap}@media(max-width:768px){.employee-profile-card .d-flex.gap-2 .btn{width:100%}.center-employee-list{max-width:none}.compact-table td,.compact-table th{white-space:normal}.compact-table .text-nowrap{white-space:normal!important}.compact-table .btn{margin-bottom:4px}}
@media print{body.print-absences-table *{visibility:hidden!important}body.print-absences-table .absences-print-area,body.print-absences-table .absences-print-area *{visibility:visible!important}body.print-absences-table .absences-print-area{position:absolute!important;left:0!important;top:0!important;width:100%!important;box-shadow:none!important;border:0!important}.absences-print-area .badge{-webkit-print-color-adjust:exact;print-color-adjust:exact}}

/* V5.6.4 Fix 1 - Buscador/paginador empleados y centros sin scroll horizontal */
.employee-list-toolbar .form-label{margin-bottom:.35rem}
.employee-list-card .card-header{padding:1rem 1.1rem}
.employee-list-photo{width:42px;height:42px;object-fit:cover;border-radius:10px;border:1px solid #e5e7eb;background:#f8fafc}
.employee-table td,.employee-table th{white-space:normal!important}
.employee-email-cell{word-break:break-word;min-width:160px}
.employee-center-badges{display:flex;flex-wrap:wrap;gap:.25rem;max-width:240px}
.employee-actions{display:flex;gap:.35rem;flex-wrap:wrap;align-items:center;min-width:260px}
.employee-actions form{display:inline-flex;margin:0}.employee-actions .btn{white-space:nowrap}
.employee-pagination .disabled{pointer-events:none;opacity:.45}.employee-pagination-top{min-width:110px;text-align:right}
.center-cards-grid{display:grid;grid-template-columns:1fr;gap:14px}
.center-card-v565{overflow:hidden}.center-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.center-card-actions{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:flex-end}
.center-card-grid{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(280px,.95fr) minmax(170px,.45fr);gap:14px;align-items:stretch}
.center-info-panel,.center-employees-panel,.center-quick-panel{border:1px solid #eef2f7;border-radius:14px;background:#f8fafc;padding:12px;min-width:0}.center-info-item{margin-bottom:10px}.center-info-item:last-child{margin-bottom:0}.center-info-item span{display:block;color:#64748b;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.02em;margin-bottom:3px}.center-info-item strong{display:block;color:#111827;font-size:.94rem;font-weight:600;line-height:1.35;white-space:normal;overflow-wrap:anywhere}.center-info-item input{max-width:100%}
.center-employees-list{display:flex;flex-direction:column;gap:8px;max-height:260px;overflow:auto;padding-right:3px}.center-employee-row{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:9px 10px}.center-employee-row strong{display:block;font-size:.92rem;line-height:1.15}.center-employee-row small{display:block;color:#64748b;font-size:.75rem;font-weight:700;margin-top:2px}.center-employee-row .status-badge{min-width:auto;font-size:.72rem;padding:.25rem .5rem}
.center-quick-panel h6,.center-employees-panel h6{font-weight:800;color:#111827}.center-quick-links{display:flex;flex-direction:column;gap:7px}.center-quick-links .btn{text-align:left;white-space:normal}
@media(max-width:1200px){.center-card-grid{grid-template-columns:1fr 1fr}.center-quick-panel{grid-column:1/-1}.center-quick-links{flex-direction:row;flex-wrap:wrap}.center-quick-links .btn{text-align:center}}
@media(max-width:768px){.employee-actions{min-width:0}.employee-actions .btn,.employee-actions form{width:100%}.employee-actions form .btn{width:100%}.employee-pagination-top{text-align:left;width:100%}.center-card-header{flex-direction:column}.center-card-actions{justify-content:flex-start}.center-card-grid{grid-template-columns:1fr}.center-employee-row{align-items:flex-start;flex-direction:column}.center-employees-list{max-height:none}.center-quick-links .btn{width:100%}}

/* V5.6.4 Fix 2 - usuarios: buscador y paginador */
.user-table td,.user-table th{vertical-align:middle}.user-email-cell{word-break:break-word}.user-actions{min-width:190px}
@media(max-width:768px){.user-actions{min-width:0}.user-actions .btn,.user-actions form{width:100%}.user-actions form .btn{width:100%}}

/* V5.6.4 Fix 3 - Botones de acción diferenciados en empleados, usuarios y centros */
.app-action-btn{
  --app-action-bg:#f8fafc;
  --app-action-border:#cbd5e1;
  --app-action-text:#0f172a;
  --app-action-hover:#eef2f7;
  display:inline-flex!important;
  align-items:center;
  justify-content:center;
  gap:.35rem;
  border:1px solid var(--app-action-border)!important;
  background:var(--app-action-bg)!important;
  color:var(--app-action-text)!important;
  border-radius:10px!important;
  font-weight:800!important;
  line-height:1.15!important;
  min-height:32px;
  padding:.42rem .7rem!important;
  text-decoration:none!important;
  box-shadow:0 1px 2px rgba(15,23,42,.06);
  transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease;
}
.app-action-btn:hover,.app-action-btn:focus{
  background:var(--app-action-hover)!important;
  color:var(--app-action-text)!important;
  transform:translateY(-1px);
  box-shadow:0 4px 10px rgba(15,23,42,.10);
}
.app-action-btn:active{transform:translateY(0);box-shadow:0 1px 2px rgba(15,23,42,.08)}
.app-action-btn.action-edit{--app-action-bg:#eff6ff;--app-action-border:#60a5fa;--app-action-text:#1d4ed8;--app-action-hover:#dbeafe}
.app-action-btn.action-schedules{--app-action-bg:#f5f3ff;--app-action-border:#a78bfa;--app-action-text:#6d28d9;--app-action-hover:#ede9fe}
.app-action-btn.action-pin{--app-action-bg:#f1f5f9;--app-action-border:#94a3b8;--app-action-text:#334155;--app-action-hover:#e2e8f0}
.app-action-btn.action-portal{--app-action-bg:#ecfdf5;--app-action-border:#34d399;--app-action-text:#047857;--app-action-hover:#d1fae5}
.app-action-btn.action-clocklink{--app-action-bg:#ecfeff;--app-action-border:#22d3ee;--app-action-text:#0e7490;--app-action-hover:#cffafe}
.app-action-btn.action-webapp{--app-action-bg:#f0fdfa;--app-action-border:#2dd4bf;--app-action-text:#0f766e;--app-action-hover:#ccfbf1}
.app-action-btn.action-delete{--app-action-bg:#fff1f2;--app-action-border:#fb7185;--app-action-text:#be123c;--app-action-hover:#ffe4e6}
.app-action-btn.action-open{--app-action-bg:#f0fdf4;--app-action-border:#4ade80;--app-action-text:#15803d;--app-action-hover:#dcfce7}
.app-action-btn.action-records{--app-action-bg:#f8fafc;--app-action-border:#64748b;--app-action-text:#475569;--app-action-hover:#e2e8f0}
.app-action-btn.action-reports{--app-action-bg:#f0f9ff;--app-action-border:#38bdf8;--app-action-text:#0369a1;--app-action-hover:#e0f2fe}
.app-action-btn.action-absences{--app-action-bg:#fffbeb;--app-action-border:#f59e0b;--app-action-text:#b45309;--app-action-hover:#fef3c7}
.employee-actions,.user-actions,.center-card-actions,.center-quick-links{gap:.45rem!important}
.employee-actions .app-action-btn,.user-actions .app-action-btn{min-width:96px}
.employee-actions .action-pin,.employee-actions .action-portal,.employee-actions .action-clocklink,.employee-actions .action-webapp{min-width:150px}
.center-card-actions .app-action-btn{min-width:78px}
.center-quick-links .app-action-btn{width:100%;justify-content:flex-start}
@media(max-width:768px){
  .app-action-btn{width:100%;min-width:0!important}
  .center-quick-links .app-action-btn{justify-content:center}
}
@media print{
  .app-action-btn{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}

/* V5.6.4 Fix 4 - Fichador integrado en panel empleado/administración */
.panel-clock-card{overflow:visible}
.panel-clock-status,.panel-clock-form{border:1px solid #eef2f7;background:#f8fafc;border-radius:16px;padding:16px}
.panel-clock-card .digital-clock{font-size:3.4rem;border-radius:18px}
.panel-clock-card .autocomplete-box{z-index:3000}
.panel-clock-card .clock-btn{border-radius:12px;box-shadow:0 8px 18px rgba(15,23,42,.08)}
.panel-clock-card .form-text{color:#64748b}
@media(max-width:768px){.panel-clock-card .digital-clock{font-size:2.55rem}.panel-clock-status,.panel-clock-form{padding:12px}.panel-clock-card .clock-btn{height:66px;font-size:1.05rem}}

/* V5.6.6 Fix 1: centros autorizados fiables sin Select2 multiple */
.authorized-centers-box{
  min-height: 42px;
  max-height: 135px;
  overflow: auto;
  border: 1px solid #ced4da;
  border-radius: 10px;
  background: #fff;
  padding: 6px;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.authorized-center-option{
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  background: #f8fafc;
  cursor: pointer;
  margin: 0;
  font-size: .92rem;
}
.authorized-center-option:hover{background:#eef6ff;border-color:#bfdbfe;}
.authorized-center-option input{margin:0;}
.authorized-center-option:has(input:checked){background:#ecfdf5;border-color:#86efac;color:#065f46;font-weight:600;}
.center-early-summary{margin-top:8px;padding-top:8px;border-top:1px dashed #e5e7eb;}
.center-early-summary strong{display:inline-flex;align-items:center;gap:6px;}

/* V5.6.6 Fix 2 - selectores fiables de centros */
.select2-container--default .select2-selection--multiple{border:1px solid #ced4da;border-radius:10px;min-height:42px;padding:3px 6px;background:#fff;}
.select2-container--default .select2-selection--multiple .select2-selection__choice{border-radius:999px;border:1px solid #bfdbfe;background:#eff6ff;color:#1e3a8a;padding:3px 8px;margin-top:4px;}
.select2-container--default .select2-selection--multiple .select2-selection__choice__remove{color:#1e40af;margin-right:5px;}
.select2-container--default .select2-results__option[aria-disabled=true]{display:none;}

/* V5.6.7 - Modales y notificaciones de acciones */
.app-modal-content{border:0;border-radius:18px;box-shadow:0 20px 45px rgba(15,23,42,.22)}
#appConfirmModal .modal-header{border-bottom:1px solid #e5e7eb;background:#f8fafc;border-radius:18px 18px 0 0}
#appConfirmModal .modal-title{font-weight:800;color:#111827}
#appConfirmModal .modal-body{font-size:15px;line-height:1.55;color:#334155}
.app-toast{border-radius:14px;box-shadow:0 12px 28px rgba(15,23,42,.22);overflow:hidden}
.app-toast .toast-body{font-weight:700;line-height:1.35}

/* V5.6.9 - Programación de horarios y cobertura de franjas */
.company-hours-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.company-hours-row{display:grid;grid-template-columns:minmax(145px,1fr) 120px 120px;gap:10px;align-items:end;border:1px solid #eef2f7;background:#f8fafc;border-radius:14px;padding:10px}.company-hours-day{align-self:center;font-weight:800;color:#111827}.schedule-programming-card{overflow:hidden}.schedule-program-grid{display:grid;grid-template-columns:repeat(7,minmax(145px,1fr));gap:1px;background:#e5e7eb;border:1px solid #e5e7eb;border-radius:16px;overflow:hidden}.schedule-program-grid-week{grid-template-columns:repeat(7,minmax(180px,1fr))}.schedule-program-head{background:#f8fafc;padding:10px 12px;font-weight:900;text-align:center;color:#111827}.schedule-program-day{border:0;background:#fff;min-height:150px;padding:10px;text-align:left;display:flex;flex-direction:column;gap:8px;color:#111827;transition:background .12s ease,box-shadow .12s ease}.schedule-program-day:hover,.schedule-program-day:focus{background:#f0f9ff;box-shadow:inset 0 0 0 2px #38bdf8;outline:0}.schedule-program-day.is-out-month{background:#f8fafc;color:#94a3b8}.schedule-program-day-number{font-weight:900;font-size:1rem}.schedule-program-items{display:flex;flex-direction:column;gap:5px}.schedule-program-chip{display:block;border-left:4px solid #0ea5e9;background:#e0f2fe;color:#0f172a;border-radius:10px;padding:6px 7px;line-height:1.15}.schedule-program-chip strong{display:block;font-size:.82rem}.schedule-program-chip small{display:block;font-size:.72rem;color:#334155;margin-top:2px}.schedule-program-more{display:inline-flex;width:max-content;border-radius:999px;background:#e2e8f0;color:#334155;font-weight:800;font-size:.75rem;padding:2px 8px}.program-weekdays{display:flex;flex-wrap:wrap;gap:6px}.program-weekday{display:inline-flex;align-items:center;gap:5px;border:1px solid #dbeafe;background:#eff6ff;border-radius:999px;padding:6px 9px;font-weight:800;font-size:.83rem;color:#1e40af;cursor:pointer}.program-weekday input{margin:0}.coverage-card-v569{border:1px solid #e5e7eb;background:#f8fafc;border-radius:16px;padding:12px}.coverage-week-grid{display:grid;grid-template-columns:1fr;gap:10px}.coverage-day{border:1px solid #e2e8f0;border-radius:14px;background:#fff;padding:10px}.coverage-day-title{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-bottom:4px}.coverage-day-title small{color:#64748b;font-weight:700}.coverage-hours{font-size:.8rem;color:#64748b;font-weight:800;margin-bottom:6px}.coverage-bar{display:flex;width:100%;min-height:46px;border-radius:12px;overflow:hidden;border:1px solid #e5e7eb;background:#fff}.coverage-segment{min-width:52px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:5px 4px;border-right:1px solid rgba(255,255,255,.65);line-height:1.1}.coverage-segment:last-child{border-right:0}.coverage-segment span{font-size:.69rem;font-weight:900}.coverage-segment small{font-size:.68rem;font-weight:800;margin-top:2px}.coverage-segment.is-covered{background:#dcfce7;color:#166534}.coverage-segment.is-uncovered{background:#fee2e2;color:#991b1b}.coverage-legend{display:inline-flex;align-items:center;border-radius:999px;padding:.28rem .6rem;font-size:.78rem;font-weight:800}.coverage-covered{background:#dcfce7;color:#166534}.coverage-uncovered{background:#fee2e2;color:#991b1b}.coverage-closed{color:#64748b;font-size:.85rem;font-weight:800;background:#f1f5f9;border-radius:10px;padding:8px;text-align:center}
@media(max-width:1200px){.schedule-program-grid{grid-template-columns:repeat(7,minmax(125px,1fr));overflow-x:auto}.company-hours-grid{grid-template-columns:1fr}.coverage-bar{overflow-x:auto}.coverage-segment{min-width:72px}}
@media(max-width:768px){.company-hours-row{grid-template-columns:1fr 1fr}.company-hours-day{grid-column:1/-1}.schedule-program-grid,.schedule-program-grid-week{display:flex;overflow-x:auto;border-radius:14px}.schedule-program-head{display:none}.schedule-program-day{min-width:260px;min-height:180px;border-right:1px solid #e5e7eb}.program-weekday{flex:1;justify-content:center}.coverage-day-title{align-items:flex-start;flex-direction:column}.coverage-segment span{font-size:.64rem}.coverage-segment small{font-size:.63rem}}
@media print{.coverage-card-v569{border:1px solid #ddd;background:#fff}.coverage-segment{-webkit-print-color-adjust:exact;print-color-adjust:exact}}
/* V5.6.9A: colores por empleado en programación y cobertura */
.employee-color-legend{display:flex;align-items:flex-start;gap:10px;flex-wrap:wrap;border:1px solid #e5e7eb;background:#f8fafc;border-radius:14px;padding:10px 12px}.employee-color-legend>strong{font-size:.86rem;color:#111827;margin-top:3px}.employee-color-legend>div{display:flex;gap:6px;flex-wrap:wrap}.employee-color-legend-item{display:inline-flex;align-items:center;border:1px solid #e2e8f0;background:#fff;border-radius:999px;padding:.25rem .6rem;font-size:.78rem;font-weight:800;color:#334155;white-space:nowrap}.schedule-program-chip .employee-color-marker{width:9px;height:9px;margin-right:4px}.coverage-employee-dots{display:flex!important;align-items:center;justify-content:center;gap:3px;margin-top:3px}.coverage-employee-dots .employee-color-marker{width:8px;height:8px;margin-right:0;border-color:rgba(15,23,42,.22)}
.schedule-program-chip.employee-color-1,.coverage-segment.is-covered.employee-color-1{background:#e0f2fe!important;border-left-color:#0284c7!important;color:#075985!important}.schedule-program-chip.employee-color-2,.coverage-segment.is-covered.employee-color-2{background:#dcfce7!important;border-left-color:#16a34a!important;color:#166534!important}.schedule-program-chip.employee-color-3,.coverage-segment.is-covered.employee-color-3{background:#fef3c7!important;border-left-color:#d97706!important;color:#92400e!important}.schedule-program-chip.employee-color-4,.coverage-segment.is-covered.employee-color-4{background:#fae8ff!important;border-left-color:#c026d3!important;color:#86198f!important}.schedule-program-chip.employee-color-5,.coverage-segment.is-covered.employee-color-5{background:#fee2e2!important;border-left-color:#dc2626!important;color:#991b1b!important}.schedule-program-chip.employee-color-6,.coverage-segment.is-covered.employee-color-6{background:#ede9fe!important;border-left-color:#7c3aed!important;color:#5b21b6!important}.schedule-program-chip.employee-color-7,.coverage-segment.is-covered.employee-color-7{background:#ccfbf1!important;border-left-color:#0d9488!important;color:#0f766e!important}.schedule-program-chip.employee-color-8,.coverage-segment.is-covered.employee-color-8{background:#e2e8f0!important;border-left-color:#475569!important;color:#334155!important}.schedule-program-chip.employee-color-9,.coverage-segment.is-covered.employee-color-9{background:#ffedd5!important;border-left-color:#ea580c!important;color:#9a3412!important}.schedule-program-chip.employee-color-10,.coverage-segment.is-covered.employee-color-10{background:#dbeafe!important;border-left-color:#2563eb!important;color:#1e40af!important}.schedule-program-chip.employee-color-11,.coverage-segment.is-covered.employee-color-11{background:#fce7f3!important;border-left-color:#db2777!important;color:#9d174d!important}.schedule-program-chip.employee-color-12,.coverage-segment.is-covered.employee-color-12{background:#ecfccb!important;border-left-color:#65a30d!important;color:#3f6212!important}
.schedule-program-chip.employee-color-1 small,.schedule-program-chip.employee-color-2 small,.schedule-program-chip.employee-color-3 small,.schedule-program-chip.employee-color-4 small,.schedule-program-chip.employee-color-5 small,.schedule-program-chip.employee-color-6 small,.schedule-program-chip.employee-color-7 small,.schedule-program-chip.employee-color-8 small,.schedule-program-chip.employee-color-9 small,.schedule-program-chip.employee-color-10 small,.schedule-program-chip.employee-color-11 small,.schedule-program-chip.employee-color-12 small{color:inherit!important;opacity:.88}.coverage-segment.is-covered.employee-color-1 small,.coverage-segment.is-covered.employee-color-2 small,.coverage-segment.is-covered.employee-color-3 small,.coverage-segment.is-covered.employee-color-4 small,.coverage-segment.is-covered.employee-color-5 small,.coverage-segment.is-covered.employee-color-6 small,.coverage-segment.is-covered.employee-color-7 small,.coverage-segment.is-covered.employee-color-8 small,.coverage-segment.is-covered.employee-color-9 small,.coverage-segment.is-covered.employee-color-10 small,.coverage-segment.is-covered.employee-color-11 small,.coverage-segment.is-covered.employee-color-12 small{color:inherit!important}
@media(max-width:768px){.employee-color-legend{display:block}.employee-color-legend>strong{display:block;margin-bottom:7px}.employee-color-legend-item{font-size:.74rem}}
@media print{.employee-color-legend-item,.schedule-program-chip,.coverage-employee-dots .employee-color-marker{-webkit-print-color-adjust:exact;print-color-adjust:exact}}

/* V5.6.9B - Colores únicos por empleado y listado completo del día en el modal */
.employee-color-marker.employee-color-dyn{background:var(--emp-dot,#38bdf8)!important;border-color:rgba(15,23,42,.22)!important}
.schedule-block.employee-color-dyn,.schedule-program-chip.employee-color-dyn,.coverage-segment.is-covered.employee-color-dyn,.program-day-schedule-item.employee-color-dyn{background:var(--emp-bg,#e0f2fe)!important;border-left-color:var(--emp-border,#0284c7)!important;color:var(--emp-text,#075985)!important}
.schedule-block.employee-color-dyn small,.schedule-program-chip.employee-color-dyn small,.coverage-segment.is-covered.employee-color-dyn small,.program-day-schedule-item.employee-color-dyn small{color:inherit!important;opacity:.88}
.program-day-summary{border:1px solid #e5e7eb;background:#f8fafc;border-radius:16px;padding:12px}
.program-day-schedules{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;max-height:240px;overflow:auto;padding-right:2px}
.program-day-schedule-item{border-left:4px solid #0ea5e9;background:#e0f2fe;border-radius:12px;padding:8px 10px;line-height:1.18}
.program-day-schedule-top{display:flex;align-items:center;gap:6px;min-width:0}
.program-day-schedule-top strong{font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:inherit}
.program-day-schedule-time{margin-left:auto;font-weight:900;font-size:.82rem;white-space:nowrap;color:inherit}
.program-day-schedule-item small{display:block;margin-top:3px;font-size:.75rem;color:inherit;opacity:.86}
.program-day-schedule-empty{border:1px dashed #cbd5e1;background:#fff;border-radius:12px;padding:12px;text-align:center;font-weight:800;color:#64748b;grid-column:1/-1}
@media(max-width:768px){.program-day-schedules{grid-template-columns:1fr;max-height:280px}.program-day-schedule-top{align-items:flex-start}.program-day-schedule-time{margin-left:0}.program-day-schedule-top{flex-wrap:wrap}}
@media print{.employee-color-marker.employee-color-dyn,.schedule-block.employee-color-dyn,.schedule-program-chip.employee-color-dyn,.program-day-schedule-item.employee-color-dyn{-webkit-print-color-adjust:exact;print-color-adjust:exact}}

/* V5.6.9C - Modal de programación con grilla diaria de 15 minutos */
.program-day-grid-host{display:block;max-height:none;overflow:visible;padding-right:0}
.program-day-grid-info{display:inline-flex;align-items:center;border:1px solid #dbeafe;background:#eff6ff;color:#1e40af;border-radius:999px;padding:.28rem .65rem;font-size:.78rem;font-weight:900;margin-bottom:8px}
.program-day-grid-wrap{width:100%;overflow:auto;border:1px solid #e2e8f0;border-radius:14px;background:#fff;max-height:360px}
.program-day-time-grid-wrap{min-width:920px;background:#fff}
.program-day-grid-row{display:grid;grid-template-columns:190px minmax(700px,1fr);border-bottom:1px solid #e5e7eb;min-height:48px}
.program-day-grid-row:last-child{border-bottom:0}
.program-day-grid-header{min-height:38px;background:#f8fafc;position:sticky;top:0;z-index:4}
.program-day-employee-head,.program-day-employee-cell{border-right:1px solid #e5e7eb;padding:9px 10px;font-weight:900;color:#334155;background:#f8fafc;display:flex;align-items:center;gap:7px;min-width:0}
.program-day-employee-cell{background:#fff;color:#111827;font-size:.86rem;position:sticky;left:0;z-index:3}
.program-day-employee-cell strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.program-day-time-scale,.program-day-timeline{position:relative;min-height:38px;background-image:repeating-linear-gradient(to right,rgba(148,163,184,.26) 0,rgba(148,163,184,.26) 1px,transparent 1px,transparent calc(100% / var(--slot-count)));background-size:100% 100%}
.program-day-time-scale{background-color:#f8fafc}
.program-day-timeline{min-height:48px;background-color:#fff}
.program-day-hour-mark{position:absolute;top:9px;transform:translateX(-1px);font-size:.72rem;color:#64748b;font-weight:900;white-space:nowrap;border-left:2px solid rgba(15,23,42,.2);padding-left:3px;line-height:1}
.program-day-time-block{position:absolute;top:6px;height:36px;border-left:4px solid var(--emp-border,#0284c7);background:var(--emp-bg,#e0f2fe);color:var(--emp-text,#075985);border-radius:10px;padding:5px 7px;overflow:hidden;box-shadow:0 1px 2px rgba(15,23,42,.08);display:flex;flex-direction:column;justify-content:center;line-height:1.05;min-width:34px}
.program-day-time-block strong{font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:inherit}
.program-day-time-block small{font-size:.66rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:inherit;opacity:.88;margin-top:2px}
.program-add-form-panel{border:1px solid #e5e7eb;background:#fff;border-radius:16px;padding:14px 16px}
#programScheduleModal .modal-body{background:#f8fafc}
#programScheduleModal .modal-content{overflow:hidden}
#programScheduleModal .program-day-summary{background:#fff}
@media(max-width:768px){.program-day-grid-wrap{max-height:300px}.program-day-time-grid-wrap{min-width:780px}.program-day-grid-row{grid-template-columns:145px minmax(620px,1fr)}.program-day-employee-cell,.program-day-employee-head{font-size:.78rem;padding:8px}.program-day-time-block{height:34px;top:7px;padding:4px 6px}.program-add-form-panel{padding:12px}.program-day-grid-info{border-radius:10px;display:flex}}
@media print{.program-day-time-block,.program-day-grid-info{-webkit-print-color-adjust:exact;print-color-adjust:exact}}

/* V5.6.9 Fix 4 - Programación por centro y modal con scroll real */
.program-fixed-center{display:flex;align-items:center;min-height:42px;border:1px solid #dbeafe;background:#eff6ff;color:#1e40af;border-radius:10px;padding:8px 11px;font-weight:900}
.program-conflict-panel{border:1px solid #fde68a;background:#fffbeb;border-radius:12px;padding:10px 12px;color:#78350f}
.program-conflict-panel .form-text{color:#92400e!important}
#programScheduleModal .modal-dialog{max-height:calc(100vh - 1.25rem);margin-top:.625rem;margin-bottom:.625rem}
#programScheduleModal .modal-content{max-height:calc(100vh - 1.25rem);display:flex;flex-direction:column;overflow:hidden}
#programScheduleModal .modal-body{overflow-y:auto;max-height:calc(100vh - 155px);padding-bottom:1rem}
#programScheduleModal .modal-footer{flex-shrink:0;background:#fff;position:sticky;bottom:0;z-index:5}
@media(max-width:768px){#programScheduleModal .modal-dialog{max-height:100vh;margin:0}#programScheduleModal .modal-content{max-height:100vh;border-radius:0}#programScheduleModal .modal-body{max-height:calc(100vh - 145px)}}

/* V5.6.9 Fix 5 - Vista semanal en grilla horaria, scroll modal real y estabilidad visual */
.program-week-help{border:1px solid #dbeafe;background:#eff6ff;color:#1e40af;border-radius:12px;padding:9px 12px;font-weight:700;font-size:.86rem;margin-bottom:10px}
.program-week-timeline-scroll{width:100%;overflow:auto;border:1px solid #e2e8f0;border-radius:16px;background:#fff;max-height:720px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.6)}
.program-week-timeline-inner{display:flex;align-items:flex-start;min-width:1020px;background:#fff;position:relative}
.program-week-time-axis{width:72px;min-width:72px;position:sticky;left:0;z-index:6;background:#f8fafc;border-right:1px solid #dbe3ef;box-shadow:4px 0 10px rgba(15,23,42,.05)}
.program-week-axis-head{height:42px;display:flex;align-items:center;justify-content:center;font-weight:900;color:#334155;border-bottom:1px solid #e2e8f0;background:#f8fafc}
.program-week-axis-body{position:relative;background-image:repeating-linear-gradient(to bottom,rgba(148,163,184,.28) 0,rgba(148,163,184,.28) 1px,transparent 1px,transparent calc(100% / var(--slot-count)));background-size:100% 100%}
.program-week-axis-body span{position:absolute;right:8px;transform:translateY(-50%);font-size:.72rem;font-weight:900;color:#64748b;background:#f8fafc;padding:1px 2px;border-radius:4px}
.program-week-day-col{border-right:1px solid #e2e8f0;background:#fff;cursor:pointer;position:relative;flex:0 0 auto}
.program-week-day-col:hover .program-week-day-head{background:#e0f2fe;color:#075985}
.program-week-day-head{height:42px;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;font-weight:900;color:#111827;background:#f8fafc;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:3}
.program-week-day-head span{display:inline-flex;align-items:center;justify-content:center;width:28px;height:26px;border-radius:999px;background:#e2e8f0;color:#334155;font-weight:900}
.program-week-day-body{position:relative;background-image:repeating-linear-gradient(to bottom,rgba(148,163,184,.23) 0,rgba(148,163,184,.23) 1px,transparent 1px,transparent calc(100% / var(--slot-count)));background-size:100% 100%;background-color:#fff}
.program-week-day-body::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(to right,rgba(226,232,240,.65),transparent 8px,transparent calc(100% - 8px),rgba(226,232,240,.65))}
.program-week-block{position:absolute;border-left:4px solid var(--emp-border,#0284c7);background:var(--emp-bg,#e0f2fe);color:var(--emp-text,#075985);border-radius:10px;padding:5px 6px;overflow:hidden;box-shadow:0 1px 4px rgba(15,23,42,.12);line-height:1.05;min-height:26px;z-index:2}
.program-week-block strong{display:block;color:inherit;font-size:.72rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:900}
.program-week-block small{display:block;color:inherit;opacity:.86;font-size:.64rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px;font-weight:700}
.program-week-empty{position:absolute;top:12px;left:10px;right:10px;border:1px dashed #cbd5e1;background:#f8fafc;color:#64748b;border-radius:10px;text-align:center;font-weight:800;padding:10px;font-size:.8rem}
#programScheduleModal .modal-dialog{height:calc(100vh - 1.25rem)!important;max-height:calc(100vh - 1.25rem)!important;margin-top:.625rem!important;margin-bottom:.625rem!important}
#programScheduleModal .modal-content{height:100%!important;max-height:100%!important;display:flex!important;flex-direction:column!important;overflow:hidden!important}
#programScheduleModal .modal-body{flex:1 1 auto!important;min-height:0!important;overflow-y:auto!important;max-height:none!important;padding-bottom:1.25rem!important}
#programScheduleModal .modal-footer{flex:0 0 auto!important;position:relative!important;bottom:auto!important;background:#fff!important;border-top:1px solid #e5e7eb!important;z-index:10!important}
@media(max-width:768px){.program-week-timeline-scroll{max-height:660px}.program-week-timeline-inner{min-width:900px}.program-week-time-axis{width:62px;min-width:62px}.program-week-day-col{min-width:240px!important}.program-week-block strong{font-size:.68rem}.program-week-block small{font-size:.61rem}#programScheduleModal .modal-dialog{height:100vh!important;max-height:100vh!important;margin:0!important}#programScheduleModal .modal-content{border-radius:0!important}}
@media print{.program-week-timeline-scroll{overflow:visible;max-height:none}.program-week-block,.program-week-help{-webkit-print-color-adjust:exact;print-color-adjust:exact}}

/* V5.6.9 Fix 6 - Programación: horas libres, semana horizontal y modales con scroll seguro */
.time-input-wide{min-width:118px;font-variant-numeric:tabular-nums}
#programScheduleModal .modal-dialog,#quickScheduleModal .modal-dialog{height:auto!important;max-height:calc(100dvh - 24px)!important;margin-top:12px!important;margin-bottom:12px!important}
#programScheduleModal .modal-content,#quickScheduleModal .modal-content{max-height:calc(100dvh - 24px)!important;display:flex!important;flex-direction:column!important;overflow:hidden!important}
#programScheduleModal .modal-body,#quickScheduleModal .modal-body{flex:1 1 auto!important;min-height:0!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important;overscroll-behavior:contain!important;padding-bottom:1.25rem!important}
#programScheduleModal .modal-footer,#quickScheduleModal .modal-footer{flex:0 0 auto!important;background:#fff!important;border-top:1px solid #e5e7eb!important;position:sticky!important;bottom:0!important;z-index:20!important}
.program-week-horizontal-scroll{width:100%;overflow:auto;border:1px solid #e2e8f0;border-radius:16px;background:#fff;max-height:720px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.65)}
.program-week-horizontal-inner{background:#fff;position:relative}
.program-week-horizontal-row{display:grid;grid-template-columns:150px minmax(820px,1fr);border-bottom:1px solid #e2e8f0}
.program-week-horizontal-row:last-child{border-bottom:0}
.program-week-horizontal-head{position:sticky;top:0;z-index:7;background:#f8fafc;min-height:44px}
.program-week-horizontal-day-head,.program-week-horizontal-day-label{position:sticky;left:0;z-index:6;background:#f8fafc;border-right:1px solid #dbe3ef;display:flex;align-items:center;justify-content:center;font-weight:900;color:#334155;padding:9px 10px;box-shadow:4px 0 10px rgba(15,23,42,.05)}
.program-week-horizontal-day-label{height:var(--row-height);flex-direction:column;align-items:flex-start;gap:3px;color:#111827;cursor:pointer}
.program-week-horizontal-day-label span{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#e2e8f0;color:#334155;font-weight:900;font-size:.78rem;padding:2px 8px}
.program-week-horizontal-hours{position:relative;min-height:44px;background:#f8fafc;background-image:repeating-linear-gradient(to right,rgba(148,163,184,.28) 0,rgba(148,163,184,.28) 1px,transparent 1px,transparent calc(100% / var(--slot-count)));background-size:100% 100%}
.program-week-hour-mark{position:absolute;top:12px;transform:translateX(-1px);font-size:.72rem;color:#64748b;font-weight:900;white-space:nowrap;border-left:2px solid rgba(15,23,42,.2);padding-left:3px;line-height:1}
.program-week-horizontal-day{cursor:pointer;background:#fff}
.program-week-horizontal-day:hover .program-week-horizontal-day-label,.program-week-horizontal-day:hover .program-week-horizontal-timeline{background-color:#f0f9ff}
.program-week-horizontal-timeline{position:relative;height:var(--row-height);background-color:#fff;background-image:repeating-linear-gradient(to right,rgba(148,163,184,.22) 0,rgba(148,163,184,.22) 1px,transparent 1px,transparent calc(100% / var(--slot-count))),repeating-linear-gradient(to bottom,rgba(226,232,240,.65) 0,rgba(226,232,240,.65) 1px,transparent 1px,transparent 44px);background-size:100% 100%,100% 100%}
.program-week-horizontal-block{position:absolute;height:36px;border-left:4px solid var(--emp-border,#0284c7);background:var(--emp-bg,#e0f2fe);color:var(--emp-text,#075985);border-radius:10px;padding:5px 7px;overflow:hidden;box-shadow:0 1px 4px rgba(15,23,42,.12);line-height:1.05;min-width:44px;z-index:2}
.program-week-horizontal-block strong{display:block;color:inherit;font-size:.74rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:900}
.program-week-horizontal-block small{display:block;color:inherit;opacity:.86;font-size:.64rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px;font-weight:700}
.program-week-horizontal-empty{position:absolute;top:12px;left:12px;right:12px;border:1px dashed #cbd5e1;background:#f8fafc;color:#64748b;border-radius:10px;text-align:center;font-weight:800;padding:9px;font-size:.8rem}
#quickScheduleModal .quick-center-note{display:flex;align-items:center;min-height:42px;border:1px solid #dbeafe;background:#eff6ff;color:#1e40af;border-radius:10px;padding:8px 11px;font-weight:900}
@media(max-width:768px){#programScheduleModal .modal-dialog,#quickScheduleModal .modal-dialog{max-height:100dvh!important;margin:0!important}#programScheduleModal .modal-content,#quickScheduleModal .modal-content{max-height:100dvh!important;border-radius:0!important}.program-week-horizontal-scroll{max-height:660px}.program-week-horizontal-row{grid-template-columns:118px minmax(760px,1fr)}.program-week-horizontal-day-head,.program-week-horizontal-day-label{font-size:.82rem;padding:8px}.program-week-horizontal-block strong{font-size:.68rem}.program-week-horizontal-block small{font-size:.6rem}.time-input-wide{min-width:100px}}
@media print{.program-week-horizontal-scroll{overflow:visible;max-height:none}.program-week-horizontal-block,.program-week-help{-webkit-print-color-adjust:exact;print-color-adjust:exact}}

/* V5.6.9 Fix 7 - Modal con desplazamiento real y bloqueo de solapes */
#programScheduleModal .modal-dialog,
#quickScheduleModal .modal-dialog{
  height:calc(100dvh - 24px)!important;
  max-height:calc(100dvh - 24px)!important;
  margin:12px auto!important;
}
#programScheduleModal .modal-content,
#quickScheduleModal .modal-content{
  height:100%!important;
  max-height:100%!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
}
#programScheduleModal .modal-body,
#quickScheduleModal .modal-body{
  flex:1 1 auto!important;
  min-height:0!important;
  height:auto!important;
  max-height:none!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  -webkit-overflow-scrolling:touch!important;
  scrollbar-gutter:stable!important;
  padding-bottom:1.5rem!important;
}
#programScheduleModal .modal-footer,
#quickScheduleModal .modal-footer{
  flex:0 0 auto!important;
  position:relative!important;
  bottom:auto!important;
  z-index:25!important;
  background:#fff!important;
}
#programScheduleModal .program-day-grid-wrap{max-height:255px!important;}
#programScheduleModal .program-add-form-panel{margin-bottom:0!important;}
#programScheduleModal .program-add-form-panel .row{align-items:start;}
.js-time-free{font-variant-numeric:tabular-nums;letter-spacing:.02em;}
@media(max-width:768px){
  #programScheduleModal .modal-dialog,#quickScheduleModal .modal-dialog{height:100dvh!important;max-height:100dvh!important;margin:0!important;}
  #programScheduleModal .modal-content,#quickScheduleModal .modal-content{border-radius:0!important;}
  #programScheduleModal .program-day-grid-wrap{max-height:220px!important;}
}

/* V5.6.9 Fix 8 - Scroll real en formulario del modal y eliminación de franjas */
#programScheduleModal .modal-dialog{
  height:calc(100dvh - 24px)!important;
  max-height:calc(100dvh - 24px)!important;
  margin:12px auto!important;
}
#programScheduleModal .modal-content{
  height:100%!important;
  max-height:100%!important;
  overflow:hidden!important;
}
#programScheduleModal #programScheduleForm{
  height:100%!important;
  min-height:0!important;
  display:flex!important;
  flex-direction:column!important;
}
#programScheduleModal #programScheduleForm>.modal-header,
#programScheduleModal #programScheduleForm>.modal-footer{
  flex:0 0 auto!important;
}
#programScheduleModal #programScheduleForm>.modal-body{
  flex:1 1 auto!important;
  min-height:0!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  -webkit-overflow-scrolling:touch!important;
  padding-bottom:2rem!important;
}
#programScheduleModal .program-day-grid-wrap{
  max-height:240px!important;
}
#programScheduleModal .program-add-form-panel{
  margin-bottom:1rem!important;
}
.program-day-time-block.has-delete{
  padding-right:30px!important;
}
.program-day-delete-btn{
  position:absolute;
  top:5px;
  right:6px;
  width:22px;
  height:22px;
  border:1px solid rgba(127,29,29,.22);
  border-radius:999px;
  background:rgba(255,255,255,.9);
  color:#991b1b;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  font-weight:900;
  line-height:1;
  cursor:pointer;
  box-shadow:0 1px 2px rgba(15,23,42,.12);
}
.program-day-delete-btn:hover,
.program-day-delete-btn:focus{
  background:#fee2e2;
  border-color:#ef4444;
  outline:none;
}
@media(max-width:768px){
  #programScheduleModal .modal-dialog{height:100dvh!important;max-height:100dvh!important;margin:0!important;}
  #programScheduleModal .program-day-grid-wrap{max-height:210px!important;}
}

/* V5.6.9 Fix 9 - Edición rápida de franjas desde la grilla */
.program-day-time-block.has-actions{
  padding-right:54px!important;
}
.program-day-action-btn{
  position:absolute;
  top:5px;
  width:22px;
  height:22px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
  font-weight:900;
  line-height:1;
  cursor:pointer;
  box-shadow:0 1px 2px rgba(15,23,42,.12);
  z-index:4;
}
.program-day-edit-btn{
  right:31px;
  border:1px solid rgba(29,78,216,.24);
  color:#1d4ed8;
}
.program-day-edit-btn:hover,
.program-day-edit-btn:focus{
  background:#dbeafe;
  border-color:#3b82f6;
  outline:none;
}
.program-day-delete-btn{
  right:6px;
}
#programCancelEditBtn{white-space:nowrap;}
#programScheduleModal.is-editing .program-add-form-panel{
  border-color:#bfdbfe;
  box-shadow:0 0 0 3px rgba(59,130,246,.08);
}
#programScheduleModal.is-editing .program-add-only-option{display:none!important;}

/* V5.6.9 Fix 10 - Ausencias visibles también en Programación de horarios */
.schedule-program-chip.program-absence-chip,
.program-week-horizontal-block.program-absence-block,
.program-day-time-block.program-absence-block{
  background:#fff1f2!important;
  border-left-color:#e11d48!important;
  color:#9f1239!important;
  border-top:1px solid #fecdd3!important;
  border-right:1px solid #fecdd3!important;
  border-bottom:1px solid #fecdd3!important;
}
.schedule-program-chip.program-absence-chip strong,
.program-week-horizontal-block.program-absence-block strong,
.program-day-time-block.program-absence-block strong{
  color:#9f1239!important;
}
.schedule-program-chip.program-absence-chip small,
.program-week-horizontal-block.program-absence-block small,
.program-day-time-block.program-absence-block small{
  color:#9f1239!important;
  opacity:.95!important;
  font-weight:800;
}
.program-day-time-block.program-absence-block{box-shadow:0 1px 2px rgba(190,18,60,.12)!important;}
@media print{
  .schedule-program-chip.program-absence-chip,
  .program-week-horizontal-block.program-absence-block,
  .program-day-time-block.program-absence-block{
    -webkit-print-color-adjust:exact;
    print-color-adjust:exact;
  }
}

/* V5.7 - Informes / liquidación de horas */
.payroll-table td,.payroll-table th{vertical-align:middle;}
.report-payroll-print-area,.report-payroll-detail-print-area{overflow:hidden;}
@media print{
  body.print-report-payroll *{visibility:hidden!important}
  body.print-report-payroll .report-payroll-print-area,
  body.print-report-payroll .report-payroll-print-area *,
  body.print-report-payroll .report-payroll-detail-print-area,
  body.print-report-payroll .report-payroll-detail-print-area *{visibility:visible!important}
  body.print-report-payroll .report-payroll-print-area,
  body.print-report-payroll .report-payroll-detail-print-area{position:relative!important;left:0!important;top:0!important;width:100%!important;box-shadow:none!important;border:0!important;page-break-inside:auto;}
}

/* V5.7.1 - Configuración de liquidación por empleado y impresión robusta */
.employee-liquidation-box{border:1px solid #e5e7eb;background:#f8fafc;border-radius:16px;padding:14px;margin-top:4px}
.contract-days-checks{display:flex;flex-wrap:wrap;gap:7px}
.contract-days-checks label{display:inline-flex;align-items:center;gap:5px;border:1px solid #dbeafe;background:#eff6ff;color:#1e40af;border-radius:999px;padding:6px 10px;font-weight:800;font-size:.84rem;cursor:pointer;margin:0}
.contract-days-checks input{margin:0}
.contract-days-checks label:has(input:checked){background:#dcfce7;border-color:#86efac;color:#166534}
@media(max-width:768px){.contract-days-checks label{flex:1;justify-content:center}}

/* V5.7.3 - Pulido final de configuración, correo y PWA */
.settings-shell{display:grid;grid-template-columns:260px minmax(0,1fr);gap:18px;align-items:start}.settings-nav{position:sticky;top:18px;border:0;box-shadow:0 8px 28px rgba(15,23,42,.06);border-radius:18px}.settings-nav-title{font-weight:900;color:#111827;margin-bottom:10px}.settings-nav-btn{width:100%;border:1px solid #e5e7eb;background:#fff;color:#334155;border-radius:14px;text-align:left;padding:10px 12px;margin-bottom:8px;font-weight:900;transition:.15s ease}.settings-nav-btn small{display:block;color:#64748b;font-weight:700;margin-top:2px}.settings-nav-btn:hover,.settings-nav-btn.active{border-color:#2563eb;background:#eff6ff;color:#1d4ed8}.settings-nav-btn.active small{color:#2563eb}.settings-content{min-width:0}.settings-section{display:none}.settings-section.active{display:block}.settings-panel{border:0;border-radius:18px;box-shadow:0 8px 28px rgba(15,23,42,.06);margin-bottom:18px}.settings-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px}.settings-panel-head h5{margin:0;font-weight:900;color:#111827}.settings-panel-head p{margin:4px 0 0;color:#64748b}.settings-info-box{background:#f8fafc;border:1px solid #e5e7eb;border-radius:14px;padding:12px 14px;color:#475569;min-height:76px}.settings-info-box strong{color:#111827}.settings-switch{background:#f8fafc;border:1px solid #e5e7eb;border-radius:14px;padding:12px 14px 12px 48px;min-height:48px;display:flex;align-items:center}.settings-switch .form-check-input{margin-left:-34px}.settings-switch-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.settings-savebar{position:sticky;bottom:0;background:linear-gradient(180deg,rgba(248,250,252,0),#f8fafc 35%);padding:18px 0 4px;display:flex;justify-content:flex-end;z-index:5}.settings-savebar .btn{min-width:190px}.mail-status-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.mail-status-grid>div{background:#f8fafc;border:1px solid #e5e7eb;border-radius:14px;padding:10px 12px;min-width:0}.mail-status-grid strong,.mail-status-grid span{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mail-status-grid strong{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.03em}.mail-status-grid span{font-weight:900;color:#111827;margin-top:2px}.form-control-color{height:38px;padding:4px}
@media(max-width:992px){.settings-shell{grid-template-columns:1fr}.settings-nav{position:static}.settings-nav .card-body{display:flex;gap:8px;overflow-x:auto}.settings-nav-title{display:none}.settings-nav-btn{min-width:180px;margin-bottom:0}.mail-status-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-switch-list{grid-template-columns:1fr}}
@media(max-width:576px){.mail-status-grid{grid-template-columns:1fr}.settings-panel-head{display:block}.settings-panel-head .badge{margin-top:8px}.settings-savebar .btn{width:100%}}

/* V5.7.5 - Identidad A-Tiempo y avisos de impresión */
.app-brand{display:flex;align-items:center;min-height:34px}.app-brand img{height:34px;width:auto;display:block;max-width:190px}.login-brand{text-align:center;margin-bottom:16px}.login-brand img{max-width:280px;width:80%;height:auto}.at-brand-print-logo{max-height:54px;width:auto}.software-property-note{font-size:.72rem;color:#64748b;text-align:center;margin-top:10px}.app-topbar .navbar-brand{padding-top:.2rem;padding-bottom:.2rem}
@media(max-width:576px){.app-brand img{height:28px;max-width:150px}.login-brand img{max-width:220px}}
@media print{
  .weekly-calendar-print-area::before,.schedule-table-print-area::before,.employee-schedule-print-area::before,.report-daily-print-area::before,.report-employee-print-area::before,.report-center-print-area::before,.report-absence-print-area::before,.records-summary-print-area::before,.records-detail-print-area::before,.absences-print-area::before,.report-payroll-print-area::before,.report-payroll-detail-print-area::before{content:"";display:block;width:210px;height:58px;background:url("brand/a-tiempo-logo.png") no-repeat left center/contain;margin:0 0 10px 0;visibility:visible!important;}
  .weekly-calendar-print-area::after,.schedule-table-print-area::after,.employee-schedule-print-area::after,.report-daily-print-area::after,.report-employee-print-area::after,.report-center-print-area::after,.report-absence-print-area::after,.records-summary-print-area::after,.records-detail-print-area::after,.absences-print-area::after,.report-payroll-print-area::after,.report-payroll-detail-print-area::after{content:"A-Tiempo by i@les - Apphos Servicios Web. Software propietario. Prohibida su reproduccion, distribucion, cesion o modificacion no autorizada.";display:block;margin-top:10px;padding-top:6px;border-top:1px solid #e5e7eb;font-size:9px;color:#64748b;text-align:center;visibility:visible!important;}
}

/* V5.8.1 Fix 11 - Paneles responsive y menú lateral modernizado */
.app-shell{padding-left:0;padding-right:0;}
.app-topbar{box-shadow:0 8px 24px rgba(15,23,42,.14);position:sticky;top:0;z-index:1040;}
.app-menu-toggle{border-radius:10px;font-weight:900;line-height:1;min-width:38px;}
.sidebar{
  background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
  border-right:1px solid #e5e7eb;
  box-shadow:8px 0 22px rgba(15,23,42,.035);
}
.sidebar-title{font-weight:900;color:#0f172a;margin:0 0 12px;padding:6px 8px;}
.sidebar a{
  display:flex;
  align-items:center;
  gap:.55rem;
  min-height:42px;
  margin:3px 0;
  padding:10px 12px;
  color:#334155;
  text-decoration:none;
  border-radius:12px;
  font-weight:800;
  transition:background .15s ease,color .15s ease,transform .15s ease,box-shadow .15s ease;
}
.sidebar a:hover,.sidebar a:focus{
  background:#eef6ff;
  color:#0b4778;
  transform:translateX(2px);
  box-shadow:inset 3px 0 0 #0b4778;
}
.sidebar a.active{
  background:linear-gradient(135deg,#0b4778,#087ea4);
  color:#fff;
  box-shadow:0 8px 18px rgba(11,71,120,.22);
}
.sidebar hr{border-color:#e2e8f0;opacity:1;margin:12px 0;}
.app-main-content{min-height:calc(100vh - 58px);}
.employee-portal-time{font-size:2.05rem;font-weight:900;letter-spacing:1px;color:#0f172a;line-height:1.05;margin-top:.35rem;}
.app-sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:1044;}
@media(max-width:767.98px){
  body.sidebar-open{overflow:hidden;}
  .app-topbar .container-fluid{gap:.5rem;}
  .app-topbar .ms-auto{gap:.35rem!important;}
  .app-topbar .btn-sm{padding:.25rem .45rem;font-size:.78rem;}
  .app-brand img{height:30px;max-width:145px;}
  .sidebar{
    position:fixed;
    left:0;
    top:58px;
    bottom:0;
    width:min(86vw,320px);
    min-height:0!important;
    overflow-y:auto;
    z-index:1045;
    transform:translateX(-105%);
    transition:transform .22s ease;
    border-right:0;
    border-bottom:0!important;
    border-radius:0 18px 18px 0;
    padding:14px!important;
  }
  body.sidebar-open .sidebar{transform:translateX(0);}
  body.sidebar-open .app-sidebar-backdrop{display:block;}
  .sidebar a{min-height:46px;font-size:.96rem;}
  .app-main-content{width:100%!important;flex:0 0 100%!important;max-width:100%!important;padding:16px!important;}
  .employee-portal-time{font-size:1.75rem;}
}

/* Manuales: visor escritorio + acceso móvil estable */
.manual-pdf-frame{
    width:100%;
    height:78vh;
    border:1px solid #d8dee9;
    border-radius:14px;
    background:#fff;
}
.manual-mobile-viewer{display:none;}
@media (max-width: 767.98px){
    .manual-desktop-viewer{display:none !important;}
    .manual-mobile-viewer{display:block !important;}
    .manual-actions{width:100%;}
    .manual-actions .btn{flex:1 1 100%;}
}
@media (min-width: 768px){
    .manual-desktop-viewer{display:block;}
}
