:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container{display:flex;justify-content:center;align-items:center;padding:60px 20px;background-color:#f5f5f5;min-height:100vh}.login-card{background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;width:100%;max-width:400px;overflow:hidden}.login-header{background-color:#007bff;color:#fff;text-align:center;padding:20px}.login-header h3{margin:0;font-size:24px}.login-body{padding:25px}.form-group label{margin-bottom:5px;font-weight:700}.login-button{width:100%;padding:12px;font-size:16px;border:none;background-color:#007bff;color:#fff;border-radius:6px;cursor:pointer;transition:background-color .2s ease}.login-button:hover{background-color:#0056b3}.login-footer{background-color:#f1f1f1;text-align:center;padding:15px;font-size:14px}.login-footer a{color:#007bff;text-decoration:none}.login-footer a:hover{text-decoration:underline}.login-alert{padding:10px;margin-bottom:15px;border-radius:6px;font-weight:700;text-align:center}.login-alert.success{background-color:#d4edda;color:#155724}.login-alert.error{background-color:#f8d7da;color:#721c24}.register-container{display:flex;justify-content:center;align-items:center;padding:60px 20px;background-color:#f8f9fa;min-height:100vh}.register-card{background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;width:100%;max-width:450px;overflow:hidden}.register-header{background-color:#007bff;color:#fff;padding:20px;text-align:center}.register-body{padding:25px}.form-group{margin-bottom:20px;display:flex;flex-direction:column}.form-group label{margin-bottom:6px;font-weight:700}.form-group input{padding:10px;border:1px solid #ccc;border-radius:6px;font-size:16px}.register-button{width:100%;padding:12px;background-color:#007bff;color:#fff;font-size:16px;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s ease-in-out}.register-button:hover{background-color:#0056b3}.register-footer{background-color:#f1f1f1;padding:15px;text-align:center;font-size:14px}.register-footer a{color:#007bff;text-decoration:none}.register-footer a:hover{text-decoration:underline}.register-alert{padding:10px;margin-bottom:15px;border-radius:6px;font-weight:700;text-align:center}.register-alert.success{background-color:#d4edda;color:#155724}.register-alert.error{background-color:#f8d7da;color:#721c24}.admin-dashboard{padding:20px;background:#f3f6fc;min-height:100vh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.admin-title{text-align:center;font-size:28px;font-weight:700;margin-bottom:30px;color:#2c3e50}.tab-buttons{display:flex;justify-content:center;gap:30px;border-bottom:2px solid #ccc;margin-bottom:25px;flex-wrap:wrap}.tab-btn{background:none;border:none;padding:12px 0;font-size:16px;font-weight:600;cursor:pointer;color:#d70799;position:relative;transition:color .3s ease}.tab-btn:hover,.tab-btn.active{color:#4b7bec}.tab-btn.active:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:3px;background-color:#4b7bec;border-radius:3px}.tab-content{max-width:100%;margin-top:20px}.admin-section{background:#fff;padding:20px;border-radius:10px;box-shadow:0 0 12px #e90808ba;overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;margin-top:10px}.admin-table th,.admin-table td{padding:14px 12px;text-align:left;border-bottom:1px solid #ddd;font-size:15px}.admin-table th{background-color:#e6f0ff;color:#2c3e50;font-weight:600}.btn-edit,.btn-delete,.btn-approve{padding:6px 12px;margin-right:6px;border:none;border-radius:4px;cursor:pointer;font-weight:500;font-size:14px;transition:background-color .2s ease}.btn-edit{background-color:#3498db;color:#fff}.btn-delete{background-color:#d70799;color:#fff}.btn-approve{background-color:#2ecc71;color:#fff}.btn-edit:hover{background-color:#2980b9}.btn-delete:hover{background-color:#c0392b}.btn-approve:hover{background-color:#27ae60}.coming-soon{padding:20px;background-color:#fff7e6;border:1px dashed #f39c12;border-radius:6px;color:#e67e22;text-align:center;margin-top:30px;font-size:16px}.appointments-table-container{overflow-x:auto;margin-top:20px}.appointments-table{width:100%;border-collapse:collapse;font-size:14px}.appointments-table th,.appointments-table td{padding:12px 16px;border:1px solid #ddd;text-align:left}.appointments-table th{background-color:#3a0ca3;color:#fff;font-weight:600}.appointments-table tr:nth-child(2n){background-color:#f9f9f9}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#f0f2f5;color:#333}.teacher-dashboard{max-width:1200px;margin:auto;padding:30px 20px;min-height:100vh;display:flex;flex-direction:column;align-items:center}.teacher-title{font-size:30px;font-weight:700;color:#2c3e50;margin-bottom:25px;display:flex;align-items:center;gap:10px}.no-data-message{font-size:18px;color:#7f8c8d;text-align:center;padding:40px 0}.card-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;width:100%;margin-bottom:30px}.appointment-card,.msg-preview-card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 12px #00000014;transition:.3s ease}.appointment-card:hover,.msg-preview-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001f}.card-text{font-size:15px;margin-bottom:10px;color:#34495e}.status-badge{padding:4px 10px;border-radius:20px;font-size:13px;font-weight:600;display:inline-block;text-transform:capitalize}.status-approved{background-color:#e0f8e9;color:#2e7d32}.status-cancelled{background-color:#fdecea;color:#c0392b}.status-pending{background-color:#fff8e1;color:#f39c12}.card-buttons{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.btn{flex:1;padding:10px;border:none;border-radius:5px;font-size:14px;color:#fff;cursor:pointer;transition:background-color .3s ease}.btn-schedule{background-color:#3498db}.btn-schedule:hover{background-color:#2980b9}.btn-approve{background-color:#27ae60}.btn-approve:hover{background-color:#1e8449}.btn-cancel{background-color:#e74c3c}.btn-cancel:hover{background-color:#c0392b}.datetime-input{width:100%;padding:8px;margin-bottom:10px;font-size:14px;border:1px solid #ccc;border-radius:5px}.msg-section-title{font-size:22px;margin-bottom:15px;align-self:flex-start;color:#2c3e50}.messages-preview{width:100%;display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.msg-preview-card p{margin-bottom:8px;font-size:14px;color:#2d3436}.msg-preview-card small{display:block;font-size:12px;color:#7f8c8d;margin-top:8px}.msg-btn{margin-top:10px;padding:8px 12px;font-size:14px;background-color:#8e44ad;color:#fff;border:none;border-radius:5px;cursor:pointer}.msg-btn:hover{background-color:#6c3483}@media (max-width: 600px){.teacher-title{font-size:24px}.card-container,.messages-preview{grid-template-columns:1fr}.btn{font-size:13px}}.dashboard-container{max-width:960px;margin:0 auto;padding:24px;background:linear-gradient(to bottom right,#e6f0ff,#e0e7ff);min-height:100vh}.dashboard-title{font-size:30px;font-weight:700;text-align:center;color:#4f46e5;margin-bottom:20px;animation:fadeIn 1s ease-in-out}.student-details{background-color:#fff;border-radius:8px;padding:20px;margin-bottom:24px;box-shadow:0 2px 8px #0000001a}.student-info{margin-bottom:20px}.student-info p{font-size:16px;color:#2c3e50;margin-bottom:8px}.student-info p strong{font-weight:700;color:#2c3e50}.stats-title{font-size:20px;color:#2c3e50;margin-bottom:10px}.appointment-stats{border-top:1px solid #e5e7eb;padding-top:10px}.appointment-stats p{font-size:16px;color:#2c3e50;margin-bottom:8px}.appointment-stats p strong{font-weight:700;color:#2c3e50}.search-section{margin-bottom:24px;display:flex;justify-content:center}.search-input{width:100%;max-width:448px;padding:12px;border-radius:9999px;border:2px solid #a5b4fc;background-color:#fff;color:#374151;font-size:16px;outline:none;transition:all .3s ease}.search-input::placeholder{color:#9ca3af}.search-input:focus{border-color:#6366f1;box-shadow:0 4px 6px -1px #0000001a;transform:scale(1.05)}.table-container{overflow-x:auto;background-color:#fff;border-radius:12px;box-shadow:0 2px 10px #00000014;padding:16px;margin-bottom:24px}.teacher-table{width:100%;border-collapse:collapse}.teacher-table th,.teacher-table td{padding:16px;text-align:left;border-bottom:1px solid #e5e7eb}.teacher-table th{background-color:#eef2ff;font-weight:600;color:#4338ca}.teacher-table tr:hover{background-color:#f9fafb}.no-data{text-align:center;padding:16px;color:#6b7280;font-style:italic}.book-btn{background-color:#4f46e5;color:#fff;padding:8px 16px;border-radius:8px;margin-left:10px;font-weight:500;border:none;cursor:pointer;transition:background-color .3s ease,transform .3s ease}.book-btn:hover{background-color:#4338ca;transform:scale(1.05)}.appointments-section{margin-top:24px}.appt-title{font-size:20px;color:#2c3e50;margin-bottom:10px}.appt-box{display:inline-block;width:calc(33.333% - 16px);gap:12px;background:#fff;border-radius:8px;margin:8px 8px 12px;padding:16px;box-shadow:0 1px 4px #0000001a;border-left:6px solid #ccc}.appt-box.cancelled{border-left-color:#e74c3c}.appt-box.approved{border-left-color:#2ecc71}.appt-box.pending{border-left-color:#f1c40f}.appt-box p{font-size:14px;color:#2c3e50;margin-bottom:8px}.appt-box p strong{font-weight:700;color:#2c3e50}.appt-box.pending .status-message{display:inline-block;font-weight:500;animation:pulse 1.5s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}@media (max-width: 640px){.dashboard-container{padding:16px}.dashboard-title{font-size:24px}.student-details{padding:16px}.student-info p,.appointment-stats p{font-size:14px}.stats-title,.appt-title{font-size:18px}.search-input,.teacher-table th,.teacher-table td{padding:10px;font-size:14px}.book-btn{padding:6px 12px;width:100%;font-size:14px}.appt-box{padding:12px}.appt-box p{font-size:13px}}.appointment-container{display:flex}.navbar{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(90deg,#6366f1,#4f46e5);padding:16px 32px;border-radius:8px;color:#fff;font-family:Segoe UI,sans-serif;position:relative;margin-bottom:24px;width:100vw}.navbar-left{font-size:1.5rem;font-weight:700;cursor:pointer;-webkit-user-select:none;user-select:none}.navbar-center{position:absolute;left:50%;transform:translate(-50%);font-size:1.2rem;font-weight:600;background-color:#a5b4fc;color:#1e1b4b;padding:6px 14px;border-radius:999px}.navbar-right{display:flex;align-items:center;gap:16px}.username{font-size:.95rem;color:#e0e7ff;background-color:#ffffff26;padding:6px 10px;border-radius:6px}.logout-button{background-color:#ef4444;color:#fff;border:none;padding:8px 14px;border-radius:8px;font-weight:600;cursor:pointer;transition:background-color .3s ease}.logout-button:hover{background-color:#dc2626}.off-screen-menu{background:linear-gradient(90deg,#6366f1,#4f46e5);width:100%;max-width:250px;position:fixed;top:90px;right:-450px;display:flex;flex-direction:column;justify-content:center;align-items:center;font-size:3rem;transition:.3s ease;z-index:1;padding:10px;border:999px}.off-screen-menu.active{right:0}.ham-menu{height:20px;width:20px;margin-left:auto;position:relative;z-index:2}.ham-menu span{height:2px;width:100%;background-color:#6f86ff;border-radius:25px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transition:.3s ease}.ham-menu span:nth-child(1){top:25%}.ham-menu span:nth-child(3){top:75%}.ham-menu.active span:nth-child(1){top:50%;transform:translate(-50%,-50%) rotate(45deg)}.ham-menu.active span:nth-child(2){opacity:0}.ham-menu.active span:nth-child(3){top:50%;transform:translate(-50%,50%) rotate(-45deg)}.mob-center{font-size:1.2rem;font-weight:600;background-color:#a5b4fc;color:#1e1b4b;padding:6px 14px;border-radius:999px}.mob-right{padding:20px;display:flex;flex-direction:column;align-items:center;gap:16px}.logout-button-mob{background-color:#ef4444;color:#fff;border:none;padding:8px 14px;border-radius:8px;font-size:1.2rem;font-weight:600;cursor:pointer;transition:background-color .3s ease}@media (min-width: 768px){.ham-menu{display:none}}@media (max-width: 768px){.navbar-right,.navbar-center{display:none}}.home h2{font-size:2.25rem;font-weight:700;color:#4f46e5;text-align:center;margin-bottom:12px}.home p{font-size:1.125rem;color:#374151;text-align:center;margin-bottom:28px}.home:after{content:"";display:block;height:2px;width:100%;background:linear-gradient(to right,#6366f1,#8b5cf6);margin-top:12px;animation:slideBar 2s infinite linear;border-radius:9999px}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideBar{0%{background-position:0% 50%}to{background-position:100% 50%}}@media (max-width: 640px){.home{padding:20px}.home h2{font-size:1.5rem}.home p{font-size:1rem}}.booking-container{max-width:600px;margin:40px auto;padding:25px;background:#fffaf5;border:1px solid #f1e6da;border-radius:10px;box-shadow:0 4px 14px #00000014}.booking-title{text-align:center;color:#d2691e;font-size:2rem;margin-bottom:20px}.info-box{background:#fdf1e1;padding:15px;border-radius:8px;margin-bottom:20px;border-left:5px solid #ffa500}.booking-form{display:flex;flex-direction:column;gap:14px}.booking-form input{padding:10px;border:1px solid #ccc;border-radius:6px;font-size:1rem}.booking-form button{padding:10px;background-color:#ff8c00;color:#fff;border:none;font-weight:700;font-size:1rem;border-radius:6px;cursor:pointer;transition:background-color .2s ease}.booking-form button:hover{background-color:#e67700}.booking-message{margin-top:15px;font-weight:700;text-align:center}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Arial,sans-serif;background-color:#f4f4f9;color:#333}.message-page{max-width:1200px;padding:0;background:linear-gradient(to bottom right,#e6f0ff,#e0e7ff);min-height:100vh}.message-page h2{font-size:30px;font-weight:700;text-align:center;color:#4f46e5;margin-bottom:20px;animation:fadeIn 1s ease-in-out}.messages-list{background-color:#748d855c;border-radius:12px;padding:16px;margin-bottom:24px;box-shadow:0 2px 10px #00000014;max-height:400px;overflow-y:auto}.msg{padding:12px;margin-bottom:12px;border-radius:18px;max-width:70%;word-wrap:break-word;animation:fadeIn .5s ease-in-out}.msg.sent{background-color:#fff;color:#372222;margin-left:auto;border-left:3px solid #72baee;box-shadow:0 2px 4px #0000001a;transition:transform .3s ease}.msg.sent:hover{transform:translateY(-4px)}.msg.received{background-color:#f9fafb;color:#9aa8b5;margin-right:auto;border-left:6px solid #a5b4fc}.msg p{font-size:16px;margin-bottom:4px}.msg small{font-size:12px;color:#6b7280;opacity:.8}.message-input{display:flex;gap:12px;margin-bottom:24px;background-color:#fff;padding:12px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.message-input input{flex:1;padding:12px;border-radius:9999px;border:2px solid #a5b4fc;font-size:16px;outline:none;transition:all .3s ease}.message-input input::placeholder{color:#9ca3af}.message-input input:focus{border-color:#6366f1;box-shadow:0 4px 6px -1px #0000001a;transform:scale(1.02)}.message-input button{background-color:#4f46e5;color:#fff;padding:8px 16px;border-radius:8px;font-weight:500;border:none;cursor:pointer;transition:background-color .3s ease,transform .3s ease}.message-input button:hover{background-color:#4338ca;transform:scale(1.05)}.message-page h3{font-size:20px;color:#2c3e50;margin-bottom:10px}.appointment-container{display:flex;flex-wrap:wrap;gap:12px}.appt-item{flex:1 1 calc(33.333% - 16px);background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 4px #0000001a;border-left:6px solid #ccc;transition:transform .3s ease}.appt-item:hover{transform:translateY(-4px)}.appt-item.cancelled{border-left-color:#e74c3c}.appt-item.approved{border-left-color:#2ecc71}.appt-item.pending{border-left-color:#f1c40f}.appt-item p{font-size:14px;color:#2c3e50;margin-bottom:8px}.appt-item p strong{font-weight:700}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.appt-item.pending p:last-child{font-weight:500;animation:pulse 1.5s infinite}@media (max-width: 768px){.msg{max-width:85%}.appointment-container{flex-direction:column}.appt-item{flex:1 1 100%}.message-page h2{font-size:24px}}@media (max-width: 480px){.message-input{flex-direction:column}.message-input button{width:100%;padding:10px;font-size:14px}.msg p{font-size:14px}.msg small{font-size:10px}}#root{margin:0;padding:0;overflow:hidden;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
