.inactivity-warning-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:10000;animation:fadeIn .3s ease-in}.inactivity-warning-modal{background:#fff;border-radius:12px;padding:2rem;max-width:400px;width:90%;box-shadow:0 10px 40px #0000004d;text-align:center;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.inactivity-warning-modal h2{margin:0 0 1rem;color:#d32f2f;font-size:1.5rem}.inactivity-warning-modal p{margin:.5rem 0;color:#333;font-size:1rem}.countdown{font-size:3rem;font-weight:700;color:#d32f2f;margin:1rem 0;font-family:Courier New,monospace}.warning-message{margin-top:1rem;color:#666;font-size:.9rem}.warning-actions{margin-top:2rem;display:flex;justify-content:center;gap:1rem}.stay-logged-in-btn{background:var(--primary, #007bff);color:#fff;border:none;padding:.75rem 2rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background .2s}.stay-logged-in-btn:hover{background:var(--primary-dark, #0056b3)}.stay-logged-in-btn:active{transform:scale(.98)}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:var(--spacing-lg);background-color:var(--gray-50)}.login-box{background:var(--white);padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:440px;border:1px solid var(--gray-200);animation:slideUp .4s ease-out}.login-box h1{color:var(--gray-900);margin-bottom:var(--spacing-sm);text-align:center;font-size:2rem;font-weight:700;letter-spacing:-.025em}.login-box h2{color:var(--gray-600);margin-bottom:var(--spacing-xl);text-align:center;font-weight:400;font-size:1rem}.form-group input{width:100%;padding:.875rem 1rem;border:2px solid var(--gray-200);border-radius:var(--radius-md);font-size:1rem;transition:all var(--transition-base);background:var(--white);color:var(--gray-900)}.login-box button{width:100%;padding:.875rem 1.5rem;background-color:var(--secondary);color:var(--white);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm);margin-top:var(--spacing-md)}.login-box button:hover:not(:disabled){background-color:var(--secondary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.login-box button:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.login-box button:disabled{opacity:.6;cursor:not-allowed;transform:none}.modal-content{background:var(--white);padding:var(--spacing-2xl);border-radius:var(--radius-lg);width:90%;max-width:520px;box-shadow:var(--shadow-lg);animation:slideUp .3s ease-out;border:1px solid var(--gray-200)}.modal-content h2{text-align:center;color:var(--gray-900);margin-bottom:var(--spacing-xl);font-size:1.75rem;font-weight:700;letter-spacing:-.025em}.form-group label{display:block;margin-bottom:var(--spacing-sm);color:var(--gray-700);font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.form-group input,.form-select{width:100%;padding:.875rem 1rem;border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:1rem;transition:all var(--transition-base);background:var(--white);color:var(--gray-900)}.form-group input:focus,.form-select:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px var(--secondary-50)}.form-group input::placeholder{color:var(--gray-400)}.form-select{cursor:pointer}.modal-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;margin-top:var(--spacing-xl)}.close-btn{background:var(--white);color:var(--gray-700);border:1px solid var(--gray-300);padding:.875rem 1.75rem;border-radius:var(--radius-md);cursor:pointer;font-size:1rem;font-weight:600;transition:all var(--transition-base)}.add-btn{background-color:var(--secondary);color:var(--white);border:none;padding:.875rem 1.75rem;border-radius:var(--radius-md);cursor:pointer;font-size:1rem;font-weight:600;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.add-btn:hover:not(:disabled){background-color:var(--secondary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.add-btn:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.add-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.dashboard{min-height:100vh;background-color:var(--gray-50)}.dashboard-header{background:var(--white);padding:var(--spacing-lg) var(--spacing-xl);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm);border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:100}.header-left h1{color:var(--gray-900);font-size:1.75rem;font-weight:700;margin:0;letter-spacing:-.025em}.header-nav{display:flex;gap:var(--spacing-sm)}.header-nav button{background:var(--white);color:var(--gray-700);border:1px solid var(--gray-300);padding:.625rem 1.25rem;border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;font-weight:500;transition:all var(--transition-base)}.header-nav button:hover{background:var(--gray-50);border-color:var(--gray-400);color:var(--gray-900)}.header-nav button:last-child{background-color:var(--error);color:var(--white);border-color:var(--error)}.header-nav button:last-child:hover{background-color:var(--error-dark)}.dashboard-main{max-width:100%;width:100%;margin:0 auto;padding:var(--spacing-xl);box-sizing:border-box}.dashboard-title{text-align:center;color:var(--gray-900);margin-bottom:var(--spacing-xl);font-size:2rem;font-weight:600;letter-spacing:-.025em}.dashboard-controls{display:flex;align-items:center;margin-bottom:var(--spacing-xl);gap:var(--spacing-md);background:var(--white);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);flex-wrap:nowrap;width:100%;box-sizing:border-box;overflow:hidden}.dashboard-controls>*{display:flex;align-items:center}.new-patient-btn{background-color:var(--secondary);color:var(--white);border:none;padding:.875rem 1.5rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;box-shadow:var(--shadow-sm);transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);white-space:nowrap;flex-shrink:0;flex-grow:0;width:fit-content;min-width:fit-content;height:42px;box-sizing:border-box;margin:0}.new-patient-btn span{font-size:1.25rem;font-weight:300;line-height:1}.new-patient-btn:hover{background-color:var(--secondary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.new-patient-btn:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.filter-container{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0;white-space:nowrap;height:100%}.filter-label{color:var(--gray-700);font-weight:600;white-space:nowrap;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center}.location-filter-select,.search-input{padding:.75rem 1rem;border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:.9375rem;background-color:var(--white);cursor:pointer;transition:all var(--transition-base);color:var(--gray-900);height:42px;box-sizing:border-box}.location-filter-select{min-width:140px;max-width:180px;width:auto}.search-container{flex:1;min-width:200px;max-width:100%;overflow:hidden;display:flex;align-items:center}.search-input{width:100%;cursor:text}.search-input::placeholder{color:var(--gray-400)}.location-filter-select:focus,.search-input:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px var(--secondary-50)}.patients-table-container{background:var(--white);border-radius:var(--radius-lg);overflow-x:auto;overflow-y:visible;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);width:100%;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.patients-table{width:100%;border-collapse:collapse;min-width:1200px;table-layout:auto}.patients-table thead{background-color:var(--primary);color:var(--white)}.patients-table th{padding:var(--spacing-lg);text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.patients-table th:first-child{min-width:140px}.patients-table td{padding:var(--spacing-lg);border-bottom:1px solid var(--gray-200);transition:background-color var(--transition-fast)}.patients-table td:first-child{font-weight:600;color:var(--gray-900)}.patient-id-btn{background:none;border:none;color:var(--primary);cursor:pointer;font-size:inherit;font-weight:600;padding:0;text-align:left;transition:all var(--transition-fast);text-decoration:underline;text-decoration-color:transparent}.patient-id-btn:hover{color:var(--secondary);text-decoration-color:var(--secondary)}.patients-table tbody tr{transition:all var(--transition-fast)}.patients-table tbody tr:nth-child(2n){background-color:var(--gray-50)}.patients-table tbody tr:hover{background-color:var(--gray-100)}.patients-table tbody tr:last-child td{border-bottom:none}.steps-cell{display:flex;gap:var(--spacing-md);flex-wrap:nowrap;align-items:center;overflow-x:auto;padding:var(--spacing-sm) 0;scrollbar-width:thin}.step-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);min-width:fit-content;flex-shrink:0}.step-button-wrapper,.step-text-wrapper{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);height:100%}.info-icon-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:var(--spacing-xs);line-height:1;opacity:.6;transition:all var(--transition-fast);color:var(--secondary);border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.info-icon-btn:hover{opacity:1;background:var(--secondary-50)}.step-btn{background:var(--secondary-50);color:var(--secondary-dark);border:1px solid var(--secondary-100);padding:.625rem 1rem;border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;font-weight:500;white-space:nowrap;min-width:fit-content;transition:all var(--transition-base);box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;justify-content:center;height:auto;line-height:1.4}.step-btn:hover:not(:disabled){background:var(--secondary-100);border-color:var(--secondary)}.step-btn.active{background-color:var(--secondary);color:var(--white);border-color:var(--secondary)}.step-btn.countdown{background-color:var(--error);color:var(--white);border-color:var(--error);animation:pulse-red 1s infinite;font-weight:600}.step-btn.countdown:hover{background-color:var(--error-dark)}.step-btn.overdue{background-color:var(--warning);color:var(--white);border-color:var(--warning);font-weight:600;animation:pulse-yellow 1.5s infinite}.step-btn.overdue:hover{background-color:#d97706}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.9}}@keyframes pulse-yellow{0%,to{opacity:1}50%{opacity:.9}}.step-btn:disabled{cursor:not-allowed;opacity:.5}.step-time{font-size:.75rem;color:var(--gray-500);white-space:nowrap;font-weight:500;text-align:center;line-height:1.2;margin-top:2px;min-height:1.2em;display:inline-block;min-width:60px}.step-time-placeholder{visibility:hidden;color:transparent}.step-time.overdue-time{color:var(--warning);font-weight:700}.step-text-disabled{background:var(--gray-100);color:var(--gray-500);border:1px solid var(--gray-200);padding:.625rem 1rem;border-radius:var(--radius-md);font-size:.875rem;white-space:nowrap;min-width:fit-content;text-align:center;font-weight:500;display:inline-flex;align-items:center;justify-content:center;height:auto;line-height:1.4}.step-text-disabled.step-past{background:var(--gray-200);color:var(--gray-400);opacity:.7;cursor:not-allowed}.discharge-btn{background:none;border:none;color:var(--error);cursor:pointer;font-size:.875rem;font-weight:500;text-decoration:underline;text-decoration-color:transparent;padding:var(--spacing-xs) var(--spacing-sm);transition:all var(--transition-fast);border-radius:var(--radius-sm)}.discharge-btn:hover{color:var(--error-dark);text-decoration-color:var(--error-dark);background:#ef44441a}.history-modal-content{background:var(--white);padding:0;border-radius:var(--radius-lg);width:90%;max-width:600px;max-height:80vh;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slideUp .3s ease-out;border:1px solid var(--gray-200)}.history-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl);border-bottom:1px solid var(--gray-200);background:var(--gray-50)}.history-modal-header h2{margin:0;color:var(--gray-900);font-size:1.5rem;font-weight:700}.close-modal-btn{background:var(--gray-100);border:none;font-size:1.5rem;color:var(--gray-600);cursor:pointer;line-height:1;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--transition-fast)}.close-modal-btn:hover{background:var(--gray-200);color:var(--gray-900)}.history-modal-body{padding:var(--spacing-xl);overflow-y:auto}.history-step-name{font-size:1.125rem;font-weight:700;color:var(--gray-900);margin:0 0 var(--spacing-sm) 0}.history-patient-id{color:var(--gray-500);font-size:.875rem;margin:0 0 var(--spacing-lg) 0;font-weight:500}.no-history{text-align:center;color:var(--gray-500);padding:var(--spacing-2xl);font-style:italic}.history-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.history-item{padding:var(--spacing-lg);background:var(--gray-50);border-radius:var(--radius-md);border-left:3px solid var(--secondary);transition:all var(--transition-fast)}.history-item:hover{background:var(--gray-100)}.history-item-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg)}.history-user{font-weight:600;color:var(--gray-900)}.history-time{color:var(--gray-500);font-size:.875rem;white-space:nowrap;font-weight:500}.history-item-time{margin-top:var(--spacing-sm);color:var(--gray-400);font-size:.8125rem;font-style:italic}.manage-messages{min-height:100vh;background-color:var(--gray-50)}.manage-messages-main{max-width:1400px;margin:0 auto;padding:var(--spacing-xl)}.manage-messages-main h2{text-align:center;color:var(--gray-900);margin-bottom:var(--spacing-sm);font-size:2rem;font-weight:600;letter-spacing:-.025em}.location-selector-container{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);background:var(--white);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200)}.location-selector-label{color:var(--gray-700);font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.location-selector-select{padding:.75rem 1.25rem;border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:1rem;background-color:var(--white);cursor:pointer;min-width:160px;transition:all var(--transition-base);color:var(--gray-900)}.location-selector-select:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px var(--secondary-50)}.messages-table-container{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-xl);border:1px solid var(--gray-200)}.messages-table{width:100%;border-collapse:collapse}.messages-table thead{background-color:var(--primary);color:var(--white)}.messages-table th{padding:var(--spacing-lg);text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.messages-table td{padding:var(--spacing-md);border-bottom:1px solid var(--gray-200);transition:background-color var(--transition-fast)}.messages-table tbody tr:hover{background-color:var(--gray-50)}.messages-table tbody tr:last-child td{border-bottom:none}.table-input,.table-textarea{width:100%;padding:.625rem .875rem;border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:.9375rem;transition:all var(--transition-base);background:var(--white);color:var(--gray-900);font-family:inherit}.table-input:focus,.table-textarea:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px var(--secondary-50)}.table-textarea{resize:vertical;min-height:60px;line-height:1.5;overflow-y:auto}.table-textarea:focus{min-height:80px}.actions-container{display:flex;justify-content:center;gap:var(--spacing-md);margin-top:var(--spacing-xl);flex-wrap:wrap}.add-step-btn,.save-btn{padding:.875rem 2rem;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.add-step-btn{background-color:var(--success);color:var(--white)}.add-step-btn:hover{background-color:#059669;box-shadow:var(--shadow-md);transform:translateY(-1px)}.save-btn{background-color:var(--secondary);color:var(--white)}.save-btn:hover{background-color:var(--secondary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.delete-step-btn{background-color:var(--error);color:var(--white);border:none;border-radius:50%;width:2rem;height:2rem;font-size:1.25rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all var(--transition-base)}.delete-step-btn:hover:not(:disabled){background-color:var(--error-dark);transform:scale(1.05)}.delete-step-btn:disabled{background:var(--gray-300);cursor:not-allowed;opacity:.5;transform:none}.pin-modal-content{background:var(--white);padding:var(--spacing-2xl);border-radius:var(--radius-lg);width:90%;max-width:420px;box-shadow:var(--shadow-lg);animation:slideUp .3s ease-out;border:1px solid var(--gray-200)}.pin-modal-content h3{margin:0 0 var(--spacing-md) 0;color:var(--gray-900);text-align:center;font-size:1.5rem;font-weight:700}.pin-modal-description{margin:0 0 var(--spacing-xl) 0;color:var(--gray-600);text-align:center;font-size:.9375rem;line-height:1.6}.pin-input{width:100%;padding:var(--spacing-lg);border:2px solid var(--gray-300);border-radius:var(--radius-md);font-size:1.5rem;text-align:center;letter-spacing:.5rem;margin-bottom:var(--spacing-lg);transition:all var(--transition-base);font-weight:600;color:var(--gray-900)}.pin-input:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px var(--secondary-50)}.pin-modal-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end}.close-btn{background:var(--white);color:var(--secondary);border:1px solid var(--gray-300);padding:.75rem 1.5rem;border-radius:var(--radius-md);cursor:pointer;font-size:1rem;font-weight:500;transition:all var(--transition-base)}.close-btn:hover{background:var(--gray-50);border-color:var(--gray-400)}.error-message{background-color:#fee2e2;color:var(--error-dark);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:.875rem;text-align:center;border-left:4px solid var(--error);box-shadow:var(--shadow-sm)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.header-with-info{display:flex;align-items:center;gap:.5rem;justify-content:center}.info-icon-btn{background:transparent;border:none;cursor:pointer;font-size:1rem;padding:.25rem .5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);opacity:.7}.info-icon-btn:hover{opacity:1;background-color:#fff3;transform:scale(1.1)}.info-modal-content{background:var(--white);padding:var(--spacing-2xl);border-radius:var(--radius-lg);width:90%;max-width:500px;box-shadow:var(--shadow-lg);animation:slideUp .3s ease-out;border:1px solid var(--gray-200)}.info-modal-content h3{margin:0 0 var(--spacing-md) 0;color:var(--gray-900);font-size:1.5rem;font-weight:700;letter-spacing:-.025em}.info-modal-content p{color:var(--gray-700);line-height:1.6;margin-bottom:var(--spacing-md)}.info-modal-content .modal-actions{display:flex;justify-content:flex-end;margin-top:var(--spacing-lg)}.audit{min-height:100vh;background-color:var(--gray-50)}.audit-main{max-width:1400px;margin:0 auto;padding:var(--spacing-xl)}.audit-main h2{text-align:center;color:var(--gray-900);margin-bottom:var(--spacing-sm);font-size:2rem;font-weight:600;letter-spacing:-.025em}.audit-filters{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);background:var(--white);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200)}.filter-label{color:var(--gray-700);font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.audit-filter-select{padding:.75rem 1.25rem;border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:1rem;background-color:var(--white);cursor:pointer;min-width:220px;transition:all var(--transition-base);color:var(--gray-900)}.audit-filter-select:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px var(--secondary-50)}.audit-table-container{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200)}.audit-table{width:100%;border-collapse:collapse}.audit-table thead{background-color:var(--primary);color:var(--white)}.audit-table th{padding:var(--spacing-lg);text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.audit-table td{padding:var(--spacing-lg);border-bottom:1px solid var(--gray-200);transition:background-color var(--transition-fast)}.audit-table tbody tr:hover{background-color:var(--gray-50)}.audit-table tbody tr:last-child td{border-bottom:none}.audit-time{white-space:nowrap;color:var(--gray-600);font-size:.875rem;font-weight:500}.audit-user{font-weight:600;color:var(--gray-900)}.audit-action{color:var(--gray-900);font-weight:500}.audit-details{max-width:400px}.audit-location{color:var(--gray-500);font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.message-change-details{display:flex;flex-direction:column;gap:var(--spacing-sm);font-size:.875rem}.old-value{color:var(--error-dark);padding:var(--spacing-xs) var(--spacing-sm);background-color:#fee2e2;border-radius:var(--radius-sm);border-left:3px solid var(--error);font-weight:500}.new-value{color:#047857;padding:var(--spacing-xs) var(--spacing-sm);background-color:#d1fae5;border-radius:var(--radius-sm);border-left:3px solid var(--success);font-weight:500}.message-change-details strong{display:inline-block;min-width:50px;font-weight:700}.users{min-height:100vh;background-color:var(--gray-50)}.users-main{max-width:1000px;margin:0 auto;padding:var(--spacing-xl)}.users-main h2{text-align:center;color:var(--gray-900);margin-bottom:var(--spacing-sm);font-size:2rem;font-weight:600;letter-spacing:-.025em}.users-table-container{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200)}.users-table{width:100%;border-collapse:collapse}.users-table thead{background-color:var(--primary);color:var(--white)}.users-table th{padding:var(--spacing-lg);text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.users-table td{padding:var(--spacing-lg);border-bottom:1px solid var(--gray-200);transition:background-color var(--transition-fast)}.users-table tbody tr:hover{background-color:var(--gray-50)}.users-table tbody tr:last-child td{border-bottom:none}.user-username{font-weight:700;color:var(--secondary);font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,monospace;font-size:.9375rem}.user-email{font-weight:500;color:var(--gray-700);font-size:.9375rem}.role-badge{display:inline-block;padding:.375rem .875rem;border-radius:9999px;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.role-badge.admin{background-color:var(--secondary-100);color:var(--secondary-dark);border:1px solid var(--secondary)}.role-badge.nurse{background-color:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-300)}.role-select{padding:.625rem .875rem;border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:.875rem;cursor:pointer;transition:all var(--transition-base);background:var(--white);color:var(--gray-900);font-weight:500}.role-select:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px var(--secondary-50)}.hospital-select{padding:.625rem .875rem;border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:.875rem;cursor:pointer;transition:all var(--transition-base);background:var(--white);color:var(--gray-900);font-weight:500;min-width:200px}.hospital-select:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px var(--secondary-50)}.user-actions{display:flex;gap:var(--spacing-sm)}.edit-role-btn,.save-role-btn,.cancel-role-btn{padding:.625rem 1.25rem;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.edit-role-btn{background-color:var(--secondary);color:var(--white)}.edit-role-btn:hover:not(:disabled){background-color:var(--secondary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.edit-role-btn:disabled{background:var(--gray-300);cursor:not-allowed;opacity:.6;transform:none}.save-role-btn{background-color:var(--success);color:var(--white)}.save-role-btn:hover{background-color:#059669;box-shadow:var(--shadow-md);transform:translateY(-1px)}.cancel-role-btn{background-color:var(--gray-500);color:var(--white)}.cancel-role-btn:hover{background-color:var(--gray-600);box-shadow:var(--shadow-md);transform:translateY(-1px)}.reports{min-height:100vh;background-color:var(--gray-50)}.reports-main{max-width:1400px;margin:0 auto;padding:var(--spacing-xl)}.reports-main h2{text-align:center;color:var(--gray-900);margin-bottom:var(--spacing-sm);font-size:2rem;font-weight:600;letter-spacing:-.025em}.summary-stats-row{display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);justify-content:center}.summary-stats-row .stat-card{flex:1;max-width:300px}.reports-controls{display:flex;justify-content:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);background:var(--white);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200)}.reports-grid{display:flex;flex-direction:column;gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:var(--spacing-xl)}.report-card.chart-card{max-width:100%}.report-card.full-width{width:100%;max-width:100%;grid-column:1 / -1}.location-charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--spacing-xl);margin-top:var(--spacing-lg)}.location-chart-column{display:flex;flex-direction:column}.location-chart-title{color:var(--primary);font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-md);text-align:center}.no-data-message{text-align:center;color:var(--gray-500);padding:var(--spacing-xl);font-style:italic}.report-card{background:var(--white);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200)}.report-card h3{color:var(--gray-900);font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-sm);letter-spacing:-.025em}.report-description{color:var(--gray-600);font-size:.9375rem;margin-bottom:var(--spacing-lg);line-height:1.6}.completion-section{margin-bottom:var(--spacing-xl)}.completion-section:last-child{margin-bottom:0}.completion-section h4{color:var(--primary);font-size:1.125rem;font-weight:600;margin-bottom:var(--spacing-md)}.completion-pies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.completion-pie-container{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md);background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--gray-200)}.pie-title{font-weight:600;font-size:.875rem;color:var(--gray-900);text-align:center;margin-bottom:var(--spacing-xs);line-height:1.3}.pie-subtitle{font-size:.75rem;color:var(--gray-600);text-align:center;margin-bottom:var(--spacing-sm)}.pie-stats{margin-top:var(--spacing-sm);text-align:center}.pie-stat{font-size:.875rem;font-weight:600;color:var(--gray-700)}.report-stats{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--gray-200)}.stat-item{display:flex;gap:var(--spacing-sm);align-items:center}.stat-label{color:var(--gray-600);font-weight:500;font-size:.875rem}.stat-value{color:var(--gray-900);font-weight:600;font-size:.875rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.stat-card{text-align:center;padding:var(--spacing-lg);background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--gray-200)}.stat-value-large{font-size:2.5rem;font-weight:700;color:var(--primary);margin-bottom:var(--spacing-sm)}.stat-label-large{font-size:1rem;font-weight:600;color:var(--gray-900);margin-bottom:var(--spacing-xs)}.stat-sublabel{font-size:.875rem;color:var(--gray-500)}@media (max-width: 768px){.reports-grid,.stats-grid{grid-template-columns:1fr}.summary-stats-row{flex-direction:column;align-items:center}.summary-stats-row .stat-card{max-width:100%;width:100%}.reports-controls{flex-direction:column}.completion-pies-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.master-admin{min-height:100vh;background-color:var(--gray-50)}.master-admin-main{max-width:1200px;margin:0 auto;padding:var(--spacing-xl)}.master-admin-main h2{text-align:center;color:var(--gray-900);margin-bottom:var(--spacing-sm);font-size:2rem;font-weight:600;letter-spacing:-.025em}.subtitle{text-align:center;color:var(--gray-600);margin-bottom:var(--spacing-xl);font-size:1.125rem;font-weight:400}.admin-section{background:var(--white);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);margin-bottom:var(--spacing-xl)}.admin-section h3{color:var(--gray-900);font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-sm);letter-spacing:-.025em}.section-description{color:var(--gray-600);font-size:.9375rem;margin-bottom:var(--spacing-lg);line-height:1.6}.pins-form,.hospital-form{margin-bottom:var(--spacing-xl)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-sm);color:var(--gray-700);font-weight:500;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.form-group input{width:100%;padding:.875rem 1rem;border:2px solid var(--gray-200);border-radius:var(--radius-md);font-size:1rem;transition:all var(--transition-base);background:var(--white);color:var(--gray-900);max-width:400px}.form-group input:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px var(--secondary-50)}.form-group small{display:block;margin-top:var(--spacing-xs);color:var(--gray-500);font-size:.875rem}.save-btn,.add-btn{padding:.875rem 1.5rem;background-color:var(--secondary);color:var(--white);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.save-btn:hover:not(:disabled),.add-btn:hover{background-color:var(--secondary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.save-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-message{background-color:#fee2e2;color:var(--error-dark);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:.875rem;border-left:4px solid var(--error);box-shadow:var(--shadow-sm)}.success-message{background-color:#d1fae5;color:#065f46;padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:.875rem;border-left:4px solid var(--success);box-shadow:var(--shadow-sm)}.hospitals-list{margin-top:var(--spacing-xl)}.hospitals-list h4{color:var(--gray-900);font-size:1.125rem;font-weight:600;margin-bottom:var(--spacing-md)}.hospitals-table{width:100%;border-collapse:collapse;background:var(--white);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.hospitals-table thead{background-color:var(--primary)}.hospitals-table th{padding:var(--spacing-md);text-align:left;color:var(--white);font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.hospitals-table tbody tr{border-bottom:1px solid var(--gray-200);transition:background-color var(--transition-fast)}.hospitals-table tbody tr:hover{background-color:var(--gray-50)}.hospitals-table tbody tr:last-child{border-bottom:none}.hospitals-table td{padding:var(--spacing-md);color:var(--gray-900)}.hospital-id{font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.875rem;color:var(--gray-600)}.no-data{text-align:center;color:var(--gray-500);padding:var(--spacing-xl);font-style:italic}.hospital-actions{display:flex;gap:.5rem;align-items:center}.edit-hospital-btn{padding:.5rem 1rem;background-color:var(--secondary);color:var(--white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.edit-hospital-btn:hover:not(:disabled){background-color:var(--secondary-dark);transform:translateY(-1px)}.edit-hospital-input{width:100%;padding:.5rem .75rem;border:2px solid var(--secondary);border-radius:var(--radius-md);font-size:.9375rem;transition:all var(--transition-base);background:var(--white);color:var(--gray-900);min-width:200px}.edit-hospital-input:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px var(--secondary-50)}.edit-hospital-input:disabled{opacity:.6;cursor:not-allowed}.save-hospital-btn{padding:.5rem 1rem;background-color:var(--success);color:var(--white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.save-hospital-btn:hover:not(:disabled){background-color:#059669;transform:translateY(-1px)}.save-hospital-btn:disabled{opacity:.6;cursor:not-allowed}.cancel-edit-btn{padding:.5rem 1rem;background-color:var(--gray-300);color:var(--gray-700);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.cancel-edit-btn:hover:not(:disabled){background-color:var(--gray-400)}.cancel-edit-btn:disabled{opacity:.6;cursor:not-allowed}.delete-hospital-btn{padding:.5rem 1rem;background-color:var(--error);color:var(--white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.delete-hospital-btn:hover:not(:disabled){background-color:var(--error-dark);transform:translateY(-1px)}.delete-hospital-btn:disabled{opacity:.6;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:var(--white);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:500px;width:90%;border:1px solid var(--gray-200)}.modal-content h3{color:var(--gray-900);font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-md);letter-spacing:-.025em}.modal-content p{color:var(--gray-700);margin-bottom:var(--spacing-md);line-height:1.6}.modal-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;margin-top:var(--spacing-lg)}.cancel-btn{padding:.75rem 1.5rem;background-color:var(--gray-200);color:var(--gray-700);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.cancel-btn:hover:not(:disabled){background-color:var(--gray-300)}.cancel-btn:disabled{opacity:.6;cursor:not-allowed}.delete-confirm-btn{padding:.75rem 1.5rem;background-color:var(--error);color:var(--white);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.delete-confirm-btn:hover:not(:disabled){background-color:var(--error-dark)}.delete-confirm-btn:disabled{opacity:.6;cursor:not-allowed}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.125rem;color:var(--gray-600);font-weight:500}.loading:after{content:"";width:20px;height:20px;margin-left:.75rem;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #1e3a5f;--primary-dark: #152a47;--primary-light: #2d4a6f;--primary-50: #e8edf3;--primary-100: #d1dbe7;--primary-200: #a3b7cf;--secondary: #4a9b9f;--secondary-dark: #3a7b7f;--secondary-light: #5abbbf;--secondary-50: #e6f2f3;--secondary-100: #cce5e7;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--error-dark: #dc2626;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--white: #ffffff;--black: #000000;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 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);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;min-height:100vh;color:var(--gray-900);line-height:1.6}code{font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace}html{scroll-behavior:smooth}*:focus-visible{outline:2px solid var(--secondary);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}
