.header{background-color:#174996a6;color:#fff;height:6em;justify-content:center;letter-spacing:.1em;position:absolute;width:100%;z-index:10}.header,.header-content{align-items:center;display:flex}.header-content{justify-content:space-between;width:90%}.header-logo-link{color:#fff;text-decoration:none}.header-logo-link,.nav-items{align-items:center;display:flex}.nav-items{font-size:1.2rem;gap:1.3em}.school-name{font-size:1.2rem;font-weight:700;margin-left:1em}.menu-wrapper{align-items:center;display:flex;gap:2em}.nav-item{color:#fff;letter-spacing:.1em;text-decoration:none}.nav-item:hover{color:#b1b1b1}.logo{width:3.2em}#visit-library-btn{font-size:1.2rem;font-weight:700;margin:0;padding-inline:1em}.profile-container{color:#1b3258;display:flex;gap:1em;position:relative}.profile{align-items:center;display:flex;flex-direction:column}.profile-icon{cursor:pointer;height:3em;width:3em}.profile-active,.profile-icon:hover{filter:brightness(.8)}.guest-label{color:#6c757d;margin-left:8px}.dropdown-menu{background:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 6px #0000001a;list-style:none;margin-top:1em;padding-left:0;position:absolute;right:0;top:100%;width:15em;z-index:100}.dropdown-menu li{cursor:pointer;padding:1em;text-align:center;transition:background .1s}.dropdown-menu li:hover{background:#2d7eff}.hamburger{background:none;border:none;color:#fff;cursor:pointer;display:none;font-size:1.6rem}@media (max-width:1200px){.header{height:auto;padding-block:1em;position:fixed}.hamburger{display:block}.nav-items,.profile-container{display:none}.nav-items.show{display:flex}.nav-item{border-bottom:1px solid #fff3;padding:.8em 0}.nav-item:last-child{border-bottom:none}.header-content{width:85%}.school-name{font-size:.8rem;margin-left:.5em}.logo{width:2.5em}#visit-library-btn{font-size:1rem;padding-inline:.8em}.profile-icon{height:2.5em;width:2.5em}.menu-wrapper{align-items:center;background-color:#174996f2;display:none;flex-direction:column;left:0;padding:1em 0;position:absolute;top:100%;width:100%}.menu-wrapper.show{display:flex}.nav-items{gap:1em}.nav-items,.profile-container{align-items:center;display:flex;flex-direction:column}.profile-container{margin-top:1em}.nav-item{font-size:1.1rem;padding:.5em 0}.btn-primary{margin-top:.5em}}*{box-sizing:border-box;margin:0;padding:0}.hero-container{background:linear-gradient(270deg,#0f2e68,#3171d1);height:100vh;overflow:hidden;position:relative}.hero-content{color:#fff;font-size:1.5rem;margin-left:3.5em;position:absolute;top:50%;transform:translateY(-50%);width:100%;z-index:3}.hero-image{height:100%;position:absolute;right:0;top:0}.title-container{font-size:2.4rem}.title-1{font-size:5rem;line-height:.5em}.title-2{color:#619eff;margin-top:.2em}.hero-subtitle{letter-spacing:.08em;margin-bottom:1em}.btn-primary{background-color:#f4c43c;border:.13em solid #f4c43c;border-radius:.25em;color:#3a3a3a;cursor:pointer;font-size:1.5rem;font-weight:600;letter-spacing:.03em;margin-bottom:.6em;padding:.5em 1.5em}.btn-primary:hover{background-color:initial;color:#f4c43c;transition:.1s ease-in}.signup-text{font-size:1rem}.link{letter-spacing:inherit}.link:hover{color:#2d7eff}@media (max-width:576px){.hero-container{display:flex;flex-direction:column;height:auto;justify-content:center;min-height:100vh;padding-inline:1.5em}.hero-image{display:none}.hero-content{font-size:1.2rem;margin:0;position:static;text-align:center;transform:none}.title-1{font-size:3rem;line-height:.8em}.title-2{font-size:2rem;line-height:.8em;margin-block:.3em}.btn-primary{font-size:1.2rem;padding:.4em 1.2em}.signup-text{font-size:.9rem}}:root{--secondary-blue:#3171d1;--accent-yellow:#f4c43c;--text-dark:#333;--text-light:#fff;--card-background:#fff;--input-border:#ccc;--spacing-unit:1rem}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0;padding:0}.signin-container{background:linear-gradient(180deg,#0f2e68,#3171d1);background:linear-gradient(to bottom,var(--primary-blue),var(--secondary-blue));color:#fff;color:var(--text-light);min-height:100vh;padding-top:10rem}.signin-container,.signin-content{align-items:center;box-sizing:border-box;display:flex;flex-direction:column}.signin-content{background-color:#fff;background-color:var(--card-background);border-radius:12px;box-shadow:0 10px 30px #0003;color:#333;color:var(--text-dark);gap:1.5rem;margin:4rem auto 0;max-width:450px;padding:2.5rem 2rem;position:relative;width:90%}.back-icon-btn{background:none;border:none;color:#0f2e68;color:var(--primary-blue);cursor:pointer;font-size:1.5rem;left:1.5rem;line-height:1;padding:0;position:absolute;top:1.5rem;transition:color .2s}.back-icon-btn:hover{color:#f4c43c;color:var(--accent-yellow)}.initial-selection-container{display:flex;flex-direction:column;gap:1.5rem;padding:0 1rem;width:100%}.selection-header{color:#0f2e68;color:var(--primary-blue);font-size:1.5rem;margin-bottom:1rem;text-align:center}.selection-card{background-color:#f7f7f7;border:2px solid #ccc;border:2px solid var(--input-border);border-radius:10px;box-shadow:0 4px 10px #0000000d;cursor:pointer;padding:1.5rem;text-align:center;transition:all .3s ease;width:100%}.selection-card:hover{border-color:#f4c43c;border-color:var(--accent-yellow);box-shadow:0 6px 15px #0000001a;transform:translateY(-2px)}.selection-card h3{color:#0f2e68;color:var(--primary-blue);font-size:1.3rem;margin-bottom:.5rem;margin-top:.5rem}.selection-card p{color:#333;color:var(--text-dark);margin:0;opacity:.8}.selection-card i{color:#3171d1;color:var(--secondary-blue);font-size:2rem}.status-message{width:100%}.signin-content .status-message label{color:#333;color:var(--text-dark);display:block;font-size:1.15rem;font-weight:600}.scan-result.error{color:#d9534f}.scan-result.info{color:#3171d1;color:var(--secondary-blue)}.librarian-form,.password-confirm-form{display:flex;flex-direction:column;gap:1rem;margin-top:.5rem;width:100%}.card-form input{background-color:#f9f9f9;border:1px solid #ccc;border:1px solid var(--input-border);border-radius:6px;font-size:1rem;padding:.8rem 1rem;transition:border-color .2s,box-shadow .2s}.card-form input:focus{border-color:#f4c43c;border-color:var(--accent-yellow);box-shadow:0 0 0 3px #f4c43c4d;outline:none}.password-prompt{color:#333;color:var(--text-dark);font-size:.95rem;margin-bottom:-.5rem;text-align:center}.signin-container .btn-primary{font-size:1rem}.signin-container .btn-primary:hover{background-color:#fbd26a;border:.13em solid #fbd26a;color:#333;color:var(--text-dark)}#reader{border:3px solid #0f2e68;border:3px solid var(--primary-blue);border-radius:8px;box-sizing:border-box;height:250px;margin-bottom:.5rem;margin-top:.5rem;max-width:250px;overflow:hidden;width:100%}#reader video{height:100%;object-fit:cover;transform:scaleX(-1);width:100%}.upload-section{margin-top:.5rem;text-align:center}.upload-btn{background-color:#f4c43c;background-color:var(--accent-yellow);border-radius:6px;color:#0f2e68;color:var(--primary-blue);cursor:pointer;display:inline-block;font-size:.9rem;font-weight:600;padding:.8rem 1.5rem;transition:background-color .2s ease}.upload-btn:hover{background-color:#e4b43a}.forgot-password-text{align-self:flex-end;color:#3171d1;color:var(--secondary-blue);cursor:pointer;display:inline-block;font-size:.9rem;font-weight:500;margin-top:0;transition:color .2s}.forgot-password-text:hover{color:#f4c43c;color:var(--accent-yellow)}.password-reset-instructions{color:#333;color:var(--text-dark);line-height:1.5;padding:1.5rem 1rem;text-align:center}.instructions-title{border-bottom:2px solid #f4c43c;border-bottom:2px solid var(--accent-yellow);color:#0f2e68;color:var(--primary-blue);font-size:1.4rem;margin-bottom:1rem;margin-top:0;padding-bottom:.5rem}.password-reset-instructions p{font-size:1rem;margin-bottom:1rem}.contact-info{color:#0f2e68;color:var(--primary-blue);font-weight:500}.verification-note{font-size:.9rem;opacity:.8}.signin-text-container{align-items:center;color:#fff;color:var(--text-light);display:flex;flex-direction:column;font-size:.9rem;gap:.5rem;margin-top:1rem;text-align:center}.link{color:#f4c43c;color:var(--accent-yellow);cursor:pointer;font-weight:500;text-decoration:underline;transition:color .2s}.link:hover{color:#0f2e68;color:var(--primary-blue)}.back-to-login{font-size:1rem}@media (max-width:768px){.signin-container{padding-top:4rem}.signin-content{margin-top:2rem;max-width:90%;padding:2rem 1.5rem}.back-icon-btn{font-size:1.2rem;left:1rem;top:1rem}.signin-content .status-message label{font-size:1rem}#reader{height:220px;max-width:220px}.btn-primary,.upload-btn{font-size:.9rem;padding:.7rem 1.2rem}.password-reset-instructions{padding:1rem}.initial-selection-container{gap:1rem}.selection-card{padding:1rem}.selection-card h3{font-size:1.2rem}}.signup-page{align-items:center;background:linear-gradient(270deg,#0f2e68,#3171d1);box-sizing:border-box;display:flex;justify-content:center;min-height:100vh;padding:4em 0}.error-text{margin-top:.5em!important}.signup-container{align-items:flex-start;display:flex;gap:0;justify-content:center;margin:auto;max-width:1100px;padding:2em 0;width:90%}.signup-title{font-size:26px;margin-bottom:5px;text-align:center}.signup-description{font-size:14px;margin-bottom:20px;text-align:center}.signup-message{border-radius:5px;font-size:1.2rem;font-weight:600;margin:10px 0;padding:10px;text-align:center;width:100%}.signup-message.success{background-color:#f4c43c;color:#0f2e68}.signup-message.error{background-color:#d84343;color:#fff}.signup-form{background-color:#ffffff80;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;flex:0 1 auto;flex-direction:column;gap:1em;max-width:600px;padding:2em 4em}.generated-qr-area{align-items:center;display:flex;flex:0 0;flex-direction:column;justify-content:flex-start;overflow:hidden;padding:0;width:0}.signup-container.qr-active{gap:4em}.signup-container.qr-active .signup-form{flex:3 1;max-width:none}.signup-container.qr-active .generated-qr-area{flex:2 1;min-width:250px;overflow:visible;padding:20px 0;width:auto}.form-group{display:flex;flex-direction:column}.form-row{display:flex;flex-wrap:wrap;gap:20px}.form-row .form-group{flex:1 1;min-width:0}.form-label{font-size:14px;font-weight:600;margin-bottom:5px}.form-input{border:1px solid #545454;border-radius:6px;font-size:14px;padding:10px;transition:border .2s ease-in-out}.signup-container .form-row:nth-child(3) .form-group:nth-child(2) .form-input{text-transform:capitalize}.form-input:focus{border-color:#007bff;outline:none}#signup-btn{font-size:inherit;margin-top:1.2em}.qr-section{background-color:#ffffffe6;border-radius:10px;box-shadow:0 4px 15px #0003;margin-top:20px;max-width:300px;padding:30px 20px;text-align:center;width:100%}.qr-section p{color:#333;font-size:.8rem}.qr-title{color:#0f2e68;margin-bottom:.8em}.qr-image{background-color:#fff;border:1px solid #ccc;border-radius:6px;height:auto;max-width:100%;padding:5px;width:200px}.qr-actions{display:flex;gap:10px;justify-content:center;margin-top:10px}.btn-secondary{background-color:#f4c43c;border:none;border-radius:6px;color:#222121;cursor:pointer;padding:10px 14px}.btn-secondary:hover{filter:brightness(.95)}.signin-text{font-size:14px;letter-spacing:.1em;margin-top:1em;text-align:center}.signin-link{color:#f4c43c}.signin-link:hover{color:#2d7eff}@media (max-width:900px){.signup-container,.signup-container.qr-active{align-items:center;flex-direction:column;gap:2em;padding:1.5em;width:90%}.signup-container.qr-active .signup-form,.signup-form{flex:none;max-width:500px;min-width:auto;width:100%}.generated-qr-area,.signup-container.qr-active .generated-qr-area{flex:none;min-width:auto;overflow:visible;padding:20px 0;width:100%}}@media (max-width:576px){.signup-form{padding:1em 1.5em}.form-row{flex-direction:column}}.visit-container{background-color:#174996;color:#fff;font-family:Arial,sans-serif;padding-block:8em}.visit-form-content{margin:0 auto;max-width:80%}.visit-title{font-size:32px;font-weight:600;margin-bottom:10px}.visit-intro{font-size:1.1rem;margin-bottom:30px}.info-section{background:#f7f7f7;border-radius:6px;color:#174996;line-height:1.5em;margin-bottom:30px;padding:15px 20px}.info-section h3{font-size:1.3rem;margin-bottom:.8em;margin-top:0}.info-section ul{margin:0;padding-left:18px}.appointment-form{background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;color:#174996;padding:30px}.appointment-form label{display:block;font-size:1.15rem;font-weight:500;margin-bottom:18px}.appointment-form input,.appointment-form select,.appointment-form textarea{border:1px solid #ccc;border-radius:4px;box-sizing:border-box;margin-top:6px;padding:10px;transition:border-color .2s;width:100%}.appointment-form input:focus,.appointment-form select:focus,.appointment-form textarea:focus{border-color:#5b8dee;outline:none}.submit-btn{background:#5b8dee;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:15px;margin-top:10px;padding:12px 30px;transition:background .2s}.submit-btn:hover{background:#4874c6}:root{--red-delete:#dc3545}.category-page,.librarian-category-page{overflow:auto;padding-inline:6em;position:relative}.dashboard-header{color:#f5c542!important;color:var(--accent-yellow)!important}.category-page{background-image:linear-gradient(270deg,#081c4166,#205099cc),url(../../static/media/literature-img.2a5c3f0ae12ba79d1983.jpg);background-position:50%;background-size:cover;height:100vh;padding-top:6em}.category-bg-image{filter:brightness(.6);height:100%;left:0;object-fit:cover;position:absolute;top:0;width:100%;z-index:-1}.category-page-container{margin:4em auto;max-width:90%}.category-header,.librarian-category-header{color:#fff;color:var(--light-text);margin-bottom:30px;text-align:center}.librarian-category-header{text-align:left}.category-title,.librarian-category-title{color:#f5c542;color:var(--accent-yellow);font-size:2.5em;margin-bottom:1.4em;text-align:center}.librarian-category-title{color:#0f2e68;color:var(--primary-blue);text-align:left}.category-list-container{background-color:#ffffffb3;border-radius:8px;padding:2em}.category-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));list-style:none;padding:0}.category-item{align-items:center;background-color:#ffffff80;border-radius:8px;box-shadow:0 2px 5px #0000001a;color:#333;color:var(--dark-text);cursor:pointer;display:flex;font-size:1.1em;font-weight:700;gap:.6em;justify-content:center;margin-bottom:.5em;padding:1em 1.4em;text-align:center;transition:background-color .3s ease,transform .2s ease}.category-item:hover{background-color:#d4e3f0;box-shadow:0 4px 10px #00000026;transform:translateY(-3px)}.category-disclaimer{color:#fff;color:var(--light-text);font-size:1em;margin-top:1em;text-align:center}.category-page.book-list-view{padding-top:10em}.add-book-btn{background-color:#f5c542;background-color:var(--accent-yellow);border:none;border-radius:8px;color:#0f2e68;color:var(--primary-blue);cursor:pointer;font-size:1rem;font-weight:700;margin-bottom:0;padding:.75rem 1.25rem;transition:background-color .2s ease}.add-book-btn:hover{background-color:#e4b43a}.search-inputs-container{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-bottom:25px}.category-search,.search-input{background-color:#fff;background-color:var(--light-text);border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:5px;color:#333;color:var(--dark-text);flex-grow:1;font-size:1em;max-width:100%;padding:10px 15px}.category-search:focus,.search-input:focus{background-color:#fff;background-color:var(--light-text);border-color:#0f2e68;border-color:var(--primary-blue);outline:2px solid #f5c542;outline:2px solid var(--accent-yellow)}.category-search{max-width:100%;width:30%}.back-to-categories{background-color:#6c757d;border:none;border-radius:8px;color:#fff;color:var(--light-text);cursor:pointer;font-size:1rem;font-weight:700;padding:.75rem 1.25rem;transition:background-color .2s ease;white-space:nowrap}.back-to-categories:hover{background-color:#5a6268}.book-container{background-color:#ffffffbf;border-radius:8px;box-shadow:0 4px 12px #0000001a;display:grid;grid-template-columns:2fr 1.5fr 1fr 1.5fr;grid-template-columns:var(--book-grid-columns,2fr 1.5fr 1fr 1.5fr)}.book-header,.book-row{display:contents}.book-header>div,.book-row>div{border-bottom:1px solid #e1e5e8;border-bottom:1px solid var(--border-color);padding:1rem 1.5rem;text-align:left;text-overflow:ellipsis;white-space:nowrap}.book-row:last-of-type>div{border-bottom:none}.book-row:hover>div{background-color:#f0f4f8}.book-header>div{color:#0f2e68;color:var(--primary-blue);font-size:.9rem;font-weight:700;text-transform:uppercase}.book-status{font-weight:600;text-align:center}.book-actions{flex-wrap:wrap;position:relative}.book-status.available{color:#28a745;color:var(--green-confirm)}.book-status.missing{color:#dc3545;color:var(--red-delete)}.librarian-form input{padding:.8em .5em}.librarian-form{display:flex;flex-direction:column;gap:1em;width:100%}.btn-action{border:none;border-radius:4px;cursor:pointer;font-size:.9em;min-width:100px;padding:8px 12px;text-align:center;transition:background-color .2s ease;white-space:nowrap}.btn-action:hover{opacity:.9}.btn-action.toggle-btn.mark-borrowed{background-color:#007bff;color:#fff;color:var(--light-text)}.btn-action.toggle-btn.mark-borrowed:hover{background-color:#0056b3}.btn-action.toggle-btn.mark-available{background-color:#28a745;background-color:var(--green-confirm);color:#fff;color:var(--light-text)}.btn-action.toggle-btn.mark-available:hover{background-color:#218838}.btn-action.borrow-btn{background-color:#0f2e68;background-color:var(--primary-blue);color:#fff;color:var(--light-text)}.btn-action.borrow-btn:hover:not(:disabled){background-color:#0f2e68c0}.btn-action.borrow-btn:disabled{background-color:#ccc;color:#666;cursor:not-allowed}.no-books-found{color:#666;font-style:italic;grid-column:1/-1;padding:2rem;text-align:center}.add-edit-form-modal-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.add-edit-form-modal-content{animation:fadeIn .3s ease-out;background:#fff;border-radius:8px;box-shadow:0 8px 25px #0000004d;max-height:80vh;max-width:500px;overflow-y:auto;padding:2rem;width:90%}.add-edit-form-modal-content h3{color:#0f2e68;color:var(--primary-blue);font-size:1.8rem;margin-bottom:1.5rem;text-align:center}.add-edit-book-form{width:100%}.add-edit-book-form label{color:#333;color:var(--dark-text);display:flex;flex-direction:column;font-weight:500;margin-bottom:1rem}.add-edit-book-form input,.add-edit-book-form select{background-color:#f4f7fa;background-color:var(--background-gray);border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:5px;box-sizing:border-box;color:#333;color:var(--dark-text);font-size:1rem;margin-top:.3rem;padding:.75rem;width:100%}.add-edit-book-form input:focus,.add-edit-book-form select:focus{background-color:#fff;background-color:var(--light-text);border-color:#0f2e68;border-color:var(--primary-blue);outline:2px solid #f5c542;outline:2px solid var(--accent-yellow)}.add-edit-book-form .form-actions{align-items:center;display:flex;gap:1rem;justify-content:center;margin-top:2rem}.add-edit-book-form .btn-primary{background-color:#0f2e68;background-color:var(--primary-blue);border:none;border-radius:8px;color:#fff;color:var(--light-text);font-size:1rem;font-weight:700;margin-bottom:0;padding:.8rem 1.5rem}.add-edit-book-form .btn-primary:hover{background-color:#1a3b7a}.add-edit-book-form .btn-secondary{background-color:#ccc;border-radius:8px;color:#333;color:var(--dark-text);font-weight:700;padding:.8rem 1.5rem}.add-edit-book-form .btn-secondary:hover{background-color:#b0b0b0}@media (max-width:992px){.book-container{grid-template-columns:2fr 1.5fr 1fr 1.5fr;grid-template-columns:var(--book-grid-columns,2fr 1.5fr 1fr 1.5fr)}.book-container[style*="--book-grid-columns"]:has(.book-isbn){grid-template-columns:2fr 1.2fr .8fr 1fr 2fr;grid-template-columns:var(--book-grid-columns,2fr 1.2fr .8fr 1fr 2fr)}.book-actions{align-items:flex-end;flex-direction:column;gap:.5rem}.kebab-dropdown-menu{left:auto;right:0}}@media (max-width:1024px){.category-page{padding-inline:3em}.category-title{font-size:2em}.search-inputs-container{flex-direction:row;flex-wrap:wrap;justify-content:center}.book-container{display:block;overflow-x:auto}.book-header,.book-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.book-header>div,.book-row>div{padding:.75em}}@media (max-width:768px){.category-page{padding-inline:1.5em;padding-top:5em}.category-title{font-size:1.7em}.category-search{margin:0 0 10px;width:100%}.category-list{gap:1em;grid-template-columns:1fr 1fr}.category-item{font-size:1em;padding:.8em}.search-inputs-container{align-items:stretch;flex-direction:column;gap:10px}.add-book-btn,.back-to-categories,.search-input{max-width:none;text-align:center;width:100%}.book-container{display:flex;flex-direction:column;gap:1em;overflow:visible}.book-header{display:none}.book-row{background-color:#ffffffb3!important;border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:10px;box-shadow:0 2px 6px #0000001a;display:flex;flex-direction:column;padding:1em}.book-row>div{border:none;padding:.4em 0}.book-title{font-size:1.1em;font-weight:700;margin-bottom:.2em}.book-author,.book-isbn,.book-status{font-size:.95em}.book-actions{align-items:stretch;flex-direction:column;gap:.5em;margin-top:.6em}.btn-action{font-size:.95em;padding:.7em;width:100%}.kebab-button{align-self:flex-end}.add-edit-form-modal-content{padding:1.5em;width:90%}.category-search,.search-input{box-sizing:border-box;max-width:100%;width:100%}}.pagination-container{gap:6px;margin-bottom:2em;margin-top:20px}.pagination-btn{background:#fff;border:1px solid #555;border-radius:4px;cursor:pointer;font-size:14px;padding:5px 12px}.pagination-btn:hover{background:#eaeaea}.pagination-btn.active{background:#007bff;border-color:#007bff;color:#fff}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:480px){.category-title{font-size:1.5em}.category-item{font-size:.9em;padding:.6em}.book-row{padding:.8em}.btn-action{padding:.6em}.btn-action,.search-input{font-size:.9em}}.success-notification{align-items:center;animation:slideIn .3s ease,fadeOut .3s ease 2.7s forwards;background-color:#4bb543;border-radius:10px;box-shadow:0 4px 12px #00000026;color:#fff;display:flex;font-size:1rem;padding:1rem 1.5rem;position:fixed;right:20px;top:20px;z-index:9999}.success-content{align-items:center;display:flex;gap:10px}.checkmark{font-size:1.3rem}@keyframes slideIn{0%{opacity:0;transform:translateX(100px)}to{opacity:1;transform:translateX(0)}}@keyframes fadeOut{to{opacity:0;transform:translateX(100px)}}.borrow-request-page{align-items:center;display:flex;font-family:sans-serif;justify-content:center;margin:0 auto;max-width:1000px;min-height:calc(100vh - 60px);padding:2rem 5%}.borrow-request-container{background-color:#fff;background-color:var(--light-text);border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 6px 20px #0000001a;margin-top:6em;max-width:550px;padding:5rem 3rem 3rem;position:relative;text-align:center;width:100%}.btn-secondary.back-button{left:1.2em;position:absolute;top:1em}.borrow-request-title{color:#0f2e68;color:var(--primary-blue);font-size:2.2rem;font-weight:700;margin-bottom:1rem}.borrow-request-title span{color:#333;color:var(--dark-text);font-weight:400}.book-details{color:#333;color:var(--dark-text);font-size:1.1rem;line-height:1.5;margin-bottom:.5rem}.borrow-form{margin-top:2.5rem;text-align:left}.borrow-form label{color:#0f2e68;color:var(--primary-blue);display:block;font-size:1rem;font-weight:600;margin-bottom:.6rem;margin-top:1.5rem}.borrow-form input[type=date],.borrow-form input[type=time]{background-color:#f4f7fa;background-color:var(--background-gray);border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:8px;box-sizing:border-box;color:#333;color:var(--dark-text);font-size:1rem;padding:.8rem;width:100%}.borrow-form input[type=date]:focus,.borrow-form input[type=time]:focus{background-color:#fff;background-color:var(--light-text);border-color:#0f2e68;border-color:var(--primary-blue);outline:2px solid #f5c542;outline:2px solid var(--accent-yellow)}.submit-borrow-btn{background-color:#f5c542;background-color:var(--accent-yellow);border:none;border-radius:8px;color:#0f2e68;color:var(--primary-blue);cursor:pointer;font-size:1.2rem;font-weight:700;margin-top:2.5rem;padding:1rem 2rem;transition:background-color .3s ease,transform .2s ease;width:100%}.submit-borrow-btn:hover{background-color:#e4b43a;transform:translateY(-2px)}.submission-message{border-radius:8px;font-size:1rem;font-weight:500;margin-top:1.5rem;padding:1rem;text-align:center}.submission-message:contains("successfully"){background-color:#d4edda;border:1px solid #c3e6cb;color:#28a745;color:var(--success-color)}.submission-message:contains("failed"){background-color:#f8d7da;border:1px solid #f5c6cb;color:#dc3545;color:var(--error-color)}@media (max-width:768px){.borrow-request-container{padding:2rem}.borrow-request-title{font-size:1.8rem}.book-details{font-size:1rem}}.student-dashboard-page{background-image:linear-gradient(270deg,#081c4166,#205099cc),url(../../static/media/library-image.469f3c798ba4036a1a6f.jpg);background-position:50%;background-size:cover;display:flex;justify-content:center}.student-dashboard-container{color:#fff;color:var(--light-text);display:flex;flex-direction:column;font-family:sans-serif;justify-content:center;margin-top:8em;max-width:80%;min-width:75%}.student-dashboard-welcome{font-size:2.5rem;font-weight:700;margin-bottom:0;text-align:center}.student-dashboard-subtitle{color:#f4f7fa;color:var(--background-gray);font-size:1.1rem;text-align:center}.student-dashboard-top{align-items:stretch;display:flex;gap:2rem;justify-content:space-between;margin-bottom:2rem}.student-dashboard-welcome-section{border-radius:8px;color:#fff;color:var(--light-text);display:flex;flex:1 1;flex-direction:column;justify-content:center;text-align:left}.dashboard-card,.stat-card,.student-dashboard-card{background-color:#ffffffb3!important}.occupancy-card{flex:1 1}@media (max-width:992px){.student-dashboard-top{flex-direction:column}}.student-dashboard-card{border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 6px #0000000d;color:#0f2e68;color:var(--primary-blue);margin-bottom:2rem;padding:1.5rem;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.student-dashboard-card:hover{box-shadow:0 3px 10px #0000001a;transform:translateY(-3px)}.student-dashboard-occupancy-count.full{color:#dc3545;color:var(--red-overdue)}.student-dashboard-occupancy-count{color:#0f2e68;color:var(--primary-blue);font-size:2.2rem;font-weight:700;margin:.5rem 0;transition:transform .3s ease,color .3s ease}.student-dashboard-occupancy-count.full{color:#d9534f}.student-dashboard-occupancy-count.pulse{animation:occupancyPulse .6s ease}@keyframes occupancyPulse{0%{color:#0f2e68;color:var(--primary-blue);text-shadow:none;transform:scale(1)}40%{color:#f5c542;color:var(--accent-yellow,#f4b400);text-shadow:0 0 10px #ffd70080;transform:scale(1.25)}to{color:#0f2e68;color:var(--primary-blue);text-shadow:none;transform:scale(1)}}.student-dashboard-status-text{color:#333;color:var(--dark-text);font-size:1rem}.student-stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:3rem}.student-stats-grid .stat-card{background-color:#ffffffb3;border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:1.5rem;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.student-stats-grid .stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-5px)}.student-stats-grid .stat-card h2{color:#0f2e68;color:var(--primary-blue);font-size:1rem;font-weight:600;margin:0 0 .5rem;text-transform:uppercase}.student-stats-grid .stat-card p{color:#0f2e68;color:var(--primary-blue);font-size:2.5rem;font-weight:700;margin:.5rem 0 1rem}.student-stats-grid .stat-card p.overdue{color:#dc3545;color:var(--red-overdue)}.view-details-link{border-bottom:2px solid #f5c542;border-bottom:2px solid var(--accent-yellow);color:#0f2e68;color:var(--primary-blue);display:inline-block;font-weight:600;padding-bottom:2px;text-decoration:none;transition:color .2s ease,border-color .2s ease}.view-details-link:hover{border-color:#0f2e68;border-color:var(--primary-blue);color:#1a3b7a}.student-announcements-recommendations-container{display:flex;gap:5em;justify-content:space-between;margin:auto;width:100%}.student-announcements,.student-recommendations{border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 4px #0000000d;color:#000;display:flex;flex-direction:column;padding-bottom:1.8em;padding-inline:3em}.card-icon{font-size:1.2em;margin-right:8px;vertical-align:middle}.student-announcements ul{list-style:none;margin-block:0}.student-announcements h2{color:#0f2e68;color:var(--primary-blue);font-size:1.8rem}.student-announcements .announcement-list{margin-bottom:1.5rem;padding-left:0;text-align:left}.action-buttons-container{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.error-message,.loading-message{border-radius:8px;margin-top:1rem;padding:1rem;text-align:center}.loading-message{background-color:#e9ecef;color:#495057}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.student-announcements-recommendations-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-bottom:3rem}.student-announcements h2,.student-recommendations h2{border-bottom:1px solid #e1e5e8;border-bottom:1px solid var(--border-color);color:#0f2e68;color:var(--primary-blue);font-size:1.5rem;margin-bottom:1rem;margin-top:0;padding-bottom:.5rem}.announcement-list{list-style:none;margin-bottom:1.5rem;padding:0}.announcement-list li{color:#333;color:var(--dark-text);font-size:1rem;line-height:1.4;margin-bottom:.8rem}.announcement-list li:last-child{margin-bottom:0}.announcement-list .announcement-date{color:#999;font-size:.85rem;margin-left:.5em}.recommended-books-grid{display:flex;flex-direction:column;gap:.8rem;margin-top:1rem}.recommended-book-card{align-items:center;background-color:#fff9!important;border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 1px 3px #0000000d;display:flex;justify-content:space-between;padding:2rem 1rem;transition:transform .2s ease,box-shadow .2s ease}.recommended-book-card:hover{box-shadow:0 3px 8px #0000001a;transform:translateY(-3px)}.recommended-book-card p{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#333;color:var(--dark-text);display:-webkit-box;font-size:.95rem;line-height:1.3;overflow:hidden;text-overflow:ellipsis}.recommended-book-card p strong{color:#0f2e68;color:var(--primary-blue);font-size:1rem}.recommended-book-card .book-author-small{color:#666;font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.announcement-pagination-controls{align-items:center;border-top:1px solid #e1e5e8;border-top:1px solid var(--border-color);color:#333;color:var(--dark-text);display:flex;font-size:.9rem;justify-content:space-between;margin-top:1.5rem;padding-top:.5rem}.btn-pagination{background-color:#0f2e68;background-color:var(--primary-blue);border:none;border-radius:4px;color:#fff;color:var(--light-text);cursor:pointer;font-weight:600;padding:.5rem .8rem;transition:background-color .2s}.btn-pagination:hover:not(:disabled){background-color:#1a3b7a}.btn-pagination:disabled{background-color:#ccc;cursor:not-allowed;opacity:.6}.borrow-recommendation-btn{background-color:#f5c542;background-color:var(--accent-yellow);border:none;border-radius:6px;color:#0f2e68;color:var(--primary-blue);cursor:pointer;display:inline-block;font-size:.9rem;font-weight:700;padding:.6rem 1rem;text-decoration:none;transition:background-color .2s ease}.borrow-recommendation-btn:hover{background-color:#e4b43a}@media (max-width:992px){.student-dashboard-welcome{font-size:2rem}.student-announcements-recommendations-container,.student-stats-grid{grid-template-columns:1fr}}@media (max-width:768px){.student-announcements-recommendations-container{gap:1.5rem}.recommended-books-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.student-quick-actions h2{font-size:1.5rem}.action-buttons-container{flex-direction:column;gap:1rem}.student-action-btn{min-width:0;min-width:auto;width:100%}}@media (max-width:576px){.student-dashboard-welcome{font-size:1.8rem}.student-dashboard-subtitle{font-size:1rem}}@media (max-width:768px){.student-recommendations.dashboard-card{align-items:center;display:flex;flex-direction:column;justify-content:center}.recommended-book-card .btn-action.borrow-recommendation-btn{width:50%}}.borrowed-books-page{background-color:#a0b2d3;display:flex;justify-content:center;min-height:100vh;overflow-x:hidden;padding-inline:2em}.borrowed-books-container{background-color:#fff;background-color:var(--light-text);border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 6px 20px #00000014;margin-block:8em 2em;max-width:1200px;padding:2.5rem;width:90%}.borrow-requests-table-wrapper,.borrowed-books-table-wrapper{-webkit-overflow-scrolling:touch;border-radius:8px;margin-top:1rem;overflow-x:auto}.borrowed-books-list{border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:8px;display:grid;grid-template-columns:2fr 1.5fr 1fr 1fr 1fr;min-width:900px}.borrowed-books-title{font-size:2.2rem;font-weight:700;margin-bottom:.8rem}.borrow-requests-title,.borrowed-books-title{color:#0f2e68;color:var(--primary-blue);text-align:center}.borrow-requests-title{font-size:1.8em;margin-top:3em}.borrow-requests-table-wrapper{background-color:#f7f9fc;border-radius:10px;box-shadow:0 0 10px #0000000d;margin-top:1.5em;padding:1.5em}.borrow-requests-list{background-color:#fff;border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:8px;display:grid;grid-template-columns:repeat(6,1fr);min-width:1100px}.borrowed-books-description,.no-borrowed-books{color:#666;font-size:1.1rem;margin-bottom:2rem;text-align:center}.no-borrowed-books{background-color:#f4f7fa;background-color:var(--background-gray);border-radius:8px;font-style:italic;padding:1.5rem}.borrowed-book-header{display:contents}.borrowed-book-header>div{background-color:#f4f7fa;background-color:var(--background-gray);border-bottom:1px solid #e1e5e8;border-bottom:1px solid var(--border-color);color:#0f2e68;color:var(--primary-blue);font-size:.9rem;font-weight:700;padding:1rem 1.2rem;text-align:left;text-transform:uppercase}.borrowed-book-row{display:contents}.borrowed-book-row>div{border-bottom:1px solid #e1e5e8;border-bottom:1px solid var(--border-color);color:#333;color:var(--dark-text);font-size:.95rem;padding:1rem 1.2rem;text-align:left;white-space:normal}.borrowed-book-row:last-of-type>div{border-bottom:none}.borrowed-book-row:hover>div{background-color:#f0f4f8}.book-borrow-date,.book-due-date{color:#666;font-size:.9em}.book-status{font-weight:700}.book-status.borrowed{color:#0f2e68;color:var(--primary-blue)}.book-status.returned{color:#28a745;color:var(--green-success)}.book-due-date.overdue-date,.book-status.overdue{color:#dc3545;color:var(--red-overdue)}.book-due-date.overdue-date{font-weight:700}.btn-action.renew-btn{background-color:#f5c542;background-color:var(--accent-yellow);border-radius:6px;color:#0f2e68;color:var(--primary-blue);font-size:.9rem;font-weight:700;padding:.6rem 1rem;transition:background-color .2s ease}.btn-action.renew-btn:hover{background-color:#e4b43a}@media (max-width:992px){.borrowed-books-list{min-width:700px}.borrow-requests-list{min-width:900px}.borrowed-books-container{padding:2rem}.borrow-requests-title,.borrowed-books-title{font-size:1.7rem}}@media (max-width:576px){.borrowed-books-list{min-width:600px}.borrow-requests-list{min-width:750px}.borrowed-books-container{padding:1.5rem}.borrow-requests-title,.borrowed-books-title{font-size:1.5rem}.btn-action.renew-btn{font-size:.8rem;padding:.5rem .8rem}}:root{--red-cancel:#dc3545;--green-confirm:#28a745;--yellow-pending:#ffc107}.manage-student-appointments-page{background-color:#a0b2d3;display:flex;justify-content:center;min-height:100vh}.manage-student-appointments-container{background-color:#174996a6;border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:15px;box-shadow:0 6px 20px #00000014;margin:auto;max-width:80%;min-width:70%;overflow-x:hidden;padding:3rem 2.5em;width:70%}.manage-student-appointments-title{color:#0f2e68;color:var(--primary-blue);font-size:2.2rem;font-weight:700;line-height:.8;margin:0 0 .4em;text-align:center}.manage-student-appointments-description,.no-appointments{color:#333;color:var(--dark-text);font-size:1.1rem;line-height:1.1;margin-bottom:2rem;margin-top:0;text-align:center}.no-appointments{background-color:#f4f7fa;background-color:var(--background-gray);border-radius:8px;font-style:italic;padding:1.5rem}.student-appointments-list{border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:8px;display:grid;grid-template-columns:1.2fr 1fr 2fr 1fr 1.5fr;overflow:hidden}.student-appointment-header{display:contents}.student-appointment-header>div{background-color:#f4f7fa;background-color:var(--background-gray);border-bottom:1px solid #e1e5e8;border-bottom:1px solid var(--border-color);color:#0f2e68;color:var(--primary-blue);font-size:.9rem;font-weight:700;padding:1rem 1.2rem;text-align:center;text-transform:uppercase}.student-appointment-row{display:contents}.student-appointment-row>div{align-items:center;background-color:#fff;border-bottom:1px solid #e1e5e8;border-bottom:1px solid var(--border-color);color:#333;color:var(--dark-text);display:flex;font-size:.95rem;justify-content:center;overflow:hidden;padding:1rem 1.2rem;text-overflow:ellipsis;white-space:nowrap}.student-appointment-row:last-of-type>div{border-bottom:none}.student-appointment-row:hover>div{background-color:#f0f4f8}.appointment-status.pending{border-radius:0;color:#ffc107;color:var(--yellow-pending);font-size:.85em;font-weight:700;white-space:nowrap}.appointment-status.confirmed{color:#28a745;color:var(--green-confirm)}.appointment-status.cancelled,.appointment-status.confirmed{font-size:.85em;font-weight:700;padding:.3em .6em;white-space:nowrap}.appointment-status.cancelled{color:#dc3545;color:var(--red-cancel)}.appointment-actions{align-items:center;display:flex;gap:.5rem;justify-content:flex-end}.btn-action.cancel-appointment-btn{background-color:#dc3545;background-color:var(--red-cancel);border-radius:6px;color:#fff;color:var(--light-text);font-size:.9rem;font-weight:700;padding:.6rem 1rem;transition:background-color .2s ease}.btn-action.cancel-appointment-btn:hover{background-color:#c82333}.btn-action.view-details-btn{background-color:#007bff;background-color:var(--blue-info);border-radius:6px;color:#fff;color:var(--light-text);font-size:.9rem;font-weight:700;padding:.6rem 1rem;transition:background-color .2s ease}.btn-action.view-details-btn:hover{background-color:#0069d9}@media (max-width:992px){.student-appointments-list{grid-template-columns:1.2fr 1fr 1.5fr 1fr 1.5fr}}@media (max-width:768px){.manage-student-appointments-container{padding:1.5rem;width:70%}.manage-student-appointments-title{font-size:1.8rem}.student-appointments-list{grid-template-columns:1.2fr 1fr 1fr 1fr 1fr}.appointment-actions{flex-direction:column;justify-content:center}.btn-action.cancel-appointment-btn,.btn-action.view-details-btn{text-align:center;width:100%}}@media (max-width:576px){.student-appointments-list{display:block}.student-appointment-header{display:none}.student-appointment-row{background:#fff;border-radius:8px;box-shadow:0 2px 5px #00000014;display:block;margin-bottom:1rem;overflow:hidden}.student-appointment-row>div{border-bottom:1px solid #e1e5e8;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1rem 1.5rem;text-align:left;white-space:normal}.student-appointment-row>div:last-child{border-bottom:none}.appointment-date:before{content:"Date: "}.appointment-date:before,.appointment-time:before{color:#0f2e68;color:var(--primary-blue);font-weight:700}.appointment-time:before{content:"Time: "}.appointment-purpose:before{content:"Purpose: "}.appointment-purpose:before,.appointment-status:before{color:#0f2e68;color:var(--primary-blue);font-weight:700}.appointment-status:before{content:"Status: "}.appointment-actions:before{color:#0f2e68;color:var(--primary-blue);content:"Actions: ";font-weight:700;margin-right:.5rem}.appointment-actions{flex-direction:row;gap:.5rem;justify-content:flex-start}.btn-action.cancel-appointment-btn,.btn-action.view-details-btn{flex:0 1}}.overdue-books-page{background-color:#a0b2d3;display:flex;height:100vh}.overdue-books-container{background-color:#fff;background-color:var(--light-text);border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 6px 20px #00000014;margin:auto;padding:2.5rem;width:70%}.overdue-books-table-wrapper{border-radius:8px;overflow-x:auto}.overdue-books-title{color:#dc3545;color:var(--red-overdue);font-size:2.2rem;font-weight:700;margin-bottom:.8rem;text-align:center}.no-overdue-books,.overdue-books-description{color:#666;font-size:1.1rem;margin-bottom:2rem;text-align:center}.no-overdue-books{background-color:#f4f7fa;background-color:var(--background-gray);border-radius:8px;font-style:italic;padding:1.5rem}.overdue-books-list{border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:8px;display:grid;grid-template-columns:2fr 1.5fr 1fr 1fr 1fr;min-width:800px;overflow:hidden}.overdue-book-header{display:contents}.overdue-book-header>div{background-color:#f4f7fa;background-color:var(--background-gray);border-bottom:1px solid #e1e5e8;border-bottom:1px solid var(--border-color);color:#0f2e68;color:var(--primary-blue);font-size:.9rem;font-weight:700;padding:1rem 1.2rem;text-align:left;text-transform:uppercase}.overdue-book-row{display:contents}.overdue-book-row>div{border-bottom:1px solid #e1e5e8;border-bottom:1px solid var(--border-color);color:#333;color:var(--dark-text);font-size:.95rem;overflow:visible;padding:1rem 1.2rem;text-overflow:clip;white-space:normal}.overdue-book-row:last-of-type>div{border-bottom:none}.overdue-book-row:hover>div{background-color:#f0f4f8}.book-author,.book-title{font-weight:500}.book-borrow-date,.book-days-overdue,.book-due-date{color:#666;font-size:.9em}.book-days-overdue,.book-due-date{color:#dc3545;color:var(--red-overdue);font-weight:700}.book-actions{align-items:center;display:flex;gap:.5rem;justify-content:flex-end}@media (max-width:576px),(max-width:768px),(max-width:992px){.overdue-books-list{grid-template-columns:2fr 1.5fr 1fr 1fr 1fr}.overdue-book-header>.header-author,.overdue-book-header>.header-borrow-date,.overdue-book-header>.header-days-overdue,.overdue-book-row>.book-author,.overdue-book-row>.book-borrow-date,.overdue-book-row>.book-days-overdue{display:block}}.edit-profile-page{align-items:flex-start;background:linear-gradient(270deg,#0f2e68,#3171d1);display:flex;justify-content:center;min-height:100vh;padding-block:10em}.edit-profile-container{background:#fff;border-radius:12px;box-shadow:0 4px 15px #0000001a;max-width:600px;padding:30px 40px;transition:all .3s ease;width:100%}.edit-profile-container h1{border-bottom:2px solid #e0e0e0;color:#004d99;font-size:1.8em;margin-bottom:25px;padding-bottom:10px;text-align:center}.edit-profile-container h2{color:#333;font-size:1.2em;margin-bottom:15px;margin-top:30px}.profile-form label{color:#555;display:block;font-weight:600;margin-bottom:5px;margin-top:15px}.profile-form input[type=email],.profile-form input[type=number],.profile-form input[type=password],.profile-form input[type=text]{border:1px solid #ccc;border-radius:6px;box-sizing:border-box;font-size:1em;margin-bottom:15px;padding:10px 12px;transition:border-color .3s;width:100%}.profile-form input:focus:not([disabled]){border-color:#007bff;outline:none}.profile-form input[disabled]{background-color:#e9ecef;color:#6c757d;cursor:not-allowed}.profile-form .btn-primary{font-size:1em;margin-left:50%;margin-top:2em;transform:translateX(-50%)}.status-message{border-radius:6px;font-weight:500;margin-bottom:20px;padding:10px;text-align:center}.status-message.success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.status-message.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}:root{--red-overdue:#dc3545;--green-success:#28a745;--orange-warn:#ffc107;--blue-info:#007bff}.dashboard-container{display:flex;font-family:sans-serif;min-height:100vh}.dashboard-sidebar{background:linear-gradient(0deg,#0f2e68,#3171d1);color:#fff;color:var(--light-text);height:100%;position:fixed;width:20%}.sidebar-container{align-items:center;display:flex;flex-direction:column;height:80%;justify-content:space-between;margin-top:3.5em}.librarian-page-content{display:flex;flex-direction:column;justify-content:center;margin:auto;margin-block:4em;max-width:80%;min-width:75%}.librarian-page-content .page-description{margin-bottom:1.2em;text-align:center}.dashboard-sidebar .header-logo-link{display:flex;flex-direction:column;gap:1em;text-align:center;text-decoration:none}.dashboard-sidebar .school-name{color:#fff;color:var(--light-text);font-size:1.1em;font-weight:700;margin-left:0;padding-inline:1.3em}.dashboard-sidebar .dropdown-menu{padding-left:0}.dashboard-sidebar .logo{height:auto;margin-bottom:.5em;width:50px}.dashboard-sidebar .sidebar-nav{width:100%}.sidebar-nav a{border-left:4px solid #0000;color:#c4d0e3;display:block;font-size:1rem;font-weight:500;padding:1rem 1.5rem;text-decoration:none;transition:background-color .2s ease,color .2s ease}.sidebar-nav a:hover{background-color:#1a3b7a;color:#fff;color:var(--light-text)}.sidebar-nav a.active{background-color:#1a3b7a80;border-left:4px solid #f5c542;border-left:4px solid var(--accent-yellow);color:#fff;color:var(--light-text);font-weight:700}.dashboard-content{background:linear-gradient(0deg,#a0b2d3,#f4f7fa);flex-grow:1;margin-left:20%;overflow-y:auto}.dashboard-header{border-bottom:1px solid #e1e5e8;border-bottom:1px solid var(--border-color);color:#0f2e68;color:var(--primary-blue);font-size:2rem;font-weight:700;margin-bottom:2rem;padding-bottom:1rem}.sidebar-profile-icon{color:#c4d0e3;cursor:pointer;font-size:2rem;margin-top:auto;opacity:.7;padding:1rem;position:relative;text-align:center}.librarian-greeting{color:#0f2e68;color:var(--primary-blue);font-size:1.2rem;font-weight:700;position:absolute;right:1.5rem;top:1.5rem}.dashboard-sidebar .dropdown-menu{background:#fff;background:var(--light-text);border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:6px;color:#333;color:var(--dark-text);left:50%;list-style:none;margin:0;min-width:150px;padding:.5em 0;position:absolute;top:100%;transform:translateX(-50%);z-index:20}.dashboard-sidebar .dropdown-menu li{cursor:pointer;padding:.7em 1em}.dashboard-sidebar .dropdown-menu li:hover{background-color:#f4f7fa;background-color:var(--background-gray)}.stat-cards-container{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:2rem}.stat-card{background-color:#fff;border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-5px)}.stat-card h2{color:#555;font-size:1rem;font-weight:600;margin:0 0 .5rem;text-transform:uppercase}.stat-card p{color:#0f2e68;color:var(--primary-blue);font-size:2.5rem;font-weight:700;margin:0}.dashboard-sections-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-top:2rem}.dashboard-card{background-color:#fff;border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:1.5rem}.dashboard-card h2{border-bottom:1px solid #e1e5e8;border-bottom:1px solid var(--border-color);color:#0f2e68;color:var(--primary-blue);font-size:1.3rem;margin-bottom:1rem;margin-top:0;padding-bottom:.5rem}.dashboard-card ul{list-style:none;padding:0}.dashboard-card li{color:#333;color:var(--dark-text);font-size:1rem;line-height:1.4;margin-bottom:.8rem}.dashboard-card li:last-child{margin-bottom:0}.no-records{color:#666;font-style:italic;padding:1rem;text-align:center}.recent-activity li{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.recent-activity .activity-type{display:none}.recent-activity .activity-date{color:#999;display:block;font-size:.9rem;margin-top:.2em}.pending-actions .pending-section{margin-bottom:1.5rem}.pending-actions .pending-section:last-child{margin-bottom:0}.pending-actions .pending-section h3{border-bottom:1px dashed #e1e5e8;border-bottom:1px dashed var(--border-color);color:#333;color:var(--dark-text);font-size:1rem;font-weight:600;margin:0 0 .8rem;padding-bottom:.3rem;text-transform:capitalize}.pending-actions li{color:#333;color:var(--dark-text);margin-bottom:.5rem}.pending-actions li:last-child{margin-bottom:0}.pending-actions .book-title-small{color:#0f2e68;color:var(--primary-blue);font-weight:700}.pagination-controls{border-top:1px solid #eee;gap:5px;margin-top:15px;padding-top:10px}.pagination-button{background-color:#f0f0f0;font-size:.85em;min-width:30px;padding:5px 10px;transition:background-color .2s}.pagination-button:hover{background-color:#e0e0e0}.pagination-button.active-page{background-color:#004d99;border-color:#004d99}.data-table-container{background-color:#fff;border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 4px #0000000d;overflow-x:auto;padding:1.6em 2.5em}.data-table{border-collapse:collapse;display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));grid-template-columns:var(--data-table-grid-columns,repeat(auto-fit,minmax(100px,1fr)));width:100%}.appointments-table{grid-template-columns:1fr 2fr 1.5fr 1.5fr 1.5fr 1fr 2fr!important}.filter-controls-appointments{align-items:center;display:flex;gap:15px;justify-content:center;margin-bottom:25px}.filter-controls-appointments select.status-select{background-color:#f4f7fa;background-color:var(--background-gray);border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-size:1rem;padding:10px 15px}.appointment-status.completed{background-color:#cce5ff;color:#004085}.data-table td,.data-table th{border-bottom:1px solid #e1e5e8;border-bottom:1px solid var(--border-color);color:#333;color:var(--dark-text);font-size:.95rem;padding:1rem 1.2rem;text-align:left}.data-table tbody,.data-table thead,.data-table tr{display:contents}.data-table th{background-color:#f4f7fa;background-color:var(--background-gray);color:#0f2e68;color:var(--primary-blue);font-size:.85rem;font-weight:700;text-transform:uppercase}.data-table tbody tr:hover>td{background-color:#f0f4f8}.data-table tbody tr:last-of-type>td{border-bottom:none}.student-status{border-radius:4px;font-size:.85em;font-weight:700;padding:.3em .6em}.student-status.active{background-color:#d4edda;color:#155724}.student-status.suspended{background-color:#f8d7da;color:#721c24}.appointment-status{border-radius:4px;font-size:.85em;font-weight:700;padding:.3em .6em}.appointment-status.pending{background-color:#fff3cd;color:#856404}.appointment-status.confirmed{background-color:#d4edda;color:#155724}.appointment-status.cancelled{background-color:#f8d7da;color:#721c24}.no-records-found{color:#6c757d;font-style:italic;grid-column:1/-1;padding:1.5rem;text-align:center}.table-actions-cell{justify-content:flex-end}.kebab-menu-container{align-items:center;display:flex;position:relative}.kebab-button{background:none;border:none;color:#0f2e68;color:var(--primary-blue);cursor:pointer;font-size:1.5rem;font-weight:700;line-height:1;padding:0 .5rem;transition:color .2s ease}.kebab-button:hover{color:#f5c542;color:var(--accent-yellow)}.kebab-dropdown-menu{background-color:#fff;background-color:var(--light-text);border:1px solid #e1e5e8;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #0000001a;list-style:none;margin:.5rem 0 0;min-width:180px;padding:.5rem 0;position:absolute;right:0;top:100%;z-index:10}.kebab-dropdown-menu li{color:#333;color:var(--dark-text);cursor:pointer;font-size:.95rem;padding:.8rem 1.2rem;transition:background-color .2s ease,color .2s ease;white-space:nowrap}.kebab-dropdown-menu li:hover{background-color:#f4f7fa;background-color:var(--background-gray);color:#0f2e68;color:var(--primary-blue)}.action-btn{border:none;border-radius:5px;cursor:pointer;font-size:.85rem;padding:.5rem .8rem;transition:background-color .2s ease;white-space:nowrap}.action-btn:hover{opacity:.9}.action-btn.edit-btn{background-color:#f5c542;background-color:var(--accent-yellow);color:#0f2e68;color:var(--primary-blue)}.action-btn.delete-btn{background-color:#dc3545;background-color:var(--red-overdue);color:#fff;color:var(--light-text)}.action-btn.confirm-btn{background-color:#28a745;background-color:var(--green-success);color:#fff;color:var(--light-text)}.action-btn.cancel-btn{background-color:#ffc107;background-color:var(--orange-warn);color:#333;color:var(--dark-text)}.action-btn.view-details-btn{background-color:#007bff;background-color:var(--blue-info);color:#fff;color:var(--light-text)}.pending-request-item{align-items:center;display:flex;gap:1rem;justify-content:space-between}.pending-request-item>div:first-child{flex-grow:1}.request-actions{display:flex;flex-shrink:0;gap:.5rem}.btn-action.accept-btn{background-color:#004d99;color:#fff;color:var(--light-text);padding:.6rem 1rem}.btn-action.accept-btn:hover{background-color:#0b62b8}.btn-action.reject-btn{background-color:#f4c43c;color:#333;color:var(--dark-text);padding:.6rem 1rem}.btn-action.reject-btn:hover{background-color:#f4c951}@media (max-width:992px){.dashboard-sections-grid{grid-template-columns:1fr}}@media (max-width:768px){.dashboard-container{flex-direction:column}.filter-controls-appointments{align-items:stretch;flex-direction:column}.filter-controls-appointments input.search-input-full{max-width:100%}.dashboard-sidebar{align-items:center;border-bottom:1px solid #1a3b7a;flex:none;flex-direction:row;justify-content:space-around;padding:1rem .5rem;width:100%}.sidebar-nav{display:flex;flex-wrap:wrap;justify-content:center}.sidebar-nav a{border-bottom:4px solid #0000;border-left:none;padding:.5rem 1rem}.sidebar-nav a.active{border-bottom:4px solid #f5c542;border-bottom:4px solid var(--accent-yellow)}.sidebar-profile-icon{display:none}.dashboard-content{margin-left:0;padding:1.5rem}.stat-cards-container{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.data-table td,.data-table th{padding:.8rem}.action-btn{padding:.4rem .6rem}.kebab-dropdown-menu{min-width:150px}.kebab-dropdown-menu li{padding:.6rem .8rem}.dashboard-sidebar{height:auto;position:relative}.sidebar-nav a.active{border-left:none}}@media (max-width:576px){.dashboard-sidebar{height:auto;position:relative}.dashboard-header{font-size:1.8rem}.stat-card p{font-size:2rem}.dashboard-card h2{font-size:1.3rem}.dashboard-card li{font-size:.9rem}.recent-activity li{align-items:flex-start;flex-direction:column}.recent-activity .activity-date{margin-left:0}.pending-request-item{align-items:flex-start;flex-direction:column;gap:.8rem}.request-actions{justify-content:flex-start;width:100%}.btn-action.accept-btn,.btn-action.reject-btn{flex-grow:1}}.librarian-page-content table.data-table{grid-template-columns:1fr 1.2fr 1fr 1fr;grid-template-columns:var(--manage-students-grid-columns,1fr 1.2fr 1fr 1fr)}.librarian-page-content table.data-table.appointments-table{grid-template-columns:1.2fr 1.6fr 1fr 1fr 1fr 1fr 1fr 1fr;grid-template-columns:var(--manage-students-grid-columns,1.2fr 1.6fr 1fr 1fr 1fr 1fr 1fr 1fr)}.filter-controls{gap:10px;margin-bottom:1rem}.search-input-full{border:1px solid #ccc;flex:1 1}.search-input-full,.status-select{border-radius:6px;font-size:1rem;padding:.6rem}.status-select{background:#fff;border:1px solid #ccc}.delete-button{background-color:#f4c43c!important;color:#373737!important;font-size:1rem;padding:.8rem 1.6rem!important;transition:background .2s ease}.delete-button:hover{background-color:#f8cc54!important}.librarian-page-content table.data-table td:first-child,.librarian-page-content table.data-table th:first-child{text-align:left}.librarian-page-content table.data-table td:nth-child(6),.librarian-page-content table.data-table th:nth-child(6){text-align:center}.pagination-container{display:flex;gap:.5rem;justify-content:center;margin-top:1rem}.pagination-button{background-color:#fff;border:1px solid #ccc;border-radius:4px;color:#333;cursor:pointer;padding:.4rem .8rem;transition:background .2s}.pagination-button:hover{background-color:#f2f2f2}.pagination-button.active{background-color:#f4c43c;border-color:#f4c43c;color:#222;font-weight:600}.table-actions-cell{align-items:center;display:flex;gap:.5rem;justify-content:center;position:relative}@media (max-width:1200px){.librarian-page-content table.data-table{grid-template-columns:.8fr 1.5fr 1fr 1fr 1.2fr;grid-template-columns:var(--manage-students-grid-columns,.8fr 1.5fr 1fr 1fr 1.2fr)}.librarian-page-content table.data-table td:nth-child(4),.librarian-page-content table.data-table th:nth-child(4){display:none}}@media (max-width:992px){.librarian-page-content table.data-table{grid-template-columns:.8fr 1.5fr 1.5fr 1fr 1.2fr;grid-template-columns:var(--manage-students-grid-columns,.8fr 1.5fr 1.5fr 1fr 1.2fr)}.librarian-page-content table.data-table td:nth-child(5),.librarian-page-content table.data-table th:nth-child(5){display:none}}@media (max-width:768px){.librarian-page-content table.data-table{grid-template-columns:1fr 1.5fr 1fr 1.2fr;grid-template-columns:var(--manage-students-grid-columns,1fr 1.5fr 1fr 1.2fr)}.librarian-page-content table.data-table td:nth-child(3),.librarian-page-content table.data-table th:nth-child(3){display:none}}@media (max-width:576px){.librarian-page-content table.data-table{grid-template-columns:1fr 1fr 1.2fr;grid-template-columns:var(--manage-students-grid-columns,1fr 1fr 1.2fr)}.admin-page-content table.data-table td:nth-child(2),.admin-page-content table.data-table th:nth-child(2){display:none}}:root{--primary-blue:#0f2e68;--accent-yellow:#f5c542;--light-text:#fff;--dark-text:#333;--background-gray:#f4f7fa;--border-color:#e1e5e8;--success-color:#28a745;--error-color:#dc3545;--info-color:#007bff}.scan-return-book-section{align-items:center;background-color:#fff;background-color:var(--light-text);border-radius:8px;box-shadow:0 4px 12px #0000001a;display:flex;flex-direction:column;gap:1.5rem;margin-left:auto;margin-right:auto;margin-top:2rem;max-width:500px;padding:2rem;position:relative}.book-scanner-reader-div{aspect-ratio:1/1;border:2px solid #0f2e68;border:2px solid var(--primary-blue);border-radius:8px;max-width:350px;overflow:hidden;transform:scaleX(-1);width:100%}.book-scanner-reader-div video{height:100%!important;object-fit:cover!important;width:100%!important}.scanner-status{text-align:center;width:100%}.scanner-status .status-message{border-radius:5px;font-weight:500;margin-bottom:1rem;padding:.8rem 1.2rem}.scanner-status .status-message.info{background-color:#e2f0fb;color:#007bff;color:var(--info-color)}.scanner-status .status-message.success{background-color:#d4edda;color:#28a745;color:var(--success-color)}.scanner-status .status-message.error{background-color:#f8d7da;color:#dc3545;color:var(--error-color)}.processing-overlay{align-items:center;background:#ffffffe6;border-radius:8px;bottom:0;display:flex;flex-direction:column;gap:1rem;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:5}.processing-overlay p{color:#0f2e68;color:var(--primary-blue);font-size:1.1rem;font-weight:500}.spinner{animation:spin 1s linear infinite;border:4px solid #0000001a;border-radius:50%;border-top-color:#0f2e68;border-top:4px solid var(--primary-blue);height:40px;width:40px}@media (max-width:576px){.scan-return-book-section{gap:1rem;padding:1.5rem}.book-scanner-reader-div{max-width:280px}}.announcement-form{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.announcement-form input,.announcement-form textarea{border:1px solid #ccc;border-radius:6px;font-size:1rem;padding:.7rem;width:100%}.announcement-form textarea{letter-spacing:0;min-height:100px}.announcements-list{margin-top:2rem}.announcement-title{margin-bottom:.3em;text-transform:uppercase}.announcements-list ul{list-style:none;padding-left:0}.announcements-list h2{margin-bottom:1em}.announcement-item{background:#f9f9f9;border:1px solid #ddd;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:1rem}.announcement-actions{display:flex;gap:.5rem;margin-top:.5rem}.btn-edit{background-color:#004d99;color:#fff}.btn-delete,.btn-edit{border:none;border-radius:6px;cursor:pointer;padding:.8rem 1.2rem}.btn-delete{background-color:#f4c43c;color:var(--dark-text)}.btn-edit:hover{background-color:#036}.btn-delete:hover{background-color:#f8cc54}.btn-cancel{background-color:gray;border:none;border-radius:6px;color:#fff;cursor:pointer;margin-left:1em;padding:.8rem 1.2rem}.btn-cancel:hover{background-color:#555}.btn-submit{background-color:#174996;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:.8rem 1.2rem}.btn-submit:hover{background-color:#123a73}.status.success{color:green;margin-top:1rem}.status.error{color:red;margin-top:1rem}.admin-dashboard-container{background-color:#f5f6fa;height:100vh}.acc-logo{height:2.5em;width:auto}.admin-dashboard-content{padding-top:10em}.admin-dashboard-content .dashboard-header{align-items:center;background-color:var(--primary-blue);display:flex;left:0;margin-bottom:0;padding-bottom:0;padding-block:.5em;position:absolute;top:0;width:100vw}.dashboard-header-content .profile-icon{height:1.5em;width:1.5em}.dashboard-header-content{align-items:center;display:flex;justify-content:space-between;margin-inline:auto;width:80%}.dashboard-header-content .dropdown-menu{font-size:1.2rem}.dashboard-header-title{color:#fff;font-size:2rem;font-weight:600}.page-description{color:#718093;font-size:1rem;margin-bottom:20px}.tab-buttons{border-bottom:1px solid #dcdde1;display:flex;margin-bottom:25px;margin-left:2em;margin-top:10px;padding-bottom:5px}.tab-content{margin:auto;width:90%}.tab-buttons button{background-color:#fff;border:1px solid #dcdde1;border-radius:4px;color:#2f3640;cursor:pointer;font-weight:500;margin-right:10px;padding:8px 15px;transition:all .2s ease;white-space:nowrap}.tab-buttons button:hover{background-color:#f1f2f6;border-color:#c8d6e5}.tab-buttons button.active{background-color:#f1f2f6;border-color:#a4b0be;color:#2f3640;font-weight:600}.admin-dashboard-container h2{color:#2f3640;font-size:1.5rem;font-weight:600;margin-bottom:15px;margin-top:25px}.create-librarian-form{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:30px}.create-librarian-form input{border:1px solid #dcdde1;border-radius:4px;box-sizing:border-box;flex:1 1;font-size:.95rem;margin:0;min-width:150px;padding:8px 12px}.create-librarian-button{background-color:#fdd835;border:none;border-radius:4px;color:#333;cursor:pointer;font-weight:600;padding:8px 20px;transition:background-color .2s;white-space:nowrap}.create-librarian-button:hover{background-color:#fbc02d}.data-grid-container{background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #0000000d;margin-bottom:30px;overflow-x:auto;padding:15px;width:100%}.librarian-grid-wrapper,.student-grid-wrapper{display:grid;min-width:650px}.grid-header-row{display:contents}.grid-header-row>.grid-cell{background-color:#f1f2f6;color:#2f3640;font-weight:600;text-align:left}.grid-data-row{display:contents}.grid-data-row:hover>.grid-cell{background-color:#f9f9f9}.grid-cell{word-wrap:break-word;align-items:center;border-bottom:1px solid #e0e0e0;display:flex;overflow-wrap:break-word;padding:12px 15px;white-space:normal}.student-grid-wrapper{grid-template-columns:.5fr 1.2fr 1.8fr 1.2fr .8fr .8fr}.student-grid-wrapper .grid-cell:first-child,.student-grid-wrapper .grid-cell:nth-child(5),.student-grid-wrapper .grid-cell:nth-child(6){justify-content:center;text-align:center}.librarian-grid-wrapper{grid-template-columns:.5fr 1.5fr 2fr .75fr;min-width:600px}.librarian-grid-wrapper .grid-cell:first-child,.librarian-grid-wrapper .grid-cell:nth-child(4){justify-content:center;text-align:center}.grid-data-row.no-records-row>.grid-cell{background-color:initial!important;border-bottom:none;color:#718093;font-style:italic;justify-content:center;padding:20px 0;text-align:center}.grid-colspan-4{grid-column:1/span 4}.grid-colspan-6{grid-column:1/span 6}.delete-button{background-color:#e84118;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;padding:6px 12px;transition:all .2s ease}.delete-button:hover{background-color:#c23616}.error-message{color:#e84118;font-weight:500;margin-top:20px;text-align:center}@media (max-width:1024px){.data-grid-container{padding:10px}.admin-dashboard-container h1{font-size:1.8rem}.grid-cell{padding:10px 8px}}@media (max-width:768px){.student-grid-wrapper{min-width:450px}.librarian-grid-wrapper{min-width:400px}.admin-dashboard-container h1{font-size:1.5rem}.admin-dashboard-container h2{font-size:1.3rem}.page-description{font-size:.9rem}.create-librarian-form{align-items:stretch;flex-direction:column}.create-librarian-form .create-librarian-button,.create-librarian-form input{min-width:0;min-width:auto;width:100%}.tab-buttons{flex-wrap:wrap}.tab-buttons button{margin-bottom:5px}}.student-attendance-page{--primary-blue:#0f2e68;--accent-yellow:#f5c542;--light-bg:#f9fbff;--card-bg:#fff;--border-color:#e1e5e8;--text-dark:#1a1a1a;--text-light:#5a5a5a;--success-color:#28a745;--error-color:#dc3545;--info-color:#007bff;align-items:center;background:linear-gradient(0deg,#a0b2d3,#f4f7fa);display:flex;flex-direction:column;min-height:100vh;padding:3rem 1rem}.student-attendance-page .attendance-status-bar{background:var(--card-bg);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 2px 8px #0000000d;padding:1rem 2rem;transition:all .3s ease}.student-attendance-page .occupancy-count{color:var(--primary-blue);font-weight:700;margin-left:.4rem}.student-attendance-page .capacity-full{color:var(--error-color)}.student-attendance-page .scan-return-book-section{background-color:var(--card-bg);border-radius:16px;box-shadow:0 8px 24px #0f2e681a;max-width:520px;padding:2rem;position:relative;text-align:center;transition:all .3s ease;width:100%}.student-attendance-page .dashboard-header{font-size:1.85rem!important}.student-attendance-page .book-scanner-reader-div{aspect-ratio:1/1;background:#000;border:3px solid var(--primary-blue);border-radius:12px;max-width:360px;overflow:hidden;position:relative;width:100%}.student-attendance-page .book-scanner-reader-div video{height:100%!important;object-fit:cover!important;transform:none!important;-webkit-transform:none!important;-moz-transform:none!important;-ms-transform:none!important;width:100%!important}.student-attendance-page .book-scanner-reader-div:after{animation:softPulse 2s ease-in-out infinite;border:2px solid #0f2e6899;border-radius:12px;content:"";inset:0;pointer-events:none;position:absolute}@keyframes softPulse{0%,to{box-shadow:0 0 0 0 #0f2e684d}50%{box-shadow:0 0 10px 4px #0f2e6833}}.student-attendance-page .scanner-status .status-message{animation:fadeIn .4s ease;border-radius:8px;font-size:.95rem;font-weight:500;padding:.9rem 1.2rem}.student-attendance-page .status-message.info{background-color:#eaf4ff;color:var(--info-color)}.student-attendance-page .status-message.success{background-color:#e5f9ec;color:var(--success-color)}.student-attendance-page .status-message.error{background-color:#ffe8e8;color:var(--error-color)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.student-attendance-page .processing-overlay{align-items:center;background:#ffffffd9;border-radius:16px;display:flex;flex-direction:column;gap:1rem;inset:0;justify-content:center;position:absolute;z-index:10}.student-attendance-page .processing-overlay p{color:var(--primary-blue);font-size:1.1rem;font-weight:600}.student-attendance-page .spinner{animation:spin 1s linear infinite;border:4px solid #0000001a;border-radius:50%;border-top:4px solid var(--accent-yellow);height:45px;width:45px}@keyframes spin{to{transform:rotate(1turn)}}.student-attendance-page .scan-return-book-section:hover{box-shadow:0 12px 30px #0f2e6826;transform:translateY(-4px)}@media (max-width:576px){.student-attendance-page .scan-return-book-section{padding:1.5rem}.student-attendance-page .book-scanner-reader-div{max-width:280px}.student-attendance-page .dashboard-header{font-size:1.6rem}}.view-attendance-page{background-color:#fff;border-radius:8px;box-shadow:0 4px 10px #0000000d;padding:20px}.view-attendance-page h2{border-bottom:2px solid #007bff;color:#333;font-size:1.8em;margin-bottom:20px;padding-bottom:10px}.date-selector-container{background-color:#f9f9f9;border:1px solid #eee;border-radius:6px;margin-bottom:30px;padding:15px}.date-selector-container h3{color:#007bff;font-size:1.2em;margin-top:0}.date-input-picker{border:1px solid #ccc;border-radius:4px;cursor:pointer;font-size:1em;padding:10px}.date-info{color:#555;font-size:.9em;margin-top:10px}.attendance-log-container{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.student-visit-card{background-color:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #00000008;padding:15px}.student-name-header{border-bottom:1px solid #f0f0f0;color:#333;font-size:1.3em;margin-bottom:15px;margin-top:0;padding-bottom:5px}.student-id-tag{color:#777;font-size:.8em;font-weight:400;margin-left:10px}.visit-detail-table{border-collapse:collapse;font-size:.9em;width:100%}.visit-detail-table td,.visit-detail-table th{border-bottom:1px dotted #eee;padding:8px;text-align:left}.visit-detail-table th{background-color:#f1f1f1;color:#444;font-weight:600}.active-status{background-color:#fffde7;font-weight:700}.cleanup-status{background-color:#fce4ec;color:#880e4f}.cleanup-notes{font-size:.85em;font-style:italic}@media (max-width:600px){.attendance-log-container{grid-template-columns:1fr}}.borrow-history-page{background-color:#fff;border-radius:8px;box-shadow:0 4px 10px #0000000d;margin:20px auto;max-width:900px;padding:20px}.borrow-history-page h2{border-bottom:2px solid #007bff;color:#333;font-size:1.8em;margin-bottom:20px;padding-bottom:10px}.period-selector{display:flex;gap:10px;margin-bottom:30px}.period-selector button{background-color:#f8f8f8;border:2px solid #ddd;border-radius:6px;color:#555;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .2s ease}.period-selector button:hover:not(:disabled){background-color:#e9e9e9}.period-selector button.active{background-color:#007bff;border-color:#007bff;color:#fff}.period-selector button:disabled{cursor:not-allowed;opacity:.6}.history-results{margin-top:20px}.history-results h3{color:#007bff;font-size:1.4em;margin-bottom:15px}.history-results table{background-color:#f9f9f9;border-collapse:collapse;margin-top:15px;width:100%}.history-results td,.history-results th{border-bottom:1px solid #eee;padding:12px 15px;text-align:left}.history-results th{background-color:#007bff;color:#fff;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.history-results tr:nth-child(2n){background-color:#f1f7fe}.history-results tr:hover{background-color:#e6f0ff}.error-message,.loading-message{border-radius:6px;font-weight:500;margin-top:20px;padding:15px}.error-message{background-color:#fdd;border:1px solid red;color:#c00}.history-row{cursor:pointer;transition:background-color .15s}.history-row:hover{background-color:#f0f8ff}.expand-indicator{color:#007bff;font-size:.8em;margin-left:10px}.detail-row{background-color:#f7f7f7}.detail-row td{border-bottom:none!important;padding:20px!important}.book-details-container h4{color:#333;font-size:1.2em;margin-bottom:15px;margin-top:0}.book-detail-list{list-style:none;padding-left:0}.book-detail-list li{border-bottom:1px dashed #ddd;color:#555;font-size:.95em;padding:8px 0}.book-detail-list li:last-child{border-bottom:none}.detail-loading,.no-details-found{color:#777;font-style:italic;padding:10px;text-align:center}@media (max-width:600px){.period-selector{flex-direction:column}.period-selector button{width:100%}}.manage-records-container{background-color:#fff;border-radius:8px;box-shadow:0 4px 10px #0000000d;padding:20px}.manage-records-container h2{border-bottom:2px solid #007bff;color:#333;font-size:1.8em;margin-bottom:25px;padding-bottom:10px}.filter-controls{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:25px}.search-input-records{border:1px solid #ccc;border-radius:6px;flex-grow:1;font-size:1em;max-width:300px;padding:10px 15px}.status-filters{display:flex;gap:10px}.filter-button{background-color:#f4f4f4;border:1px solid #ddd;border-radius:6px;color:#555;cursor:pointer;font-weight:500;padding:8px 15px;transition:all .2s}.filter-button.active{background-color:#007bff;border-color:#007bff;color:#fff}.filter-button:hover:not(.active){background-color:#e9e9e9}.records-table-wrapper{overflow-x:auto}.borrow-records-table{border-collapse:collapse;font-size:.95em;width:100%}.borrow-records-table td,.borrow-records-table th{border-bottom:1px solid #eee;padding:12px 15px;text-align:left}.borrow-records-table th{background-color:#3f51b5;color:#fff;font-weight:700}.borrow-records-table tbody tr:nth-child(2n){background-color:#f8f8f8}.borrow-records-table tbody tr:hover{background-color:#f0f0ff}.status-pill{border-radius:15px;font-size:.85em;font-weight:600;padding:5px 10px;white-space:nowrap}.status-active{background-color:#e0f7fa;color:#006064}.status-overdue{animation:pulse-red 1s infinite alternate;background-color:#ffebee;color:#c62828}.status-returned{background-color:#e8f5e9;color:#2e7d32}.pending-return{color:#999;font-style:italic}.returned-date{font-weight:500}@keyframes pulse-red{0%{box-shadow:0 0 0 0 #c6282866}to{box-shadow:0 0 0 6px #c6282800}}.pagination-controls{align-items:center;display:flex;gap:8px;justify-content:center;margin-top:25px}.pagination-arrow,.pagination-button{background-color:#f9f9f9;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:.9em;padding:8px 15px;transition:background-color .2s,border-color .2s}.pagination-arrow:hover:not(:disabled),.pagination-button:hover:not(:disabled){background-color:#eee}.pagination-button.active-page{background-color:#007bff;border-color:#007bff;color:#fff;font-weight:700}.pagination-arrow:disabled,.pagination-button:disabled{background-color:#f1f1f1;cursor:not-allowed;opacity:.5}@media (max-width:768px){.filter-controls{align-items:flex-start;flex-direction:column}.search-input-records{max-width:100%;width:100%}.status-filters{flex-wrap:wrap}}.App{font-family:Source Sans\ 3,sans-serif}#root,.App,body,html{box-sizing:border-box;margin:0;padding:0}
/*# sourceMappingURL=main.315aa4d3.css.map*/