: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;min-width:320px;min-height:100vh}#root{width:100%}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}}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0;padding:0;background-color:#f0f2f5;color:#333}.app{min-height:100vh;display:flex;flex-direction:column}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:15px;box-sizing:border-box}.login-card{background:#fff;padding:2rem;border-radius:15px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px;box-sizing:border-box}.login-header{text-align:center;margin-bottom:1.5rem}.login-header h1{font-size:1.4rem;color:#333;margin-bottom:.3rem;word-wrap:break-word}.login-header p{margin:.3rem 0;color:#555}.login-tabs{display:flex;margin-bottom:1.5rem;border-bottom:2px solid #eee}.login-tab{flex:1;padding:10px;border:none;background:none;cursor:pointer;font-weight:600;color:#666;transition:all .3s}.login-tab.active{color:#667eea;border-bottom:2px solid #667eea}.login-card .form-group{margin-bottom:1rem}.login-card .form-control{width:100%;padding:14px 12px;font-size:16px;border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;transition:border-color .3s}.login-card .form-control:focus{outline:none;border-color:#667eea}.login-card .btn-block{padding:14px;font-size:1rem;font-weight:600;border-radius:8px;margin-top:10px}.admin-dashboard{display:flex;min-height:100vh}.sidebar{width:260px;background:#2c3e50;color:#fff;display:flex;flex-direction:column;position:fixed;height:100vh;overflow-y:auto}.sidebar-header{padding:20px;background:#1a252f;text-align:center}.sidebar-menu{flex:1;padding:20px 0}.sidebar-item{display:flex;align-items:center;width:100%;padding:15px 20px;border:none;background:none;color:#bdc3c7;cursor:pointer;text-align:left;transition:all .3s;font-size:1rem}.sidebar-item:hover,.sidebar-item.active{background:#34495e;color:#fff;border-left:4px solid #3498db}.sidebar-item .icon{margin-right:10px;width:24px;text-align:center}.sidebar-footer{padding:20px;border-top:1px solid #34495e}.dashboard-content{flex:1;margin-left:260px;padding:20px;background:#f0f2f5}.content-header{background:#fff;padding:15px 25px;border-radius:10px;box-shadow:0 2px 5px #0000000d;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.teacher-dashboard{padding:20px}.dashboard-header{background:#fff;padding:15px 25px;border-radius:10px;box-shadow:0 2px 5px #0000000d;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.user-info{margin-right:20px;font-size:1.1rem}.panel{background:#fff;padding:25px;border-radius:10px;box-shadow:0 2px 10px #0000000d;margin-bottom:20px}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:#555}.form-control{width:100%;padding:10px;border:1px solid #ddd;border-radius:5px;font-size:1rem;box-sizing:border-box}.btn{padding:10px 20px;border:none;border-radius:5px;cursor:pointer;font-weight:600;transition:all .3s;font-size:1rem}.btn-primary{background:#3498db;color:#fff}.btn-primary:hover{background:#2980b9}.btn-secondary{background:#95a5a6;color:#fff}.btn-secondary:hover{background:#7f8c8d}.btn-success{background:#2ecc71;color:#fff}.btn-success:hover{background:#27ae60}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:hover{background:#c0392b}.btn-warning{background:#f1c40f;color:#fff}.btn-warning:hover{background:#f39c12}.btn-info{background:#17a2b8;color:#fff}.btn-info:hover{background:#138496}.btn-block{width:100%}.alert{padding:10px;border-radius:5px;margin-bottom:15px}.alert-error{background:#fee2e2;color:#c0392b;border:1px solid #fecaca}.alert-success{background:#d1fae5;color:#047857;border:1px solid #a7f3d0}.alert-info{background:#e0f2fe;color:#0369a1;border:1px solid #bae6fd}.logout-btn{width:100%;padding:10px;background:#c0392b;color:#fff;border:none;border-radius:5px;cursor:pointer;transition:background .3s}.logout-btn:hover{background:#a93226}table{width:100%;border-collapse:collapse;margin-top:10px}th,td{padding:12px;text-align:left;border-bottom:1px solid #eee}th{background-color:#f8f9fa;font-weight:600;color:#555}tr:hover{background-color:#f9f9f9}.role-selector{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap;justify-content:center}.role-btn{flex:1;min-width:90px;padding:12px 10px;border:2px solid #e0e0e0;background:#fff;border-radius:10px;cursor:pointer;font-weight:600;transition:all .3s;font-size:.9rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:3px}.role-btn:hover{border-color:#667eea;background:#f8f9ff}.role-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;box-shadow:0 4px 12px #667eea4d}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}@media(max-width:1024px){.sidebar{width:220px}.dashboard-content{margin-left:220px;padding:15px}.panel{padding:20px}}@media(max-width:768px){.sidebar{position:fixed;left:-260px;width:260px;z-index:1000;transition:left .3s ease}.sidebar.open{left:0}.dashboard-content{margin-left:0;padding:10px;width:100%}.admin-dashboard{flex-direction:column}.content-header,.dashboard-header{flex-direction:column;align-items:flex-start;gap:10px;padding:15px}.user-info{margin:0;font-size:1rem}.panel{padding:15px;margin-bottom:15px;border-radius:8px}.panel h2,.panel h3{font-size:1.2rem}.form-group{margin-bottom:12px}.form-control{padding:12px 10px;font-size:16px}.btn{padding:12px 16px;font-size:.95rem;width:100%;margin-bottom:8px}table{font-size:.85rem}th,td{padding:8px 6px;white-space:nowrap}div[style*=gridTemplateColumns]{grid-template-columns:1fr!important}div[style*="display: flex"][style*=gap]{flex-direction:column}.login-card{margin:15px;padding:1.5rem}.login-header h1{font-size:1.3rem}.role-btn{padding:8px 12px;font-size:.85rem}}@media(max-width:480px){body{font-size:14px}.login-card{margin:10px;padding:1.25rem;border-radius:10px}.login-header h1{font-size:1.1rem}.panel{padding:12px;margin-bottom:10px}.panel h2{font-size:1.1rem;margin-bottom:15px}.panel h3{font-size:1rem}table{font-size:.8rem}th,td{padding:6px 4px}.table-container{margin:0 -12px;padding:0 12px;width:calc(100% + 24px)}.btn{padding:10px 12px;font-size:.9rem}.btn-sm{padding:6px 10px;font-size:.8rem}select.form-control,input.form-control{font-size:16px;padding:10px 8px}div[style*=linear-gradient]{padding:15px!important;flex-direction:column!important;gap:15px!important}div[style*=linear-gradient] h2{font-size:1.2rem!important;margin-bottom:10px!important}div[style*=linear-gradient] button{width:100%!important;margin-bottom:8px!important}input[type=number]{width:60px!important;padding:8px!important;font-size:14px!important}.alert{padding:10px 12px;font-size:.9rem}}.mobile-menu-toggle{display:none;position:fixed;top:10px;left:10px;z-index:1001;background:#2c3e50;color:#fff;border:none;padding:10px 15px;border-radius:5px;font-size:1.5rem;cursor:pointer}@media(max-width:768px){.mobile-menu-toggle{display:block}}.sidebar-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:999}.sidebar-overlay.active{display:block}@media print{.sidebar,.btn,.mobile-menu-toggle,.logout-btn{display:none!important}.dashboard-content{margin-left:0!important}}
