@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-dark: #070b16;--bg-deep: #0c1222;--bg-gradient: linear-gradient(140deg, #070b16 0%, #0f1629 35%, #151c38 65%, #0e1a30 100%);--surface-color: rgba(15, 23, 50, .55);--surface-elevated: rgba(22, 33, 62, .6);--surface-border: rgba(255, 255, 255, .07);--surface-border-hover: rgba(255, 255, 255, .14);--primary: #818cf8;--primary-hover: #6366f1;--primary-glow: rgba(129, 140, 248, .35);--primary-soft: rgba(129, 140, 248, .08);--secondary: #a78bfa;--accent-teal: #2dd4bf;--accent-amber: #fbbf24;--danger: #f87171;--danger-bg: rgba(248, 113, 113, .08);--success: #34d399;--success-bg: rgba(52, 211, 153, .08);--warning: #fbbf24;--warning-bg: rgba(251, 191, 36, .08);--text-main: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #64748b;--text-dim: #475569;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .25);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3), 0 1px 3px rgba(0, 0, 0, .2);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .35), 0 4px 12px rgba(0, 0, 0, .2);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .45), 0 8px 20px rgba(0, 0, 0, .3);--shadow-glow: 0 0 20px var(--primary-glow), 0 0 60px rgba(129, 140, 248, .1);--shadow-glow-sm: 0 0 10px rgba(129, 140, 248, .2);--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, .04);--glass-blur: 16px;--glass-bg: rgba(15, 23, 50, .5);--glass-bg-heavy: rgba(10, 17, 40, .7);--glass-shine: linear-gradient(135deg, rgba(255,255,255,.06) 0%, transparent 50%);--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--radius-full: 9999px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--transition-fast: .15s var(--ease-out);--transition-base: .25s var(--ease-out);--transition-slow: .4s var(--ease-out)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg-gradient);background-attachment:fixed;color:var(--text-main);min-height:100vh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;font-size:16px;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;z-index:0}#root{flex-grow:1;display:flex;flex-direction:column;position:relative;z-index:1}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg),var(--shadow-inset);position:relative;overflow:hidden}.glass-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1) 30%,rgba(255,255,255,.1) 70%,transparent);pointer-events:none;z-index:1}.glass-panel-heavy{background:var(--glass-bg-heavy);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl),var(--shadow-inset)}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;margin-bottom:.5em;color:var(--text-main);letter-spacing:-.02em}h1{font-size:2.25rem;font-weight:800;background:linear-gradient(135deg,var(--text-main) 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}h2{font-size:1.75rem}h3{font-size:1.25rem}p{color:var(--text-secondary);line-height:1.7;margin-bottom:1rem}a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--secondary)}.input-group{margin-bottom:1.25rem;display:flex;flex-direction:column;gap:.5rem}.input-label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;transition:color var(--transition-fast)}.input-group:focus-within .input-label{color:var(--primary)}.form-input{width:100%;padding:.75rem 1rem;background:#0a0f2399;border:1px solid var(--surface-border);border-radius:var(--radius-sm);color:var(--text-main);font-size:.95rem;font-family:inherit;transition:all var(--transition-base);outline:none;box-shadow:inset 0 1px 3px #0003}.form-input:hover{border-color:var(--surface-border-hover)}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #818cf826,inset 0 1px 3px #0003;background:#0a0f23cc}.form-input::placeholder{color:var(--text-dim)}select.form-input,select{color-scheme:dark;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem}select.form-input option,select option{background:#131b35;color:#e2e8f0;padding:.5rem}select.form-input option:checked,select option:checked{background:#818cf84d;color:#c4b5fd}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1.4rem;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;font-family:inherit;cursor:pointer;transition:all var(--transition-base);border:none;outline:none;position:relative;overflow:hidden;letter-spacing:.01em}.btn:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none;opacity:0;transition:opacity var(--transition-fast)}.btn:hover:after{opacity:1}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);color:#fff;box-shadow:var(--shadow-md),0 0 20px #818cf826}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-glow),var(--shadow-md);filter:brightness(1.1)}.btn-primary:active:not(:disabled){transform:translateY(1px);filter:brightness(.95)}.btn-secondary{background:#ffffff0a;color:var(--text-main);border:1px solid var(--surface-border);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background:#ffffff14;border-color:var(--surface-border-hover);transform:translateY(-1px)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:var(--shadow-md)}.btn-danger:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 20px #ef44444d,var(--shadow-md);filter:brightness(1.1)}.btn-ghost{background:transparent;color:var(--text-muted);padding:.5rem .75rem}.btn-ghost:hover:not(:disabled){color:var(--text-main);background:#ffffff0d}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;filter:none!important}.btn-small{padding:.4rem .75rem;font-size:.8rem}.btn-icon{padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;position:relative;overflow:hidden}.auth-bg-shape1{position:absolute;top:-15%;left:-10%;width:55vw;height:55vw;border-radius:50%;background:radial-gradient(circle,rgba(129,140,248,.12) 0%,transparent 65%);z-index:0;filter:blur(60px);pointer-events:none;animation:float-slow 20s ease-in-out infinite}.auth-bg-shape2{position:absolute;bottom:-20%;right:-10%;width:60vw;height:60vw;border-radius:50%;background:radial-gradient(circle,rgba(45,212,191,.08) 0%,transparent 65%);z-index:0;filter:blur(60px);pointer-events:none;animation:float-slow 25s ease-in-out infinite reverse}@keyframes float-slow{0%,to{transform:translate(0) scale(1)}33%{transform:translate(2%,-3%) scale(1.03)}66%{transform:translate(-2%,2%) scale(.97)}}.auth-card{width:100%;max-width:440px;padding:2.5rem;position:relative;z-index:10;animation:fadeSlideUp .6s var(--ease-out)}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h2{background:linear-gradient(135deg,var(--text-main),var(--primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:1.75rem}.auth-header p{color:var(--text-muted);font-size:.9rem}.auth-icon{width:48px;height:48px;color:var(--primary);margin-bottom:1rem;filter:drop-shadow(0 0 12px var(--primary-glow))}.auth-nav{display:flex;gap:.5rem;margin-bottom:2rem;position:relative;background:#0003;padding:.3rem;border-radius:var(--radius-sm)}.auth-nav:after{display:none}.auth-nav-tab{flex-grow:1;text-align:center;padding:.6rem;background:none;border:none;color:var(--text-muted);font-weight:600;cursor:pointer;position:relative;transition:all var(--transition-base);font-size:.9rem;border-radius:.35rem;font-family:inherit}.auth-nav-tab:hover{color:var(--text-secondary)}.auth-nav-tab.active{color:#fff;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);box-shadow:var(--shadow-glow-sm)}.auth-nav-tab.active:after{display:none}.form-error{color:var(--danger);background:var(--danger-bg);border:1px solid rgba(248,113,113,.15);padding:.75rem 1rem;border-radius:var(--radius-sm);margin-bottom:1.5rem;font-size:.85rem;font-weight:500;display:flex;align-items:center;gap:.5rem;animation:shake .4s ease-in-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dashboard-container{min-height:100vh;display:flex;flex-direction:column}.navbar{padding:.85rem 2rem;background:#070b16bf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--surface-border);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:50;box-shadow:0 4px 30px #0000004d}.navbar:after{content:"";position:absolute;bottom:-1px;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(129,140,248,.15),transparent);pointer-events:none}.nav-brand{display:flex;align-items:center;gap:.75rem;font-weight:700;font-size:1.15rem;color:var(--text-main);letter-spacing:-.01em}.nav-user{display:flex;align-items:center;gap:1.25rem}.user-info{display:flex;align-items:center;gap:.75rem}.avatar{width:38px;height:38px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary) 0%,#a78bfa 100%);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;color:#fff;border:2px solid rgba(255,255,255,.1);box-shadow:0 0 15px #818cf833;flex-shrink:0}.user-text{display:flex;flex-direction:column}.user-name{font-weight:600;font-size:.9rem;line-height:1.2}.user-handle{font-size:.75rem;color:var(--text-muted)}.dashboard-content{flex-grow:1;padding:2.5rem 2rem;max-width:1200px;margin:0 auto;width:100%}.grid-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:2rem}.info-card{padding:1.5rem;display:flex;flex-direction:column;gap:1rem;transition:all var(--transition-base);position:relative}.info-card:after{content:"";position:absolute;inset:0;border-radius:inherit;background:var(--glass-shine);pointer-events:none;opacity:0;transition:opacity var(--transition-base)}.info-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-xl),0 0 30px #818cf814;border-color:#818cf833}.info-card:hover:after{opacity:1}.card-header{display:flex;align-items:center;gap:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--surface-border)}.card-header-icon{color:var(--primary);filter:drop-shadow(0 0 6px var(--primary-glow))}.card-title{margin-bottom:0;font-size:1.05rem;font-weight:700}.card-body{flex-grow:1}.data-row{display:flex;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid rgba(255,255,255,.03);transition:background var(--transition-fast)}.data-row:hover{background:#ffffff05;margin:0 -.5rem;padding-left:.5rem;padding-right:.5rem;border-radius:var(--radius-sm)}.data-row:last-child{border-bottom:none}.data-label{color:var(--text-muted);font-size:.875rem}.data-value{font-weight:600;color:var(--text-main);text-align:right}.loading-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem;color:var(--text-muted)}.loading-container p{font-size:.9rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;animation:pulse-text 2s ease-in-out infinite}@keyframes pulse-text{0%,to{opacity:.5}50%{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:42px;height:42px;border:3px solid rgba(129,140,248,.15);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;box-shadow:0 0 15px #818cf826}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(24px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes glow-pulse{0%,to{opacity:.5}50%{opacity:1}}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#04060ebf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--glass-bg-heavy);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--surface-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl),0 0 80px #0000004d;display:flex;flex-direction:column;animation:modalSlideUp .3s var(--ease-out);overflow:hidden;max-height:90vh}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--surface-border);background:#ffffff05}.modal-header h3{margin:0;font-size:1.1rem}.modal-body{padding:1.5rem;overflow-y:auto}.dashboard-content-app{padding:1.5rem 2rem;max-width:1400px}.teacher-layout,.student-layout{display:grid;gap:1.5rem}.teacher-layout{grid-template-columns:280px 1fr}.sidebar{padding:1.25rem;display:flex;flex-direction:column;gap:1.25rem;height:calc(100vh - 120px);position:sticky;top:90px;border-radius:var(--radius-lg)}.section-title{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-muted);margin-bottom:0;text-transform:uppercase;letter-spacing:.08em;font-weight:700}.mini-form{display:flex;gap:.5rem}.mini-form .form-input{padding:.5rem .75rem;font-size:.85rem}.class-list{display:flex;flex-direction:column;gap:.35rem;overflow-y:auto}.class-item{background:#ffffff05;border:1px solid rgba(255,255,255,.04);padding:.7rem 1rem;border-radius:var(--radius-sm);text-align:left;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);font-weight:500;font-size:.9rem;font-family:inherit}.class-item:hover{background:#818cf80f;border-color:#818cf826;color:var(--text-main)}.class-item.active{background:linear-gradient(135deg,#818cf826,#6366f11a);color:#fff;border-color:#818cf859;box-shadow:var(--shadow-glow-sm)}.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem}.vertical-form{display:flex;flex-direction:column;gap:1rem}.vertical-form textarea{resize:vertical;min-height:80px}.mt-2{margin-top:1.5rem}.mb-2{margin-bottom:1.5rem}.mb-0{margin-bottom:0}.ml-1{margin-left:.25rem}.ml-2{margin-left:1rem}.p-4{padding:1rem}.flex-grow{flex-grow:1}.flex-col{display:flex;flex-direction:column}.align-center{align-items:center}@media(min-width:768px){.col-span-2{grid-column:span 2}}.badge{background:#818cf81a;color:var(--primary);padding:.2rem .65rem;border-radius:var(--radius-full);font-size:.7rem;font-weight:700;border:1px solid rgba(129,140,248,.2);display:inline-flex;align-items:center;justify-content:center;gap:.25rem;white-space:nowrap;letter-spacing:.02em;text-transform:uppercase}.avatar-teacher{background:linear-gradient(135deg,var(--accent-amber) 0%,#d97706 100%)}.text-success{color:var(--success)}.text-muted{color:var(--text-muted)}.font-medium{font-weight:500}.text-sm{font-size:.85rem}.stat-pill{background:#ffffff0f;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.8rem;font-weight:500;color:var(--text-secondary);border:1px solid rgba(255,255,255,.05)}.assignments-list{display:flex;flex-direction:column;gap:.75rem;padding:.5rem 0}.assignment-item{background:#0a0f2366;border:1px solid var(--surface-border);padding:1.25rem;border-radius:var(--radius-md);display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;transition:all var(--transition-base);position:relative}.assignment-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary);border-radius:3px 0 0 3px;opacity:0;transition:opacity var(--transition-fast)}.assignment-item:hover{background:#0a0f2399;border-color:#818cf826;transform:translate(2px)}.assignment-item:hover:before{opacity:1}.assignment-item.is-done{border-color:#34d39926;background:#34d39908}.assignment-item.is-done:before{background:var(--success);opacity:.6}.assign-meta{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.due-date{font-size:.75rem;color:var(--danger);display:flex;align-items:center;gap:.25rem;font-weight:600}.floating-chat{position:fixed;bottom:2rem;right:2rem;width:360px;height:500px;z-index:100;display:flex;flex-direction:column;border-radius:var(--radius-xl);animation:chatSlideUp .35s var(--ease-out);box-shadow:var(--shadow-xl),0 0 60px #0000004d;overflow:hidden}@keyframes chatSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.chat-close{position:absolute;top:-2.5rem;right:0}.chat-container{display:flex;flex-direction:column;height:100%;border-radius:var(--radius-xl);overflow:hidden;background:var(--glass-bg-heavy);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--surface-border)}.chat-header{padding:1rem 1.25rem;background:#ffffff08;border-bottom:1px solid var(--surface-border)}.chat-header h4{margin:0;font-size:.95rem;font-weight:700}.chat-messages{flex-grow:1;padding:1rem;overflow-y:auto;display:flex;flex-direction:column;gap:.6rem}.chat-empty{text-align:center;color:var(--text-dim);margin-top:auto;margin-bottom:auto;font-size:.85rem}.chat-bubble-wrapper{display:flex;width:100%;animation:fadeSlideUp .2s var(--ease-out)}.chat-bubble-wrapper.is-me{justify-content:flex-end}.chat-bubble-wrapper.is-them{justify-content:flex-start}.chat-bubble{max-width:80%;padding:.6rem 1rem;border-radius:var(--radius-lg);font-size:.875rem;line-height:1.5;word-wrap:break-word}.is-me .chat-bubble{background:linear-gradient(135deg,var(--primary),var(--primary-hover));color:#fff;border-bottom-right-radius:.3rem;box-shadow:0 2px 8px #818cf833}.is-them .chat-bubble{background:#ffffff0f;color:var(--text-main);border-bottom-left-radius:.3rem;border:1px solid rgba(255,255,255,.04)}.chat-input-area{display:flex;padding:.75rem 1rem;gap:.5rem;background:#00000026;border-top:1px solid var(--surface-border)}.chat-input{margin:0;font-size:.875rem;padding:.5rem .85rem;border-radius:var(--radius-full)}@keyframes pulse-glow{0%{box-shadow:0 0 #f87171b3}70%{box-shadow:0 0 0 8px #f8717100}to{box-shadow:0 0 #f8717100}}.notification-dot{display:inline-block;width:8px;height:8px;background-color:var(--danger);border-radius:50%;animation:pulse-glow 2s infinite}.notification-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .6rem;background:var(--danger-bg);border:1px solid rgba(248,113,113,.15);border-radius:var(--radius-full);color:var(--danger);font-size:.7rem;font-weight:700}.ql-toolbar.ql-snow{background:#ffffff05!important;border:1px solid rgba(129,140,248,.12)!important;border-radius:var(--radius-md) var(--radius-md) 0 0!important;padding:.5rem .75rem!important}.ql-container.ql-snow{border:1px solid rgba(129,140,248,.12)!important;border-top:none!important;border-radius:0 0 var(--radius-md) var(--radius-md)!important;background:#0a0f2380!important;font-family:inherit!important;font-size:.92rem!important;color:var(--text-main)!important;min-height:100px}.ql-editor{color:var(--text-main)!important;min-height:100px}.ql-editor.ql-blank:before{color:var(--text-dim)!important;font-style:normal!important;opacity:.7}.ql-toolbar .ql-stroke{stroke:var(--text-muted)!important}.ql-toolbar .ql-fill{fill:var(--text-muted)!important}.ql-toolbar .ql-picker-label{color:var(--text-muted)!important}.ql-toolbar button:hover .ql-stroke,.ql-toolbar .ql-active .ql-stroke{stroke:var(--secondary)!important}.ql-toolbar button:hover .ql-fill,.ql-toolbar .ql-active .ql-fill{fill:var(--secondary)!important}.ql-toolbar button:hover,.ql-toolbar .ql-active{background:#818cf81a!important;border-radius:.3rem!important}.ql-toolbar .ql-picker-label:hover,.ql-toolbar .ql-picker-label.ql-active{color:var(--secondary)!important}.ql-toolbar .ql-picker-options{background:var(--glass-bg-heavy)!important;-webkit-backdrop-filter:blur(16px)!important;backdrop-filter:blur(16px)!important;border:1px solid rgba(129,140,248,.15)!important;border-radius:var(--radius-sm)!important;box-shadow:var(--shadow-xl)!important;padding:.3rem!important}.ql-toolbar .ql-picker-item{color:var(--text-muted)!important;padding:.3rem .6rem!important;border-radius:.3rem!important}.ql-toolbar .ql-picker-item:hover{color:var(--text-main)!important;background:#818cf814!important}.ql-snow .ql-tooltip{background:var(--glass-bg-heavy)!important;-webkit-backdrop-filter:blur(16px)!important;backdrop-filter:blur(16px)!important;border:1px solid rgba(129,140,248,.2)!important;color:var(--text-main)!important;box-shadow:var(--shadow-xl)!important;border-radius:var(--radius-sm)!important}.ql-editor h1,.ql-editor h2,.ql-editor h3{color:var(--text-main)!important;margin-bottom:.5rem}.ql-editor p{margin-bottom:.3rem}.ql-editor ul,.ql-editor ol{color:var(--text-main);padding-left:1.5rem}.announcement-card{position:relative;padding:1.25rem 1.4rem;border-radius:var(--radius-md);background:#0a0f2366;border:1px solid rgba(255,255,255,.04);border-left:3px solid rgba(251,191,36,.4);transition:all var(--transition-base)}.announcement-card:hover{background:#0a0f238c;border-color:#fbbf241a;border-left-color:#fbbf24b3;transform:translate(2px)}.announcement-card .ann-content{font-size:.92rem;line-height:1.7;color:var(--text-main)}.announcement-card .ann-content h1,.announcement-card .ann-content h2,.announcement-card .ann-content h3{margin-top:.5rem;margin-bottom:.3rem;color:var(--text-main)}.announcement-card .ann-content p{margin:.25rem 0}.announcement-card .ann-content ul,.announcement-card .ann-content ol{padding-left:1.5rem;margin:.3rem 0}.announcement-card .ann-content strong{color:#e2e8f0}.quill-disabled{line-height:1.7;color:var(--text-main);font-size:.92rem}.quill-disabled h1,.quill-disabled h2,.quill-disabled h3{color:var(--text-main);margin-bottom:.3rem}.quill-disabled p{margin:.2rem 0}.quill-disabled ul,.quill-disabled ol{padding-left:1.5rem;margin:.2rem 0}.quill-disabled strong{color:#e2e8f0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#ffffff26}*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.08) transparent}@media(max-width:768px){.teacher-layout{grid-template-columns:1fr}.hidden-mobile{display:none}.sidebar{height:auto;position:static}.navbar{padding:.75rem 1rem}.dashboard-content{padding:1.5rem 1rem}.dashboard-content-app{padding:1rem}.grid-cards,.grid-2{grid-template-columns:1fr}.auth-card{padding:1.75rem}h1{font-size:1.75rem}h2{font-size:1.35rem}.floating-chat{bottom:0;right:0;width:100%;height:60vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0}}@media(max-width:480px){.auth-card{padding:1.5rem}.navbar{padding:.6rem .75rem}.user-text{display:none}.nav-user{gap:.75rem}}::selection{background:#818cf84d;color:#fff}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
