*{box-sizing:border-box;margin:0;padding:0}.container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#2c0748;font-family:Poppins,Arial,Helvetica,sans-serif}.logo-container img{width:100px;padding-bottom:80px}.login-box{text-align:center;background-color:#f5f5f5;padding:60px;border-radius:16px;box-shadow:0 4px 6px #0000001a;width:700px;min-height:700px}.logo{width:250px;height:auto}.title{font-size:24px;color:#333;margin-bottom:25px}.input{width:100%;height:45px;margin-bottom:20px;padding:10px 15px;border:1px solid #ccc;border-radius:5px;font-size:18px}.button-container{display:flex;align-items:center;justify-content:center;gap:15px}.login-button,.signup-button{flex:1;padding:15px;border:none;border-radius:5px;font-size:18px;cursor:pointer;font-weight:700;text-align:center}.login-button{background-color:#6a0dad;color:#fff;transition:background-color .3s ease}.login-button:hover{background-color:#590b96}.signup-button{background-color:#fff;border:2px solid #6a0dad;color:#6a0dad;transition:background-color .3s ease,color .3s ease}.signup-button:hover{background-color:#6a0dad;color:#fff}.forgot-container{margin-top:20px}.forgot-password{background:none;border:none;color:#6a0dad;font-size:20px;text-decoration:underline;cursor:pointer}.footer{margin-top:30px;font-size:14px;color:#777}*{box-sizing:border-box;margin:0;padding:0;font-family:Poppins,Arial,Helvetica,sans-serif}.dashboard-container{display:flex;flex-direction:column;align-items:center;justify-content:space-between;text-align:center;padding:20px;background:linear-gradient(to bottom right,#f5f0ff,#ece7f7);min-height:100vh}.dashboard-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 50px;background:#fff;box-shadow:0 4px 6px #0000001a;border-radius:10px;margin-bottom:20px;position:relative}.logo-container1 img{width:60px}.welcome-text{flex:2;font-size:27px;font-weight:700;text-align:center}.profile-container{position:relative;display:flex;flex-direction:column;align-items:center;cursor:pointer}.pfp-container1{display:flex;align-items:center;justify-content:center}.pfp{width:60px;height:60px;border-radius:50%;border:2px solid #6a0dad}.class-logout-button{background-color:#6a0dad;color:#fff;border:none;padding:10px 20px;border-radius:15px;cursor:pointer;font-size:20px;white-space:nowrap;box-shadow:0 4px 6px #0000001a;display:block}.schedule-header{display:flex;align-items:center;justify-content:center;font-weight:700;width:100%}.date-container{display:flex;align-items:center;justify-content:center}.schedule{background:#fff;padding:20px;border-radius:10px;box-shadow:0 4px 6px #0000001a;width:80%;display:flex;flex-direction:column;justify-content:center}.schedule-list{display:flex;flex-direction:column;gap:15px}.schedule-item{display:flex;justify-content:space-between;align-items:center;padding:15px;background:#f9f9f9;border-radius:8px}.active-item{background:#6a0dad;color:#fff}.subject{font-weight:700}.qr-button{background:#fff;color:#6a0dad;border:2px solid #fff;border-radius:5px;padding:10px 15px;font-weight:700;cursor:pointer;transition:all .3s ease}.qr-button:hover{background:#6a0dad;color:#fff}.dashboard-footer{width:100%;text-align:center;font-size:14px;color:#555;padding:10px}.sidebar{height:100%;width:300px;background-image:linear-gradient(to bottom,#6a0dad,#9b59b6);border-radius:20px;display:flex;flex-direction:column;align-items:center;padding:1rem}.logoContainer{padding:.5rem;background-color:#fff;border-radius:20px}.logo{width:82px;height:auto}.sidebar-nav{width:100%;height:100%;display:flex;flex-direction:column;justify-content:space-between}.navItems{display:flex;flex-direction:column;gap:1rem;margin-top:2rem;width:100%;height:fit-content}.navLink{text-decoration:none;color:#fff;font-size:1.2rem;display:flex;align-items:center;gap:.5rem;background-color:#6a0dad60;width:100%;padding:.5rem;border-radius:10px;border:none;cursor:pointer}.header{width:100%;height:17rem;background-image:linear-gradient(to bottom,#fff,#ececec);border-radius:20px;display:flex;justify-content:space-between}.content{padding:2rem;height:100%;display:flex;flex-direction:column;justify-content:space-between}.todaysDate{font-size:1.2rem;color:#333}.welcomeAndGettingStarted{display:flex;flex-direction:column;gap:.5rem}.welcomeText{font-size:2rem;font-weight:700;color:#333}.aMeaningfulText{font-size:1.2rem;color:#333}.educationImage{width:100%;height:100%;max-width:300px;max-height:300px;object-fit:contain}.scheduleTitle{font-size:2rem;font-weight:700;color:#333;text-align:center}.todaysSchedule{width:100%;height:100%;display:flex;flex-direction:column;gap:1rem}.scheduleContainer{height:100%}.no-classes{height:100%;width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center}.no-classes h1{font-size:2rem;color:#333;text-align:center}.no-classes-icon{display:flex;flex-direction:column;align-items:center;justify-content:center}.schedule-wrapper{padding:1rem;background:#e1e1e1;border-radius:10px}.qr-button{width:200px;padding:10px 20px;border:none;background-color:#fff!important;color:#6a0dad!important;border-radius:5px;cursor:pointer;font-size:1rem;font-weight:700}body{margin:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#f3f3f3}.qr-main-content{flex-grow:1;display:flex;flex-direction:column;padding:2rem;background-color:#fff;border-radius:20px;box-shadow:0 0 12px #0000000f;overflow-y:hidden}.dashboard-header1{display:flex;justify-content:flex-end;margin-bottom:1rem}.pfp-container1{width:50px;height:50px;border-radius:50%;overflow:hidden;border:2px solid #9333ea;cursor:pointer;transition:transform .3s}.pfp-container1:hover{transform:scale(1.05)}.pfp{width:100%;height:100%;object-fit:cover}.content-container{text-align:center}.schedule-header{display:flex;justify-content:center;margin-bottom:2rem}.date-container{background-color:#f8f6fc;padding:.5rem 1.5rem;border-radius:10px;box-shadow:inset 0 0 4px #0000000d}.date{font-size:1.2rem;color:#6b21a8;font-weight:500}.qr-code-container{background-color:#f8f6fc;border:1px solid #e4d8f9;padding:2rem;border-radius:16px;width:100%;max-width:500px;margin:auto;box-shadow:0 4px 12px #8000800d;display:flex;flex-direction:column;align-items:center}.qr-instruction{margin-top:1.5rem;font-size:1.2rem;font-weight:600;color:#6a0dad;text-align:center;background:#6a0dad1a;padding:.8rem 1.5rem;border-radius:12px;box-shadow:0 2px 6px #6a0dad33;width:fit-content;margin-left:auto;margin-right:auto}@media (max-width: 600px){.qr-code-container,.qr-main-content{padding:1rem}.date,.qr-scan-btn{font-size:1rem}}.reset-password-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f5f5f5;padding:20px}.reset-password-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;width:100%;max-width:400px}.reset-password-card h2{margin-top:0;margin-bottom:1rem;color:#333}.reset-password-card p{color:#666;margin-bottom:1.5rem}.forgot-password-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f5f5f5;padding:20px}.forgot-password-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;width:100%;max-width:400px}.forgot-password-card h2{margin-top:0;margin-bottom:1rem;color:#333}.forgot-password-card p{color:#666;margin-bottom:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus{outline:none;border-color:#4a90e2}button{width:100%;padding:.75rem;background-color:#4a90e2;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .3s}button:hover{background-color:#3a7bc8}button:disabled{background-color:#ccc;cursor:not-allowed}.error-message{color:#e74c3c;margin-bottom:1rem;padding:.5rem;background-color:#fdecea;border-radius:4px}.success-message{color:#2ecc71;margin-bottom:1rem;padding:.5rem;background-color:#e8f8f0;border-radius:4px}.back-to-login{margin-top:1.5rem;text-align:center;color:#666}.back-to-login span{color:#4a90e2;cursor:pointer;font-weight:500}.back-to-login span:hover{text-decoration:underline}.dashboard-layout{display:flex;height:100vh;padding:1rem;gap:1rem;background-color:#f5f7fa}.status-cell-a{text-align:center;cursor:pointer;width:40px;transition:all .2s;color:#fff;padding:.5rem;border-radius:20%;background:#d82f3d;font-weight:700}.status-cell-p{text-align:center;cursor:pointer;width:40px;transition:all .2s;color:#fff;padding:.5rem;border-radius:20%;background:green;font-weight:700}.status-cell:hover{transform:scale(1.2)}.status-p{color:#2ecc71}.status-a{color:#e74c3c}.status-cell:empty{color:#3498db}table th:nth-child(5),table td:nth-child(5){text-align:center;width:120px}table th:nth-child(4),table td:nth-child(4){text-align:center;width:80px}.main-content{width:100%;display:flex;flex-direction:column;gap:1rem;overflow-y:auto}.attendance-view-container{background-color:#fff;border-radius:10px;padding:2rem;box-shadow:0 2px 10px #0000000d}.attendance-view-container h2{color:#2c3e50;margin-bottom:1.5rem;font-size:1.5rem}.filters{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:flex-end}.form-group{display:flex;flex-direction:column;min-width:200px}.form-group label{margin-bottom:.5rem;font-weight:500;color:#4a5568;font-size:.9rem}.form-group input[type=date]{padding:.5rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9rem;color:#4a5568}.error-message{color:#e53e3e;padding:.75rem;background-color:#fff5f5;border-radius:6px;margin-bottom:1rem;border-left:4px solid #e53e3e}.loading{text-align:center;padding:2rem;color:#718096}.no-records{text-align:center;padding:2rem;color:#718096;font-style:italic}.attendance-list{display:flex;flex-direction:column;gap:2rem}.attendance-date-group{background-color:#f8f9fa;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000000d}.attendance-date-group h3{color:#2d3748;margin-bottom:1rem;font-size:1.1rem;padding-bottom:.5rem;border-bottom:1px solid #e2e8f0}.attendance-date-group h4{color:#4a5568;margin:1rem 0 .5rem;font-size:.95rem}.mark-present-btn{padding:.5rem 1rem;background-color:#48bb78;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background-color .2s}.mark-present-btn:hover:not(:disabled){background-color:#38a169}.mark-present-btn:disabled{background-color:#c6f6d5;cursor:not-allowed}table th:nth-child(4),table td:nth-child(4){text-align:center;width:120px}table{width:100%;border-collapse:collapse;margin-bottom:1.5rem}table th{background-color:#edf2f7;color:#4a5568;text-align:left;padding:.75rem;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}table td{padding:.75rem;border-bottom:1px solid #e2e8f0;color:#4a5568;font-size:.9rem}table tr:last-child td{border-bottom:none}table tr:hover td{background-color:#f7fafc}.dashboard-footer{text-align:center;padding:1rem;color:#718096;font-size:.8rem;background-color:#f8f9fa;border-top:1px solid #e2e8f0}@media (max-width: 768px){.dashboard-layout{flex-direction:column;height:auto;min-height:100vh}.filters{flex-direction:column;align-items:stretch}.form-group{width:100%}.attendance-view-container{padding:1rem}table{display:block;overflow-x:auto;white-space:nowrap}}.minimalist-input select,.minimalist-input input[type=date]{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border:1px solid #e0e0e0;padding:.55rem .9rem;font-size:.95rem;border-radius:8px;box-shadow:0 1px 3px #0000000d;transition:border .2s,box-shadow .2s;color:#2d3748}.minimalist-input select:focus,.minimalist-input input[type=date]:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f133}.date-filter-wrapper{display:flex;gap:.5rem;align-items:center}.clear-filter{padding:.55rem .9rem;background-color:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;color:#374151;font-size:.95rem;line-height:1.2;height:100%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s}.clear-filter:hover{background-color:#e2e8f0}.date-filter-wrapper{display:flex;gap:.5rem;align-items:stretch}.form-group label{margin-bottom:.4rem;font-size:.88rem;color:#4b5563;font-weight:600}.date-filter-wrapper{display:flex;align-items:center;gap:8px}.date-input,.clear-filter{height:36px;padding:6px 12px;font-size:14px;border:1px solid #ccc;border-radius:6px;box-sizing:border-box}.clear-filter{background-color:#f5f5f5;cursor:pointer;transition:background-color .2s}.clear-filter:hover:not(:disabled){background-color:#e2e2e2}.clear-filter:disabled{cursor:not-allowed;opacity:.6}.qr-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f9f9f9}.location-qr-screen{background:linear-gradient(to bottom right,#a020f0,#6a0dad);border-radius:12px;padding:3.5rem 2.5rem;max-width:580px;margin:2rem auto;text-align:center;color:#fff;box-shadow:0 6px 16px #00000026;font-family:Segoe UI,sans-serif}.location-qr-screen h2{font-size:2.5rem;margin-bottom:.5rem;font-weight:700}.qr-subtext{font-size:1.2rem;margin-bottom:1.5rem;color:#e0e0e0}.qr-box{display:inline-block;background:#fff;padding:1rem;border-radius:8px;box-shadow:0 4px 12px #0000001a}.qr-status{margin-top:1.5rem;font-size:1.2rem;color:#f0f0f0}
