*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,Arial,sans-serif;font-size:19px;line-height:1.6;background:#eef2f7;color:#1a1a2e;min-height:100vh;-webkit-font-smoothing:antialiased}.loading{min-height:100vh;display:flex;align-items:center;justify-content:center;font-size:22px;color:#64748b}.loading-msg{color:#94a3b8;font-size:18px;padding:24px 0;text-align:center}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px}.login-card{background:#fff;border-radius:20px;padding:52px 44px;width:100%;max-width:460px;box-shadow:0 6px 32px #0000001f}.login-card h1{font-size:34px;font-weight:800;text-align:center;color:#1a1a2e;margin-bottom:8px;letter-spacing:-.5px}.subtitle{text-align:center;color:#64748b;font-size:17px;margin-bottom:40px}label{display:block;font-weight:700;font-size:17px;color:#374151;margin-top:22px;margin-bottom:8px}input[type=text],input[type=password]{width:100%;padding:15px 18px;font-size:19px;border:2px solid #cbd5e1;border-radius:12px;outline:none;transition:border-color .15s;background:#fff;color:#1a1a2e}input[type=text]:focus,input[type=password]:focus{border-color:#2563eb}.btn-primary{display:block;width:100%;padding:18px;margin-top:30px;font-size:21px;font-weight:700;background:#2563eb;color:#fff;border:none;border-radius:12px;cursor:pointer;transition:background .15s,transform .1s}.btn-primary:hover{background:#1d4ed8}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{background:#93c5fd;cursor:not-allowed}.btn-link{display:block;width:100%;background:none;border:none;color:#64748b;font-size:16px;padding:14px;margin-top:8px;cursor:pointer;text-align:center;text-decoration:underline}.btn-link:hover{color:#2563eb}.btn-logout{padding:11px 22px;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:10px;font-size:16px;color:#475569;cursor:pointer;flex-shrink:0}.btn-logout:hover{background:#e2e8f0}.btn-add{padding:15px 30px;font-size:19px;font-weight:700;background:#2563eb;color:#fff;border:none;border-radius:12px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s}.btn-add:hover{background:#1d4ed8}.btn-add:disabled{background:#93c5fd;cursor:not-allowed}.btn-remove{padding:10px 18px;font-size:16px;background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;color:#dc2626;cursor:pointer;white-space:nowrap;flex-shrink:0}.btn-remove:hover{background:#fecaca}.btn-remove:disabled{opacity:.5;cursor:not-allowed}.btn-claim{width:100%;padding:20px;font-size:22px;font-weight:800;background:#16a34a;color:#fff;border:none;border-radius:12px;cursor:pointer;transition:background .15s,transform .1s;letter-spacing:.2px}.btn-claim:hover{background:#15803d}.btn-claim:active{transform:scale(.98)}.btn-claim:disabled{background:#86efac;cursor:not-allowed}.btn-cancel{width:100%;padding:18px;font-size:20px;font-weight:700;background:#dc2626;color:#fff;border:none;border-radius:12px;cursor:pointer;transition:background .15s;margin-top:8px}.btn-cancel:hover{background:#b91c1c}.btn-cancel:disabled{background:#fca5a5;cursor:not-allowed}.error-msg{color:#dc2626;font-size:17px;margin-top:14px;text-align:center}.dashboard{max-width:780px;margin:0 auto;padding:0 20px 80px}header{display:flex;align-items:center;justify-content:space-between;padding:28px 0 32px;border-bottom:2px solid #e2e8f0;margin-bottom:40px;gap:16px}header h1{font-size:30px;font-weight:800;color:#1a1a2e}section{margin-bottom:52px}section h2{font-size:24px;font-weight:700;margin-bottom:8px;color:#1a1a2e}.section-hint{color:#64748b;font-size:17px;margin-bottom:18px}.add-slot-section{background:#fff;border-radius:16px;padding:32px;margin-bottom:44px;box-shadow:0 2px 8px #00000012}.add-slot-section h2{margin-bottom:4px}.add-slot-form{display:flex;gap:12px;margin-top:4px}.slot-input{flex:1;padding:15px 18px;font-size:19px;border:2px solid #cbd5e1;border-radius:12px;outline:none;background:#fff;color:#1a1a2e}.slot-input:focus{border-color:#2563eb}.slot-list{display:flex;flex-direction:column;gap:14px}.slot-card{background:#fff;border-radius:14px;padding:22px 26px;display:flex;align-items:center;justify-content:space-between;gap:16px;box-shadow:0 2px 8px #00000012}.slot-available{border-left:6px solid #16a34a}.slot-claimed{border-left:6px solid #94a3b8;opacity:.75}.slot-desc{font-size:20px;font-weight:600;color:#1a1a2e}.claimed-info{display:flex;flex-direction:column;gap:3px}.claimed-by-line{font-size:15px;color:#475569;margin-top:4px}.claimed-at-line{font-size:14px;color:#94a3b8}.empty-msg{color:#94a3b8;font-style:italic;font-size:17px;padding:12px 0}.student-card{flex-direction:column;align-items:stretch;gap:18px;padding:28px}.slot-desc-large{font-size:26px;font-weight:700;color:#1a1a2e;text-align:center;line-height:1.3}.no-slots-card{background:#fff;border-radius:14px;padding:52px 32px;text-align:center;box-shadow:0 2px 8px #00000012}.no-slots-main{font-size:22px;font-weight:700;color:#475569;margin-bottom:12px}.no-slots-sub{font-size:18px;color:#94a3b8;max-width:400px;margin:0 auto}.cancel-section{background:#fff;border-radius:16px;padding:32px;box-shadow:0 2px 8px #00000012}.cancel-section>.section-hint{margin-bottom:22px}.cancel-form{display:flex;flex-direction:column;gap:0}.cancel-fields{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:20px}.cancel-field label{display:block;font-weight:700;font-size:17px;margin-bottom:8px;margin-top:0}.cancel-field input{width:100%;padding:15px 18px;font-size:19px;border:2px solid #cbd5e1;border-radius:12px;outline:none;background:#fff}.cancel-field input:focus{border-color:#dc2626}.cancel-success-box{background:#dcfce7;border:2px solid #86efac;border-radius:12px;padding:22px 24px;color:#15803d;font-size:20px;font-weight:600;text-align:center}.success-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px}.success-card{background:#fff;border-radius:20px;padding:52px 44px;text-align:center;max-width:500px;width:100%;box-shadow:0 6px 32px #0000001f}.success-icon{width:84px;height:84px;background:#16a34a;color:#fff;font-size:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 28px;font-weight:700}.success-card h1{font-size:34px;font-weight:800;color:#15803d;margin-bottom:16px}.success-card p{font-size:19px;color:#475569;margin-bottom:10px}.claimed-slot-text{font-size:24px;font-weight:700;color:#1a1a2e;background:#f0fdf4;padding:16px 20px;border-radius:10px;margin:16px 0 24px;display:block}@media (max-width: 600px){.login-card{padding:36px 24px}.login-card h1{font-size:28px}.add-slot-form{flex-direction:column}.btn-add{width:100%}header h1{font-size:24px}.cancel-fields{grid-template-columns:1fr}.slot-desc-large{font-size:22px}.btn-claim{font-size:20px;padding:18px}.success-card{padding:36px 24px}.success-card h1{font-size:28px}}
