@media (min-width: 1400px){.portal-hero{grid-template-columns:1fr 1fr;gap:clamp(2.5rem,4vw,8rem)}.portal-grid{gap:clamp(2rem,3.5vw,3rem)}}@media (min-width: 1800px){.portal-main{padding:0 6vw}.portal-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}}.portal-body{min-height:100vh}.portal-hero{position:relative;overflow:hidden}.portal-hero-illustration{display:flex;align-items:center;justify-content:center;min-height:clamp(220px,32vw,420px);width:100%;position:relative}.portal-orbit{position:absolute;border-radius:50%;border:1px dashed rgba(37,99,235,.22);mix-blend-mode:hard-light;transform-origin:center}.portal-orbit.orbit-1{width:clamp(140px,28vw,320px);height:clamp(140px,28vw,320px);top:8%;left:8%}.portal-orbit.orbit-2{width:clamp(200px,36vw,420px);height:clamp(200px,36vw,420px);top:2%;right:6%;transform:rotate(.5turn)}.portal-orbit.orbit-3{width:clamp(240px,42vw,520px);height:clamp(240px,42vw,520px);top:18%;right:-4%;animation-duration:26s}.portal-hero-illustration:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 10% 20%,rgba(37,99,235,.08),transparent 25%),radial-gradient(circle at 80% 30%,rgba(99,102,241,.06),transparent 30%);z-index:-1;pointer-events:none}@media (max-width: 980px){.portal-orbit.orbit-2,.portal-orbit.orbit-3{display:none}.portal-orbit.orbit-1{width:clamp(100px,34vw,220px);height:clamp(100px,34vw,220px);left:50%;transform:translate(-50%);top:6%}.portal-hero-illustration:after{background:radial-gradient(circle at 50% 40%,rgba(37,99,235,.1),transparent 40%),radial-gradient(circle at 20% 80%,rgba(14,165,233,.06),transparent 30%)}}@media (max-width: 520px){.portal-hero-illustration{min-height:200px}.portal-orbit{display:none}.portal-hero-illustration:after{background-size:cover;opacity:.9}}:root{--status-success-bg: rgba(46, 204, 113, .12);--status-success-text: #1b9c63;--status-warning-bg: rgba(243, 156, 18, .12);--status-warning-text: #b66a0c;--status-danger-bg: rgba(231, 76, 60, .12);--status-danger-text: #b83227}.st-status-label{display:inline-flex;align-items:center;gap:.35rem;padding:.15rem .8rem;border-radius:999px;font-size:.85rem;font-weight:600;line-height:1.4;letter-spacing:.01em}.st-status-label .icon{font-size:.85rem}.st-status-success{background:var(--status-success-bg);color:var(--status-success-text)}.st-status-warning{background:var(--status-warning-bg);color:var(--status-warning-text)}.st-status-danger{background:var(--status-danger-bg);color:var(--status-danger-text)}.st-table-wrapper{background:var(--surface, #fff);border-radius:var(--border-radius, 12px);box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1));padding:1rem;position:relative}.st-table-scroll{width:100%;overflow-x:auto}.st-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.st-table thead th{text-align:left;font-size:.85rem;font-weight:600;color:var(--text-secondary, #4a5568);text-transform:uppercase;letter-spacing:.04em;padding:.75rem .65rem;border-bottom:1px solid var(--border, #e2e8f0);background:var(--primary-lighter, rgba(67, 97, 238, .08))}.st-table tbody td{padding:.85rem .65rem;border-bottom:1px solid var(--border, #e2e8f0);color:var(--text-primary, #1f2933);font-size:.95rem}.st-table tbody tr:hover{background:#4361ee0d}.st-table tbody tr:last-child td{border-bottom:none}.st-table-wrapper.loading:after{content:"Cargando datos...";position:absolute;top:0;right:0;bottom:0;left:0;background:#fffc;display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--primary, #4361ee)}.st-table-empty{text-align:center;padding:1.5rem;color:var(--text-secondary, #6c757d);font-size:.95rem}.st-table-pagination{margin-top:1rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;font-size:.9rem;color:var(--text-secondary, #6c757d)}.st-pagination-controls{display:inline-flex;align-items:center;gap:.4rem}.st-pagination-button{border:1px solid var(--border, #e2e8f0);background:#fff;border-radius:6px;width:36px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease}.st-pagination-button:disabled{opacity:.4;cursor:not-allowed}.st-pagination-button:not(:disabled):hover{background:var(--primary-lighter, rgba(67, 97, 238, .12))}.st-page-size{border:1px solid var(--border, #e2e8f0);border-radius:6px;padding:.25rem .6rem;background:#fff}@media (max-width: 768px){.st-table-pagination{flex-direction:column;align-items:flex-start}}.st-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:1100;padding:2rem 1rem}.st-modal{background:#fff;border-radius:16px;box-shadow:var(--shadow-lg, 0 10px 15px -3px rgba(0, 0, 0, .1));width:min(960px,95vw);max-height:calc(100vh - 4rem);display:flex;flex-direction:column;overflow:hidden}.st-modal.sm{width:min(420px,95vw)}.st-modal.md{width:min(640px,95vw)}.st-modal.lg{width:min(820px,96vw)}.st-modal.wide{width:min(1120px,98vw)}.st-modal-header{padding:1.2rem 1.5rem;border-bottom:1px solid var(--border, #e2e8f0);display:flex;align-items:center;justify-content:space-between;gap:1rem}.st-modal-title{font-size:1.1rem;font-weight:600;color:var(--text-primary, #111827);display:flex;align-items:center;gap:.6rem}.st-modal-body{padding:1.5rem;overflow-y:auto;flex:1}.st-modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:.75rem}.st-modal-close{border:none;background:transparent;font-size:1.2rem;cursor:pointer;color:var(--text-secondary, #6c757d)}@media (max-width: 640px){.st-modal-overlay{padding:.75rem;align-items:flex-start}.st-modal{width:100%;max-height:calc(100vh - 1.5rem)}}.login-container{display:flex}.login-card{max-width:min(900px,70vw);width:100%}@media (min-width: 1400px){.login-logo img{width:min(480px,28vw);height:auto}.login-card{padding:48px 56px}}@media (max-width: 700px){.login-card{max-width:98vw;padding:24px 6vw}}:root{color-scheme:light;--portal-bg: #f8fafc;--portal-card-bg: #ffffff;--portal-card-border: rgba(148, 163, 184, .2);--portal-card-shadow: 0 15px 35px -15px rgba(15, 23, 42, .25);--portal-text: #1e293b;--portal-text-secondary: #475569;--portal-highlight: #2563eb;--portal-radius-lg: 28px;--portal-radius-md: 20px;--portal-radius-sm: 12px}.portal-body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:linear-gradient(180deg,#f8fafc,#eef2ff 45%,#f8fafc);color:var(--portal-text);min-height:100vh;margin:0;display:flex;flex-direction:column}.portal-hero{position:relative;overflow:hidden;padding:clamp(3rem,5vw,5rem) clamp(1.5rem,5vw,6rem) clamp(3rem,6vw,6rem);display:grid;grid-template-columns:minmax(0,680px) minmax(0,1fr);align-items:center;gap:clamp(2rem,4vw,6rem)}.portal-hero-gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 15% 15%,rgba(37,99,235,.15),transparent 55%),radial-gradient(circle at 80% 20%,rgba(14,165,233,.12),transparent 50%),radial-gradient(circle at 50% 110%,rgba(139,92,246,.15),transparent 55%);z-index:-2}.portal-hero-content{display:flex;flex-direction:column;gap:1.5rem}.portal-eyebrow{font-size:.95rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:#2563ebd9}.portal-hero h1{font-size:clamp(2.5rem,4vw,3.5rem);line-height:1.1;margin:0}.portal-hero p{margin:0;max-width:46ch;color:var(--portal-text-secondary);font-size:clamp(1.05rem,2.2vw,1.2rem)}.portal-hero-cta{display:inline-flex;align-items:center;gap:.65rem;padding:.85rem 1.4rem;background:var(--portal-highlight);color:#fff;font-weight:600;border-radius:var(--portal-radius-sm);box-shadow:0 12px 25px -12px #2563eb99;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease}.portal-hero-cta:hover{transform:translateY(-2px);box-shadow:0 20px 35px -18px #2563eba6}.portal-hero-illustration{position:relative;min-height:clamp(260px,40vw,420px)}.portal-orbit{position:absolute;border-radius:50%;border:1px dashed rgba(37,99,235,.25);animation:portalOrbit 18s linear infinite;mix-blend-mode:hard-light}.portal-orbit.orbit-1{width:clamp(200px,35vw,320px);height:clamp(200px,35vw,320px);top:10%;left:15%}.portal-orbit.orbit-2{width:clamp(280px,45vw,420px);height:clamp(280px,45vw,420px);top:0;right:12%;animation-direction:reverse}.portal-orbit.orbit-3{width:clamp(360px,55vw,520px);height:clamp(360px,55vw,520px);top:20%;right:-5%;animation-duration:26s}@keyframes portalOrbit{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.portal-main{width:min(1200px,94vw);margin:0 auto clamp(5rem,10vw,8rem);padding:0 2rem;box-sizing:border-box}.portal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(1.5rem,3vw,2.5rem)}.portal-card{position:relative;display:flex;flex-direction:column;gap:1.35rem;background:var(--portal-card-bg);border-radius:var(--portal-radius-md);padding:1.75rem;border:1px solid var(--portal-card-border);box-shadow:var(--portal-card-shadow);transition:transform .25s ease,box-shadow .25s ease;isolation:isolate}.portal-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(135deg,rgba(37,99,235,.08),transparent 65%);opacity:0;transition:opacity .25s ease;z-index:-1}.portal-card:hover{transform:translateY(-6px);box-shadow:0 25px 45px -25px #0f172a73}.portal-card:hover:before{opacity:1}.portal-card-header{display:flex;align-items:flex-start;justify-content:space-between}.portal-card-icon{width:54px;height:54px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;background:color-mix(in srgb,var(--portal-accent, var(--portal-highlight)) 18%,transparent);color:color-mix(in srgb,var(--portal-accent, var(--portal-highlight)) 85%,#0f172a 5%)}.portal-card-logo{height:54px;display:flex;align-items:center}.portal-card-logo img{max-height:54px;width:auto;object-fit:contain}.portal-card-badge{padding:.35rem .75rem;background:#33415514;border-radius:999px;font-size:.75rem;font-weight:600;color:#0f172abf;text-transform:uppercase;letter-spacing:.12em}.portal-card-body h3{margin:0 0 .65rem;font-size:1.4rem}.portal-card-body p{margin:0;color:var(--portal-text-secondary);line-height:1.55}.portal-card-tags{margin:1rem 0 0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:.5rem}.portal-card-tags li{background:#2563eb14;color:#2563ebd9;padding:.35rem .65rem;border-radius:999px;font-size:.75rem;font-weight:600}.portal-card-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem}.portal-card-status{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600}.portal-status-indicator{width:.7rem;height:.7rem;border-radius:50%;background:currentColor;box-shadow:0 0 0 4px #2563eb1f}.status-online{color:#16a34a}.status-maintenance{color:#f59e0b}.status-offline{color:#ef4444}.status-coming-soon{color:#6366f1}.portal-card-cta{display:inline-flex;align-items:center;gap:.6rem;padding:.7rem 1.1rem;border-radius:999px;border:1px solid rgba(37,99,235,.25);text-decoration:none;font-weight:600;color:var(--portal-highlight);transition:background .2s ease,color .2s ease,transform .2s ease}.portal-card-cta:hover{background:var(--portal-highlight);color:#fff;transform:translate(2px)}.portal-footer{margin-top:auto;padding:2.5rem clamp(1.5rem,5vw,4rem);background:#0f172a0a}.portal-footer-content{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem 2rem;color:#0f172aa6;font-size:.95rem}.portal-footer-links{display:flex;gap:1rem 1.5rem;flex-wrap:wrap}.portal-footer-links a{display:inline-flex;align-items:center;gap:.4rem;color:inherit;text-decoration:none;font-weight:600}.portal-footer-links a:hover{color:var(--portal-highlight)}@media (max-width: 980px){.portal-hero{grid-template-columns:1fr;text-align:center}.portal-hero-content{align-items:center}.portal-hero-illustration{order:-1}.portal-card{padding:1.5rem}.portal-card-footer{flex-direction:column;align-items:stretch}.portal-card-cta{justify-content:center}.portal-footer-content{flex-direction:column;text-align:center}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.login-page{background:linear-gradient(135deg,#e3f0ff,#f0f6fe);min-height:100vh;width:100%;margin:0;display:flex;align-items:center;justify-content:center;position:relative}.login-page .login-container{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.login-page .login-background-frame{position:absolute;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:0}.login-page .login-background-frame .frame{position:absolute;border-radius:36px;border:6px solid #2B7DE9;opacity:.11;box-shadow:0 0 48px #2b7de9;transition:opacity .3s}.login-page .login-background-frame .frame.frame1{width:82vw;height:80vh;left:9vw;top:10vh;border-color:#2b7de9}.login-page .login-background-frame .frame.frame2{width:65vw;height:60vh;left:17vw;top:19vh;border-color:#4b96fa;opacity:.09}.login-page .login-background-frame .frame.frame3{width:45vw;height:44vh;left:27vw;top:28vh;border-color:#1e5ebb;opacity:.11}.login-card{background:var(--surface, #fff);border-radius:20px;border:2.5px solid #2B7DE9;box-shadow:0 8px 28px 4px #2b7de914,0 2px 16px #b5d6fb;padding:40px 32px 32px;min-width:320px;max-width:min(900px,75vw);width:100%;display:flex;flex-direction:column;align-items:center;animation:fadeIn .5s cubic-bezier(.41,1.01,.87,1.02);position:relative;z-index:2}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-logo{text-align:center;margin-bottom:24px;display:flex;flex-direction:column;align-items:center}.login-logo img{width:380px;height:200px;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(43,125,233,.13));margin-bottom:12px}.login-logo h2{margin:0;font-size:2.2rem;font-weight:700;color:var(--primary, #2B7DE9);letter-spacing:1px}.login-logo .tagline{font-size:1rem;font-weight:500;color:var(--text-secondary, #718096);margin-top:4px}.form-group{width:100%;margin-bottom:22px}.form-group label{font-size:1rem;color:var(--text-primary, #2D3748);font-weight:500;display:flex;align-items:center;gap:7px;margin-bottom:8px}.form-group input{width:100%;padding:10px 14px;border:1px solid var(--border, #E2E8F0);border-radius:8px;background:var(--primary-lighter, #f0f6fe);font-size:1rem;color:var(--text-primary, #2D3748);outline:none;transition:border .2s}.form-group input:focus{border:1.5px solid var(--primary, #2B7DE9);background:#fff}.btn-primary.btn-block{width:100%;padding:12px 0;border:none;border-radius:8px;background:var(--primary, #2B7DE9);color:#fff;font-size:1.08rem;font-weight:600;cursor:pointer;margin-top:8px;transition:background .18s}.btn-primary.btn-block:hover{background:var(--primary-dark, #1E5EBB)}.login-error{width:100%;margin-top:16px;color:var(--danger, #e53e3e);background:#ffe5e5;border-radius:6px;padding:8px 0;text-align:center;font-size:.97rem;font-weight:500;letter-spacing:.2px}@media (max-width: 700px){.login-logo img{width:140px;height:140px}.login-card{padding:24px 6vw;min-width:unset;max-width:98vw}.login-background-frame .frame{border-width:3px}}html,body,#root{height:100%}.route-loader{display:flex;align-items:center;justify-content:center;min-height:50vh;font-size:1.05rem;font-weight:500}.header-title{display:inline-flex;align-items:center;gap:.5rem;font-size:1.15rem;font-weight:700;margin:0}.header-title .icon-md{color:var(--primary)}.timezone-label{font-size:.85rem;color:var(--text-secondary)}.user-menu-divider{border:none;border-top:1px solid var(--border);margin:.5rem 0}.user-info-details{display:flex;gap:.75rem;align-items:center;padding:.75rem 1rem}.user-full-name{font-weight:700;color:var(--text-primary);font-size:.95rem}.user-role{font-size:.85rem;color:var(--text-secondary)}.user-company{font-size:.8rem;color:var(--text-secondary);opacity:.9}.user-menu-actions{padding:.35rem .5rem .5rem}.user-menu .logout-btn{display:flex;align-items:center;gap:.75rem;color:var(--danger);width:100%;padding:.55rem 1rem;text-decoration:none;background:none;border:none;font:inherit;cursor:pointer;border-radius:8px;transition:background .14s ease}.user-menu .logout-btn:hover,.user-menu .logout-btn:focus{background:var(--primary-lighter)}.user-menu{min-width:220px}.dashboard-container{padding:2rem;background:var(--background)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:2rem}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--surface);border-radius:var(--border-radius);padding:1.5rem;box-shadow:var(--shadow-md);border:1px solid var(--border);display:flex;align-items:center;gap:1rem;height:100%;min-height:84px;transition:transform .3s ease,box-shadow .3s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-card.clickable{cursor:pointer;position:relative;overflow:hidden}.stat-card.clickable:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s}.stat-card.clickable:hover:before{left:100%}.stat-card.clickable:hover{transform:translateY(-4px);box-shadow:0 8px 25px #00000026}.stat-card.clickable:after{content:"";font-family:"Font Awesome 5 Free";font-weight:900;position:absolute;top:1rem;right:1rem;font-size:.875rem;color:var(--text-tertiary);opacity:0;transition:opacity .3s ease}.stat-card.clickable:hover:after{opacity:1}.stat-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.stat-icon.success{background-color:#75ca9886;color:#48bb78}.stat-icon.warning{background-color:#f1b8728c;color:#f6ad55}.stat-icon.danger{background-color:#f5656569;color:#f56565}.stat-icon.info{background-color:#4b97fa7e;color:#4b96fa}.stat-info{flex:1}.stat-info h3{font-size:.875rem;font-weight:500;color:var(--text-secondary);margin:0 0 .5rem}.stat-value{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.stat-trend{display:flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:500}.stat-trend.up{color:#48bb78}.stat-trend.down{color:#f56565}.stat-trend.neutral{color:var(--text-tertiary)}.stat-trend i{font-size:.7rem}.stat-trend span{color:var(--text-tertiary)}.chart-card{background:var(--surface);border-radius:var(--border-radius);padding:1.5rem;box-shadow:var(--shadow-md);border:1px solid var(--border);height:100%}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.chart-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.chart-actions{display:flex;gap:.5rem}.btn-icon{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.btn-icon:hover{background:#4b96fa1a;color:var(--primary)}.chart-container{height:350px;min-height:240px}.activity-section{background:var(--surface);border-radius:var(--border-radius);box-shadow:var(--shadow-md);border:1px solid var(--border);margin-bottom:2rem;overflow:hidden}.section-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.section-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.btn-primary{background:var(--primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s ease}.activity-table{width:100%;border-collapse:collapse}.activity-table th{text-align:left;padding:.75rem 1.5rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;background:var(--background);border-bottom:1px solid var(--border)}.activity-table td{padding:1rem 1.5rem;font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border)}.activity-table tr:last-child td{border-bottom:none}.employee-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600}.employee-name{font-weight:500}.employee-id{font-size:.75rem;color:var(--text-tertiary)}.status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.status-badge.ontime{background-color:#48bb781a;color:#48bb78}.status-badge.late{background-color:#f6ad551a;color:#f6ad55}.status-badge.info{background-color:#4b96fa1a;color:#4b96fa}.location-column{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary)}.filters-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;background:var(--surface);padding:1rem 1.5rem;border-radius:var(--border-radius);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.company-info h2{margin:0;color:var(--text-primary);font-size:1.25rem;font-weight:600}.location-filters{display:flex;gap:1rem}.filter-group{display:flex;align-items:center;gap:.5rem;min-width:0}.location-filters .filter-row{flex-wrap:wrap;gap:.6rem}.dashboard-container{width:100%;box-sizing:border-box}.filter-group label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.filter-select{padding:.5rem 2rem .5rem .75rem;border:1px solid var(--border);border-radius:var(--border-radius-sm);background-color:var(--surface);color:var(--text-primary);font-size:.875rem;min-width:180px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;background-size:16px}.filter-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #4b96fa1a}.no-data{text-align:center;color:var(--text-tertiary);padding:2rem 0;font-style:italic}@media (max-width: 1400px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1200px){.charts-grid{grid-template-columns:1fr}}@media (max-width: 992px){.filters-section{flex-direction:column;align-items:flex-start;gap:1rem}.location-filters{width:100%}}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr}.dashboard-container{padding:1rem}}.dashboard-card{transition:all .2s ease-in-out;border:none;box-shadow:0 2px 5px #00000014}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 5px 15px #0000001a}.dashboard-card .card-body{padding:1.25rem}.card-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem}#temprano-card:hover .card-icon{box-shadow:0 0 0 4px #28a74533}#atiempo-card:hover .card-icon{box-shadow:0 0 0 4px #0d6efd33}#tarde-card:hover .card-icon{box-shadow:0 0 0 4px #ffc10733}#faltas-card:hover .card-icon{box-shadow:0 0 0 4px #dc354533}.card-title{font-size:1.4rem;font-weight:600;line-height:1.2}[id$=-card]{position:relative}[id$=-card]:after{content:"";font-family:"Font Awesome 5 Free";font-weight:900;position:absolute;right:15px;bottom:15px;opacity:0;transition:all .2s;color:#6c757d}[id$=-card]:hover:after{opacity:.7;right:10px}#dashboard-loader{padding:30px;background-color:#fffc;border-radius:8px}.modal{display:none;position:fixed;z-index:1050;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#00000080;opacity:0;transition:opacity .3s}.modal.show{display:flex;align-items:center;justify-content:center;opacity:1}.modal-content{position:relative;background-color:#fff;margin:auto;padding:0;border-radius:.5rem;box-shadow:0 5px 15px #00000080;width:90%;max-width:min(800px,95vw);animation:modalIn .3s}.modal-lg{max-width:min(1400px,95vw);width:95%}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #dee2e6}.modal-header h3{margin:0;font-size:1.25rem;display:flex;align-items:center}.modal-header h3 i{margin-right:.5rem}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#adb5bd;transition:color .15s}.modal-close:hover{color:#212529}.modal-body{padding:1rem;max-height:calc(100vh - 200px);overflow-y:auto}.modal-footer{padding:1rem;border-top:1px solid #dee2e6;display:flex;justify-content:flex-end;gap:.5rem}.modal-filters{background-color:#f8f9fa;border-radius:.25rem;padding:.75rem;margin-bottom:1rem;font-size:.9rem}.filter-info i{color:#6c757d;margin-right:.25rem}.table{width:100%;margin-bottom:1rem;color:#212529;border-collapse:collapse}.table th,.table td{padding:.75rem;vertical-align:middle;border-top:1px solid #dee2e6}.table thead th{vertical-align:bottom;border-bottom:2px solid #dee2e6;background-color:#f8f9fa}.table-striped tbody tr:nth-of-type(odd){background-color:#0000000d}.text-success{color:#28a745}.text-info{color:#17a2b8}.text-warning{color:#ffc107}.text-danger{color:#dc3545}.text-muted{color:#6c757d}@keyframes modalIn{0%{transform:translateY(-30px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.modal-content{width:95%;margin:10px}.table-responsive{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}}#temprano-modal .modal-header,#aTiempo-modal .modal-header,#tarde-modal .modal-header,#faltas-modal .modal-header,#salidaTemprana-modal .modal-header,#salidaTarde-modal .modal-header,#ausencias-modal .modal-header,#justificaciones-modal .modal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff!important;border-bottom:1px solid rgba(255,255,255,.2)}#temprano-modal .modal-header h3,#aTiempo-modal .modal-header h3,#tarde-modal .modal-header h3,#faltas-modal .modal-header h3,#salidaTemprana-modal .modal-header h3,#salidaTarde-modal .modal-header h3,#ausencias-modal .modal-header h3,#justificaciones-modal .modal-header h3,#temprano-modal .modal-header h3 i,#aTiempo-modal .modal-header h3 i,#tarde-modal .modal-header h3 i,#faltas-modal .modal-header h3 i,#salidaTemprana-modal .modal-header h3 i,#salidaTarde-modal .modal-header h3 i,#ausencias-modal .modal-header h3 i,#justificaciones-modal .modal-header h3 i{color:#fff!important}#temprano-modal .modal-header .modal-close,#aTiempo-modal .modal-header .modal-close,#tarde-modal .modal-header .modal-close,#faltas-modal .modal-header .modal-close,#salidaTemprana-modal .modal-header .modal-close,#salidaTarde-modal .modal-header .modal-close,#ausencias-modal .modal-header .modal-close,#justificaciones-modal .modal-header .modal-close{color:#fff!important;opacity:.8}#temprano-modal .modal-header .modal-close:hover,#aTiempo-modal .modal-header .modal-close:hover,#tarde-modal .modal-header .modal-close:hover,#faltas-modal .modal-header .modal-close:hover,#salidaTemprana-modal .modal-header .modal-close:hover,#salidaTarde-modal .modal-header .modal-close:hover,#ausencias-modal .modal-header .modal-close:hover,#justificaciones-modal .modal-header .modal-close:hover{color:#fff!important;opacity:1}.dashboard-container{padding:1rem}.chart-container{min-height:240px}.dashboard-modal-summary{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.summary-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .85rem;border-radius:999px;border:1px solid var(--border, #e2e8f0);background:#fff;font-size:.85rem;color:var(--text-secondary, #475569)}.summary-chip .icon{font-size:.85rem}.summary-chip.tone-info{border-color:#3b82f659;color:#2563eb;background:#3b82f614}.summary-chip.tone-success{border-color:#10b98159;color:#047857;background:#10b98114}.summary-chip.tone-warning{border-color:#fbbf2466;color:#b45309;background:#fbbf241f}.summary-chip.tone-danger{border-color:#ef444466;color:#b91c1c;background:#ef44441f}.dashboard-modal-caption{margin:0 0 1rem;color:var(--text-secondary, #64748b);font-size:.9rem}.dashboard-modal-employee,.dashboard-modal-location,.dashboard-modal-checks{display:flex;flex-direction:column;gap:.15rem}.dashboard-modal-employee small,.dashboard-modal-location small,.dashboard-modal-checks span{font-size:.8rem;color:var(--text-secondary, #94a3b8)}.dashboard-modal-empty{padding:1.5rem;text-align:center;color:var(--text-secondary, #94a3b8)}.dashboard-modal-diff{display:flex;flex-direction:column;gap:.15rem}.dashboard-modal-diff strong{font-size:.95rem}.dashboard-modal-diff.early strong{color:#0ea5e9}.dashboard-modal-diff.late strong{color:#f97316}.dashboard-modal-diff small{font-size:.75rem;color:var(--text-secondary, #94a3b8)}.notification-toast{position:fixed;top:1.25rem;right:1.25rem;min-width:280px;max-width:360px;display:flex;align-items:flex-start;gap:.75rem;padding:.85rem 1rem;border-radius:14px;box-shadow:var(--shadow-lg, 0 12px 24px rgba(15, 23, 42, .15));color:#fff;z-index:999;transform:translate(0);animation:notification-slide-in .24s ease-out}.notification-toast__icon{display:inline-flex;width:32px;height:32px;border-radius:999px;align-items:center;justify-content:center;background:#fff3}.notification-toast__content{flex:1}.notification-toast__content strong{display:block;margin-bottom:.2rem;font-size:.95rem}.notification-toast__content p{margin:0;font-size:.85rem;line-height:1.3;color:#ffffffe6}.notification-toast__close{border:none;background:transparent;color:inherit;cursor:pointer;padding:.25rem;line-height:0}.notification-toast--success{background:linear-gradient(120deg,#0f9d58,#16a34a)}.notification-toast--error{background:linear-gradient(120deg,#dc2626,#b91c1c)}.notification-toast--warning{background:linear-gradient(120deg,#f97316,#ea580c)}.notification-toast--info{background:linear-gradient(120deg,#2563eb,#4338ca)}@keyframes notification-slide-in{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.employees-module{display:flex;flex-direction:column;gap:1.5rem}.employee-toolbar{display:flex;justify-content:flex-end;padding-bottom:.5rem;border-bottom:1px solid var(--border, #e2e8f0);gap:.5rem;flex-wrap:wrap;width:100%}.employee-actions{display:flex;flex-wrap:wrap;gap:.5rem}.employee-query-box{background:var(--surface, #fff);border-radius:var(--border-radius, 12px);box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1));padding:1.5rem;width:100%}.employee-query-form .filter-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(.6rem,1vw,1rem);align-items:flex-end}.employee-query-form .filter-group{min-width:0}.employee-query-form .filter-select,.employee-query-form .filter-input{width:100%}.employee-query-form .filter-actions{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:flex-end;grid-column:1 / -1}.employee-table-section{margin-bottom:2rem}.employee-error-message{width:100%;padding:.9rem 1.1rem;border-radius:12px;border:1px solid #f8b4b0;background:#fdecea;color:#991b1b;font-weight:600}.employee-form .filter-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(.6rem,1vw,1rem)}.employee-form .filter-group{min-width:0}.employee-form .filter-label{font-size:.85rem;font-weight:600;color:var(--primary, #4361ee)}.employee-form .filter-select,.employee-form .filter-input{border:1px solid var(--border, #e2e8f0);border-radius:10px;background:#f8fafc;padding:.55rem .65rem;font-size:.95rem;width:100%}.employee-form .filter-select:focus,.employee-form .filter-input:focus{border-color:var(--primary, #4361ee);outline:none;background:#fff}.employee-row-actions{display:inline-flex;gap:.3rem}@media (max-width: 720px){.employee-actions{width:100%;justify-content:flex-start}.employee-query-form .filter-actions{justify-content:flex-start}}.attendance-module{display:flex;flex-direction:column;gap:1.5rem}.attendance-toolbar{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;align-items:center}.attendance-actions{display:flex;flex-wrap:wrap;gap:.5rem}.attendance-warning{display:inline-flex;align-items:center;gap:.4rem;font-size:.9rem;color:var(--text-secondary, #64748b);padding:.4rem .75rem;border-radius:999px;background:#f59e0b1f}.attendance-query-box{background:var(--surface, #fff);border-radius:14px;box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1));padding:1.5rem}.attendance-query-form{display:flex;flex-direction:column;gap:1rem}.attendance-filter-stack{display:flex;flex-direction:column;gap:.9rem}.attendance-filter-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(.6rem,1vw,1rem);align-items:flex-end}.attendance-filter-row .filter-group{min-width:0}.attendance-table-section{background:var(--surface, #fff);border-radius:16px;box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1));padding:1rem}.attendance-query-form .filter-actions{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:flex-end;align-items:center}.attendance-filter-actions{padding-top:.25rem}@media (max-width: 640px){.attendance-filter-actions{flex-direction:column;align-items:stretch}.attendance-filter-actions .st-button{width:100%}}.attendance-name-cell{display:flex;flex-direction:column;gap:.25rem}.attendance-name-cell strong{font-size:1rem}.attendance-subtext{font-size:.85rem;color:var(--text-secondary, #94a3b8)}.attendance-row-actions{display:inline-flex;gap:.35rem}.attendance-site-cell{display:flex;flex-direction:column;gap:.2rem}.attendance-site-cell strong{display:block}.attendance-times{display:flex;flex-direction:column;gap:.15rem;font-size:.85rem;color:var(--text-secondary, #64748b);text-align:left;white-space:nowrap}.attendance-times strong{color:var(--text-primary, #0f172a)}.attendance-time-status{color:var(--text-secondary, #64748b);font-weight:600}.attendance-status-chip{display:inline-flex;align-items:center;padding:.2rem .7rem;border-radius:999px;font-weight:600;font-size:.85rem}.attendance-status-chip.tone-success{background:#10b98126;color:#059669}.attendance-status-chip.tone-info{background:#3b82f626;color:#2563eb}.attendance-status-chip.tone-warning{background:#fbbf2426;color:#b45309}.attendance-status-chip.tone-danger{background:#f871712e;color:#b91c1c}.attendance-status-chip.tone-neutral{background:#94a3b833;color:#64748b}.attendance-status-stack{display:flex;flex-direction:column;gap:.35rem;align-items:flex-start}.attendance-photo-trigger{background:none;border:none;display:flex;flex-direction:column;align-items:center;gap:.25rem;cursor:pointer}.attendance-photo-trigger img{width:48px;height:48px;border-radius:12px;object-fit:cover;box-shadow:var(--shadow-sm, 0 1px 2px rgba(0,0,0,.08))}.attendance-photo-fallback{width:48px;height:48px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:#f1f5f9;color:#64748b;box-shadow:var(--shadow-sm, 0 1px 2px rgba(0,0,0,.08))}.attendance-photo-trigger span{font-size:.8rem;color:var(--primary, #4361ee)}.attendance-modal-grid{display:flex;flex-direction:column;gap:1rem}.register-modal-header{display:flex;flex-direction:column;gap:.4rem}.register-mode-switch{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:flex-start;padding:.9rem 1rem;border:1px dashed var(--border, #e2e8f0);border-radius:12px;background:#f8fafc}.register-mode-title{margin:0;font-weight:600}.register-mode-actions{display:flex;flex-wrap:wrap;gap:.5rem}.register-mode-active{pointer-events:none;border:1px solid var(--primary, #4361ee);color:var(--primary, #4361ee)}.register-info-banner{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .8rem;border-radius:10px;background:#4361ee14;color:var(--primary, #4361ee);font-weight:600}.register-filter-form{display:flex;flex-direction:column;gap:.75rem}.register-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.register-filter-actions{display:flex;gap:.5rem;justify-content:flex-end}.attendance-register-table{border:1px solid var(--border, #e2e8f0);border-radius:12px;overflow:hidden}.attendance-register-table table{width:100%;border-collapse:collapse}.attendance-register-table thead{background:var(--primary-lighter, rgba(67, 97, 238, .1))}.attendance-register-table th,.attendance-register-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border, #e2e8f0)}.register-action-group{display:flex;flex-direction:column;gap:.35rem}.register-action-group .st-button{width:100%}.no-data-cell{text-align:center;padding:1.25rem;color:var(--text-secondary, #94a3b8)}.auto-id-subject-card{display:flex;justify-content:space-between;align-items:center;gap:1rem;background:#fff;border-radius:16px;padding:1rem 1.25rem;box-shadow:var(--shadow-sm)}.subject-label{margin:0 0 .2rem;font-size:.85rem;color:var(--text-secondary, #94a3b8)}.subject-placeholder{color:var(--text-secondary, #cbd5f5);font-weight:600}.capture-pill{border-radius:999px;padding:.35rem .9rem;font-weight:600;border:1px solid transparent}.capture-pill.capture-auto{color:#0b3a82;background:#0e749014;border-color:#0e749059}.capture-pill.capture-biometric{color:#155e75;background:#0ea5e91f;border-color:#0ea5e959}.capture-pill.capture-traditional{color:#92400e;background:#fbbf242e;border-color:#fbbf2473}.auto-id-workbench{background:#fff;border-radius:16px;padding:1.25rem;box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1));display:flex;flex-direction:column;gap:1rem}.auto-id-tabs{display:flex;flex-wrap:wrap;gap:.5rem}.auto-id-tab{border:1px solid var(--border, #e2e8f0);border-radius:999px;padding:.4rem .9rem;background:#f8fafc;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem;font-weight:600;color:var(--text-secondary, #64748b)}.auto-id-tab.active{background:var(--primary-lighter, rgba(67, 97, 238, .15));color:var(--primary, #4361ee);border-color:var(--primary, #4361ee)}.auto-id-workspace{display:flex;flex-wrap:wrap;gap:1.5rem}.auto-id-camera-panel{flex:1 1 440px;min-width:420px;background:#f8fafc;border-radius:18px;padding:1rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:var(--shadow-sm)}.auto-id-camera-view{position:relative;border-radius:18px;overflow:hidden;background:#0f172a;height:340px;border:2px dashed rgba(148,163,184,.4)}.auto-id-camera-view.active{border-style:solid;border-color:#22c55eb3}.auto-id-camera-view video{width:100%;height:100%;object-fit:cover}.auto-id-camera-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:#cbd5f5;text-align:center;padding:1rem}.auto-id-camera-actions{display:flex;flex-wrap:wrap;gap:.5rem}.auto-id-error{margin:0;color:#dc2626;font-weight:600}.auto-id-feedback{margin:0;color:#1f2937;font-weight:600}.auto-id-snapshot{display:flex;flex-direction:column;gap:.4rem}.auto-id-snapshot img{width:100%;border-radius:12px;border:1px solid #e2e8f0}.auto-id-snapshot-placeholder{border:1px dashed rgba(148,163,184,.7);border-radius:12px;padding:.75rem;color:var(--text-secondary, #94a3b8);text-align:center}.auto-id-confirmation{margin-top:.75rem;padding:.85rem;border-radius:14px;background:#f1f5f9;border:1px solid var(--border, #e2e8f0);display:flex;flex-direction:column;gap:.6rem}.auto-id-confirmation strong{display:block;font-size:1rem;margin-bottom:.2rem}.auto-id-confirmation small{display:block;color:var(--text-secondary, #64748b)}.auto-id-similarity{display:inline-flex;margin-top:.4rem;font-weight:600;color:#0f172a}.auto-id-confirm-actions{display:flex;gap:.5rem;flex-wrap:wrap}.auto-id-metrics-inline{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.85rem;color:var(--text-secondary, #64748b)}.auto-id-progress{display:flex;flex-direction:column;gap:.35rem;margin-top:.25rem}.auto-id-progress-track{width:100%;height:8px;background:var(--border, #e2e8f0);border-radius:999px;overflow:hidden}.auto-id-progress-bar{height:100%;border-radius:999px;background:linear-gradient(90deg,#4361ee,#3b82f6);transition:width .2s ease}.auto-id-progress-steps{display:flex;gap:.35rem}.auto-id-progress-steps span{flex:1;height:6px;border-radius:999px;background:var(--border, #e2e8f0)}.auto-id-progress-steps span.complete{background:#4361ee}.auto-id-progress-steps span.active{background:#f59e0b;animation:pulse-step 1.2s ease-in-out infinite}.auto-id-progress-steps span.active.error{background:#dc2626}@keyframes pulse-step{0%{opacity:.6;transform:scaleX(.9)}50%{opacity:1;transform:scaleX(1)}to{opacity:.6;transform:scaleX(.9)}}.auto-id-hidden-canvas{display:none}.auto-id-preview-card img{width:100%;border-radius:14px;object-fit:cover;border:1px solid #e2e8f0;background:#fff}.auto-id-preview-card{flex:1 1 280px;max-width:360px;background:#f1f5f9;border-radius:18px;padding:1rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:var(--shadow-sm)}.auto-id-reader-panel{flex:1 1 440px;min-width:360px;background:#f8fafc;border-radius:18px;padding:1.2rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem}.auto-id-reader-header{display:flex;gap:1rem;align-items:center}.auto-id-reader-header img{width:132px;height:132px;object-fit:contain;border-radius:12px;background:#fff;border:1px solid #e2e8f0;padding:.5rem}.reader-label{margin:0;font-size:.85rem;color:var(--text-secondary, #94a3b8)}.auto-id-reader-actions{display:flex;flex-wrap:wrap;gap:.6rem}.auto-id-reader-log{border:1px dashed rgba(148,163,184,.7);border-radius:12px;padding:.75rem 1rem;display:flex;flex-direction:column;gap:.2rem;background:#fff}.auto-id-reader-log p{margin:0;font-size:.85rem;color:var(--text-secondary, #94a3b8)}.auto-id-reader-log span{font-weight:600;color:var(--text-primary, #0f172a)}.auto-id-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.6rem}.auto-id-metrics div{background:#fff;border-radius:12px;padding:.6rem;box-shadow:var(--shadow-sm, 0 1px 2px rgba(0,0,0,.08));display:flex;flex-direction:column;gap:.2rem}.auto-id-metrics div.metric-ok{background:#10b98129;color:#065f46}.auto-id-metrics div.metric-bad{background:#ef444429;color:#991b1b}.auto-id-metrics span{font-size:.8rem;color:var(--text-secondary, #94a3b8)}.auto-id-details{flex:1 1 320px;display:flex;flex-direction:column;gap:.75rem}.auto-id-details h4{margin:0}.auto-id-details ul{margin:0 0 0 1.1rem;color:var(--text-secondary, #94a3b8)}.auto-id-guidance{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem .8rem;background:#f973161f;border-radius:10px;color:#c2410c;font-weight:600}.auto-id-actions{display:flex;flex-wrap:wrap;gap:.5rem}.help-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.help-tab{border:1px solid var(--border, #e2e8f0);border-radius:999px;padding:.4rem .9rem;background:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;font-weight:600;color:var(--text-secondary, #6c757d)}.help-tab.active{background:var(--primary-lighter, rgba(67, 97, 238, .15));color:var(--primary, #4361ee)}.help-content ul,.help-content ol{margin-left:1.25rem}.open-entries-table{width:100%;border-collapse:collapse}.open-entries-table th,.open-entries-table td{padding:.65rem;border-bottom:1px solid var(--border, #e2e8f0);text-align:left}.photo-viewer{text-align:center;display:flex;flex-direction:column;gap:.4rem}.photo-viewer img{width:100%;border-radius:16px;object-fit:cover;box-shadow:var(--shadow-md, 0 4px 6px rgba(0,0,0,.15))}.photo-fallback{min-height:240px;border-radius:16px;border:1px dashed var(--border, #e2e8f0);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--text-secondary, #94a3b8);background:#f8fafc}.photo-fallback p{margin:0;font-weight:600}.attendance-exit-content{display:flex;flex-direction:column;gap:.75rem}.attendance-exit-card{padding:.75rem 1rem;border-radius:12px;border:1px solid var(--border, #e2e8f0);background:#f8fafc;display:flex;flex-direction:column;gap:.15rem}.attendance-exit-card strong{font-size:1rem}.attendance-exit-card small{color:var(--text-secondary, #64748b)}.attendance-exit-warning{margin:0;font-weight:600;color:#b45309}.attendance-exit-actions{display:flex;justify-content:flex-end;gap:.5rem}.observation-form{display:flex;flex-direction:column;gap:.8rem}.observation-header{display:flex;flex-direction:column;gap:.25rem}.open-entries-subtitle{color:var(--text-secondary, #94a3b8);margin-bottom:.5rem}@media (max-width: 720px){.attendance-toolbar{flex-direction:column;align-items:flex-start}.attendance-warning{width:100%;justify-content:space-between}.auto-id-workspace{flex-direction:column}.auto-id-camera-panel,.auto-id-preview-card{min-width:100%}}.justifications-module{display:flex;flex-direction:column;gap:1.5rem}.justifications-toolbar{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;align-items:center}.justifications-actions{display:flex;flex-wrap:wrap;gap:.5rem}.justifications-status-summary{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .9rem;border-radius:12px;background:#3b82f61f;color:#1d4ed8;font-weight:600}.justifications-query-box,.justifications-table-section{background:#fff;border-radius:16px;box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1));padding:1.25rem}.justifications-filter-stack{display:flex;flex-direction:column;gap:1rem}.justifications-filter-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.justifications-filter-row.secondary{grid-template-columns:minmax(180px,1fr) minmax(220px,2fr) minmax(160px,auto);align-items:end}.justifications-date-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.justifications-query-form .filter-actions{display:flex;flex-wrap:wrap;gap:.6rem;margin-left:auto;padding-left:.5rem;align-items:flex-end}.justifications-query-form .filter-actions.stacked{flex-direction:column;align-items:stretch;min-width:160px}.justifications-table-section{padding:1rem}.justification-employee{display:flex;flex-direction:column;gap:.2rem}.justification-hours{font-size:.85rem;color:var(--text-secondary, #94a3b8)}.justification-actions{display:inline-flex;gap:.35rem}.justification-form{display:flex;flex-direction:column;gap:.75rem}.justification-employee-picker{display:flex;flex-direction:column;gap:.35rem}.justification-employee-trigger{display:inline-flex;align-items:center;justify-content:space-between;gap:.75rem;width:100%;padding:.65rem .75rem;border-radius:12px;border:1px solid var(--border, #e2e8f0);background:#f8fafc;color:var(--text-primary, #0f172a);font-weight:600}.justification-employee-trigger:hover{border-color:var(--primary, #4361ee)}.justification-picker-search{margin-bottom:.75rem}.justification-picker-list{display:grid;gap:.75rem;max-height:360px;overflow:auto;padding-right:.25rem}.justification-picker-item{display:grid;grid-template-columns:auto 1fr;gap:.75rem;align-items:center;padding:.65rem .75rem;border-radius:14px;border:1px solid var(--border, #e2e8f0);background:#f8fafc}.justification-picker-item input{width:18px;height:18px}.justification-picker-item strong{display:block;margin-bottom:.2rem}.justification-picker-item p{margin:0;color:var(--text-secondary, #64748b);font-size:.85rem}.justification-picker-item small{color:var(--text-secondary, #94a3b8)}.justification-picker-empty{color:var(--text-secondary, #94a3b8);text-align:center}.justification-picker-footer{display:flex;justify-content:space-between;align-items:center;gap:1rem}.justification-picker-count{font-weight:600}.justification-picker-actions{display:flex;gap:.5rem}.justification-shifts-block{display:grid;gap:.6rem;margin:.75rem 0 1rem}.st-textarea{border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:.75rem;font-family:inherit;font-size:.95rem;background:#f8fafc}.st-textarea:focus{border-color:var(--primary, #4361ee);outline:3px solid rgba(67,97,238,.12);background:#fff}.justification-hint{display:inline-flex;align-items:center;gap:.35rem;font-size:.9rem;color:var(--text-secondary, #94a3b8)}.justification-modal-footer{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem}.form-error-text{color:#b91c1c;font-weight:600}.justification-modal-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.justification-detail{display:flex;flex-direction:column;gap:1rem}.justification-detail-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.justification-detail-summary p{margin:0;color:var(--text-secondary, #94a3b8)}.justification-detail-summary strong{font-size:1.1rem}.justification-detail-body h4{margin:.5rem 0 .25rem}.justification-shifts{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}.justification-shifts li{border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:.65rem .75rem;background:#f8fafc;display:grid;gap:.25rem}.justification-shift-option{display:grid}.justification-shift-label{display:grid;grid-template-columns:18px 1fr;gap:.65rem;align-items:start;cursor:pointer}.justification-shift-label input{margin-top:.2rem}.justification-shift-label span{display:grid;gap:.2rem}.justification-shifts span{font-size:.85rem;color:var(--text-secondary, #64748b)}.justification-shifts small,.justification-empty{color:var(--text-secondary, #94a3b8)}.justification-attachment{text-align:center;display:flex;flex-direction:column;gap:.4rem}.justification-attachment img{width:100%;border-radius:16px;object-fit:cover;box-shadow:var(--shadow-md, 0 4px 6px rgba(0,0,0,.15))}@media (max-width: 720px){.justifications-toolbar{flex-direction:column;align-items:flex-start}.justifications-filter-row.secondary{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.justifications-query-form .filter-actions.stacked{width:100%}}.schedules-module{display:flex;flex-direction:column;gap:1.5rem}.schedules-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;border:1px solid var(--border, #e2e8f0);border-radius:16px;background:#fff;box-shadow:var(--shadow-sm)}.schedules-actions{display:inline-flex;flex-wrap:wrap;gap:.75rem}.schedules-status-summary{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .9rem;border-radius:999px;background:#4361ee1a;color:var(--primary, #4361ee);font-weight:600}.schedules-query-box,.schedules-table-section{border:1px solid var(--border, #e2e8f0);border-radius:20px;padding:1.25rem;background:#fff;box-shadow:var(--shadow-sm)}.schedules-empty-state{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1rem 0;color:var(--text-secondary, #6c757d)}.schedules-filter-form{display:flex;flex-direction:column;gap:1.25rem}.schedule-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem 1.25rem}.schedules-filter-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.75rem}@media (max-width: 900px){.schedules-toolbar{flex-direction:column;align-items:flex-start}.schedules-actions{width:100%;justify-content:flex-start}.schedule-filter-grid{grid-template-columns:1fr}.schedules-filter-actions{justify-content:flex-start;width:100%}}.schedule-export-form{display:flex;flex-direction:column;gap:1rem}.schedule-export-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.schedule-export-picker{width:100%;border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:.55rem .75rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem;background:#f8fafc;cursor:pointer}.schedule-export-picker span{font-weight:600;color:var(--text-primary, #0f172a)}.schedule-export-note{font-size:.85rem;color:var(--text-secondary, #64748b);background:#f8fafc;border:1px dashed rgba(148,163,184,.6);padding:.6rem .8rem;border-radius:12px}.schedule-export-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.schedule-export-actions{display:inline-flex;gap:.75rem}.schedule-row-actions{display:inline-flex;gap:.35rem}.schedule-editor-form{display:flex;flex-direction:column;gap:1.25rem}.schedule-editor-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;padding:1rem;border-radius:16px;background:#f6f8ff;border:1px solid rgba(67,97,238,.15)}.summary-label{font-size:.8rem;color:var(--text-secondary, #94a3b8);margin-bottom:.1rem}.summary-value{font-weight:600;color:var(--text-primary, #0f172a)}.schedule-editor-panel{border:1px solid var(--border, #e2e8f0);border-radius:18px;padding:1.25rem;background:#fff;display:flex;flex-direction:column;gap:1rem;box-shadow:var(--shadow-xs)}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.panel-header-info{display:inline-flex;align-items:center;gap:.6rem;flex-wrap:wrap}.panel-header h4{margin:0;font-size:1rem;color:var(--text-primary, #0f172a)}.scope-pill{display:inline-flex;align-items:center;border-radius:999px;padding:.2rem .8rem;font-size:.85rem;font-weight:600;border:1px solid var(--border, #e2e8f0);background:#f8fafc}.scope-pill.scope-bulk{color:#0b6bcb;border-color:#0b6bcb4d;background:#0b6bcb1a}.scope-pill.scope-individual{color:#0f9d58;border-color:#0f9d5840;background:#0f9d581a}.bulk-selection textarea{min-height:110px}.layer-list{display:flex;flex-wrap:wrap;gap:.75rem}.layer-chip{border:1px solid var(--border, #e2e8f0);border-radius:14px;padding:.6rem .9rem;display:flex;align-items:center;gap:.65rem;cursor:pointer;background:#fff;min-width:190px;transition:border-color .2s ease,box-shadow .2s ease}.layer-chip.active{border-color:var(--primary, #4361ee);box-shadow:var(--shadow-sm)}.layer-chip strong{display:block;font-size:.95rem}.layer-chip small{color:var(--text-secondary, #94a3b8)}.layer-color{width:16px;height:16px;border-radius:50%;border:2px solid rgba(15,23,42,.08)}.layer-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.lane-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.75rem}.lane-card{border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:.75rem 1rem;background:#f8fafc;cursor:pointer;display:flex;flex-direction:column;gap:.35rem;transition:border-color .2s ease,box-shadow .2s ease}.lane-card header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.lane-card.active{border-color:var(--primary, #4361ee);box-shadow:var(--shadow-sm);background:#fff}.lane-card span{font-size:.85rem;color:var(--text-secondary, #94a3b8)}.lane-card.disabled{opacity:.6;border-style:dashed;cursor:not-allowed}.lane-card-note{font-size:.8rem;color:var(--text-secondary, #94a3b8)}.schedule-day-picker{display:flex;flex-wrap:wrap;gap:.5rem}.schedule-day-picker button{border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:.4rem .85rem;background:#fff;cursor:pointer;display:flex;flex-direction:column;gap:.15rem;min-width:70px;transition:border-color .2s ease,background .2s ease}.schedule-day-picker button.active{border-color:var(--primary, #4361ee);color:var(--primary, #4361ee);background:#4361ee14}.schedule-day-picker small{font-size:.7rem;color:var(--text-secondary, #94a3b8)}.schedule-timeline-board{border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:.75rem;background:#f8fafc;display:flex;flex-direction:column;gap:.5rem}.schedule-timeline-scale{position:relative;height:24px;font-size:.75rem;color:var(--text-secondary, #94a3b8)}.schedule-timeline-scale span{position:absolute;transform:translate(-50%)}.schedule-timeline-track{position:relative;border-radius:14px;background:#fff;overflow:hidden}.schedule-timeline-grid{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:repeat(48,1fr)}.schedule-timeline-grid .grid-slot{border-right:1px solid rgba(148,163,184,.15)}.schedule-timeline-block{position:absolute;height:70px;border-radius:12px;color:#fff;padding:.5rem 1rem .5rem .75rem;display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--shadow-md);cursor:default;-webkit-user-select:none;user-select:none}.schedule-timeline-label{font-weight:600;font-size:.9rem}.schedule-timeline-label span{display:block;font-weight:400;font-size:.8rem}.schedule-timeline-remove{position:absolute;top:6px;right:6px;border:none;background:#0f172a66;color:#fff;width:26px;height:26px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.schedule-timeline-remove:hover{background:#ef4444e6}.lane-timeline-stack{display:flex;flex-direction:column;gap:1.25rem}.lane-timeline{display:flex;flex-direction:column;gap:.65rem;border:1px solid rgba(67,97,238,.15);border-radius:16px;padding:.75rem 1rem;background:#f8fafc}.schedule-conflict-alert{margin-top:.75rem;display:flex;gap:.6rem;align-items:flex-start;padding:.65rem .85rem;border-radius:12px;background:#eab30829;border:1px solid rgba(234,179,8,.35);font-size:.9rem;color:#854d0e}.schedule-conflict-alert ul{margin:.25rem 0 0;padding-left:1.25rem}.lane-timeline header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.lane-timeline header strong{display:block;font-size:.95rem}.lane-timeline header small,.schedule-shift-table-wrapper{overflow-x:auto}.schedule-shift-table{width:100%;border-collapse:collapse;min-width:520px}.schedule-shift-table th,.schedule-shift-table td{border-bottom:1px solid rgba(15,23,42,.08);padding:.55rem;text-align:left}.schedule-shift-table input{width:100%;border:1px solid var(--border, #e2e8f0);border-radius:8px;padding:.35rem .45rem}.schedule-shift-table th:first-child,.schedule-shift-table td:first-child{width:25%}.schedule-shift-table td:first-child input{min-width:220px}.shift-delete{border:none;background:none;cursor:pointer;color:var(--danger, #e74c3c)}.empty-row{text-align:center;color:var(--text-secondary, #94a3b8)}.schedule-week-table-wrapper{overflow-x:auto}.schedule-week-table{width:100%;border-collapse:collapse;min-width:560px}.schedule-week-table.compact{min-width:unset}.schedule-week-table th,.schedule-week-table td{padding:.65rem;border-bottom:1px solid rgba(15,23,42,.08);text-align:left;font-size:.9rem}.schedule-week-table th{font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;color:var(--text-secondary, #94a3b8)}.schedule-week-table tr:last-child td{border-bottom:none}.schedule-editor-actions{display:inline-flex;gap:.75rem}.schedule-summary{display:flex;flex-direction:column;gap:1rem}.schedule-summary-notes{margin:0;padding:.75rem 1rem;background:#4361ee14;border-radius:12px;font-size:.9rem}.schedule-detail-helper{margin-top:.5rem;font-size:.85rem;color:var(--text-secondary, #64748b)}.schedule-detail-helper .schedule-submit-error{margin-top:.75rem;color:var(--st-color-danger, #dc2626);font-size:.9rem}.schedule-today-card{border:1px dashed rgba(67,97,238,.4);border-radius:14px;padding:.85rem 1rem;background:#4361ee0d}.schedule-today-card ul{list-style:none;padding:0;margin:.75rem 0 0;display:flex;flex-direction:column;gap:.35rem}.schedule-today-card li{display:flex;justify-content:space-between;font-size:.9rem;color:var(--text-primary, #0f172a)}.schedule-today-card .schedule-today-header{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;font-size:.9rem;color:var(--text-secondary, #475569)}.schedule-help-content ul{padding-left:1.25rem;margin:.5rem 0 1rem}.schedule-temporary-form{display:flex;flex-direction:column;gap:1rem}.schedule-temporary-form .temporary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.schedule-temporary-form .temporary-col{display:flex;flex-direction:column;gap:.75rem}.temporary-selection{display:flex;flex-direction:column;gap:.6rem}.temporary-selection-box{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;border:1px solid var(--border, #e2e8f0);border-radius:14px;background:#f8fafc}.temporary-selection-box strong{display:block;font-size:1.1rem}.temporary-selection-box p{margin:.15rem 0 0;color:var(--text-secondary, #94a3b8);font-size:.85rem}.temporary-selection-list{list-style:none;margin:0;padding:0;border:1px solid var(--border, #e2e8f0);border-radius:12px;max-height:180px;overflow-y:auto}.temporary-selection-list li{padding:.6rem .9rem;border-bottom:1px solid rgba(15,23,42,.08);display:flex;flex-direction:column;gap:.1rem}.temporary-selection-list li:last-child{border-bottom:none}.temporary-selection-list span{font-size:.85rem;color:var(--text-secondary, #94a3b8)}.temporary-selection-empty{margin:0;font-size:.9rem;color:var(--text-secondary, #94a3b8)}.time-pair{display:grid;grid-template-columns:repeat(2,minmax(120px,1fr));gap:.75rem}.schedule-help-content{display:flex;flex-direction:column;gap:.75rem}.schedule-detail-card{border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:1rem;background:#fff}.bulk-selection-modal{display:flex;flex-direction:column;gap:1rem}.bulk-selection-controls{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end;justify-content:space-between}.bulk-selection-list{border:1px solid var(--border, #e2e8f0);border-radius:16px;background:#fff;max-height:360px;overflow:hidden}.bulk-selection-list table{width:100%;border-collapse:collapse}.bulk-selection-list thead{background:#f8fafc;position:sticky;top:0;z-index:1;display:block}.bulk-selection-list th,.bulk-selection-list td{padding:.65rem .9rem;border-bottom:1px solid rgba(15,23,42,.08);text-align:left;font-size:.9rem}.bulk-selection-list tbody{display:block;max-height:300px;overflow-y:auto}.bulk-selection-list thead tr,.bulk-selection-list tbody tr{display:grid;grid-template-columns:60px repeat(4,minmax(120px,1fr))}.bulk-selection-list tbody tr:hover{background:#4361ee14}.bulk-selection-list input[type=checkbox]{width:16px;height:16px}.bulk-selection-footer{width:100%;display:flex;justify-content:space-between;align-items:center}@media (max-width: 720px){.schedules-toolbar{flex-direction:column;align-items:flex-start}.schedules-filter-actions{width:100%;justify-content:flex-end}.schedule-week-table,.schedule-shift-table{min-width:480px}}.biometric-enrollment-module{display:flex;flex-direction:column;gap:1.5rem}.enrollment-header{background:var(--surface, #fff);border-radius:16px;padding:1.25rem 1.5rem;box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1));display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;align-items:flex-start}.enrollment-header-label{font-size:.85rem;color:var(--text-secondary, #94a3b8);margin:0 0 .35rem}.enrollment-header-title{margin:0;font-size:1.5rem}.enrollment-header-hint{margin:.25rem 0 .9rem;font-size:.95rem;color:var(--text-secondary, #94a3b8)}.enrollment-labels{display:flex;flex-wrap:wrap;gap:.5rem}.enrollment-label{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .9rem;border-radius:999px;font-weight:600}.enrollment-label strong{font-size:1.1rem}.enrollment-label.success{background:#10b9812e;color:#047857}.enrollment-label.warning{background:#fbbf242e;color:#92400e}.enrollment-query-box,.enrollment-table-section{background:var(--surface, #fff);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1))}.enrollment-query-form{display:flex;flex-direction:column;gap:1rem}.enrollment-filter-stack{display:flex;flex-direction:column;gap:.9rem}.enrollment-filter-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(.6rem,1vw,1rem);align-items:flex-end}.enrollment-filter-row .filter-group{min-width:0}.enrollment-filter-actions{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:flex-end}.enrollment-help-body{display:flex;flex-direction:column;gap:.75rem}.enrollment-help-body ol{margin:0;padding-left:1.25rem;display:flex;flex-direction:column;gap:.35rem}.enrollment-cell{display:flex;flex-direction:column;gap:.2rem}.enrollment-cell .muted,.enrollment-progress span,.enrollment-header-hint{color:var(--text-secondary, #94a3b8)}.enrollment-chip{display:inline-flex;align-items:center;padding:.2rem .65rem;border-radius:999px;background:#4361ee1f;color:#4338ca;font-size:.8rem;font-weight:600}.enrollment-chip.warning{background:#fbbf242e;color:#92400e}.enrollment-chip.success{background:#10b9812e;color:#047857}.enrollment-methods{display:flex;flex-wrap:wrap;gap:.35rem}.enrollment-progress{display:flex;flex-direction:column;gap:.3rem}.enrollment-progress-track{width:160px;max-width:100%;height:8px;background:var(--border, #e2e8f0);border-radius:999px}.enrollment-progress-bar{height:100%;border-radius:999px;background:linear-gradient(90deg,#4361ee,#3b82f6)}.enrollment-actions{display:flex;gap:.4rem}.auto-id-feedback.danger{color:#dc2626}@media (max-width: 640px){.enrollment-header{flex-direction:column}.enrollment-filter-actions{flex-direction:column;align-items:stretch}.enrollment-filter-actions .st-button,.enrollment-progress-track{width:100%}}.hours-module{display:flex;flex-direction:column;gap:1.5rem}.hours-head{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;padding:1.25rem;border:1px solid var(--border, #e2e8f0);border-radius:18px;background:#fff;box-shadow:var(--shadow-sm);gap:1rem}.hours-head-copy h2{margin:0 0 .35rem;display:flex;align-items:center;gap:.4rem}.hours-head-copy p{margin:0 0 .5rem;color:var(--text-secondary, #64748b)}.hours-head-badge{display:inline-flex;align-items:center;gap:.35rem;font-weight:600;color:#0b6bcb;background:#0b6bcb1f;border-radius:999px;padding:.25rem .9rem}.hours-head-actions{display:flex;flex-wrap:wrap;gap:.75rem}.hours-quick-filters{display:flex;flex-wrap:wrap;gap:.5rem}.hours-quick-button{border:1px solid var(--border, #e2e8f0);border-radius:999px;padding:.45rem .9rem;background:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;font-weight:600;color:var(--text-secondary, #475569);transition:border-color .2s ease,background .2s ease}.hours-quick-button.active{border-color:var(--primary, #4361ee);color:var(--primary, #4361ee);background:#4361ee1f}.hours-filter-box,.hours-table-box,.hours-summary-grid{border:1px solid var(--border, #e2e8f0);border-radius:20px;background:#fff;padding:1.25rem;box-shadow:var(--shadow-sm)}.hours-filter-form{display:flex;flex-direction:column;gap:1rem}.hours-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.hours-filter-actions{display:flex;justify-content:flex-end;flex-wrap:wrap;gap:.75rem}.hours-employee-picker{width:100%;border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:.55rem .75rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem;background:#f8fafc;cursor:pointer}.hours-employee-picker span{font-weight:600;color:var(--text-primary, #0f172a)}.hours-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1rem}.hours-summary-card{display:flex;gap:.75rem;border:1px solid var(--border, #e2e8f0);border-radius:18px;padding:.9rem}.hours-summary-icon{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;color:var(--text-secondary, #475569)}.tone-primary .hours-summary-icon{color:#4361ee;background:#4361ee26}.tone-info .hours-summary-icon{color:#0ea5e9;background:#0ea5e926}.tone-warning .hours-summary-icon{color:#f59e0b;background:#f59e0b26}.tone-success .hours-summary-icon{color:#10b981;background:#10b98126}.tone-danger .hours-summary-icon{color:#ef4444;background:#ef444426}.tone-neutral .hours-summary-icon{color:#475569;background:#94a3b833}.hours-summary-copy h4{margin:0;font-size:.95rem}.hours-summary-value{margin:.15rem 0;font-size:1.25rem;font-weight:700}.hours-table-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.hours-empty-state{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary, #94a3b8)}.hours-employee-cell{display:flex;flex-direction:column;gap:.2rem}.hours-extra-cell{display:flex;flex-direction:column;gap:.25rem}.hours-extra-cell .st-status-label{font-size:.75rem;padding:.1rem .5rem;align-self:flex-start}.hours-picker-search{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.hours-picker-helpers{display:flex;gap:1rem;flex-wrap:wrap}.hours-picker-helpers button{border:none;background:none;color:var(--primary, #4361ee);font-weight:600;cursor:pointer}.hours-picker-list{max-height:360px;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.hours-picker-item{border:1px solid var(--border, #e2e8f0);border-radius:14px;padding:.65rem;display:flex;gap:.6rem;align-items:flex-start}.hours-picker-item input{margin-top:.35rem}.hours-picker-footer{display:flex;justify-content:space-between;align-items:center;gap:1rem}.hours-picker-count{font-weight:600}.civic-form{display:flex;flex-direction:column;gap:.9rem}.hours-extras-filters{border:1px solid var(--border, #e2e8f0);border-radius:18px;padding:1rem;background:#f8fafc;margin-bottom:1rem}.hours-extras-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.hours-extras-quick{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem}.hours-extras-status-buttons,.hours-extras-date-buttons{display:flex;flex-wrap:wrap;gap:.4rem}.hours-extras-status-buttons button,.hours-extras-date-buttons button{border:1px solid var(--border, #e2e8f0);border-radius:999px;padding:.35rem .8rem;background:#fff;cursor:pointer}.hours-extras-status-buttons button.active,.hours-extras-date-buttons button.active{border-color:var(--primary, #4361ee);color:var(--primary, #4361ee)}.hours-extras-bulk{border:1px dashed var(--primary, #4361ee);border-radius:14px;padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;background:#4361ee14}.hours-extras-bulk-actions{display:flex;gap:.5rem}.hours-extras-table{border:1px solid var(--border, #e2e8f0);border-radius:18px;padding:1rem;background:#fff}.hours-extras-table-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.hours-extras-actions{display:inline-flex;gap:.35rem}.hours-help-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.hours-help-tab{border:1px solid var(--border, #e2e8f0);border-radius:999px;padding:.45rem .9rem;background:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem}.hours-help-tab.active{border-color:var(--primary, #4361ee);color:var(--primary, #4361ee);background:#4361ee1f}.hours-help-content{border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:1rem;background:#f8fafc}@media (max-width: 768px){.hours-head{flex-direction:column}.hours-head-actions{width:100%;justify-content:flex-start}}.reports-module{display:flex;flex-direction:column;gap:1.5rem}.reports-head,.reports-filter-box,.reports-table-box{border:1px solid var(--border, #e2e8f0);border-radius:20px;background:#fff;padding:1.25rem;box-shadow:var(--shadow-sm)}.reports-head{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem}.reports-head-copy h2{margin:0;display:flex;align-items:center;gap:.4rem}.reports-head-copy p{margin:.35rem 0 .75rem;color:var(--text-secondary, #64748b)}.reports-head-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-start}.reports-head-badge{display:inline-flex;align-items:center;gap:.35rem;font-weight:600;color:#0b6bcb;background:#0b6bcb1f;border-radius:999px;padding:.25rem .9rem}.reports-quick-filters{display:flex;flex-wrap:wrap;gap:.5rem}.reports-quick-button{border:1px solid var(--border, #e2e8f0);border-radius:999px;padding:.4rem .85rem;background:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem;font-weight:600;color:var(--text-secondary, #475569)}.reports-quick-button.active{border-color:var(--primary, #4361ee);color:var(--primary, #4361ee);background:#4361ee1f}.reports-filter-form{display:flex;flex-direction:column;gap:1rem}.reports-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.reports-filter-actions{display:flex;justify-content:flex-end;gap:.75rem;flex-wrap:wrap}.reports-table-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.reports-table-caption{margin:.15rem 0 0;color:var(--text-secondary, #94a3b8)}.reports-employee-cell{display:flex;flex-direction:column;gap:.15rem}.reports-date-cell{display:flex;flex-direction:column}.reports-register-cell{display:flex;flex-direction:column;gap:.15rem}.reports-register-cell span{display:inline-flex;align-items:center;gap:.35rem}.reports-observations-text{margin:0;font-size:.9rem;line-height:1.4;color:var(--text-primary, #0f172a);white-space:pre-line}.reports-observations-empty{color:var(--text-secondary, #94a3b8)}.reports-status-cell{display:flex;flex-direction:column;gap:.25rem}.reports-status-badge{display:inline-flex;align-items:center;gap:.25rem;border-radius:999px;padding:.2rem .7rem;font-size:.8rem;font-weight:600}.reports-status-badge.status-success{background:#10b98126;color:#047857}.reports-status-badge.status-warning{background:#f59e0b26;color:#b45309}.reports-status-badge.status-danger{background:#ef444426;color:#b91c1c}.reports-actions{display:inline-flex}.reports-empty-state{display:inline-flex;align-items:center;gap:.4rem;color:var(--text-secondary, #94a3b8)}.reports-help-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.reports-help-tab{border:1px solid var(--border, #e2e8f0);border-radius:999px;padding:.4rem .9rem;background:#fff;cursor:pointer}.reports-help-tab.active{border-color:var(--primary, #4361ee);color:var(--primary, #4361ee);background:#4361ee1f}.reports-help-content{border:1px solid var(--border, #e2e8f0);border-radius:18px;padding:1rem;background:#f8fafc}.reports-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.reports-detail-card{border:1px solid var(--border, #e2e8f0);border-radius:18px;padding:1rem;background:#fff;display:flex;flex-direction:column;gap:.75rem}.reports-detail-card header{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.reports-detail-card dl{margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.5rem 1rem}.reports-detail-card dt{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary, #94a3b8)}.reports-detail-card dd{margin:0;font-weight:600;color:var(--text-primary, #0f172a)}.reports-detail-photo img{width:100%;border-radius:16px;object-fit:cover}.reports-detail-metrics{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem}.reports-detail-metrics li{border:1px solid var(--border, #e2e8f0);border-radius:14px;padding:.7rem;background:#f8fafc;display:grid;gap:.35rem}.reports-detail-metrics span{font-size:.8rem;color:var(--text-secondary, #94a3b8)}.reports-detail-metrics strong{font-size:1rem;color:var(--text-primary, #0f172a)}.reports-detail-metrics small{font-size:.75rem;color:var(--text-secondary, #64748b)}.reports-detail-metrics small{color:var(--text-secondary, #64748b)}.reports-detail-history,.reports-detail-justification-history{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}.reports-detail-history li,.reports-detail-justification-history li{border-left:3px solid var(--primary, #4361ee);padding-left:.75rem;background:#f8fafc;border-radius:12px;padding:.75rem .9rem;display:grid;gap:.35rem}.reports-detail-justification{border:1px dashed var(--primary, #4361ee);border-radius:12px;padding:.75rem;background:#4361ee14}.reports-detail-empty{text-align:center;color:var(--text-secondary, #94a3b8)}.reports-detail-footer{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}@media (max-width: 768px){.reports-head{flex-direction:column}.reports-head-actions{width:100%}}:root{--primary: #4361ee;--primary-dark: #3a56d4;--primary-light: #5c77f2;--primary-lighter: rgba(67, 97, 238, .1);--text-primary: #212529;--text-secondary: #6c757d;--surface: #FFFFFF;--background: #FFFFFF;--border: #dee2e6;--success: #2ecc71;--warning: #f39c12;--danger: #e74c3c;--danger-lighter: rgba(231, 76, 60, .1);--header-height: 70px;--sidebar-width: 260px;--sidebar-collapsed-width: 80px;--border-radius: 12px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--background);color:var(--text-primary);line-height:1.5;font-size:14px}.btn-primary{background:var(--primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;cursor:pointer;transition:all .3s ease}.btn-primary:hover{background:var(--primary-dark)}.btn-icon{background:none;border:none;padding:.5rem;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .3s ease}.btn-icon:hover{background:var(--primary-lighter);color:var(--primary)}.st-button{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;padding:.65rem 1.35rem;border-radius:999px;font-weight:600;cursor:pointer;text-decoration:none;border:1px solid transparent;letter-spacing:.01em;transition:background-color .2s ease,color .2s ease,box-shadow .2s ease,transform .2s ease}.st-primary{background:var(--primary, #2B7DE9);color:#fff;border-color:var(--primary, #2B7DE9);box-shadow:0 10px 25px #4361ee40}.st-secondary{background:#4361ee14;color:var(--primary, #2B7DE9);border-color:#4361ee47}.st-ghost{background:transparent;color:var(--text-primary);border-color:#0000000d}.st-icon{border:none;background:#4361ee1a;color:var(--primary, #2B7DE9)}.st-button.st-icon{width:42px;height:42px;padding:0;border-radius:50%}.st-sm{padding:.35em .8em;font-size:.86rem;border-radius:6px}.st-md{padding:.52em 1.2em;font-size:1rem;border-radius:8px}.st-lg{padding:.8em 1.6em;font-size:1.05rem;border-radius:10px}.st-block{width:100%;display:flex}.portal-card-cta{display:inline-flex;align-items:center;gap:.6rem;padding:.7rem 1.1rem;border-radius:999px;border:1px solid rgba(37,99,235,.25);font-weight:600;color:var(--portal-highlight, #2563eb);background:transparent}.st-button:focus{outline:3px solid rgba(79,126,226,.12);outline-offset:2px}.st-button:hover{transform:translateY(-2px);box-shadow:0 12px 30px #4361ee52}.st-button.st-secondary:hover{background:#4361ee2e}.st-button.st-ghost:hover{background:#0f172a0d}.st-button.st-icon:hover{background:#4361ee33}.st-button:active{transform:translateY(-1px)}.icon{display:inline-block;line-height:1;vertical-align:middle}.icon.icon-sm{font-size:.9rem}.icon.icon-md{font-size:1.05rem}.icon.icon-lg{font-size:1.3rem}.icon+.icon-label{margin-left:.5rem}.filter-group,.st-field{display:flex;flex-direction:column;gap:.35rem}.filter-label,.st-field-label{font-size:.85rem;color:var(--text-secondary);font-weight:600}.filter-input,.filter-select,.st-field-control{border:1px solid var(--border, #e2e8f0);border-radius:10px;background:#f8fafc;padding:.55rem .65rem;font-size:.95rem;width:100%;min-height:42px}.filter-input:focus,.filter-select:focus,.st-field-control:focus{border-color:var(--primary, #4361ee);outline:3px solid rgba(67,97,238,.12);outline-offset:2px;background:#fff}.filter-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background:var(--surface, #fff)}.filter-input{cursor:text}.st-field-message{font-size:.78rem;color:var(--text-secondary)}.st-field-message.is-error{color:var(--danger, #e74c3c)}.st-field-required{color:var(--danger, #e74c3c);margin-left:.25rem}.filter-row{display:flex;gap:.8rem;align-items:center}.btn-main{background:#2b7de9;color:#fff;border:none;border-radius:7px;padding:.52em 1.3em;font-size:1em;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.5em;transition:background .2s}.btn-main:hover,.btn-main:focus{background:#205bb5}.btn-secondary{background:#fff;color:#2b7de9;border:none;border-radius:7px;padding:.52em 1.3em;font-size:1em;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.5em}.btn-secondary:hover,.btn-secondary:focus{background:#f0f6fe}.btn-secondary:disabled{background:#f0f6fe;color:#2b7de9;cursor:not-allowed}.app-container{display:flex;min-height:100vh;position:relative}.sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;background:var(--surface);box-shadow:var(--shadow-lg);transition:all .3s ease;z-index:1000;display:flex;flex-direction:column;overflow-y:auto;transform-origin:left;will-change:transform}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a59;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:900}.sidebar-overlay.active{opacity:1;pointer-events:auto}.sidebar.collapsed{width:80px;transform:translate(0)}.main-wrapper{flex:1;display:flex;flex-direction:column;margin-left:var(--sidebar-width);transition:all .3s ease;width:calc(100% - var(--sidebar-width));min-width:0}.main-wrapper.sidebar-collapsed{margin-left:80px;width:calc(100% - 80px)}.sidebar-header{height:70px;display:flex;align-items:center;padding:0 5px}.logo-container{display:flex;align-items:center;gap:10px;width:100%}.logo-container img{width:90px;height:50px;object-fit:contain}.logo-text{font-size:20px;font-weight:600;color:var(--text-primary);white-space:nowrap;opacity:1;transition:all .3s ease}.sidebar.collapsed .logo-text{opacity:0;width:0}.nav-menu{padding:10px 0}.nav-section{margin-bottom:10px}.nav-section-title{padding:10px 20px;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);white-space:nowrap;transition:all .3s ease}.sidebar.collapsed .nav-section-title{opacity:0}.nav-items{list-style:none;padding:0;margin:0}.nav-item{position:relative}.nav-link{display:flex;align-items:center;padding:12px 20px;color:var(--text-primary);text-decoration:none;transition:all .3s ease}.nav-link i{min-width:24px;font-size:20px;color:var(--text-primary);transition:all .3s ease}.nav-link span{margin-left:12px;white-space:nowrap;opacity:1;transition:all .3s ease}.sidebar.collapsed .nav-link span{opacity:0;width:0}.nav-link:hover,.nav-link.active{background:var(--primary-lighter);color:var(--primary)}.nav-link:hover i,.nav-link.active i{color:var(--primary)}.nav-link.active{background:var(--primary-lighter, #f0f6fe);color:var(--primary, #2B7DE9);font-weight:600}.nav-link.active i{color:var(--primary, #2B7DE9)}.header{position:sticky;top:0;width:100%;background:var(--surface);border-bottom:1px solid rgba(15,23,42,.05);box-shadow:var(--shadow-sm);z-index:900}.header-content{display:flex;align-items:center;justify-content:space-between;gap:clamp(12px,2vw,40px);min-height:var(--header-height, 70px);width:100%;padding:0 clamp(16px,3vw,64px)}.header-left{display:flex;align-items:center;gap:clamp(12px,1.5vw,24px);min-width:0}.toggle-sidebar{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:none;background:var(--primary-lighter);color:var(--primary);border-radius:8px;cursor:pointer;transition:all .3s ease}.toggle-sidebar:hover{background:var(--primary);color:#fff}.toggle-sidebar i{font-size:20px}.header-right{display:flex;align-items:center;justify-content:flex-end;gap:clamp(12px,1.5vw,28px);flex:1}.system-info{display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:flex-end}.datetime-display{display:flex;align-items:center;gap:12px;background:var(--primary-lighter);padding:8px 16px;border-radius:8px;font-family:Roboto Mono,monospace}.datetime-display i{color:var(--primary)}#currentDateTime{color:var(--primary);font-weight:500}.user-dropdown{position:relative;display:flex;align-items:center}.user-dropdown-menu,.user-dropdown-panel{position:absolute;right:0;top:calc(100% + 8px);z-index:1200}.user-info{display:flex;align-items:center;gap:8px;background:var(--primary-lighter);padding:8px 16px;border-radius:8px;color:var(--primary);border:none;cursor:pointer;font:inherit;outline:none;transition:background .2s;position:relative}.user-info .dropdown-arrow{font-size:1rem;color:var(--primary);transition:transform .2s}.user-info.active .dropdown-arrow,.user-dropdown.open .dropdown-arrow{transform:rotate(-180deg)}.user-menu{display:none;position:absolute;top:100%;right:0;margin-top:6px;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 16px #2c3e501f;min-width:170px;z-index:3000;padding:.5rem 0;animation:dropdownIn .18s cubic-bezier(.41,1.01,.87,1.02)}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.user-dropdown.open .user-menu{display:block}.user-menu a.logout-btn{display:flex;align-items:center;gap:10px;color:var(--danger, #e53e3e);padding:10px 20px;text-decoration:none;background:none;border:none;font:inherit;width:100%;cursor:pointer;transition:background .2s}.user-menu a.logout-btn:hover{background:var(--primary-lighter)}.user-info i{color:var(--primary)}.user-name{color:var(--primary);font-weight:500}.main-content{padding:24px;transition:all .3s ease}@media (max-width: 1024px){.sidebar{transform:translate(-100%);position:fixed;height:100vh;overflow-y:auto}.sidebar.collapsed{transform:translate(-100%)}.main-wrapper,.main-wrapper.sidebar-collapsed{margin-left:0;width:100%}.sidebar.mobile-active{transform:translate(0);width:260px}.sidebar-overlay.active{opacity:1}}@media (max-width: 768px){.header-content{flex-direction:column;align-items:stretch;padding:0 16px 16px;gap:12px}.header-right,.system-info{width:100%;justify-content:space-between}.system-info{gap:8px;flex-wrap:nowrap;overflow-x:auto}.datetime-display{padding:6px 10px;font-size:.8rem;white-space:nowrap}.user-dropdown{flex-shrink:0}}@media (min-width: 1200px){.main-content{padding:32px 48px}.dashboard-container{width:100%;max-width:none;margin:0}}@media (min-width: 1600px){.main-content{padding:40px 72px}.dashboard-container{width:100%;max-width:none}}@media (max-width: 768px){.sidebar{width:100%;height:100vh;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.collapsed{transform:translate(-100%)}.main-wrapper,.main-wrapper.sidebar-collapsed{margin-left:0;width:100%}.sidebar.mobile-active{transform:translate(0);width:100%}}.activity-section{background:var(--surface);border-radius:var(--border-radius);box-shadow:var(--shadow-md);margin-top:2rem}.section-header{padding:1.5rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.section-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.table-container{overflow-x:auto}.activity-table{width:100%;border-collapse:separate;border-spacing:0}.activity-table thead th{background:var(--primary-lighter);color:var(--primary);font-weight:600;padding:1rem 1.5rem;text-align:left;border-bottom:2px solid var(--border)}.activity-table tbody td{padding:1rem 1.5rem;border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle}.activity-table tbody tr:hover{background:var(--primary-lighter)}.employee-column{display:flex;align-items:center;gap:.75rem}.employee-avatar{width:36px;height:36px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:500;font-size:1rem}.employee-details{display:flex;flex-direction:column}.employee-name{font-weight:500;color:var(--text-primary)}.employee-id{font-size:.875rem;color:var(--text-secondary)}.status-badge{display:inline-flex;align-items:center;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500}.status-badge.ontime{background:#48bb781a;color:#48bb78}.status-badge.late{background:#f6ad551a;color:#f6ad55}.status-badge i{margin-right:.5rem}.location-column{display:flex;align-items:center;gap:.5rem}.location-column i{color:var(--primary)}.configuration-module{display:flex;flex-direction:column;gap:1.5rem}.configuration-card{border:1px solid var(--border, #e2e8f0);border-radius:20px;background:#fff;padding:1.25rem;box-shadow:var(--shadow-sm)}.configuration-toolbar{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;align-items:center}.configuration-toolbar .toolbar-actions,.configuration-tabs{display:flex;flex-wrap:wrap;gap:.75rem}.configuration-tab{border:1px solid var(--border, #e2e8f0);border-radius:999px;padding:.4rem 1rem;background:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;font-weight:600;color:var(--text-secondary, #475569)}.configuration-tab.active{border-color:var(--primary, #4361ee);color:var(--primary, #4361ee);background:#4361ee1f}.configuration-table-head{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.75rem;align-items:center;margin-bottom:1rem}.configuration-table-head h3{margin:0}.configuration-table-actions{display:flex;flex-wrap:wrap;gap:.5rem}.configuration-selection-info{font-size:.9rem;color:var(--text-secondary, #64748b)}.configuration-filters{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.configuration-empty-state{display:inline-flex;align-items:center;gap:.4rem;color:var(--text-secondary, #94a3b8)}.password-card{max-width:540px;display:flex;flex-direction:column;gap:1rem}.password-message{margin:0;padding:.75rem 1rem;border-radius:12px;font-weight:600}.password-message.success{background:#22c55e1f;color:#15803d}.password-message.error{background:#f871711f;color:#b91c1c}.help-list{display:flex;flex-direction:column;gap:.75rem;margin:0;padding:0 1rem}.help-list li{line-height:1.5}.configuration-modal-form{display:flex;flex-direction:column;gap:1rem}@media (max-width: 768px){.configuration-toolbar,.configuration-table-head{flex-direction:column;align-items:flex-start}}
