*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2563eb;--primary-dark: #1e40af;--success: #16a34a;--danger: #dc2626;--warning: #f59e0b;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;color:var(--gray-800);background:var(--gray-50)}.app{min-height:100vh;display:flex}.sidebar{width:260px;background:#fff;border-right:1px solid var(--gray-200);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100}.sidebar-header{padding:2rem 1.5rem;border-bottom:1px solid var(--gray-200)}.sidebar-header h2{font-size:1.25rem;font-weight:700;color:var(--gray-900)}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto;display:flex;flex-direction:column}.sidebar-nav-main{flex:1}.sidebar-nav-footer{border-top:1px solid var(--gray-200);padding-top:1rem}.user-profile-section{display:flex;align-items:center;gap:.75rem;padding:1rem .75rem;margin-bottom:.5rem;background:var(--gray-50);border-radius:.5rem;margin-left:.5rem;margin-right:.5rem}.user-profile-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.user-profile-info{flex:1;min-width:0}.user-profile-name{font-weight:600;font-size:.875rem;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-profile-email{font-size:.75rem;color:var(--gray-600);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav-btn.logout{color:var(--danger)}.sidebar-nav-btn.logout:hover{background:#fee2e2;color:var(--danger);border-left-color:var(--danger)}.sidebar-nav-btn{width:100%;padding:.875rem 1.5rem;background:transparent;border:none;cursor:pointer;font-size:.95rem;font-weight:500;color:var(--gray-700);transition:all .2s;display:flex;align-items:center;gap:.75rem;text-align:left;border-left:3px solid transparent}.sidebar-nav-btn:hover{background:var(--gray-50);color:var(--primary)}.sidebar-nav-btn.active{background:#eff6ff;border-left-color:var(--primary);color:var(--primary)}.sidebar-nav-btn svg{flex-shrink:0}.main-content{flex:1;margin-left:260px;padding:2rem;min-height:100vh;background:var(--gray-50)}.loading{text-align:center;padding:3rem;color:var(--gray-600);font-size:1.125rem}.loading-more{text-align:center;padding:1rem;color:var(--gray-600);font-size:.875rem;font-style:italic}.dashboard h2{font-size:1.5rem;font-weight:700;color:var(--gray-900);margin-bottom:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2.5rem}.stat-card{background:#fff;padding:1.75rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200);transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-card.active{border-color:var(--success);background:linear-gradient(135deg,#fff,#f0fdf4)}.stat-value{font-size:2.5rem;font-weight:700;color:var(--primary);line-height:1.2}.stat-card.active .stat-value{color:var(--success)}.stat-label{font-size:.95rem;color:var(--gray-600);margin-top:.5rem;font-weight:500}.top-employees{background:#fff;padding:2rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200)}.top-employees h3{font-size:1.25rem;font-weight:600;color:var(--gray-900);margin-bottom:1.25rem}.employees-list{display:flex;flex-direction:column;gap:.75rem}.employee-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--gray-50);border-radius:.5rem;border:1px solid var(--gray-200);transition:background .2s}.employee-item:hover{background:var(--gray-100)}.employee-item .rank{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--primary);color:#fff;border-radius:50%;font-weight:700;font-size:.875rem}.employee-item .name{flex:1;font-weight:500;color:var(--gray-800)}.employee-item .time{font-weight:600;color:var(--primary);font-size:1.125rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.section-header h2{font-size:1.5rem;font-weight:700;color:var(--gray-900)}.btn-primary{padding:.625rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:.95rem;font-weight:600;transition:background .2s}.btn-primary:hover{background:var(--primary-dark)}.btn-refresh{padding:.625rem 1.25rem;background:#fff;color:var(--gray-700);border:1px solid var(--gray-300);border-radius:.5rem;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s}.btn-refresh:hover{background:var(--gray-50);border-color:var(--gray-400)}.table-container{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200);overflow:hidden}.logs-table{width:100%;border-collapse:collapse}.logs-table thead{background:var(--gray-50);border-bottom:2px solid var(--gray-200)}.logs-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-700)}.logs-table td{padding:1rem;border-bottom:1px solid var(--gray-200);color:var(--gray-800)}.logs-table tbody tr:last-child td{border-bottom:none}.logs-table tbody tr:hover{background:var(--gray-50)}.logs-table tr.active-row{background:#fef3c7}.logs-table tr.active-row:hover{background:#fde68a}.logs-table tr.inactive-row{opacity:.6}.duration{display:inline-block;padding:.25rem .75rem;background:var(--gray-100);border-radius:.375rem;font-weight:600;color:var(--gray-700)}.status{display:inline-block;padding:.25rem .75rem;border-radius:.375rem;font-size:.875rem;font-weight:600}.status.active{background:#d1fae5;color:#065f46}.status.inactive{background:var(--gray-200);color:var(--gray-700)}.btn-small{padding:.375rem .75rem;background:#fff;color:var(--primary);border:1px solid var(--primary);border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.btn-small:hover{background:var(--primary);color:#fff}.btn-small.btn-success{border-color:var(--success);color:var(--success)}.btn-small.btn-success:hover{background:var(--success);color:#fff}.btn-small.btn-cancel{border-color:var(--gray-400);color:var(--gray-700)}.btn-small.btn-cancel:hover{background:var(--gray-100)}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.btn-edit-small{background:#fff;color:var(--primary);border:1px solid var(--primary)}.btn-edit-small:hover{background:var(--primary);color:#fff}.btn-delete-small{background:#fff;color:var(--danger);border:1px solid var(--danger)}.btn-delete-small:hover{background:var(--danger);color:#fff}.btn-group{display:flex;gap:.5rem}.time-input{padding:.375rem .5rem;border:1px solid var(--gray-300);border-radius:.375rem;font-size:.875rem}.empty-state{text-align:center;padding:3rem;color:var(--gray-600);font-size:1rem}.form{background:#fff;padding:2rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200);margin-bottom:2rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--gray-700);font-size:.95rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--gray-300);border-radius:.5rem;font-size:.95rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}code{background:var(--gray-100);padding:.25rem .5rem;border-radius:.25rem;font-family:Courier New,monospace;font-size:.875rem;color:var(--gray-800)}.locations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.location-card{background:#fff;border-radius:.75rem;overflow:hidden;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200);transition:all .3s}.location-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #00000026}.location-card.inactive{opacity:.6}.location-image{position:relative;width:100%;height:200px;overflow:hidden;background:var(--gray-100)}.location-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.location-card:hover .location-image img{transform:scale(1.05)}.location-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--gray-400);background:linear-gradient(135deg,var(--gray-100) 0%,var(--gray-200) 100%)}.location-status{position:absolute;top:.75rem;right:.75rem;padding:.375rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.location-status.active{background:#16a34ae6;color:#fff}.location-status.inactive{background:#6b7280e6;color:#fff}.location-content{padding:1.5rem}.location-content h3{font-size:1.25rem;font-weight:600;color:var(--gray-900);margin-bottom:.5rem}.location-address{color:var(--gray-600);font-size:.875rem;margin-bottom:1rem;display:flex;align-items:flex-start;gap:.25rem;min-height:2.5rem}.location-content h3.clickable{cursor:pointer;transition:color .2s}.location-content h3.clickable:hover{color:var(--primary)}.location-image.clickable{cursor:pointer}.location-actions{display:flex;gap:.5rem;flex-wrap:wrap}.location-actions .btn-small{flex:1;min-width:120px;justify-content:center}.btn-small.btn-view{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-small.btn-view:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.location-detail{max-width:1200px;margin:0 auto}.btn-back{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#fff;color:var(--gray-700);border:1px solid var(--gray-300);border-radius:.5rem;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s;margin-bottom:1.5rem}.btn-back:hover{background:var(--gray-50);border-color:var(--primary);color:var(--primary)}.employee-name-link{color:var(--primary);cursor:pointer;font-weight:500;text-decoration:underline;text-decoration-color:transparent;transition:all .2s}.employee-name-link:hover{text-decoration-color:var(--primary);color:var(--primary-dark)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-content.small{max-width:400px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--gray-200)}.modal-header h2{font-size:1.25rem;font-weight:600;color:var(--gray-900);margin:0}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--gray-500);cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .2s}.modal-close:hover{background:var(--gray-100);color:var(--gray-700)}.modal-content form{padding:1.5rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.btn-primary,.btn-secondary,.btn-danger{padding:.625rem 1.25rem;border-radius:.5rem;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.btn-secondary{background:#fff;border-color:var(--gray-300);color:var(--gray-700)}.btn-secondary:hover{background:var(--gray-50)}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c;border-color:#b91c1c}.form-group-checkbox{margin-bottom:1rem}.form-group-checkbox label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.form-group-checkbox input[type=checkbox]{width:1.25rem;height:1.25rem;cursor:pointer}.confirm-message{padding:1.5rem;color:var(--gray-700);line-height:1.6}.confirm-message strong{color:var(--gray-900);font-weight:600}.confirm-message small{color:var(--gray-600);font-size:.875rem}.reports-filters-card{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200);padding:1.5rem;margin-bottom:2rem}.reports-filters-row{display:flex;gap:1rem;align-items:flex-end;flex-wrap:nowrap}.multi-select{min-height:120px}.multi-select option{padding:.5rem;cursor:pointer}.multi-select option:checked{background:var(--primary);color:#fff}.location-report-section{margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid var(--gray-200)}.location-report-section:last-child{border-bottom:none}.reports-filters-row .form-group{display:flex;flex-direction:column}.btn-generate-report{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:.5rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;height:44px}.btn-generate-report:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 6px #2563eb4d}.btn-generate-report:disabled{opacity:.6;cursor:not-allowed}.btn-generate-report svg{flex-shrink:0}.btn-export{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;background:#fff;color:var(--primary);border:1px solid var(--primary);border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;height:44px}.btn-export:hover{background:var(--primary);color:#fff;transform:translateY(-1px);box-shadow:0 2px 4px #2563eb33}.btn-export svg{flex-shrink:0}.section-header-with-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header-with-actions h2{margin:0}.export-buttons{display:flex;gap:.5rem}.report-content{margin-top:2rem}.report-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-bottom:1.5rem}.report-header{background:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200);margin-bottom:1.5rem}.report-header h3{font-size:1.5rem;font-weight:600;color:var(--gray-900);margin-bottom:.5rem}.report-period{color:var(--gray-600);font-size:.95rem;margin-bottom:1rem}.report-total{color:var(--gray-700);font-size:1.1rem}.report-total strong{color:var(--primary);font-size:1.5rem;font-weight:700}.clickable-row{cursor:pointer;transition:background-color .2s}.clickable-row:hover{background-color:var(--gray-50)}.day-summary-cell{display:flex;align-items:center;gap:.5rem}.expand-icon{transition:transform .2s;color:var(--gray-500)}.expand-icon.expanded{transform:rotate(180deg)}.expanded-details td{padding:0!important;background-color:var(--gray-50);border-top:none!important}.day-details{padding:1.5rem}.loading-details,.no-details{padding:2rem;text-align:center;color:var(--gray-600)}.details-table{width:100%;border-collapse:collapse;background:#fff;border-radius:.5rem;overflow:hidden;box-shadow:0 1px 3px #0000000d}.details-table thead{background:var(--gray-100)}.details-table th{padding:.75rem 1rem;text-align:left;font-size:.875rem;font-weight:600;color:var(--gray-700);border-bottom:1px solid var(--gray-200)}.details-table tbody tr{border-bottom:1px solid var(--gray-200)}.details-table tbody tr:last-child{border-bottom:none}.details-table td{padding:1rem;font-size:.875rem;color:var(--gray-700)}.employee-info{display:flex;flex-direction:column;gap:.25rem}.employee-info strong{color:var(--gray-900);font-weight:600}.employee-info small{color:var(--gray-500);font-size:.75rem;font-family:Courier New,monospace}.duration-badge{display:inline-block;padding:.25rem .75rem;background:var(--primary);color:#fff;border-radius:.375rem;font-weight:600;font-size:.875rem}.settings-content{max-width:1200px}.settings-section{margin-bottom:3rem}.settings-section h3{font-size:1.25rem;font-weight:600;color:var(--gray-900);margin-bottom:.5rem}.settings-description{color:var(--gray-600);font-size:.95rem;margin-bottom:1.5rem}.settings-card{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200);overflow:hidden}.settings-item{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--gray-200)}.settings-item:last-child{border-bottom:none}.settings-item-info h4{font-size:1rem;font-weight:600;color:var(--gray-900);margin-bottom:.25rem}.settings-item-info p{font-size:.875rem;color:var(--gray-600)}.settings-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;padding:1.5rem}.settings-info-item{display:flex;flex-direction:column;gap:.25rem}.settings-info-label{font-size:.875rem;color:var(--gray-600);font-weight:500}.settings-info-value{font-size:1rem;color:var(--gray-900);font-weight:600}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;left:0;right:0;bottom:0;background-color:var(--gray-300);border-radius:28px;transition:background-color .2s ease}.toggle-slider:before{content:"";position:absolute;height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;border-radius:50%;transition:transform .2s ease}.toggle-switch input:checked+.toggle-slider{background-color:var(--primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.location-detail-header{display:flex;gap:2rem;margin-bottom:2rem;background:#fff;padding:2rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200)}.location-detail-image{flex-shrink:0;width:300px;height:200px;border-radius:.5rem;overflow:hidden}.location-detail-image img{width:100%;height:100%;object-fit:cover}.location-detail-info{flex:1}.location-title-row{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.location-detail-info h1{font-size:2rem;font-weight:700;color:var(--gray-900);margin:0}.location-detail-address{color:var(--gray-600);font-size:1rem;margin-bottom:1rem}.location-detail-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.section{margin-bottom:2rem}.section h2{font-size:1.5rem;font-weight:600;color:var(--gray-900);margin-bottom:1.5rem}.history-section{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200);padding:1.5rem}.history-section h2{font-size:1.25rem;font-weight:600;color:var(--gray-900);margin-bottom:1.5rem}.active-employees-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-bottom:2rem}.employee-badge{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200)}.employee-avatar{width:3rem;height:3rem;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem}.employee-info{flex:1}.employee-name{font-weight:600;color:var(--gray-900);margin-bottom:.25rem}.employee-card{font-size:.875rem;color:var(--gray-600);font-family:Courier New,monospace}.status-indicator{width:.75rem;height:.75rem;border-radius:50%;background:var(--success)}.status-indicator.active-pulse{animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 #16a34ab3}50%{opacity:.8;box-shadow:0 0 0 8px #16a34a00}}.employee-cell{display:flex;flex-direction:column;gap:.25rem}.employee-cell.clickable{cursor:pointer;transition:all .2s}.employee-cell.clickable:hover{color:var(--primary)}.employee-cell.clickable:hover strong{color:var(--primary);text-decoration:underline}.employee-cell strong{font-weight:600}.employee-cell small{font-size:.75rem;color:var(--gray-600);font-family:Courier New,monospace}.location-cell{display:flex;flex-direction:column;gap:.25rem}.location-cell small{font-size:.75rem;color:var(--gray-600)}.status.completed{background:var(--gray-200);color:var(--gray-700)}.manager-info{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0;padding:1rem;background:var(--gray-50);border-radius:.5rem;border:1px solid var(--gray-200)}.manager-item{display:flex;align-items:center;gap:.5rem;color:var(--gray-700);font-size:.95rem}.manager-item svg{color:var(--primary);flex-shrink:0}.manager-item a{color:var(--primary);text-decoration:none;font-weight:500}.manager-item a:hover{text-decoration:underline}.section-header-with-filters{margin-bottom:1.5rem}.section-header-with-filters h2{margin-bottom:1rem}.filters{display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end;padding:1.5rem;background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200)}.filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:180px}.filter-group label{font-size:.875rem;font-weight:500;color:var(--gray-700)}.filter-input{padding:.625rem .875rem;border:1px solid var(--gray-300);border-radius:.375rem;font-size:.95rem;color:var(--gray-800);transition:all .2s}.filter-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.search-group{flex:1;min-width:250px}.search-wrapper{position:relative}.search-input{width:100%;padding-right:2.5rem}.clear-search{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);width:1.5rem;height:1.5rem;border:none;background:var(--gray-300);color:var(--gray-700);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;line-height:1;transition:all .2s}.clear-search:hover{background:var(--gray-400)}.suggestions-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;background:#fff;border:1px solid var(--gray-200);border-radius:.375rem;box-shadow:0 4px 6px #0000001a;max-height:200px;overflow-y:auto;z-index:10}.suggestion-item{padding:.75rem 1rem;cursor:pointer;display:flex;flex-direction:column;gap:.25rem;transition:background .2s}.suggestion-item:hover{background:var(--gray-50)}.suggestion-item strong{color:var(--gray-900);font-weight:600}.suggestion-item small{color:var(--gray-600);font-size:.75rem;font-family:Courier New,monospace}.employee-profile{max-width:100%}.profile-card-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid var(--gray-200);margin-top:1rem}.btn-edit-profile,.btn-delete-profile{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem;border-radius:.5rem;border:1px solid;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-edit-profile{background:#fff;border-color:var(--gray-300);color:var(--gray-700)}.btn-edit-profile:hover{background:var(--gray-50);border-color:var(--primary);color:var(--primary)}.btn-delete-profile{background:#fff;border-color:var(--gray-300);color:var(--danger)}.btn-delete-profile:hover{background:#fee2e2;border-color:var(--danger)}.btn-edit,.btn-delete{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:.5rem;border:1px solid;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-edit{background:#fff;border-color:var(--gray-300);color:var(--gray-700)}.btn-edit:hover{background:var(--gray-50);border-color:var(--primary);color:var(--primary)}.btn-delete{background:#fff;border-color:var(--gray-300);color:var(--danger)}.btn-delete:hover{background:#fee2e2;border-color:var(--danger)}.employee-profile-grid{display:grid;grid-template-columns:1.5fr 1.8fr 2.4fr;gap:1.5rem;margin-bottom:2rem}.profile-info-card{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200);padding:1.5rem}.profile-info-content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem}.employee-profile-avatar{width:5rem;height:5rem;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.75rem;flex-shrink:0}.profile-info-details{width:100%}.profile-info-details h2{font-size:1.25rem;font-weight:600;color:var(--gray-900);margin-bottom:1rem}.profile-info-meta{display:flex;flex-direction:column;gap:.75rem}.profile-meta-item{display:flex;align-items:center;gap:.5rem;color:var(--gray-600);font-size:.875rem;justify-content:center}.profile-meta-item svg{flex-shrink:0}.profile-meta-item a{color:var(--primary);text-decoration:none}.profile-meta-item a:hover{text-decoration:underline}.stats-compact-card,.calendar-compact-card{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200);padding:1.5rem}.stats-compact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.stat-compact-item{text-align:center;padding:1rem;background:var(--gray-50);border-radius:.5rem}.stat-compact-value{font-size:1.75rem;font-weight:700;color:var(--primary);margin-bottom:.25rem}.stat-compact-label{font-size:.75rem;color:var(--gray-600);font-weight:500;text-transform:uppercase;letter-spacing:.025em}.calendar-compact-header{margin-bottom:1rem}.calendar-month-label{font-size:.875rem;font-weight:600;color:var(--gray-900);text-transform:capitalize}.calendar-header{display:flex;justify-content:space-between;align-items:center}.calendar-nav{background:none;border:none;color:var(--primary);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:.375rem;transition:background .2s}.calendar-nav:hover{background:var(--gray-100)}.calendar{border:1px solid var(--gray-200);border-radius:.5rem;padding:.5rem;background:var(--gray-50)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem;margin-bottom:.25rem;text-align:center;font-weight:600;font-size:.625rem;color:var(--gray-700)}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:.2rem;font-size:.625rem;font-weight:500;background:#fff;border:1px solid var(--gray-200);color:var(--gray-700);cursor:pointer;transition:all .2s}.calendar-day:hover:not(.empty){border-color:var(--primary);transform:scale(1.05)}.calendar-day.empty{background:transparent;border:none}.calendar-day.today{border:2px solid var(--primary);font-weight:700}.calendar-day.worked{background:#dcfce7;border-color:#86efac;color:#166534}.calendar-day.no-work{background:#fee2e2;border-color:#fca5a5;color:#991b1b}.calendar-day.selected{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:700}.calendar-day.in-range{background:#dbeafe;border-color:#93c5fd;color:#1e40af}.calendar-info{margin-top:.75rem;padding:.5rem;background:var(--gray-50);border-radius:.375rem;text-align:center;font-size:.75rem;color:var(--gray-700)}.selected-range{display:flex;align-items:center;justify-content:center;gap:.75rem;font-weight:500;color:var(--primary)}.btn-clear{padding:.25rem .75rem;font-size:.75rem;background:var(--primary);color:#fff;border:none;border-radius:.25rem;cursor:pointer;transition:background .2s}.btn-clear:hover{background:var(--primary-dark)}.selecting-range{color:var(--gray-600);font-style:italic}.no-selection{color:var(--gray-500)}.calendar-legend{display:flex;gap:.75rem;margin-top:.75rem;justify-content:center;padding-top:.75rem;border-top:1px solid var(--gray-200)}.legend-item{display:flex;align-items:center;gap:.25rem;font-size:.625rem;color:var(--gray-700)}.legend-color{width:.75rem;height:.75rem;border-radius:.15rem;border:1px solid}.legend-color.worked{background:#dcfce7;border-color:#86efac}.legend-color.no-work{background:#fee2e2;border-color:#fca5a5}.employee-profile-info h1{font-size:1.5rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem}.employee-profile-card{color:var(--gray-600);font-size:1rem;font-family:Courier New,monospace;margin-bottom:.5rem}.employee-phone{display:flex;align-items:center;gap:.5rem;color:var(--gray-700);font-size:.95rem;margin-bottom:1rem}.employee-phone svg{color:var(--primary);flex-shrink:0}.employee-phone a{color:var(--primary);text-decoration:none;font-weight:500}.employee-phone a:hover{text-decoration:underline}@media (max-width: 768px){.header .container,.container{padding:0 1rem}.header h1{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.table-container{overflow-x:auto}.logs-table{min-width:800px}.section-header{flex-direction:column;align-items:flex-start}.locations-grid{grid-template-columns:1fr}}.checkbox-group{display:flex;flex-direction:column;gap:.75rem;padding:.75rem;background:var(--gray-50);border-radius:.5rem;border:1px solid var(--gray-200)}.checkbox-label{display:flex;align-items:flex-start;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:.375rem;transition:background-color .2s}.checkbox-label:hover{background:#fff}.checkbox-label input[type=checkbox]{margin-top:.25rem;cursor:pointer;width:18px;height:18px;flex-shrink:0}.checkbox-label span{flex:1}.checkbox-label strong{display:block;color:var(--gray-900);margin-bottom:.125rem}.log-datetime{display:flex;flex-direction:column;gap:.125rem}.log-datetime strong{color:var(--gray-900)}.log-datetime small{color:var(--gray-600);font-size:.75rem}.log-user{display:flex;flex-direction:column;gap:.125rem}.log-user strong{color:var(--gray-900)}.log-user small{color:var(--gray-600);font-size:.75rem}.log-action{color:var(--gray-800);font-weight:500}.log-details{cursor:pointer}.log-details summary{color:var(--primary);font-size:.875rem;-webkit-user-select:none;user-select:none}.log-details pre{margin-top:.5rem;padding:.75rem;background:var(--gray-800);color:#10b981;border-radius:.375rem;font-size:.75rem;overflow-x:auto;max-width:400px}.text-muted{color:var(--gray-500)}.filters-card{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--gray-200);padding:1.5rem;margin-bottom:2rem}.filters-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;align-items:flex-end}.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706}.location-input-wrapper{position:relative;width:100%}.location-input-field{min-height:44px;padding:.5rem 2.5rem .5rem .75rem;background:#fff;border:1px solid var(--gray-300);border-radius:.5rem;cursor:pointer;display:flex;align-items:center;transition:all .2s;position:relative}.location-input-field:hover{border-color:var(--primary)}.location-input-field:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.location-chips{display:flex;flex-wrap:wrap;gap:.375rem;flex:1;min-height:24px;align-items:center}.placeholder-text{color:var(--gray-400);font-size:.875rem}.location-chip{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .5rem;background:var(--primary);color:#fff;border-radius:.25rem;font-size:.875rem;font-weight:500}.location-chip span{line-height:1}.chip-remove{display:flex;align-items:center;justify-content:center;width:16px;height:16px;padding:0;background:#fff3;color:#fff;border:none;border-radius:50%;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;line-height:1}.chip-remove:hover{background:#ffffff59}.dropdown-arrow{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);color:var(--gray-400);pointer-events:none}.location-dropdown{position:absolute;top:calc(100% + .25rem);left:0;right:0;background:#fff;border:1px solid var(--gray-300);border-radius:.5rem;box-shadow:0 4px 6px #0000001a;max-height:200px;overflow-y:auto;z-index:100}.location-dropdown-item{padding:.625rem .75rem;cursor:pointer;transition:background-color .15s;font-size:.875rem;color:var(--gray-800);display:flex;gap:.5rem;align-items:center}.location-dropdown-item:hover{background:var(--gray-50)}.location-dropdown-item:first-child{border-radius:.5rem .5rem 0 0}.location-dropdown-item:last-child{border-radius:0 0 .5rem .5rem}.location-dropdown-name{font-weight:500;color:var(--gray-900)}.location-dropdown-address{color:var(--gray-600);font-size:.8125rem}.location-dropdown-empty{padding:.75rem;text-align:center;color:var(--gray-500);font-size:.875rem;font-style:italic}.role-tags{display:flex;flex-wrap:wrap;gap:.375rem}.role-tag{display:inline-block;padding:.25rem .625rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:.375rem;font-size:.8125rem;font-weight:500;white-space:nowrap;cursor:help;box-shadow:0 2px 4px #667eea33;transition:transform .15s,box-shadow .15s}.role-tag:hover{transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.text-muted{color:var(--gray-500);font-style:italic;font-size:.875rem}.location-badge{display:inline-block;padding:.375rem .75rem;border-radius:.375rem;font-size:.8125rem;font-weight:500;white-space:nowrap}.location-all{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;box-shadow:0 2px 4px #11998e33}.location-limited{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;box-shadow:0 2px 4px #4facfe33}.users-manager-modern{padding:2rem;max-width:1200px;margin:0 auto}.users-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.users-header h2{margin:0 0 .5rem;font-size:2rem;font-weight:700;color:var(--gray-900)}.users-subtitle{margin:0;color:var(--gray-600);font-size:1rem}.btn-add-modern{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:.75rem;font-weight:600;font-size:1rem;cursor:pointer;box-shadow:0 4px 12px #2563eb4d;transition:all .2s}.btn-add-modern:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2563eb66}.users-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.users-stat-card{background:#fff;border-radius:1rem;padding:1.5rem;display:flex;align-items:center;gap:1.25rem;box-shadow:0 2px 8px #0000000d;transition:all .2s}.users-stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.users-stat-icon{width:56px;height:56px;border-radius:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.users-stat-icon.blue{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.users-stat-icon.green{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.users-stat-icon.red{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.users-stat-icon.purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.users-stat-details{flex:1}.users-stat-value{font-size:2rem;font-weight:700;color:var(--gray-900);line-height:1;margin-bottom:.25rem}.users-stat-label{font-size:.875rem;color:var(--gray-600);font-weight:500}.users-filters{background:#fff;border-radius:1rem;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000000d;display:flex;gap:1.5rem;flex-wrap:wrap;align-items:center}.users-search-box{flex:1;min-width:300px;position:relative;display:flex;align-items:center}.users-search-box svg{position:absolute;left:1rem;color:var(--gray-400)}.users-search-box input{width:100%;padding:.875rem 1rem .875rem 3rem;border:2px solid var(--gray-200);border-radius:.75rem;font-size:1rem;transition:all .2s}.users-search-box input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.users-filter-tabs{display:flex;gap:.5rem;background:var(--gray-100);padding:.375rem;border-radius:.75rem}.users-filter-tabs button{padding:.625rem 1.25rem;border:none;background:transparent;border-radius:.5rem;font-weight:600;font-size:.875rem;color:var(--gray-600);cursor:pointer;transition:all .2s;white-space:nowrap}.users-filter-tabs button:hover{color:var(--gray-900)}.users-filter-tabs button.active{background:#fff;color:#3b82f6;box-shadow:0 2px 4px #0000000d}.users-loading{text-align:center;padding:4rem 2rem}.spinner{width:48px;height:48px;border:4px solid var(--gray-200);border-top-color:#3b82f6;border-radius:50%;margin:0 auto 1rem;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.users-loading p{color:var(--gray-600);font-size:1rem}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.users-empty-state{grid-column:1 / -1;text-align:center;padding:4rem 2rem;background:#fff;border-radius:1rem;box-shadow:0 2px 8px #0000000d}.users-empty-state svg{color:var(--gray-300);margin-bottom:1.5rem}.users-empty-state h3{margin:0 0 .5rem;color:var(--gray-900);font-size:1.5rem}.users-empty-state p{margin:0;color:var(--gray-600)}.user-card{background:#fff;border-radius:1rem;box-shadow:0 2px 8px #0000000d;transition:all .2s;overflow:hidden;border:2px solid transparent}.user-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a;border-color:#3b82f6}.user-card.inactive{opacity:.7;background:var(--gray-50)}.user-card-header{padding:1.5rem;display:flex;align-items:center;gap:1rem;border-bottom:1px solid var(--gray-100)}.user-avatar{width:56px;height:56px;border-radius:1rem;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;flex-shrink:0}.user-card-info{flex:1;min-width:0}.user-card-info h3{margin:0 0 .25rem;font-size:1.125rem;font-weight:600;color:var(--gray-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-card-info p{margin:0;font-size:.875rem;color:var(--gray-600);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-status-badge{padding:.375rem .875rem;border-radius:.5rem;font-size:.8125rem;font-weight:600;white-space:nowrap}.user-status-badge.active{background:#dcfce7;color:#166534}.user-status-badge.inactive{background:#fee2e2;color:#991b1b}.user-card-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.user-card-section{display:flex;flex-direction:column;gap:.75rem}.user-card-section-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--gray-700)}.user-card-section-label svg{color:var(--gray-400)}.user-roles-list{display:flex;flex-wrap:wrap;gap:.5rem}.user-role-badge{padding:.375rem .75rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border-radius:.5rem;font-size:.8125rem;font-weight:500;cursor:help}.user-no-data{color:var(--gray-500);font-size:.875rem;font-style:italic}.user-locations-info{display:flex;align-items:center}.user-access-all{padding:.375rem .875rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:.5rem;font-size:.875rem;font-weight:500}.user-access-limited{padding:.375rem .875rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-radius:.5rem;font-size:.875rem;font-weight:500}.user-card-actions{padding:1rem 1.5rem;background:var(--gray-50);display:flex;gap:.75rem;border-top:1px solid var(--gray-100)}.user-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:none;border-radius:.5rem;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s}.user-btn-edit{background:#dbeafe;color:#1e40af}.user-btn-edit:hover{background:#bfdbfe}.user-btn-activate{background:#dcfce7;color:#166534}.user-btn-activate:hover{background:#bbf7d0}.user-btn-deactivate{background:#fef3c7;color:#92400e}.user-btn-deactivate:hover{background:#fde68a}.user-btn-delete{background:#fee2e2;color:#991b1b}.user-btn-delete:hover{background:#fecaca}.users-modal-overlay{position:fixed;top:0;right:0;bottom:0;left: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}.users-modal{background:#fff;border-radius:1rem;max-width:700px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.users-modal-header{padding:1.5rem 2rem;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between}.users-modal-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--gray-900)}.users-modal-close{width:40px;height:40px;border:none;background:var(--gray-100);border-radius:.5rem;color:var(--gray-600);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.users-modal-close:hover{background:var(--gray-200);color:var(--gray-900)}.users-modal-body{padding:2rem;overflow-y:auto;flex:1}.users-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.users-form-group{margin-bottom:1rem}.users-form-group:last-child{margin-bottom:0}.users-form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--gray-700);font-size:.875rem}.required{color:#dc2626}.users-form-group input{width:100%;padding:.875rem 1rem;border:2px solid var(--gray-200);border-radius:.5rem;font-size:1rem;transition:all .2s}.users-form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.users-roles-checkboxes{display:flex;flex-direction:column;gap:.75rem}.users-checkbox-card{display:flex;align-items:flex-start;gap:.875rem;padding:1rem;border:2px solid var(--gray-200);border-radius:.75rem;cursor:pointer;transition:all .2s}.users-checkbox-card:hover{border-color:#3b82f6;background:#f0f9ff}.users-checkbox-card.special{background:#f0fdf4;border-color:#10b981}.users-checkbox-card input[type=checkbox]{width:20px;height:20px;margin-top:.125rem;cursor:pointer;flex-shrink:0}.users-checkbox-content{display:flex;flex-direction:column;gap:.25rem;flex:1}.users-checkbox-content strong{font-size:.9375rem;color:var(--gray-900)}.users-checkbox-content span{font-size:.8125rem;color:var(--gray-600)}.users-checkbox-label{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--gray-50);border-radius:.5rem;cursor:pointer;margin-bottom:0}.users-checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer}.users-checkbox-label span{font-size:.9375rem;font-weight:600;color:var(--gray-700)}.users-locations-selection{display:flex;flex-direction:column;gap:1rem}.users-locations-list{max-height:240px;overflow-y:auto;border:2px solid var(--gray-200);border-radius:.75rem;padding:.5rem}.users-checkbox-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:.5rem;cursor:pointer;transition:all .2s}.users-checkbox-item:hover{background:#f0f9ff}.users-checkbox-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;flex-shrink:0}.users-location-item{display:flex;flex-direction:column;gap:.125rem;flex:1}.users-location-name{font-size:.9375rem;font-weight:600;color:var(--gray-900)}.users-location-address{font-size:.8125rem;color:var(--gray-600)}.users-form-hint{margin-top:.5rem;font-size:.875rem;color:var(--gray-600)}.users-modal-footer{padding:1.5rem 2rem;border-top:1px solid var(--gray-200);display:flex;gap:1rem;justify-content:flex-end}.users-btn-cancel{padding:.875rem 1.5rem;border:2px solid var(--gray-300);background:#fff;border-radius:.5rem;font-weight:600;font-size:1rem;color:var(--gray-700);cursor:pointer;transition:all .2s}.users-btn-cancel:hover{background:var(--gray-50);border-color:var(--gray-400)}.users-btn-save{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;border:none;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border-radius:.5rem;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #2563eb4d}.users-btn-save:hover{transform:translateY(-1px);box-shadow:0 6px 16px #2563eb66}@media (max-width: 768px){.users-manager-modern{padding:1rem}.users-header{flex-direction:column;gap:1rem}.btn-add-modern{width:100%}.users-filters{flex-direction:column;align-items:stretch}.users-search-box{min-width:auto}.users-grid,.users-form-row{grid-template-columns:1fr}.user-card-actions{flex-direction:column}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.login-card{background:#fff;border-radius:1rem;box-shadow:0 20px 60px #0000004d;padding:3rem;width:100%;max-width:450px}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.75rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem}.login-header p{font-size:.9375rem;color:var(--gray-600)}.login-card .form-group{margin-bottom:1.5rem}.login-card .form-group label{display:block;font-weight:600;color:var(--gray-700);margin-bottom:.5rem;font-size:.9375rem}.login-card .form-group input{width:100%;padding:.875rem 1rem;border:2px solid var(--gray-200);border-radius:.5rem;font-size:.9375rem;transition:all .2s;box-sizing:border-box}.login-card .form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.login-card .form-group input:disabled{background:var(--gray-100);cursor:not-allowed}.btn-login{width:100%;padding:.875rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.btn-login:disabled{opacity:.6;cursor:not-allowed}.btn-forgot-password{width:100%;padding:.75rem;background:transparent;color:#667eea;border:none;font-size:.9375rem;font-weight:500;cursor:pointer;margin-top:1rem;transition:all .2s}.btn-forgot-password:hover:not(:disabled){text-decoration:underline}.btn-forgot-password:disabled{opacity:.5;cursor:not-allowed}.btn-back-to-login{width:100%;padding:.75rem;background:#fff;color:var(--gray-700);border:2px solid var(--gray-300);border-radius:.5rem;font-size:.9375rem;font-weight:500;cursor:pointer;margin-top:1rem;transition:all .2s}.btn-back-to-login:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-400)}.btn-back-to-login:disabled{opacity:.5;cursor:not-allowed}.reset-message{padding:1rem;border-radius:.5rem;margin-bottom:1rem;font-size:.9375rem;font-weight:500}.reset-message.success{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.reset-message.error{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}@media (max-width: 768px){.login-card{padding:2rem}.login-header h1{font-size:1.5rem}}
