@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;z-index:999;transition:width var(--transition);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.06);min-height:var(--header-height)}.brand-icon{width:40px;height:40px;border-radius:10px;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}.brand-icon img{width:100%;height:100%;display:block}.brand-text{color:#fff;font-size:1.25rem;font-weight:700;white-space:nowrap;letter-spacing:-.025em}.brand-content{display:flex;flex-direction:column;gap:.25rem;min-width:0}.brand-switches{display:flex;gap:.35rem}.brand-switch{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .5rem;font-size:.7rem;font-weight:600;color:var(--gray-400);background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:4px;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;letter-spacing:.02em;text-transform:uppercase}.brand-switch:hover:not(:disabled){color:var(--primary-light);background:#6366f126;border-color:#6366f14d}.brand-switch:disabled{opacity:.5;cursor:not-allowed}.brand-switch.switching{opacity:.6}.brand-switch.switching .brand-switch-icon{animation:spin .8s linear infinite}.brand-switch-icon{font-size:.8rem;flex-shrink:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:.5rem 0}.nav-section{margin-bottom:.25rem}.nav-section-title{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem 1.25rem;color:var(--gray-400);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;border:none;background:none;transition:color var(--transition-fast)}.nav-section-title:hover{color:var(--gray-300)}.nav-section-title.active{color:var(--primary-light)}.section-chevron{font-size:.85rem;transition:transform var(--transition-fast)}.section-chevron.expanded{transform:rotate(180deg)}.nav-section-divider{height:1px;background:#ffffff0f;margin:.5rem 1rem}.nav-items{overflow:hidden;transition:max-height var(--transition);max-height:600px}.nav-items.hidden{max-height:0}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.6rem 1.25rem;color:var(--sidebar-text);font-size:.9rem;font-weight:500;border-radius:0;margin:1px .5rem;border-radius:var(--border-radius-sm);transition:all var(--transition-fast);white-space:nowrap;text-decoration:none}.sidebar.collapsed .nav-item{justify-content:center;padding:.7rem;margin:1px .5rem}.nav-item:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active)}.nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-text-active)}.nav-item.active .nav-icon{color:var(--primary-light)}.nav-icon{font-size:1.25rem;flex-shrink:0}.nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-footer{border-top:1px solid rgba(255,255,255,.06);padding:.5rem 0}.logout-btn{width:calc(100% - 1rem);color:var(--sidebar-text)!important}.logout-btn:hover{color:var(--danger)!important;background:#ef44441a!important}@media(max-width:768px){.sidebar{transform:translate(-100%);width:var(--sidebar-width)!important}.sidebar.mobile-open{transform:translate(0)}}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:#fff;border-radius:16px;width:100%;max-width:420px;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-100)}.modal-header-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;flex-shrink:0}.modal-header h2{font-size:1.1rem;font-weight:700;color:var(--gray-900);flex:1}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);color:var(--gray-400);font-size:1.2rem;transition:all var(--transition-fast)}.modal-close:hover{background:var(--gray-100);color:var(--gray-700)}.modal-form{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.modal-field{display:flex;flex-direction:column;gap:.3rem}.modal-field label{font-size:.8rem;font-weight:600;color:var(--gray-600)}.modal-field input{padding:.6rem .85rem;border:1px solid var(--gray-200);border-radius:var(--border-radius-sm);background:var(--gray-50);font-size:.88rem;color:var(--gray-800);outline:none;transition:all var(--transition-fast)}.modal-field input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px var(--primary-50)}.modal-field input:disabled{opacity:.6;cursor:not-allowed}.modal-actions{display:flex;gap:.75rem;margin-top:.5rem}.modal-btn-cancel{flex:1;padding:.65rem;border:1px solid var(--gray-200);border-radius:var(--border-radius-sm);color:var(--gray-600);font-weight:600;font-size:.88rem;background:#fff;transition:all var(--transition-fast)}.modal-btn-cancel:hover{background:var(--gray-50);border-color:var(--gray-300)}.modal-btn-submit{flex:1;padding:.65rem;background:var(--primary);color:#fff;font-weight:600;font-size:.88rem;border-radius:var(--border-radius-sm);transition:all var(--transition-fast)}.modal-btn-submit:hover{background:var(--primary-dark)}.modal-btn-submit:disabled{opacity:.5;cursor:not-allowed}.modal-error{display:flex;align-items:center;gap:.5rem;padding:.6rem .85rem;background:#fee2e2;border:1px solid #fecaca;border-radius:var(--border-radius-sm);color:#991b1b;font-size:.82rem;font-weight:500}.modal-error svg{font-size:1.1rem;flex-shrink:0}.modal-success{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:2.5rem 1.5rem;color:#166534;font-size:1rem;font-weight:600}.modal-success svg{font-size:1.5rem}.header{height:var(--header-height);background:#fff;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}.header-left{display:flex;align-items:center;gap:1rem}.header-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);color:var(--gray-600);font-size:1.35rem;transition:all var(--transition-fast)}.header-btn:hover{background:var(--gray-100);color:var(--gray-800)}.menu-toggle-mobile{display:none}.header-title{font-size:1.35rem;font-weight:700;color:var(--gray-900)}.header-right{display:flex;align-items:center;gap:.75rem}.header-user{display:flex;align-items:center;gap:.6rem;padding:.35rem .75rem .35rem .35rem;border-radius:9999px;cursor:pointer;transition:background var(--transition-fast)}.header-user:hover{background:var(--gray-100)}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.9rem}.user-info{display:flex;flex-direction:column;line-height:1.2}.user-name{font-weight:600;font-size:.85rem;color:var(--gray-800)}.user-role{font-size:.7rem;color:var(--gray-400)}@media(max-width:768px){.menu-toggle-desktop{display:none}.menu-toggle-mobile{display:flex}.user-info{display:none}}.header-user-wrapper{position:relative}.user-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:200px;background:#fff;border:1px solid var(--gray-200);border-radius:12px;box-shadow:0 10px 25px -5px #0000001f,0 4px 10px -5px #0000000f;padding:.4rem;z-index:200;animation:dropdownIn .15s ease}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;align-items:center;gap:.6rem;width:100%;padding:.55rem .75rem;border-radius:8px;font-size:.85rem;font-weight:500;color:var(--gray-700);background:none;border:none;cursor:pointer;transition:all var(--transition-fast)}.dropdown-item:hover{background:var(--gray-100);color:var(--gray-900)}.dropdown-item svg{font-size:1.1rem;flex-shrink:0}.dropdown-item-danger{color:#dc2626}.dropdown-item-danger:hover{background:#fef2f2;color:#b91c1c}.dropdown-divider{height:1px;background:var(--gray-100);margin:.3rem .4rem}.layout{display:flex;min-height:100vh}.layout-main{flex:1;min-width:0;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition)}.layout.sidebar-collapsed .layout-main{margin-left:var(--sidebar-collapsed-width)}.layout-content{flex:1;min-width:0;padding:1.5rem;overflow-x:hidden;overflow-y:auto}.sidebar-overlay{display:none}@media(max-width:768px){.layout-main{margin-left:0!important}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:998;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-dark) 0%,#1e1e2d 100%);padding:1rem}.login-card{background:#fff;border-radius:16px;padding:2.5rem;width:100%;max-width:400px;box-shadow:0 25px 50px -12px #00000040}.login-brand{text-align:center;margin-bottom:2rem}.login-brand-icon{width:60px;height:60px;border-radius:16px;overflow:hidden;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.login-brand-icon img{width:100%;height:100%;display:block}.login-brand h1{font-size:1.5rem;color:var(--gray-900);margin-bottom:.25rem}.login-brand p{color:var(--gray-500);font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:.85rem;color:var(--gray-400);font-size:1.15rem;pointer-events:none}.input-wrapper input{width:100%;padding:.7rem .85rem .7rem 2.5rem;border:1px solid var(--gray-200);border-radius:var(--border-radius-sm);background:var(--gray-50);font-size:.9rem;color:var(--gray-800);outline:none;transition:all var(--transition-fast)}.input-wrapper input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px var(--primary-50)}.input-wrapper input::placeholder{color:var(--gray-400)}.login-btn{width:100%;padding:.75rem;background:var(--primary);color:#fff;font-weight:600;font-size:.95rem;border-radius:var(--border-radius-sm);transition:all var(--transition-fast);margin-top:.5rem}.login-btn:hover{background:var(--primary-dark);box-shadow:var(--shadow-md)}.login-btn:active{transform:scale(.98)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fee2e2;border:1px solid #fecaca;border-radius:var(--border-radius-sm);color:#991b1b;font-size:.85rem;font-weight:500;margin-bottom:.5rem}.login-error svg{font-size:1.2rem;flex-shrink:0}.login-change-pwd-link{display:flex;align-items:center;justify-content:center;gap:.4rem;background:none;border:none;color:var(--gray-500);font-size:.82rem;font-weight:500;cursor:pointer;padding:.4rem;border-radius:var(--border-radius-sm);transition:all var(--transition-fast)}.login-change-pwd-link:hover{color:var(--primary)}.login-change-pwd-link svg{font-size:.95rem}.loader-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.85rem;padding:3rem 1rem;color:var(--text-secondary)}.loader-spinner{width:34px;height:34px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:loader-spin .75s linear infinite}@keyframes loader-spin{to{transform:rotate(360deg)}}.loader-text{font-size:.85rem;font-weight:500;letter-spacing:.01em;color:var(--gray-500);animation:loader-pulse 1.5s ease-in-out infinite}@keyframes loader-pulse{0%,to{opacity:1}50%{opacity:.45}}.dashboard{display:flex;flex-direction:column;gap:1.5rem}.dashboard-welcome{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,var(--primary),var(--primary-dark))!important;color:#fff}.dashboard-welcome h2{font-size:1.3rem;margin-bottom:.25rem;color:#fff}.dashboard-welcome p{opacity:.85;font-size:.9rem;color:#fff}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{display:flex;align-items:center;gap:1rem}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700;color:var(--gray-900);line-height:1.2}.stat-label{font-size:.8rem;color:var(--gray-500);font-weight:500}.dashboard-actions h3{margin-bottom:1rem;font-size:1rem}.quick-actions{display:flex;gap:.75rem;flex-wrap:wrap}.quick-action-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:var(--primary-50);color:var(--primary-dark);border-radius:var(--border-radius-sm);font-size:.85rem;font-weight:600;transition:all var(--transition-fast)}.quick-action-btn:hover{background:var(--primary-100)}.quick-action-btn svg{font-size:1.1rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem}.dashboard-grid h3{font-size:1rem;margin-bottom:1rem;color:var(--gray-800)}.text-muted{color:var(--gray-400);font-size:.85rem}.city-list{display:flex;flex-direction:column;gap:.5rem}.city-item{display:flex;align-items:center;padding:.6rem 0;border-bottom:1px solid var(--gray-100)}.city-item:last-child{border-bottom:none}.city-info{display:flex;flex-direction:column}.city-name{font-weight:600;font-size:.9rem;color:var(--gray-800)}.city-meta{font-size:.78rem;color:var(--gray-400)}.recent-list{display:flex;flex-direction:column;gap:.5rem}.recent-item{display:flex;align-items:center;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid var(--gray-100)}.recent-item:last-child{border-bottom:none}.recent-info{display:flex;flex-direction:column}.recent-title{font-weight:600;font-size:.9rem;color:var(--gray-800)}.recent-meta{font-size:.78rem;color:var(--gray-400)}.recent-date{font-size:.78rem;color:var(--gray-500);white-space:nowrap}@media(max-width:768px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}}.schedule-page{display:flex;flex-direction:column;gap:1rem}.schedule-toolbar{display:flex;align-items:flex-end;gap:1rem;flex-wrap:wrap}.toolbar-selectors{display:flex;gap:.75rem;flex-wrap:wrap}.toolbar-group{display:flex;flex-direction:column;gap:.25rem}.toolbar-group label{font-size:.75rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em}.toolbar-group .form-control{min-width:180px}.toolbar-month{display:flex;align-items:center;gap:.5rem;margin-left:auto}.month-label{font-size:1.05rem;font-weight:700;color:var(--gray-800);min-width:160px;text-align:center}.toolbar-actions{display:flex;gap:.5rem}.schedule-content{display:grid;grid-template-columns:1fr 280px;gap:1rem}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--gray-200);border:1px solid var(--gray-200);border-radius:var(--border-radius-sm);overflow:hidden}.calendar-header{padding:.5rem;text-align:center;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--gray-50);color:var(--gray-600)}.calendar-header.weekend{color:var(--danger)}.calendar-cell{min-height:90px;padding:.35rem;background:#fff;cursor:pointer;transition:background var(--transition-fast);position:relative}.calendar-cell:hover{background:var(--primary-50)}.calendar-cell.empty{background:var(--gray-50);cursor:default}.calendar-cell.empty:hover{background:var(--gray-50)}.calendar-cell.weekend{background:#fff7ed}.calendar-cell.weekend:hover{background:#fed7aa}.cell-day{font-size:.75rem;font-weight:700;color:var(--gray-500);display:block;margin-bottom:.2rem}.calendar-cell.weekend .cell-day{color:var(--danger)}.cell-shifts{display:flex;flex-direction:column;gap:2px}.shift-chip{display:flex;align-items:center;justify-content:space-between;padding:.15rem .35rem;background:var(--primary-50);border:1px solid var(--primary-100);border-radius:4px;font-size:.7rem;color:var(--primary-dark);font-weight:500}.shift-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shift-delete{display:flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:3px;font-size:.6rem;color:var(--gray-400);flex-shrink:0;padding:0}.shift-delete:hover{color:var(--danger);background:#fee2e2}.schedule-sidebar h3{font-size:.95rem;margin-bottom:.75rem;color:var(--gray-800)}.employee-list{display:flex;flex-direction:column;gap:.25rem;max-height:600px;overflow-y:auto}.employee-item{display:flex;align-items:center;justify-content:space-between;padding:.45rem .6rem;border-radius:var(--border-radius-sm);transition:background var(--transition-fast)}.employee-item:hover{background:var(--gray-50)}.employee-item.employee-active{background:var(--primary-50);border-left:3px solid var(--primary)}.employee-item.employee-has-schedule{border-left:3px solid #16a34a}.employee-item.employee-active.employee-has-schedule{border-left:3px solid var(--primary)}.employee-info{display:flex;flex-direction:column;min-width:0}.employee-name{font-size:.82rem;font-weight:600;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.employee-meta{font-size:.7rem;color:var(--gray-400)}.shift-highlighted{background:var(--primary)!important;color:#fff!important;box-shadow:0 0 0 2px var(--primary-light)}.shift-highlighted .shift-name{color:#fff!important}.shift-dimmed{opacity:.3}.employee-count{font-size:.82rem;font-weight:700;color:var(--gray-600);flex-shrink:0;padding:.15rem .5rem;border-radius:9999px;background:var(--gray-100)}.employee-count.over{background:#fee2e2;color:#991b1b}.employee-count.under{background:#fef3c7;color:#92400e}@media(max-width:900px){.schedule-content{grid-template-columns:1fr}.schedule-toolbar{flex-direction:column;align-items:stretch}.toolbar-month{margin-left:0;justify-content:center}}.emp-calendar-banner{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--primary-50);border:1px solid var(--primary-200);border-radius:8px;margin-bottom:.75rem;color:var(--primary-700);font-size:.9rem}.emp-calendar-banner .btn{flex-shrink:0;display:flex;align-items:center;gap:.3rem;font-size:.8rem;padding:.3rem .6rem}.emp-has-shift{background:var(--primary-50)!important;border-color:var(--primary-200)!important}.emp-shift-info{display:flex;flex-direction:column;gap:.15rem}.emp-shift-object{font-size:.75rem;font-weight:600;color:var(--primary-700);line-height:1.2}.emp-shift-coworkers{font-size:.65rem;color:var(--gray-500);line-height:1.2}@media(max-width:600px){.calendar-cell{min-height:60px}.shift-chip{font-size:.6rem;padding:.1rem .2rem}}.vacations-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.vacations-header h2{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;color:var(--gray-900)}.vacations-toolbar{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;margin-bottom:1rem}.vacations-toolbar .search-box{display:flex;align-items:center;gap:.5rem;flex:1;color:var(--gray-400)}.vacations-toolbar .search-box input{border:none;outline:none;flex:1;font-size:.9rem;background:transparent}.vacations-list{overflow-x:auto}.vacations-list .table{width:100%;border-collapse:collapse}.vacations-list .table th,.vacations-list .table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--gray-100);font-size:.9rem}.vacations-list .table th{font-weight:600;color:var(--gray-500);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.vacations-list .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--gray-400);gap:.75rem}.vacations-list .empty-state svg{font-size:2.5rem}.badge{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge-success{background:#dcfce7;color:#16a34a}.badge-warning{background:#fef3c7;color:#d97706}.badge-danger{background:#fee2e2;color:#dc2626}.btn-icon{background:none;border:none;cursor:pointer;padding:.35rem;border-radius:.375rem;display:inline-flex;align-items:center;font-size:1.1rem;transition:background .15s}.btn-danger-icon{color:var(--gray-400)}.btn-danger-icon:hover{color:#dc2626;background:#fee2e2}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{width:100%;max-width:480px;padding:1.5rem}.modal h3{margin-bottom:1.25rem;font-size:1.15rem;font-weight:700}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.35rem;font-size:.85rem;font-weight:600;color:var(--gray-700)}.form-group input,.form-group select{width:100%;padding:.5rem .75rem;border:1px solid var(--gray-200);border-radius:.5rem;font-size:.9rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.reports-header{margin-bottom:1.5rem}.reports-header h2{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;color:var(--gray-900)}.reports-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;margin-bottom:1.5rem}.report-card{padding:1.25rem;cursor:pointer;transition:border-color .15s,box-shadow .15s;border:2px solid transparent}.report-card:hover{border-color:var(--primary-200, #c4b5fd)}.report-card.active{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50, #ede9fe)}.report-card h4{font-size:1rem;font-weight:700;margin-bottom:.35rem;color:var(--gray-900)}.report-card p{font-size:.85rem;color:var(--gray-500);margin:0}.report-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--gray-400);gap:.75rem;text-align:center}.report-placeholder svg{font-size:2.5rem}.report-placeholder p{font-size:.95rem}.emp-schedule-page{display:flex;flex-direction:column;gap:1rem}.emp-schedule-content{display:grid;grid-template-columns:1fr 220px;gap:1rem;align-items:start}.emp-calendar-banner{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--primary-50);border:1px solid var(--primary-200);border-radius:8px;color:var(--primary-700);font-size:.9rem}.emp-calendar-banner svg{font-size:1.2rem;flex-shrink:0}.emp-calendar-banner span{flex:1}.emp-city-group{margin-bottom:.75rem}.emp-city-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-400);padding:.25rem .5rem;margin-bottom:.25rem}.emp-city-group .employee-item{display:block;padding:.4rem .5rem;border-radius:6px;text-decoration:none;color:var(--gray-700);font-size:.82rem;transition:background .15s}.emp-city-group .employee-item:hover{background:var(--gray-50)}.emp-city-group .employee-item.employee-active{background:var(--primary-50);color:var(--primary-700);font-weight:600;border-left:3px solid var(--primary-500)}.emp-city-group .employee-item.employee-has-schedule{border-left:3px solid #16a34a}.emp-city-group .employee-item.employee-active.employee-has-schedule{border-left:3px solid var(--primary-500)}@media(max-width:900px){.emp-schedule-content{grid-template-columns:1fr}}:root{--primary: #6366f1;--primary-light: #818cf8;--primary-dark: #4f46e5;--primary-50: #eef2ff;--primary-100: #e0e7ff;--accent: #f59e0b;--accent-light: #fbbf24;--accent-dark: #d97706;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--sidebar-width: 260px;--sidebar-collapsed-width: 72px;--sidebar-bg: #1e1e2d;--sidebar-text: #a2a3b7;--sidebar-text-active: #ffffff;--sidebar-hover: rgba(255, 255, 255, .06);--sidebar-active-bg: rgba(99, 102, 241, .15);--header-height: 64px;--border-radius: 12px;--border-radius-sm: 8px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--transition-fast: .15s ease;--transition: .25s ease;--border: var(--gray-200);--card-bg: #ffffff;--bg: #ffffff;--bg-primary: #ffffff;--bg-secondary: var(--gray-50);--bg-hover: var(--gray-100);--text: var(--gray-800);--text-primary: var(--gray-700);--text-secondary: var(--gray-500);--text-muted: var(--gray-400)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--gray-100);color:var(--gray-800);line-height:1.6;min-height:100vh;margin:0}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;background:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;appearance:textfield}.page-toolbar,.page-actions{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--border-radius);padding:.75rem 1rem}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.card{background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow);padding:1.5rem}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;letter-spacing:.025em}.badge-success{background:#dcfce7;color:#166534}.badge-danger{background:#fee2e2;color:#991b1b}.badge-warning{background:#fef3c7;color:#92400e}.badge-info{background:#dbeafe;color:#0c4a6e}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:var(--border-radius-sm);font-size:.85rem;font-weight:600;transition:all var(--transition-fast)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#16a34a}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-secondary{background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-200)}.btn-secondary:hover{background:var(--gray-200)}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.85rem;font-weight:600;color:var(--gray-700)}.form-control{padding:.6rem .85rem;border:1px solid var(--gray-200);border-radius:var(--border-radius-sm);background:var(--gray-50);font-size:.88rem;color:var(--gray-800);outline:none;transition:all var(--transition-fast)}.form-control:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px var(--primary-50)}.form-control:disabled{opacity:.6;cursor:not-allowed}.data-table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.85rem}.data-table th{background:var(--gray-50);padding:.65rem .85rem;text-align:left;font-weight:600;color:var(--gray-600);border-bottom:2px solid var(--gray-200);white-space:nowrap}.data-table td{padding:.6rem .85rem;border-bottom:1px solid var(--gray-100);color:var(--gray-700)}.data-table tr:hover td{background:var(--gray-50)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:var(--gray-400);text-align:center}.empty-state svg{font-size:2.5rem;margin-bottom:.75rem}.empty-state p{font-size:.9rem;font-weight:500}
