.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:2.5rem;border-radius:.5rem;box-shadow:0 20px 25px -5px #0000001a;width:100%;max-width:400px}.login-box h1{color:var(--primary);margin-bottom:.5rem;text-align:center}.login-box h2{color:var(--gray-700);font-size:1.5rem;margin-bottom:1.5rem;text-align:center}.error-message{background:#fef2f2;color:var(--danger);padding:.75rem;border-radius:.375rem;margin-bottom:1rem;border:1px solid #fecaca}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--gray-700);font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid var(--gray-300);border-radius:.375rem;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.login-box button[type=submit]{width:100%;background:var(--primary);color:#fff;padding:.75rem;border:none;border-radius:.375rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s;margin-top:.5rem}.login-box button[type=submit]:hover:not(:disabled){background:var(--primary-dark)}.toggle-text{text-align:center;margin-top:1.5rem;color:var(--gray-600)}.toggle-button{background:none;border:none;color:var(--primary);font-weight:600;cursor:pointer;padding:0}.toggle-button:hover{text-decoration:underline}.calendar-container{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem;position:relative}.loading{text-align:center;padding:1rem;color:var(--gray-600)}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--gray-200)}.calendar-header h2{font-size:1.5rem;color:var(--gray-900);margin:0}.calendar-header button{background:var(--primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-weight:500;cursor:pointer;transition:background .2s}.calendar-header button:hover{background:var(--primary-dark)}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:.5rem}.calendar-day-name{text-align:center;font-weight:600;color:var(--gray-700);padding:.5rem;font-size:.875rem}.calendar-body{display:flex;flex-direction:column;gap:.5rem}.calendar-row{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.calendar-cell{min-height:100px;padding:.5rem;border:1px solid var(--gray-200);border-radius:.375rem;cursor:pointer;transition:all .2s;position:relative;background:#fff}.calendar-cell:hover:not(.disabled){border-color:var(--primary);box-shadow:0 2px 4px #0000001a}.calendar-cell.disabled{background:var(--gray-50);cursor:default}.calendar-cell.disabled .day-number{color:var(--gray-400)}.calendar-cell.has-availability{background:#eff6ff}.day-number{font-weight:600;color:var(--gray-900);display:block;margin-bottom:.25rem}.availability-indicators{display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem}.availability-badge{font-size:.75rem;padding:.25rem .5rem;border-radius:.25rem;font-weight:600;cursor:pointer;transition:opacity .2s}.availability-badge:hover{opacity:.8}.availability-badge.morning{background:#fef3c7;color:#92400e}.availability-badge.afternoon{background:#dbeafe;color:#1e40af}.availability-badge.full_day{background:#d1fae5;color:#065f46}.user-name{font-weight:400;margin-left:.25rem}.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{background:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 20px 25px -5px #0000001a;max-width:400px;width:90%}.modal h3{margin-bottom:1.5rem;color:var(--gray-900)}.modal-buttons{display:flex;gap:.75rem;flex-direction:column}.modal-buttons button{padding:.75rem;border:none;border-radius:.375rem;font-weight:600;cursor:pointer;transition:all .2s}.modal-buttons button:nth-child(1){background:#fef3c7;color:#92400e}.modal-buttons button:nth-child(1):hover{background:#fde68a}.modal-buttons button:nth-child(2){background:#dbeafe;color:#1e40af}.modal-buttons button:nth-child(2):hover{background:#bfdbfe}.modal-buttons button:nth-child(3){background:#d1fae5;color:#065f46}.modal-buttons button:nth-child(3):hover{background:#a7f3d0}.modal-close{margin-top:1rem;width:100%;padding:.75rem;background:var(--gray-200);color:var(--gray-700);border:none;border-radius:.375rem;font-weight:600;cursor:pointer}.modal-close:hover{background:var(--gray-300)}.admin-panel{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--gray-200)}.admin-header h2{margin:0;color:var(--gray-900)}.admin-header button{background:var(--primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-weight:600;cursor:pointer;transition:background .2s}.admin-header button:hover{background:var(--primary-dark)}.users-table{width:100%;border-collapse:collapse}.users-table th{background:var(--gray-50);padding:.75rem;text-align:left;font-weight:600;color:var(--gray-700);border-bottom:2px solid var(--gray-200)}.users-table td{padding:1rem .75rem;border-bottom:1px solid var(--gray-200);color:var(--gray-900)}.users-table tr:hover{background:var(--gray-50)}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase}.role-badge.admin{background:#fef3c7;color:#92400e}.role-badge.user{background:#dbeafe;color:#1e40af}.btn-edit,.btn-delete{padding:.375rem .75rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;margin-right:.5rem}.btn-edit{background:var(--gray-200);color:var(--gray-700)}.btn-edit:hover{background:var(--gray-300)}.btn-delete{background:#fee2e2;color:var(--danger)}.btn-delete:hover{background:#fecaca}.modal form{display:flex;flex-direction:column;gap:1rem}.modal .form-group{margin-bottom:0}.modal .form-group label{display:block;margin-bottom:.5rem;color:var(--gray-700);font-weight:500;font-size:.875rem}.modal .form-group input,.modal .form-group select{width:100%;padding:.75rem;border:1px solid var(--gray-300);border-radius:.375rem;font-size:1rem;transition:border-color .2s}.modal .form-group input:focus,.modal .form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.modal .modal-buttons{flex-direction:row;margin-top:.5rem}.modal .modal-buttons button[type=submit]{flex:1;background:var(--primary);color:#fff}.modal .modal-buttons button[type=submit]:hover{background:var(--primary-dark)}.modal .modal-buttons button[type=button]{flex:1;background:var(--gray-200);color:var(--gray-700)}.modal .modal-buttons button[type=button]:hover{background:var(--gray-300)}:root{--primary: #2563eb;--primary-dark: #1e40af;--danger: #dc2626;--success: #16a34a;--warning: #ea580c;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-600: #4b5563;--gray-700: #374151;--gray-900: #111827}.app{min-height:100vh;background:var(--gray-50)}.navbar{background:#fff;box-shadow:0 1px 3px #0000001a;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}.nav-brand h1{font-size:1.5rem;color:var(--primary);margin:0}.nav-links{display:flex;gap:1.5rem;flex:1}.nav-links a{color:var(--gray-700);text-decoration:none;font-weight:500;padding:.5rem 1rem;border-radius:.375rem;transition:all .2s}.nav-links a:hover{background:var(--gray-100);color:var(--primary)}.nav-user{display:flex;align-items:center;gap:1rem}.nav-user span{color:var(--gray-700);font-weight:500}.user-role{color:var(--gray-600);font-size:.875rem;font-weight:400;margin-left:.25rem}.nav-user button{background:var(--danger);color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-weight:500;cursor:pointer;transition:background .2s}.nav-user button:hover{background:#b91c1c}.main-content{max-width:1400px;margin:2rem auto;padding:0 2rem}.loading-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.25rem;color:var(--gray-600)}button{font-family:inherit}button:disabled{opacity:.5;cursor:not-allowed}
