.navbar{align-items:center;background:#fff;color:#000;display:flex;justify-content:space-between;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:999}.logo{color:#000;cursor:pointer;font-size:1.5rem;font-weight:700}.nav-links{display:flex;gap:1rem}.nav-links button{background:#000;border:1px solid #000;border-radius:6px;color:#fff;cursor:pointer;padding:.5rem 1rem;transition:all .2s ease}.nav-links button:hover{background:#2d2b2b;color:#fff}.hamburger{color:#000;cursor:pointer;display:none;flex-direction:column;gap:4px}.hamburger div{background:#000;height:3px;transition:.3s ease;width:25px}.hamburger.open div:first-child{transform:translateY(7px) rotate(45deg)}.hamburger.open div:nth-child(2){opacity:0}.hamburger.open div:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media (max-width:768px){.nav-links{align-items:flex-start;background:#d5e0f5;flex-direction:column;opacity:0;padding:1rem 2rem;pointer-events:none;position:absolute;right:0;top:70px;transform:translateY(-100%);transition:transform .3s ease-in-out;width:100%}.nav-links.open{opacity:1;pointer-events:auto;transform:translateY(0)}.hamburger{display:flex}}.home{font-family:Segoe UI,sans-serif}.welcome-section{align-items:center;background:url(/static/media/hostel.16428db3ad42b3cd07a8.jpeg) no-repeat 50%/cover;color:#fff;display:flex;height:80vh;justify-content:center;position:relative;text-align:center}.overlay{background-color:#00000080;border-radius:10px;font-size:1.8rem;padding:40px}.welcome-section p{color:#eaeaea;font-size:1.2rem}.button-group{margin-top:20px}.primary,.secondary{border:none;border-radius:6px;cursor:pointer;font-size:16px;margin:5px;padding:10px 20px}.primary{background-color:#2563eb;color:#fff}.secondary{background-color:#fff;color:#2563eb}.how-it-works{padding:60px 20px;text-align:center}.cards{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-top:30px}.card{background:#f9f9f9;border-radius:10px;box-shadow:0 4px 12px #0000001a;max-width:300px;padding:25px}.footer{background-color:#eaeaea;margin-top:40px;padding:20px;text-align:center}.login-container{display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;gap:2rem;margin:2rem auto;max-width:900px}.login-form{background:#fff;border-radius:10px;box-shadow:0 6px 20px #0000001a;display:flex;flex:1 1;flex-direction:column;padding:2rem}.login-form h2{color:#0d6efd;font-size:1.8rem;font-weight:700;margin-bottom:1.5rem}.login-form label{font-weight:600}.login-form input{border:1px solid #ccc;border-radius:6px;box-sizing:border-box;font-size:1rem;margin-top:.3rem;padding:.5rem .8rem}.login-form button{background-color:#0d6efd;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;margin-top:1.5rem;padding:.75rem;transition:background-color .3s ease}.login-form button:focus,.login-form button:hover{background-color:#084eca;outline:none}.credentials-panel{background:#f0f4ff;border-radius:10px;box-shadow:0 6px 20px #0000001a;color:#222;flex:1 1;font-family:monospace,monospace;font-size:1rem;overflow:visible;padding:2rem 1.5rem}.credentials-panel h3{color:#0d6efd;font-size:1.5rem;font-weight:700;margin-bottom:1rem;margin-top:0}.credential-section{margin-bottom:2rem}.credential-section strong{color:#333;display:block;font-weight:700;margin-bottom:.5rem}.tech-group{margin-bottom:.4rem}.tech-group em{color:#0d6efd;font-style:normal;font-weight:600}.credential-section p{margin:.2rem 0}.code{background-color:#e9ecef;border-radius:3px;font-family:monospace;font-weight:600;padding:0 5px}.complaint-form-page{align-items:center;background:#eef1f5;display:flex;flex-direction:column;min-height:100vh;padding:2rem}.complaint-form-page h2{color:#333;margin-bottom:.5rem}.complaint-form-page p{color:#666;margin-bottom:2rem}.complaint-form{background:#fff;border-radius:10px;box-shadow:0 4px 12px #0000001a;max-width:600px;padding:2rem;width:100%}.complaint-form label{color:#444;display:block;font-weight:500;margin-bottom:1rem}.complaint-form select,.complaint-form textarea{border:1px solid #ccc;border-radius:8px;font-size:1rem;margin-top:.5rem;padding:.75rem;width:100%}.complaint-form textarea{min-height:100px;resize:vertical}.complaint-form button{background-color:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;margin-top:1rem;padding:.75rem;transition:background .3s ease}.complaint-form button:hover{background-color:#218838}.complaint-form input,.complaint-form select,.complaint-form textarea{border:1px solid #ccc;border-radius:8px;font-size:1rem;margin-top:.5rem;padding:.75rem;width:100%}.toast{animation:fadeInOut 3.5s ease-in-out;border-radius:6px;font-weight:700;padding:12px 20px;position:fixed;right:20px;top:20px;z-index:1000}.toast.success{background-color:#e6ffed;border:1px solid #4caf50;color:#2e7d32}.toast.error{background-color:#ffe6e6;border:1px solid #f44336;color:#c62828}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-10px)}10%{opacity:1;transform:translateY(0)}90%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.ticket-number-banner{background-color:#f0f9ff;border-left:4px solid #2196f3;border-radius:4px;color:#0d47a1;font-weight:700;margin-bottom:1rem;padding:12px}.login-page{margin:auto;max-width:400px;padding:2rem}.login-form label{display:block;margin-bottom:1rem}.login-form input{padding:.5rem;width:100%}*{box-sizing:border-box;margin:0;padding:0}body,html{background-color:#f9f9f9;color:#333;font-family:Segoe UI,sans-serif;height:100%;overflow-x:hidden}.admin-dashboard{display:flex;min-height:100vh;position:relative;width:100%}.sidebar{background:#fff;border-right:1px solid #ddd;padding:2rem 1rem;transition:left .3s ease-in-out;width:220px}.sidebar h2{font-size:20px;margin-bottom:2rem}.sidebar ul{list-style:none}.sidebar ul li{border-radius:6px;cursor:pointer;margin-bottom:.5rem;padding:.75rem;transition:background .3s ease}.sidebar ul li.active,.sidebar ul li:hover{background-color:#e8f0fe;font-weight:700}.logout-btn{background:#f44336;border:none;border-radius:6px;color:#fff;cursor:pointer;margin-top:2rem;padding:.5rem 1rem;width:100%}.hamburger-menu{background:#1e88e5;color:#fff;cursor:pointer;display:none;font-size:28px;left:0;padding:1rem;position:fixed;top:0;z-index:1100}.dashboard-content{flex:1 1;overflow-y:auto;padding:2rem}.dashboard-content h1{font-size:24px;margin-bottom:1rem}.stats{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:10px;box-shadow:0 2px 6px #0000000d;flex:1 1 250px;padding:1rem 1.5rem}.stat-card h3{font-size:16px;margin-bottom:.75rem}.filters{display:flex;flex-wrap:wrap;gap:1rem;margin:1rem 0}.filters input,.filters select{background:#fff;border:1px solid #ccc;border-radius:6px;flex:1 1 200px;padding:.5rem}.complaint-list table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 0 10px #0000000d;overflow:hidden;width:100%}.complaint-list td,.complaint-list th{border-bottom:1px solid #eee;font-size:14px;padding:.75rem 1rem;text-align:left}.complaint-list input,.complaint-list select{border:1px solid #ccc;border-radius:6px;padding:.4rem;width:100%}.complaint-list tr:last-child td{border-bottom:none}button{border:none;border-radius:6px;cursor:pointer;padding:.5rem 1rem}button:hover{opacity:.95}.user-management{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}.btn-blue{background:#1e88e5;color:#fff}.btn-outline{background:#0000;border:1px solid #1e88e5;color:#1e88e5}@media (max-width:768px){.admin-dashboard{flex-direction:column}.hamburger-menu{display:block}.sidebar{background:#fff;height:100vh;left:-250px;position:fixed;top:0;transition:left .3s ease-in-out;width:220px;z-index:1000}.sidebar.open{left:0}.dashboard-content{padding:4rem 1rem 1rem;width:100%}.filters,.stats{flex-direction:column}}@media (max-width:480px){.btn-blue,.btn-outline,.filters input,.filters select{width:100%}.user-management{align-items:stretch;flex-direction:column;gap:.75rem}.stat-card{padding:1rem}}.notifications-section{background-color:#fff;border-radius:10px;box-shadow:0 2px 12px #0000000d;color:#222;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;margin-top:3rem;max-width:1000px;padding:1.5rem 2rem}.notifications-section h2{color:#0d6efd;font-size:1.5rem;font-weight:700;margin-bottom:1.25rem;margin-top:0}.notifications-table{border-collapse:collapse;display:block;overflow-x:auto;width:100%}.notifications-table thead{background-color:#f1f3f5}.notifications-table td,.notifications-table th{border-bottom:1px solid #ddd;font-size:.95rem;padding:.75rem 1rem;text-align:left;white-space:nowrap}.notifications-table th{color:#333;font-weight:700}.notifications-table tbody tr:hover{background-color:#e6f0ff;cursor:pointer}.notifications-table button{background-color:#0d6efd;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.4rem .9rem;transition:background-color .25s ease}.notifications-table button:focus,.notifications-table button:hover{background-color:#084eca;outline:none}@media (max-width:600px){.notifications-table{font-size:.85rem}.notifications-table thead{display:none}.notifications-table,.notifications-table tbody,.notifications-table td,.notifications-table tr{display:block;width:100%}.notifications-table tr{border-bottom:2px solid #0d6efd;margin-bottom:1rem}.notifications-table td{padding-left:50%;position:relative;text-align:left}.notifications-table td:before{color:#0d6efd;font-weight:600;left:10px;position:absolute;top:50%;transform:translateY(-50%);white-space:nowrap}.notifications-table td:first-of-type:before{content:"Ticket"}.notifications-table td:nth-of-type(2):before{content:"Student Roll"}.notifications-table td:nth-of-type(3):before{content:"Comment"}.notifications-table td:nth-of-type(4):before{content:"Date"}.notifications-table td:nth-of-type(5):before{content:"Action"}.notifications-table button{margin-top:.5rem;width:100%}}.user-management-page{background-color:#f9f9f9;font-family:Segoe UI,sans-serif;min-height:100vh;padding:2rem}.user-management-page h2{font-size:24px;margin-bottom:.5rem}.user-management-page p{color:#555;margin-bottom:2rem}.form-section{background:#fff;border-radius:10px;box-shadow:0 0 10px #0000000d;margin-bottom:2rem;padding:2rem}.form-section h3{font-size:18px;font-weight:600;margin-bottom:1.5rem}.form-section form{display:flex;flex-direction:column;gap:1rem}.form-section input,.form-section select{border:1px solid #ccc;border-radius:6px;font-size:14px;padding:.75rem}.form-section button{align-self:flex-start;background:#1e88e5;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:.5rem 1rem}.form-section button:hover{background:#1565c0}@media (max-width:600px){.form-section{padding:1rem}}.success-message{background:#e0f7e9;border:1px solid #a5d6a7;border-radius:6px;color:#2e7d32;font-weight:500;margin-bottom:1.5rem;padding:.75rem 1rem;transition:all .3s ease-in-out}.student-dashboard{color:#222;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;margin:2rem auto;max-width:900px;padding:0 1rem}.student-dashboard header{align-items:center;display:flex;flex-wrap:wrap;justify-content:space-between;margin-bottom:1.5rem}.student-dashboard header h2{font-size:1.8rem;font-weight:700;margin:0}.student-dashboard header div{color:#555;font-size:1rem;margin-top:.5rem}.new-complaint-btn{background-color:#0d6efd;border:none;border-radius:8px;box-shadow:0 4px 12px #0d6efd33;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-bottom:1.5rem;padding:.7rem 1.3rem;transition:background-color .25s}.new-complaint-btn:focus,.new-complaint-btn:hover{background-color:#084eca;outline:none}.loading,.no-complaints{color:#666;font-size:1.1rem;margin-top:2rem;text-align:center}.complaints-table{border-collapse:collapse;font-size:1rem;max-width:100%;overflow-x:auto;width:100%}.complaints-table thead{background-color:#f1f3f5}.complaints-table td,.complaints-table th{border-bottom:1px solid #ddd;padding:.9rem 1rem}.complaints-table td.feedback-col,.complaints-table th.feedback-col{text-align:center;width:140px}.status{border-radius:15px;color:#fff;display:inline-block;font-size:.9rem;font-weight:600;min-width:80px;padding:.2rem .7rem;text-align:center}.status.pending{background-color:#ffc107;color:#3e2e00}.status.in-progress{background-color:#0d6efd}.status.resolved{background-color:#198754}.compact-feedback-yn{align-items:center;display:flex;font-size:.95rem;font-weight:600;gap:.7rem;justify-content:center}.compact-feedback-yn span{margin-right:.5rem}.yn-btn{border:none;border-radius:999px;box-shadow:0 2px 8px #0000001a;cursor:pointer;font-size:.95rem;font-weight:600;padding:.4rem 1rem;transition:background-color .25s}.yes-btn{background-color:#198754;color:#fff}.yes-btn:focus,.yes-btn:hover{background-color:#146c43;outline:none}.no-btn{background-color:#dc3545;color:#fff}.no-btn:focus,.no-btn:hover{background-color:#b02a37;outline:none}.modal-overlay{align-items:center;background-color:#24282c99;display:flex;height:100vh;justify-content:center;left:0;padding:1rem;position:fixed;top:0;width:100vw;z-index:1500}.modal-content{background-color:#fff;border-radius:15px;box-shadow:0 8px 24px #0003;display:flex;flex-direction:column;max-width:90vw;padding:2rem 2.5rem;width:400px}.modal-content h3{color:#0d6efd;font-size:1.25rem;font-weight:700;margin-bottom:1rem;margin-top:0}.modal-content textarea{border:1.5px solid #ddd;border-radius:10px;font-family:inherit;font-size:1rem;margin-bottom:1.5rem;min-height:100px;outline:none;padding:1rem;resize:vertical;transition:border-color .2s}.modal-content textarea:focus{border-color:#0d6efd}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.submit-btn{background-color:#0d6efd;border:none;border-radius:9999px;box-shadow:0 5px 18px #0d6efd66;color:#fff;cursor:pointer;font-weight:700;padding:.6rem 1.4rem;transition:background-color .2s}.submit-btn:focus,.submit-btn:hover{background-color:#084eca;outline:none}.cancel-btn{background-color:#e2e6ea;border:none;border-radius:9999px;box-shadow:0 2px 6px #0000001f;color:#495057;cursor:pointer;font-weight:600;padding:.63rem 1.4rem;transition:background-color .2s}.cancel-btn:focus,.cancel-btn:hover{background-color:#d6d8db;outline:none}@media (max-width:480px){.complaints-table{display:block;overflow-x:auto;white-space:nowrap}.student-dashboard header{align-items:flex-start;flex-direction:column}.new-complaint-btn{margin-bottom:1rem;width:100%}}.technician-dashboard{color:#222;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;margin:2rem auto;max-width:1200px;padding:0 1rem}header{margin-bottom:2rem;text-align:center}h2{margin:0 0 .5rem}p{color:#555;font-size:1rem}table.complaints-table{border-collapse:collapse;font-size:.95rem;margin-bottom:2rem;width:100%}.complaints-table td,.complaints-table th{border:1px solid #ddd;padding:.75rem 1rem;text-align:left;vertical-align:middle;white-space:nowrap}.complaints-table th{background-color:#f5f5f5;color:#333;font-weight:700}.complaints-table select{border:1px solid #ccc;border-radius:6px;cursor:pointer;font-size:.9rem;padding:.3rem .6rem}.complaints-table select:focus{border-color:#0d6efd;box-shadow:0 0 4px #0d6efd80;outline:none}.complaints-table button{background-color:#0d6efd;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:.4rem 1rem;transition:background-color .25s ease}.complaints-table button:focus,.complaints-table button:hover{background-color:#084eca;outline:none}.save-status{color:green;font-size:.85rem;margin-left:10px}@media (max-width:600px){.technician-dashboard{padding:0 .5rem}table.complaints-table,tbody,td,th,thead,tr{display:block}thead tr{display:none}tbody tr{border:1px solid #ddd;border-radius:8px;margin-bottom:1rem;padding:.5rem}tbody td{border:none;padding-left:50%;position:relative;text-align:left;white-space:normal}tbody td:before{color:#0d6efd;font-weight:600;left:10px;position:absolute;top:50%;transform:translateY(-50%);white-space:nowrap}tbody td:first-of-type:before{content:"Ticket"}tbody td:nth-of-type(2):before{content:"Category"}tbody td:nth-of-type(3):before{content:"Location"}tbody td:nth-of-type(4):before{content:"Description"}tbody td:nth-of-type(5):before{content:"Status"}tbody td:nth-of-type(6):before{content:"Date Submitted"}tbody td:nth-of-type(7):before{content:"Save"}.complaints-table button{margin-top:.5rem;width:100%}.save-status{display:block;margin-left:0;margin-top:.3rem}}
/*# sourceMappingURL=main.b648a1b5.css.map*/