body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{text-align:center}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-header h1{margin-bottom:20px}.logout-button{background-color:#dc3545;border:none;font-size:16px;margin-top:30px;padding:12px 24px}.logout-button:hover{background-color:#c82333}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.login-box{background:#fff;border-radius:10px;box-shadow:0 10px 25px #0003;max-width:400px;padding:40px;width:100%}.login-box h1{color:#333;font-size:28px;margin:0 0 30px;text-align:center}.form-group label{color:#555;font-weight:500}.form-group input{border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-size:14px;padding:12px;transition:border-color .3s;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px;transition:transform .2s,box-shadow .2s;width:100%}.login-button:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.login-button:active{transform:translateY(0)}.dashboard{background-color:#f5f5f5;display:flex;flex-direction:column;height:100vh;overflow:hidden}.dashboard-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:20px 40px}.dashboard-header h1{font-size:24px;margin:0}.dashboard-content{box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;margin:0 auto;max-width:1880px;overflow:hidden;padding:20px;width:100%}.loading{color:#666;font-size:18px;padding:60px 20px}.error,.loading{text-align:center}.error{background-color:#fee;border:1px solid #fcc;border-radius:5px;color:#c33;padding:20px}.logout-button{background-color:#fff3;border:2px solid #fff;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background-color .3s,transform .2s}.logout-button:hover{background-color:#ffffff4d;transform:translateY(-2px)}.logout-button:active{transform:translateY(0)}.content-header{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:20px}.content-header h2{color:#333;font-size:28px;margin:0}.search-container{flex:1 1;max-width:400px;min-width:250px}.search-input{border:2px solid #ddd;border-radius:8px;box-sizing:border-box;padding:12px 40px 12px 16px;transition:border-color .3s}.search-input::placeholder{color:#999}.clear-search{background:#0000;border-radius:50%;color:#999;font-size:24px;height:30px;transition:background-color .2s,color .2s;width:30px}.clear-search:hover{background-color:#f0f0f0;color:#666}.no-data{border-radius:8px;color:#666}.no-data,.table-container{background:#fff;box-shadow:0 2px 8px #0000001a}.table-container{min-height:0}.schools-table{border-collapse:collapse;font-size:14px;position:relative;width:100%}.schools-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:10}.schools-table th{cursor:pointer;font-size:12px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase;transition:background-color .2s;-webkit-user-select:none;user-select:none}.schools-table th:hover{background:linear-gradient(135deg,#7688eb,#8556ad)}.th-content{gap:5px}.sort-indicator{font-size:14px;font-weight:700;min-width:12px}.schools-table tbody tr{border-bottom:1px solid #eee;transition:background-color .2s}.schools-table tbody tr.clickable-row{cursor:pointer}.schools-table tbody tr:hover{background-color:#f8f9fa}.schools-table tbody tr.clickable-row:hover{background-color:#e8eaf6}.schools-table tbody tr:last-child{border-bottom:none}.schools-table td{color:#333;padding:16px}.schools-table td:first-child{color:#667eea;font-weight:600}.school-detail{display:flex;flex-direction:column;height:100%;overflow:hidden}.school-detail-header{align-items:center;border-bottom:2px solid #e1e4e8;display:flex;flex-shrink:0;justify-content:space-between;margin-bottom:20px;padding:20px 0}.school-detail-header .header-left{align-items:center;display:flex;gap:20px}.school-info{display:flex;flex-direction:column;gap:4px}.school-detail-header h2{color:#1a202c;font-size:24px;margin:0}.school-district{color:#718096;margin:0}.back-button,.school-district{font-size:14px;font-weight:500}.back-button{background-color:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:8px 16px;transition:background-color .2s}.back-button:hover{background-color:#5a67d8}.tabs{display:flex;gap:10px}.tab{background-color:initial;border:none;border-bottom:3px solid #0000;color:#4a5568;cursor:pointer;font-size:16px;font-weight:500;padding:10px 24px;transition:all .2s}.tab:hover{background-color:#f7fafc;color:#667eea}.tab.active{border-bottom-color:#667eea;color:#667eea}.tab-content{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.students-and-users-container{gap:20px}.students-and-users-container,.students-section{display:flex;flex:1 1;min-height:0;overflow:hidden}.students-section{flex-direction:column;min-width:0}.right-panels{display:flex;flex:0 0 auto;flex-direction:row;gap:20px;min-height:0;overflow:hidden}.students-header{flex-shrink:0;justify-content:space-between;margin-bottom:20px}.students-header,.students-left{align-items:center;display:flex;gap:20px}.students-left{flex:1 1}.students-left h3{color:#1a202c;font-size:20px;margin:0;white-space:nowrap}.students-right{align-items:center;display:flex;gap:15px}.add-student-button{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 18px;transition:all .3s;white-space:nowrap}.add-student-button:hover{background:#5a67d8;box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.invite-user-button{background:#48bb78;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 18px;transition:all .3s;white-space:nowrap}.invite-user-button:hover{background:#38a169;box-shadow:0 4px 12px #48bb7866;transform:translateY(-1px)}.students-table{background-color:#fff;border-collapse:collapse;width:100%}.students-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:10}.students-table th{cursor:pointer;font-size:14px;font-weight:600;padding:12px 16px;text-align:left;transition:background-color .2s;-webkit-user-select:none;user-select:none}.students-table th:hover{background-color:#ffffff1a}.students-table td{border-bottom:1px solid #e2e8f0;color:#2d3748;font-size:14px;padding:12px 16px}.students-table tbody tr:hover{background-color:#f7fafc}.students-table tbody tr:last-child td{border-bottom:none}.delete-button{background:none;border:none;cursor:pointer;font-size:18px;opacity:.6;padding:4px 8px;transition:opacity .2s,transform .2s}.delete-button:hover{opacity:1;transform:scale(1.2)}.form-group input,.form-group select,.form-group textarea{border:1px solid #cbd5e0;border-radius:6px;box-sizing:border-box;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.confirm-dialog{max-width:400px}.invite-details,.student-details{background-color:#f7fafc;border-radius:6px;margin:16px 0;padding:12px}.warning-text{color:#e53e3e;font-size:13px;margin-top:12px}.modal-button.delete-confirm{background-color:#e53e3e}.modal-button.delete-confirm:hover{background-color:#c53030}.role-select{cursor:pointer}.email-textarea{font-family:inherit;resize:vertical}.form-hint{color:#718096;display:block;font-size:12px;margin-top:6px}.school-users{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;height:100%;max-width:400px;min-width:300px;overflow:hidden;padding:20px;width:350px}.school-users h3{border-bottom:2px solid #eee;color:#333;flex-shrink:0;font-size:20px;margin:0 0 20px;padding-bottom:15px}.users-list{display:flex;flex:1 1;flex-direction:column;gap:15px;min-height:0;overflow-y:auto}.users-list,.users-list .user-card:last-child{margin-bottom:20px}.no-users{color:#999;font-style:italic;padding:40px 20px;text-align:center}.user-card{background:#fafafa;border:1px solid #e0e0e0;border-radius:6px;padding:15px;transition:box-shadow .2s,transform .2s}.user-card:hover{box-shadow:0 2px 8px #667eea26;transform:translateY(-2px)}.user-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.user-name{color:#333;font-size:16px;font-weight:600}.user-role{border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.role-administrator{background-color:#dc3545;color:#fff}.role-teacher{background-color:#26c6da;color:#fff}.role-staff{background-color:#66bb6a;color:#fff}.user-email{color:#666;font-size:13px;margin-bottom:10px;word-break:break-word}.user-notifications{margin-bottom:6px}.user-notifications,.user-settings{color:#666;font-size:12px}.label{color:#555;font-weight:500}.school-invites{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;height:100%;max-width:400px;min-width:300px;overflow:hidden;padding:20px;width:350px}.school-invites h3{border-bottom:2px solid #eee;color:#333;flex-shrink:0;font-size:20px;margin:0 0 20px;padding-bottom:15px}.invites-list{display:flex;flex:1 1;flex-direction:column;gap:15px;margin-bottom:20px;min-height:0;overflow-y:auto}.no-invites{color:#999;font-size:14px;padding:40px 20px;text-align:center}.invite-card{background:#f8f9fa;border-left:4px solid #ffc107;border-radius:8px;padding:15px;transition:all .2s}.invite-card:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.invite-header{align-items:flex-start;display:flex;gap:10px;justify-content:space-between;margin-bottom:10px}.invite-info{display:flex;flex:1 1;flex-direction:column;gap:8px;min-width:0}.invite-email{color:#333;font-size:14px;font-weight:600;word-break:break-word}.invite-role{align-self:flex-start;border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase;white-space:nowrap}.invite-role.role-administrator{background-color:#dc3545;color:#fff}.invite-role.role-teacher{background-color:#17a2b8;color:#fff}.invite-role.role-staff{background-color:#28a745;color:#fff}.invite-time{color:#666;font-size:12px;margin-top:5px}.invites-list::-webkit-scrollbar{width:6px}.invites-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.invites-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.invites-list::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.delete-invite-button{align-items:center;background:#0000;border:none;border-radius:4px;cursor:pointer;display:flex;flex-shrink:0;font-size:16px;justify-content:center;padding:4px 6px;transition:all .2s}.delete-invite-button:hover{background:#fee;transform:scale(1.1)}.modal-overlay{background:#00000080}.modal-content{box-shadow:0 10px 40px #0003;overflow:hidden}.confirm-dialog{max-width:450px}.modal-header{border-bottom:1px solid #eee}.modal-header h3{color:#333}.modal-close{background:#0000;color:#999}.modal-close:hover{background:#f5f5f5;color:#333}.modal-body p{color:#555;line-height:1.6;margin:0 0 15px}.invite-details{background:#f8f9fa;border-radius:6px;color:#333;margin:15px 0;padding:15px}.warning-text{color:#dc3545;font-size:14px;font-weight:500;margin-bottom:0;margin-top:10px}.modal-footer{border-top:1px solid #eee;padding:16px 24px}.modal-button{transition:all .3s}.modal-button.cancel{background:#e9ecef;color:#495057}.modal-button.cancel:hover{background:#dee2e6}.modal-button.delete-confirm{background:#dc3545;color:#fff}.modal-button.delete-confirm:hover{background:#c82333;box-shadow:0 4px 12px #dc35454d}.bags-header{justify-content:space-between;margin-bottom:20px}.bags-header,.bags-left{align-items:center;display:flex;gap:20px}.bags-left{flex:1 1}.bags-left h3{color:#1a202c;font-size:20px;margin:0;white-space:nowrap}.bags-right{align-items:center;display:flex;gap:15px}.bags-table{background-color:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden;width:100%}.bags-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:10}.bags-table th{cursor:pointer;font-size:14px;font-weight:600;padding:12px 16px;text-align:left;transition:background-color .2s;-webkit-user-select:none;user-select:none}.bags-table th:hover{background-color:#ffffff1a}.bags-table td{border-bottom:1px solid #e2e8f0;color:#2d3748;font-size:14px;padding:12px 16px}.bags-table tbody tr:hover{background-color:#f7fafc}.bags-table tbody tr:last-child td{border-bottom:none}.status-damaged{color:#dc3545;font-weight:700}.status-lost{color:#d4a017;font-weight:700}.filter-search-container{align-items:center;display:flex;gap:15px}.add-bag-button{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 18px;transition:all .3s;white-space:nowrap}.add-bag-button:hover{background:#5a67d8;box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.search-container{min-width:300px}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:500px;overflow:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h3{color:#1a202c;font-size:20px;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#a0aec0;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.modal-close:hover{background-color:#edf2f7;color:#4a5568}.modal-body{padding:24px}.form-group{margin-bottom:20px}.form-group:last-child{margin-bottom:0}.form-group label{color:#2d3748;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-group input,.form-group select{border:1px solid #cbd5e0;border-radius:6px;box-sizing:border-box;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.form-group input:focus,.form-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.model-select{background-color:#fff;cursor:pointer}.modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.modal-button{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.modal-button.cancel{background-color:#e2e8f0;color:#4a5568}.modal-button.cancel:hover{background-color:#cbd5e0}.modal-button.submit{background-color:#667eea;color:#fff}.modal-button.submit:hover:not(:disabled){background-color:#5a67d8}.modal-button.submit:disabled{cursor:not-allowed;opacity:.5}.activity-header{flex-wrap:wrap;justify-content:space-between;margin-bottom:20px}.activity-header,.activity-left{align-items:center;display:flex;gap:20px}.activity-left{flex:1 1;flex-wrap:wrap}.activity-title{display:flex;flex-direction:column;gap:2px}.activity-left h3{color:#1a202c;font-size:20px;margin:0;white-space:nowrap}.activity-subtitle{color:#718096;font-size:12px;margin:0;white-space:nowrap}.event-filters{flex-wrap:wrap;gap:15px}.checkbox-label,.event-filters{align-items:center;display:flex}.checkbox-label{color:#4a5568;cursor:pointer;font-size:14px;gap:8px;white-space:nowrap}.checkbox-label input[type=checkbox]{cursor:pointer;height:18px;width:18px}.activity-table{background-color:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden;width:100%}.activity-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:10}.activity-table th{cursor:pointer;font-size:14px;font-weight:600;padding:12px 16px;text-align:left;transition:background-color .2s;-webkit-user-select:none;user-select:none}.activity-table th:hover{background-color:#ffffff1a}.activity-table td{border-bottom:1px solid #e2e8f0;color:#2d3748;font-size:14px;padding:12px 16px}.activity-table tbody tr:hover{background-color:#f7fafc}.activity-table tbody tr:last-child td{border-bottom:none}.th-content{align-items:center;display:flex;justify-content:space-between}.sort-indicator{margin-left:8px;opacity:.7}.no-data{color:#718096;font-size:16px;padding:40px;text-align:center}.table-container{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;flex:1 1;overflow:auto}.search-container{min-width:400px;position:relative}.search-input{border:1px solid #cbd5e0;border-radius:6px;font-size:14px;padding:8px 32px 8px 12px;transition:border-color .2s;width:100%}.search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.clear-search{align-items:center;background:none;border:none;border-radius:4px;color:#a0aec0;cursor:pointer;display:flex;font-size:20px;height:24px;justify-content:center;padding:0;position:absolute;right:8px;top:50%;transform:translateY(-50%);transition:background-color .2s;width:24px}.clear-search:hover{background-color:#edf2f7;color:#4a5568}.pagination{align-items:center;background-color:#f7fafc;border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;font-size:14px;gap:10px;padding:16px}.pagination button{background-color:#fff;border:1px solid #cbd5e0;border-radius:4px;cursor:pointer;font-size:14px;padding:6px 12px;transition:all .2s}.pagination button:hover:not(:disabled){background-color:#667eea;border-color:#667eea;color:#fff}.pagination button:disabled{cursor:not-allowed;opacity:.5}.pagination input{width:100px}.pagination input,.pagination select{border:1px solid #cbd5e0;border-radius:4px;font-size:14px;padding:6px 8px}.pagination select{background-color:#fff;cursor:pointer}.event-violation{color:#dc3545;font-weight:600}.event-assigned{color:#28a745;font-weight:600}.event-damaged{color:#ffc107;font-weight:600}.event-lost{color:#9333ea;font-weight:600}
/*# sourceMappingURL=main.808ca2dc.css.map*/